

# intel

## MICROCONTROLLER HANDBOOK

1985

About Our Cover:

The design on our front cover is an abstract portrayal of the basic microcontroller function. The center sphere, symbolic of a microcontroller, contains a molecular orbital diagram of the architectural construction of a cubic unit of silicon. The red pathways leading from the central sphere, are symbolic of distant or remote controlled applications.

2.15

Intel Corporation makes no warranty for the use of its products and assumes no responsibility for any errors which may appear in this document nor does it make a commitment to update the information contained herein.

Intel retains the right to make changes to these specifications at any time, without notice.

Contact your local sales office to obtain the latest specifications before placing your order.

The following are trademarks of Intel Corporation and may only be used to identify Intel Products:

BITBUS, COMMputer, CREDIT, Data Pipeline, GENIUS, i,  $\hat{T}$ , ICE, iCS, iDBP, iDIS, I<sup>2</sup>ICE, iLBX, i<sub>m</sub>, iMMX, Insite, Intel, int<sub>e</sub>l, int<sub>e</sub>lBOS, Intelevision, int<sub>e</sub>ligent Identifier, int<sub>e</sub>ligent Programming, Intellec, Intellink, iOSP, iPDS, ISBC, iSBX, iSDM, ISXM, Library Manager, MCS, Megachassis, MICROMAINFRAME, MULTIBUS, MULTICHANNEL, MULTIMODULE, Plug-A-Bubble, PROMPT, Promware, QUEST, QUEX, Ripplemode, RMX/80, RUPI, Seamless, SOLO, SYSTEM 2000, and UPI, and the combination of ICE, iCS, iRMX, iSBC, MCS, or UPI and a numerical suffix.

MDS is an ordering code only and is not used as a product name or trademark. MDS® is a registered trademark of Mohawk Data Sciences Corporation.

\* MULTIBUS is a patented Intel bus.

Additional copies of this manual or other Intel literature may be obtained from:

Intel Corporation Literature Department 3065 Bowers Avenue Santa Clara, CA 95051

### **Table of Contents**

| MCS®-96 FAMILY                                          | ,                         |             |
|---------------------------------------------------------|---------------------------|-------------|
| CHAPTER 1                                               | • • • •                   |             |
| CHAPTER 1<br>Introduction To MCS®-96                    |                           |             |
| CHAPTER 2                                               |                           |             |
|                                                         |                           | 2-1         |
| CHAPTER 3                                               |                           |             |
| MCS®-96 Software Design Information                     |                           | 3.1         |
| CHAPTER 4                                               |                           |             |
| MCS®-96 Hardware Design Information                     | × .                       | . 4 1       |
| CHAPTER 5                                               | • • • • • • • • • • • • • |             |
| MCS®-96 Data Sheet.                                     |                           |             |
| CHAPTER 6                                               |                           |             |
|                                                         |                           |             |
| MCS®-96 Article Reprint                                 |                           | •           |
| AR-321: High Performance Event Interface For A Microcom | puter                     |             |
|                                                         |                           | r •         |
| MCS®-51 FAMILY                                          |                           |             |
| CHAPTER 7                                               |                           |             |
| MCS®-51 Architecture                                    |                           |             |
| CHAPTER 8                                               |                           | ,           |
| MCS®-51 Instruction Set                                 |                           |             |
| CHAPTER 9                                               |                           |             |
| MCS®-51 Data Sheets                                     |                           |             |
| 8031/8051 8031AH/8051AH 8032AH/8052AH 8751H/8751H       | 1-12                      |             |
| 8052AH-Basic                                            |                           |             |
| 80C51BH/80C51BH-2 80C31BH/80C31BH-2                     |                           |             |
| 8031AH/8051AH 8032AH/8052AH 8751H/8751H Express .       |                           |             |
| CHAPTER 10                                              |                           |             |
| MCS®-51 Application Notes                               |                           | 1           |
| AP-69: An Introduction To The Intel MCS®-51             |                           |             |
| Single-Chip Microcomputer Family.                       |                           | . 10-1      |
| AP-70: Using The Intel MCS®-51 Boolean                  |                           |             |
| Processing Capabilities                                 | ,                         | 10-31       |
| AP-223: 8051 Based CRT/Terminal Controller              |                           | 10-65       |
| CHAPTER 11                                              |                           | 10-05       |
| MCS®-51 Article Reprint                                 |                           |             |
| AR-224: Controller Chip Takes On Many                   |                           |             |
| Industrial, Computer Uses                               |                           |             |
|                                                         |                           | ••••••••••• |
| MCS®-48 FAMILY                                          |                           |             |
|                                                         |                           |             |
| CHAPTER 12                                              |                           |             |
| MCS®-48 Single Component System                         |                           |             |
| CHAPTER 13                                              |                           |             |
| MCS®-48 Expanded System.                                |                           | 13-1        |
| CHAPTER 14                                              |                           |             |
| MCS®-48 Instruction Set                                 |                           | 14-1        |
| CHAPTER 15                                              |                           |             |
| MCS®-48 Data Sheets                                     |                           | а.<br>С     |
| 8243                                                    |                           |             |
| 8048AH/8035AHL/8049AH/8039AHL/8050AH/8040AHL            |                           |             |
| 8748H/8035H/8749H/8039H                                 |                           |             |
| MCS®-48 Express                                         |                           |             |
| 80C39-9/80C49-7                                         |                           | 15-34       |

i

|     | ,                                                                             |              |
|-----|-------------------------------------------------------------------------------|--------------|
|     |                                                                               |              |
|     |                                                                               |              |
|     |                                                                               |              |
| × . |                                                                               |              |
|     | ````                                                                          |              |
|     |                                                                               | `, a         |
|     | THE RUPI™ FAMILY: MICROCONTROLLER                                             |              |
|     | WITH ON-CHIP COMMUNICATION CONTROLLER                                         |              |
|     | CHAPTER 16<br>The RUPI™-44 Family                                             | 16-1         |
|     | CHAPTER 17                                                                    |              |
|     | 8044 Architecture                                                             | 17-1         |
|     | 8044 Serial Interface                                                         | <b>1</b> 8-1 |
|     | CHAPTER 19<br>8044 Application Examples                                       | 19-1         |
|     | CHAPTER 20                                                                    |              |
|     | RUPI™ Data Sheets<br>8044AH/8344AH                                            | 20-1         |
|     | 8744                                                                          |              |
|     | CHAPTER 21<br>RUPI™ Article Reprint                                           | ·21-1        |
|     |                                                                               | 21-1         |
|     | DESIGN CONSIDERATIONS<br>CHAPTER 22                                           |              |
|     | Application Notes                                                             | · ·          |
|     | AP-125: Designing Microcontroller Systems For Electrically Noisy Environments |              |
|     | AP-155: Oscillators For Microcontrollers                                      |              |
|     | DESIGN CONSIDERATIONS                                                         |              |
|     | WHEN USING CHMOS                                                              | ,            |
|     | CHAPTER 23                                                                    | 23-1         |
|     | Article Reprints AR-302AR-302                                                 | 23-6         |
|     | AR-332                                                                        | . 23-17      |
|     | ADVANCED PACKAGING INFORMATION                                                |              |
|     | CHAPTER 24                                                                    | 24-1         |
|     |                                                                               |              |
|     |                                                                               |              |
|     |                                                                               |              |
|     |                                                                               |              |
|     |                                                                               | · · ·        |
|     |                                                                               | st.          |
|     |                                                                               |              |
|     |                                                                               | • (,         |
|     |                                                                               |              |
|     |                                                                               |              |
|     |                                                                               |              |
|     |                                                                               |              |
|     |                                                                               |              |

ï

### ALPHANUMERICAL INDEX

| 8031 Data Sheet                |
|--------------------------------|
| 8031AH Data Sheet              |
| 8031AH Express Data Sheet      |
| 8032AH Data Sheet              |
| 8032AH Data Sheet              |
| 8035H Data Sheet               |
| 8035AHL Data Sheet             |
| 8039H Data Sheet               |
| 8039AHL Data Sheet             |
| 8040AHL Data Sheet             |
| 8044 Application Example       |
| 8044 Architecture              |
| 8044 Serial Interface          |
| 8044AH Data Sheet              |
| 8048AH Data Sheet              |
| 8049AH Data Sheet              |
| 8050AH Data Sheet              |
| 8051 Data Sheet                |
| 8051AH Data Sheet              |
| 8051AH Express Data Sheet      |
| 8052AH Data Sheet              |
| 8052AH Basic Data Sheet        |
| 8052AH Express Data Sheet      |
| 8243 Data Sheet                |
| 8344AH Data Sheet              |
| 8744 Data Sheet                |
| 8748H Data Sheet               |
| 8749H Data Sheet               |
| 8751H Data Sheet               |
| 8751H Express Data Sheet       |
| 8751H-12 Data Sheet            |
| 80C31BH Data Sheet             |
| 80C31BH-2 Data Sheet           |
| 80C39-9 Data Sheet             |
| 80C51BH Data Sheet             |
| 80C51BH-2 Data Sheet           |
| ADVANCED Packaging Information |
| Design Considerations          |

### ALPHANUMERICAL INDEX

| •      | nsiderations Application Notes                |   |
|--------|-----------------------------------------------|---|
| •      | siderations When Using CHMOS Article Reprints |   |
| MCS-48 | Data Sheets                                   |   |
| MCS-48 |                                               |   |
| MCS-48 | Expanded System                               |   |
|        | nstruction Set                                |   |
| MCS-48 | Single Component System                       |   |
| MCS-51 | Application Notes                             | 5 |
| MCS-51 |                                               | 1 |
| MCS-51 | Article Reprint                               | 1 |
| MCS-51 | Data Sheets                                   | 9 |
| MCS-51 | nstruction Set                                | 1 |
| MCS-96 | Architectural Overview                        |   |
| MCS-96 | Article Reprint                               |   |
| MCS-96 | Data Sheet                                    | 1 |
| MCS-96 | -4-dardware Information                       | 1 |
| MCS-96 | ntroduction                                   | 1 |
| MSC-96 | Software Design Information                   | 1 |
| RUPI D | a Sheets                                      |   |
|        | cle Reprints                                  |   |
|        | Family                                        |   |

1

## Introduction to MCS<sup>®</sup>-96

`

.

### CHAPTER 1 INTRODUCTION TO MCS®-96

### 1.0 CONTINUING MICROCONTROLLER EVOLUTION

Beginning with the introduction of the world standard 8048 (MCS\*-48) Microcontroller in 1976, Intel has continued to drive the evolution of single chip microcontrollers. In 1980, Intel introduced the 8051 (MCS-51) offering performance levels significantly higher than the 8048. With the advent of the 8051, the microcontroller applications base took a marked vertical leap. These versatile chips are used in applications from keyboards and terminals to controlling automobile engines. The 8051quickly gained the position of the second generation world standard microcontroller.

Now that the semiconductor process technologies are

being pushed to new limits, it has become possible to integrate more than 100,000 transistors onto a single silicon chip. Microcontroller designers at Intel have taken today's process technology achievements and forged a new generation of single chip microcontrollers called the MCS-96. The 8096 (generic part number for MCS-96) offers the highest level of system integration ever achieved on a single chip microcontroller. It uses over 120,000 transistors to implement a high performance 16-bit CPU, 8K bytes of program memory, 232 bytes of data memory and both analog and digital types of I/O features. Figure 1-1 shows the evolution of single chip microcontroller at Intel.



Figure 1-1. Evolution of Microcontrollers at Intel

### 1.1 INTRODUCTION TO THE MCS®-96

The 8096 consists of a 16-bit powerful CPU tightly coupled with program and data memory along with several I/O features all integrated onto a single piece of silicon. The CPU supports bit, byte, and word operations. 32-bit double words are also supported for a subset of the instruction set. With a 12 MHz input frequency, the 8096 can perform a 16-bit addition in 1.0  $\mu$ s and 16  $\times$  16 multiply or 32/16 divide in 6.5  $\mu$ s.

Four high-speed trigger inputs are provided to record the times at which external events occur with a resolution of 2  $\mu$ s (at 12 MHz crystal frequency). Up to six high-speed pulse generator outputs are provided to trigger external events at preset times. The high speed output unit can simultaneously perform timer functions, up to four such

16-bit software timers can be in operation at once in addition to the two 16-bit hardware timers.

An optional on-chip A/D converter converts up to four (in the 48-pin version) or 8 (in the 68-pin version) analog input channels into 10-bit digital values. Also provided on-chip, is a serial port, a watchdog timer, and a pulsewidth modulated output signal. Table 1.1 shows the features and benefits summary for the MCS-96.

The 8096 with its 16-bit CPU and all the I/O features and interface resources on a single piece of silicon represents the highest level of system integration in the world of microcontrollers. It will open up new applications which had to use multiple chip solutions in the past.

| FEATURES                                                                 | BENEFITS                                                                                                                         |
|--------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 16-Bit CPU                                                               | Efficient machine with higher throughput.                                                                                        |
| 8K Bytes ROM                                                             | Large program space for more complex, larger programs.                                                                           |
| 232 Bytes RAM                                                            | Large on-board register file.                                                                                                    |
| Hardware MUL/DIV                                                         | Provides good math capability 16 by 16 multiply or 32 by 16 divide in 6.5 $\mu$ s @ 12 MHz.                                      |
| 6 Addressing Modes                                                       | Provides greater flexibility of programming and data manipulation.                                                               |
| High Speed I/O Unit<br>4 dedicated I/O lines<br>4 programmable I/O lines | Can measure and generate pulses with high resolution (2 $\mu$ s @ 12 MHz).                                                       |
| 10-Bit A/D Converter                                                     | Reads the external analog inputs.                                                                                                |
| Full Duplex Serial Port                                                  | Provides asynchronous serial link to other processors or systems.                                                                |
| Up to 40 I/O Ports                                                       | Provides TTL compatible digital data I/O including system expansion with standard 8 or 16-bit peripherals.                       |
| Programmable 8 Source Priority<br>Interrupt System                       | Respond to asynchronous events.                                                                                                  |
| Pulse Width Modulated Output                                             | Provides a programmable pulse train with variable duty cycle. Also used to generate analog output.                               |
| Watchdog Timer                                                           | Provides ability to recover from software malfunction or hardware upset.                                                         |
| 48 Pin (DIP) & 68 Pin (Flatpack, Pin<br>Grid Array) Versions             | Offers a variety of package types to choose from to better fit a specific application need for number of I/O's and package size. |

### Table 1-1 MCS®-96 Features and Benefits Summary

### 1.2. MCS®-96 APPLICATIONS

The MCS-96 products are stand-alone high performance single chip microcontrollers designed for use in sophisticated real-time demanding applications such as industrial control, instrumentation and intelligent computer peripherals. The wide base of applications cut across all industry segments (see table 1.2). With the 16-bit CPU horsepower, high-speed math processing and high-speed I/O, the 8096 is ideal for complex motor control and axis control systems. Examples include three phase, large horsepower AC motors and robotics.

With its 10-bit A/D converter option, the device finds usage in data acquisition systems and closed-loop analog controllers. It permits considerable system integration by

### Table 1-2 MCS®-96 Broad Base of Applications

INDUSTRIAL

Motor Control

Robotics

Discrete and Continuous Process Control Numerical Control Intelligent Transducers

### INSTRUMENTATION

Medical Instrumentation Liquid and Gas Chromatographs Oscillioscopes

### CONSUMER

Video Recorder

Laser Disk Drive High-end Video Games

### **GUIDANCE & CONTROL**

Missile Control Torpedo Guidance Control Intelligent Ammunition Aerospace Guidance Systems

### DATA PROCESSING

Plotters Color and B&W Copiers Winchester Disk Drive Tape Drives Impact and Non-Impact Printers

#### **TELECOMMUNICATIONS**

Modems Intelligent Line Card Control

### AUTOMOTIVE

Ignition Control Transmission Control Anti Skid Braking Emission Control combining analog and digital I/O processing in the single chip.

This chip is ideally suited in the area of instrumentation products such as gas chromatographs, which combine analog processing with high speed number crunching. The same features make it a desirable component for aerospace applications like missile guidance and control.

### 1.3. MCS®-96 FAMILY DEVELOPMENT SUPPORT TOOLS

The product family is supported by a range of Intel software and hardware development tools. These tools shorten the product development cycle, thus bringing the product to the market sooner.

### 1.3.1. MCS®-96 Software Development Package

The 8096 software development package provides development system support specifically designed for the MCS-96 family of single chip microcontrollers. The package consists of a symbolic macro assembler ASM-96, Linker/ Relocator RL-96 and the librarian LIB-96. Among the high level languages, PLM-96 is offered along with a floating point math package. Additional high level languages are being developed for the MCS-96 product family.

### 1.3.2. ASM-96 MACRO Assembler

The 8096 macro assembler translates the symbolic assembly language instructions into the machine executable object code. ASM-96 enables the programmer to write the program in a modular fashion. The modular programs divide a rather complex program into smaller functional units, that are easier to code, to debug, and to change. The separate modules can then be linked and located into one program module using the RL-96 utility. This utility combines the selected input object modules into a single output object module. It also allocates memory to input segments and binds the relocatable addresses to absolute addresses. It then produces a print file that consists of a link summary, a symbol table listing and an intermediate cross-reference listing. LIB-96, another utility helps to create, modify, and examine library files. The ASM-96 runs on Intellec Series III or IV.

### 1.3.3. PL/M-96

The PL/M-96 compiler translates the PL/M-96 language into 8096 relocatable object modules. This allows improved programmer productivity and application reliability. This high level language has been efficiently designed to map into the machine architecture, so as not to trade off higher programmer productivity with inefficient code. Since the language and the compiler are optimized for the 8096 and its application environment, developing software with PL/M-96 is a 'low-risk' project.

### 1.3.4. Hardware Development Support: iSBE-96

The iSBE-96 is a hardware execution and debug tool for the MCS-96 products. It consists of a monitor/debugger resident in an 8096 system. This development system interfaces with the user's 8096 system via two ribbon cables, one for the 8096 I/O ports, and the other for the memory bus. The iSBE-96 is controlled by an Intellec Series III or other computer system over a serial link. Power for the iSBE-96 can be supplied by plugging it into the MUL-TIBUS® card slot, or by an external power supply. The iSBE-96 is contained on one standard MULTIBUS board.

The iSBE-96 provides the most often used features for real-time hardware emulation. The user can display and modify memory, set up break points, execute with or without breakpoints and change the memory map. In addition, the user can single step through the system program.

### 1.3.5. MCS®-96 Workshop

The workshop provides the design engineer or system designer hands-on experience with the MCS-96 family of products. The course includes an explanation of the Intel 8096 architecture, system timing, input/output design. The lab sessions allow the attendees to gain in-depth knowledge of the MCS-96 product family and support tools.

### 1.3.6. Insite<sup>™</sup> Library

The Intel Insite Library contains several application programs. A very useful program contained in the Insite is SIM-96, the software simulator for 8096. It allows software simulations of user's system. The simulator provides the ability to set breakpoints, examine and modify memory, disassemble the object code and single step through the code.

### 1.4. MCS®-96 FAMILY OF PRODUCTS

Although 8096 is the generic part number often used for the MCS-96 products throughout this manual, the product family consists of eight configurations with eight part numbers including the 8096. This wide variety of products is offered to best meet user's application requirements in terms of number of I/O's and package size. The options include on-board 8K bytes of mask programmed memory, 10-bit A/D converter, and 48 or 68 pin package type.

Table 1-3 summarizes all the current products in the  $MCS^{\oplus}-96$  product family.

### Table 1-3 MCS®-96 Family of Products

| OPTIONS        |         | 68 PIN | 48 PIN |
|----------------|---------|--------|--------|
| DIGITAL        | ROMLESS | 8096   | 8094   |
| I/O            | ROM     | 8396   | 8394   |
| ANALOG<br>AND  | ROMLESS | 8097   | 8095   |
| DIGITAL<br>I/O | ROM     | 8397   | 8395   |

The 48 pin version is available in a DIP (dual inline) package.

The 68 pin version comes in two packages, the Plastic Flatpack and the Pin Grid Array.

12.0

# Architectural Overview

2

### CHAPTER 2 ARCHITECTURAL OVERVIEW

### 2.0. INTRODUCTION

The 8096 can be separated into several sections for the purpose of describing its operation. There is a CPU, a programmable High Speed I/O Unit, an analog to digital converter, a serial port, and a Pulse Width Modulated (PWM) output for digital to analog conversion. In addition to these functional units, there are some sections which support overall operation of the chip such as the clock generator and the back-bias generator. The CPU and the programmable I/O make the 8096 very different from any other microcontroller, let us first examine the CPU.

### 2.1. CPU OPERATION

The major components of the CPU on the 8096 are the Register File and the RALU. Communication with the outside world is done through either the Special Function Registers (SFRs) or the Memory Controller. The RALU (Register/Arithmetic Logic Unit) does not use an accumulator, it operates directly on the 256-byte register space made up of the Register File and the SFRs. Efficient I/O

operations are possible by directly controlling the I/O through the SFRs. The main benefits of this structure are the ability to quickly change context, the absence of accumulator bottleneck, and fast throughput and I/O times.

### 2.1.1. CPU Buses

A "Control Unit" and two buses connect the Register File and RALU. Figure 2-1 shows the CPU with its major bus connections. The two buses are the "A-Bus" which is 8-bits wide, and the "D-Bus" which is 16-bits wide. The D-Bus transfers data only between the RALU and the Register File or Special Function Registers (SFRs). The A-Bus is used as the address bus for the above transfers or as a multiplexed address/data bus connecting to the "Memory Controller". Any accesses of either the internal ROM or external memory are done through the Memory Controller.

Within the memory controller is a slave program counter (Slave PC) which keeps track of the PC in the CPU. By having most program fetches from memory referenced to





the slave PC, the processor saves time as addresses seldom have to be sent to the memory controller. If the address jumps sequence then the slave PC is loaded with a new value and processing continues. Data fetches from memory are also done through the memory controller, but the slave PC is bypassed for this operation.

### 2.1.2. CPU Register File

The Register File contains 232 bytes of RAM which can be accessed as bytes, words, or double-words. Since each of these locations can be used by the RALU, there are essentially 232 "accumulators". The first word in the Register File is reserved for use as the stack pointer so it can not be used for data when stack manipulations are taking place. Addresses for accessing the Register File and SFRs are temporarily stored in two 8-bit address registers by the CPU hardware.

### 2.1.3. RALU Control

Instructions to the RALU are taken from the A-Bus and stored temporarily in the instruction register. The Control

Unit decodes the instructions and generates the correct sequence of signals to have the RALU perform the desired function. Figure 2-1 shows the instruction register and the control unit.

### 2.1.4. RALU

Most calculations performed by the 8096 take place in the RALU. The RALU, shown in Figure 2-2, contains a 17bit ALU, the Program Status Word (PSW), the Program Counter (PC), a loop counter, and three temporary registers. All of the registers are 16-bits or 17-bits (16+ sign extension) wide. Some of the registers have the ability to perform simple operations to off-load the ALU.

A separate incrementer is used for the PC; however, jumps must be handled through the ALU. Two of the temporary registers have their own shift logic. These registers are used for the operations which require logical shifts, including Normalize, Multiply, and Divide. The "Lower Word" register is used only when double-word quantities are being shifted, the "Upper Word" register is used



### Figure 2-2. RALU Block Diagram

whenever a shift is performed or as a temporary register for many instructions. Repetitive shifts are counted by the 5-bit "Loop Counter".

A temporary register is used to store the second operand of two operand instructions. This includes the multiplier during multiplications and the divisor during divisions. To perform subtractions, the output of this register can be complemented before being placed into the "B" input of the ALU.

The DELAY shown in Figure 2-2 is used to convert the 16-bit bus into an 8-bit bus. This is required as all addresses and instructions are carried on the 8-bit A bus. Several constants, such as 0, 1 and 2 are stored in the RALU for use in speeding up certain calculations. These come in handy when the RALU needs to make a 2's complement number or perform an increment or decrement instruction.

### 2.2. BASIC TIMING

The 8096 requires an input clock frequency of between 6.0 MHz and 12 MHz to function. This frequency can be applied directly to XTAL1. Alternatively, since XTAL1 and XTAL2 are inputs and outputs of an inverter, it is also possible to use a crystal to generate the clock. A block diagram of the oscillator section is shown in Figure 2-3. Details of the circuit and suggestions for its use can be found in section 4.1.

### 2.2.1. Internal Timings

The crystal or external oscillator frequency is divided by



Figure 2-3. Block Diagram of Oscillator

3 to generate the three internal timing phases as shown in Figure 2-4. Each of the internal phases repeat every 3 oscillator periods: 3 oscillator periods are referred to as one "state time", the basic time measurement for 8096 operations. Most internal operations are synchronized to either Phase A, B or C, each of which have a 33% duty cycle. Phase A is represented externally by CLKOUT, a signal available on the 68-pin part. Phases B and C are not available externally. The relationships of XTAL1, CLKOUT, and Phases A, B, and C are shown in Figure 2-4. It should be noted that propagation delays have not



Figure 2-4. Internal Timings Relative to XTAL 1

been taken into account in this diagram. Details on these and other timing relationships can be found in sections 4.1, 4.4 and 4.6.

The **RESET** line can be used to start the 8096 at an exact time to provide for synchronization of test equipment and multiple chip systems. Use of this feature is fully explained under **RESET**, sections 2.15 and 4.1.

### 2.3. MEMORY SPACE

The addressable memory space on the 8096 consists of 64K bytes, most of which is available to the user for program or data memory. Locations which have special purposes are 0000H through 00FFH and 1FFEH through 2010H. All other locations can be used for either program or data storage or for memory mapped peripherals. A memory map is shown in figure 2-5.

### 2.3.1. Register File

Locations 00H through 0FFH contain the Register File and SFRs. Complete information on this section of memory space can be found in section 2.4. No code can be executed from this internal RAM section. If an attempt to execute instructions from locations 000H through 0FFH is made, the instructions will be fetched from *external* memory. This section of external memory is reserved for use by Intel development tools. Execution of a nonmaskable interrupt (NMI) will force a call to external location 0000H, therefore, the NMI instruction is also reserved for Intel development tools.

### 2.3.2. Reserved Memory Spaces

Locations 1FFEH and 1FFFH are reserved for Ports 3 and 4 respectively. This is to allow easy reconstruction of these ports if external memory is used in the system. An example of reconstructing the I/O ports is given in section 4.6.7. If ports 3 and 4 are not going to be reconstructed then these locations can be treated as any other external memory location.

The 9 interrupt vectors are stored in locations 2000H through 2011H. The 9th vector is used by Intel development systems, as explained in section 2.5. Internal locations 2012H through 207FH are reserved for Intel's factory test code. To ensure compatibility with future parts external locations 2012H through 207FH must contain the hex value FFH.

Resetting the 8096 causes instructions to be fetched starting from location 2080H. This location was chosen to allow a system to have up to 8K of RAM continuous with the register file. Further information on reset can be found in section 2.15.

### 2.3.3. Internal ROM

When a ROM part is ordered, the internal memory locations 2080H through 3FFFH are user specified as are the interrupt vectors in locations 2000H through 2011H.



Figure 2-5. Memory Map

Instruction and data fetches from the internal ROM occur only if the part has a ROM,  $\overline{EA}$  is tied high, and the address is between 2000H and 3FFFH. At all other times data is accessed from either the internal RAM space or external memory and instructions are fetched from external memory.

### 2.3.4. Memory Controller

The RALU talks to the memory (except for the locations in the register file and SFR space) through the memory controller which is connected to the RALU by the A-bus and several control lines. Since the A-bus is eight bits wide, the memory controller uses a Slave Program Counter to avoid having to always get the instruction location from the RALU. This slave PC is incremented after each fetch. When a jump or call occurs, the slave PC must be loaded from the A-bus before instruction fetches can continue.

In addition to holding a slave PC, the memory controller contains a 3 byte queue to help speed execution. This queue is transparent to the RALU and to the user unless wait states are forced during external bus cycles. The instruction execution times shown in Tables 3-3 and 3-4 show the normal execution times with no wait states

added. Reloading the slave PC and fetching the first byte of the new instruction stream takes 4 state times. This is reflected in the jump taken/not-taken times shown in Table 3-4.

### 2.3.5. System Bus

External memory is addressed through lines AD0 through AD15 which form a 16-bit multiplexed (address/data) data bus. These lines share pins with I/O ports 3 and 4. The falling edge of the Address Latch Enable (ALE) line is used to provide a clock to a transparent latch (74LS373) in order to demultiplex the bus. A typical circuit and the required timings are shown in section 4.6. Since the 8096's external memory can be addressed as either bytes or words, the decoding is controlled with two lines, Bus High Enable (BHE) and Addresss/Data Line 0 (AD0). The BHE line must be transparently latched, just as the addresses are.

To avoid confusion during the explanation of the memory system it is reasonable to give names to the demultiplexed address/data signals. The address signals will be called MA0 through MA15 (Memory Address), and the data signals will be called MD0 through MD15 (Memory Data).



Figure 2-6. External Memory Timings

When  $\overline{BHE}$  is active (low), the memory connected to the high byte of the data bus should be selected. When MA0 is low the memory connected to the low byte of the data bus should be selected. In this way accesses to a 16-bit wide memory can be to the low (even) byte only (MA0-=0,  $\overline{BHE}$ =1), to the high (odd) byte only (MA0=1,  $\overline{BHE}$ =0), or to both bytes (MA0=0,  $\overline{BHE}$ =0). When a memory block is being used only for reads,  $\overline{BHE}$  and MA0 need not be decoded.

Figure 2-6 shows the idealized waveforms related to the following description of external memory manipulations. For exact timing specifications please refer to the latest data sheet. When an external memory fetch begins, the address latch enable (ALE) line rises, the address is put on AD0-AD15 and BHE is set to the required state. ALE then falls, the address is taken off the pins, and the RD (Read) signal goes low. The READY line can be pulled low to hold the processor in this condition for a few extra state times.

### 2.3.6. Bus Control Lines

The READY line can be used to hold the processor in the above condition in order to allow access to slow memories or for DMA purposes. Sampling of the READY line occurs internally during Phase A, which is the signal that generates CLKOUT. There is a minimum time in which READY must be stable before CLKOUT goes low. If this set-up time is violated while the part is going to the notready state, the part may fail to operate predictably.

Since READY is synchronized with CLKOUT, the 8096 will be in a not-ready condition for a period equal to some multiple of CLKOUT, although the READY line can be brought high at any time. There is a maximum time for holding the 8096 in the not-ready condition, typically on the order of 1  $\mu$ S. The exact time is specified in the data sheet for the particular part and temperature range desired.

The data from the external memory must be on the bus and stable for a minimum of the specified set-up time before the rising edge of  $\overline{RD}$ . The rising edge of  $\overline{RD}$ latches the information into the 8096. If the read is for data, the INST pin will be low when the address is valid, if it is for an instruction the INST pin will be high during this time. The 48-lead part does not have the INST pin.

Writing to external memory requires timings that are similar to those required when reading from it. The main difference is that the write  $(\overline{WR})$  signal is used instead of the  $\overline{RD}$  signal. The timings are the same until the falling edge of the  $\overline{WR}$  line. At this point the 8096 removes the address and places the data on the bus. The READY line must be held in the desired state at that time as described above. When the  $\overline{WR}$  line goes high the data should be latched to the external memory. INST is always low during a write, as instructions cannot be written. The exact timing specifications for memory accesses can be found in the data sheet.



Figure 2-7. Register File Memory Map

### 2.4. RAM SPACE

The internal register locations on the 8096 are divided into two groups, a register file and a set of Special Function Registers (SFRs). The RALU can operate on any of these 256 internal register locations. Locations 00H through 17H are used to access the SFRs. Locations 18H and 19H<sup>-</sup> contain the stack pointer. The stack pointer must be initialized by the user program and can point anywhere in the 64K memory space. The stack builds down. There are no restrictions on the use of the remaining 230 locations except that code cannot be executed from them.

**2.4.1.** Special Function Registers All of the I/O on the 8096 is controlled through the SFRs. Many of these registers serve two functions; one if they

are read from, the other if they are written to. Figure 2-7 shows the locations and names of these registers. A summary of the capabilities of each of these registers is shown

| Register      | Description                                                                                                                | Chapter         |
|---------------|----------------------------------------------------------------------------------------------------------------------------|-----------------|
| R0            | Zero Register — Always reads as a zero, useful for a base when indexing and as a constant for calculations and compares.   | 3.2.7           |
| AD RESULT     | A/D Result Hi/Low — Low and high order Results of the A/D converter (byte read only)                                       | 2.9.3           |
| AD_COMMAND    | A/D Command Register — Controls the A/D                                                                                    | 2.9.2           |
| HSI MODE      | HSI Mode Register — Sets the mode of the High Speed Input unit.                                                            | 2.7.1           |
| HSI TIME      | HSI Time Hi/Lo — Contains the time at which the High Speed Input<br>unit was triggered. (word read only)                   | 2.7.4           |
| HSO TIME      | HSO Time Hi/Lo — Sets the time for the High Speed Output to execute the command in the Command Register. (word write only) | 2.8.3           |
| HSO COMMAND   | HSO Command Register — Determines what will happen at the time loaded into the HSO Time registers.                         | 2.8.2           |
| HSI STATUS    | HSI Status Registers — Indicates which HSI pins were detected at the time in the HSI Time registers.                       | 2.7.4           |
| SBUF (TX)     | Transmit buffer for the serial port, holds contents to be outputed.                                                        | 2.11            |
| SBUF (RX)     | Receive buffer for the serial port, holds the byte just received by the serial port.                                       | 2.11            |
| INT MASK      | Interrupt Mask Register — Enables or disables the individual interrupts.                                                   | 2.5.2<br>3.6.2  |
| INT _ PENDING | Interrupt Pending Register — Indicates when an interrupt signal has occurred on one of the sources.                        | 2.5.2<br>3.6.2  |
| WATCHDOG      | Watchdog Timer Register — Written to periodically to hold off automatic reset every 64K state times.                       | 2.14            |
| TIMER1        | Timer 1 Hi/Lo — Timer 1 high and low bytes. (word read only)                                                               | 2.6.1<br>2.7-8  |
| TIMER2        | Timer 2 Hi/Lo — Timer 2 high and low bytes. (word read only)                                                               | 2.6.2           |
| IOPORT0       | Port 0 Register — Levels on pins of port 0.                                                                                | 2.12.1          |
| BAUD _ RATE   | Register which contains the baud rate, this register is loaded sequentially.                                               | 2.11.4          |
| IOPORT1       | Port 1 Register — Used to read or write to Port 1.                                                                         | 2.12.2          |
| IOPORT2       | Port 2 Register — Used to read or write to Port 2.                                                                         | 2.12.3          |
| SP STAT       | Serial Port Status - Indicates the status of the serial port.                                                              | 2.11.3          |
| SP_CON        | Serial port control — Used to set the mode of the serial port.                                                             | 2.11.1          |
| IOS0          | I/O Status Register 0 — Contains information on the HSO status.                                                            | 2.13.4          |
| IOS1          | I/O Status Register 1 — Contains information on the status of the timers and of the HSI.                                   | 2.13.5<br>3.7.2 |
| IOC0          | I/O Control Register 0 — Controls alternate functions of HSI pins,<br>Timer 2 reset sources and Timer 2 clock sources.     | 2.13.2          |
| IOC1          | I/O Control Register 1 — Controls alternate functions of Port 2 pins, timer interrupts and HSI interrupts.                 | 2.13.3          |
| PWM _ CONTROL | Pulse Width Modulation Control Register — Sets the duration of the PWM pulse.                                              | 2.10<br>4.3.2   |
| OPORT2        | Port 2 Register — Used to read or write to Port 2.                                                                         | 2.12.3          |

Figure 2-8. SFR Summary

in Figure 2-8, with complete descriptions reserved for later chapters. Note that these registers can be accessed only as bytes unless otherwise indicated.

Within the SFR space are several registers labeled as "RE-SERVED". These registers are reserved for future expansion or test purposes. Reads or writes of these registers may produce unexpected results. For example, writing to location 000CH will set both timers to 0FFFXH, this feature is for use in testing the part and should not be used in programs.

### 2.4.2. Power Down

The upper 16 RAM locations (0F0H through 0FFH) receive their power from both the VCC pin and the VPD pin. If it is desired to keep the memory in these locations alive during a power down situation, one need only keep voltage on the VPD pin. The current required to keep the RAM alive is approximately 1 milliamp (refer to the data sheet for the exact specification).

To place the 8096 into a power down mode, the  $\overrightarrow{RESET}$  pin is pulled low. Two state times later the part will be in reset. This is necessary to prevent the part from writing into RAM as the power goes down. The power may now be removed from the VCC pin, the VPD pin must remain within specifications. The 8096 can remain in this state for any amount of time and the 16 RAM bytes will retain their values.

To bring the 8096 out of power down,  $\overrightarrow{\text{RESET}}$  is held low while VCC is applied. Two state times after the oscillator and the back bias generator have stabilized (~1 millisecond), the  $\overrightarrow{\text{RESET}}$  pin can be pulled high. The 8096 will begin to execute code at location 02080H 10 state times after  $\overrightarrow{\text{RESET}}$  is pulled high. Figure 2-9 shows a timing diagram of the power down sequence. To ensure that the 2 state time minimum reset time (synchronous with CLKOUT) is met, it is recommended that 10 XTAL1 cycles be used. Suggestions for actual hardware connections are given in section 4.1. Reset is discussed in section 2.15.

### 2.5. INTERRUPT STRUCTURE

### 2.5.1. Interrupt Sources

Eight interrupt sources are available on the 8096. When enabled, an interrupt occurring on any of these sources will force a call to the location stored in the vector location for that source. The interrupt sources and their respective vector locations are listed in Figure 2-10. In addition to the 8 standard interrupts, there is a TRAP instruction which acts as a software generated interrupt. This instruction is not currently supported by the MCS-96 Assembler and is reserved for use by Intel development systems. Many of the interrupt sources can be activated by several methods, Figure 2-11 shows all of the possible sources for interrupts.

| Source          | Vector Location |               | Priority       |
|-----------------|-----------------|---------------|----------------|
| е х             | (High<br>Byte)  | (Low<br>Byte) |                |
| Software        | 2011H           | 2010H         | Not Applicable |
| Extint          | 200FH           | 200EH         | 7 (Highest)    |
| Serial Port     | 200DH           | 200CH         | 6              |
| Software Timers | 200BH           | 200AH         | 5              |
| HSI.0           | 2009H           | 2008H         | 4              |
| High Speed      | 2007H           | 2006H         | 3              |
| Outputs         |                 |               |                |
| HSI Data        | 2005H           | 2004H         | 2              |
| Available       |                 |               |                |
| A/D Conversion  | 2003H           | 2002H         | 1              |
| Complete        |                 |               |                |
| Timer Overflow  | 2001H           | 2000H         | 0 (Lowest)     |

### Figure 2-10. Interrupt Vector Locations



Figure 2-9. Power Down Timing

### 2.5.2. Interrupt Control

A block diagram of the interrupt system is shown in Figure 2-12. Each of the interrupt sources is tested for a 0 to 1 transition. If this transition occurs, the corresponding bit in the Interrupt Pending Register, located at 0009H, is set. The bit is cleared when the vector is taken to the interrupt routine. Since this register can be written to, it is possible to generate software interrupts by setting bits within the register, or remove pending interrupts by clearing the bits in this register. The pending register can be set even if the interrupt is disabled.

Caution must be used when writing to the pending register to clear interrupts. If the interrupt has already been acknowledged when the bit is cleared, a 4 state time "partial" interrupt cycle will occur. This is because the 8096 will have to fetch the next instruction of the normal instruction flow, instead of proceeding with the interrupt processing as it was going to. The effect on the program will be essentially that of an extra NOP. This can be prevented by clearing the bits using a 2 operand immediate logical, as the 8096 holds off acknowledging interrupts during these "read/modify/write" instructions. Enabling and disabling of individual interrupts is done through the Interrupt Mask Register, located at 0008H. If the bit in the mask register is a 1 then the interrupt is enabled, otherwise it is disabled. Even if an interrupt is masked it may still become pending. It may, therefore, be desirable to clear the pending bit before unmasking an interrupt.

The Interrupt Mask Register is also the low byte of the PSW. All of the interrupts may be enabled and disabled simultaneously by using the "EI" (Enable Interrupt) and "DI" (Disable Interrupt) instructions. EI and DI set and clear PSW.9, the interrupt enable bit, they do not effect the contents of the mask register.

### 2.5.3. Interrupt Priority Programming

The priority encoder looks at all of the interrupts which are *both pending and enabled*, and selects the one with the highest priority. The priorities are shown in Figure 2-10 (7 is highest, 0 is lowest.) The interrupt generator then forces a call to the location in the indicated vector location. This location would be the starting location of the Interrupt Service Routine (ISR).



Figure 2-11. All Possible Interrupt Sources



Figure 2-12. Block Diagram of Interrupt System

At least one instruction in the ISR will always be executed before another interrupt can be acknowledged. Usually this instruction is "DI" or "PUSHF" (push flags). The PUSHF instruction pushes the PSW onto the stack and then clears it.

Clearing the PSW disables all interrupts in two ways; by clearing PSW.9, the interrupt enable bit and because the Interrupt Mask Register is located in bits 0 through 7 of the PSW. The interrupts which should be permitted to interrupt this ISR can then be set in the mask register and an "EI" instruction executed.

By selectively determining which interrupts are enabled or disabled within which interrupt service routines, it is possible to configure the interrupt system in any way one would desire. More information on programming the interrupts can be found under software programming of interrupts, section 3.6.

The last two instructions in an ISR are normally a "POPF" (pop flags), which restores the PSW and, therefore, the interrupt mask register, followed by a 'RET', which restores the Program Counter. Execution will then continue from the point at which the call was forced.

### 2.5.4. Interrupt Timing

Interrupts are not always acknowledged immediately. If the interrupt signal does not occur prior to 4 state-times before the end of an instruction, the interrupt will not be acknowledged until after the next instruction has been executed. This is because an instruction is fetched and prepared for execution a few state times before it is actually executed.

There are 6 instructions which always inhibit interrupts from being acknowledged until after the next instruction has been executed. These instructions are:

| EI, DI      |             | Enable and Disable Interrupts        |
|-------------|-------------|--------------------------------------|
| POPF, PUSHF |             | Pop and Push Flags                   |
| SIGND       |             | Prefix to perform signed multiply    |
|             |             | and divide (Note that this is not an |
|             |             | ASM-96 Mnemonic, but is used for     |
|             |             | signed multiply and divide)          |
| TRAP        | <del></del> | Software interrupt                   |

When an interrupt is acknowledged, a call is forced to the location indicated by the specified interrupt vector. This call occurs after the completion of the instruction in process, except as noted above. The procedure of getting the vector and forcing the call requires 21 state times. If the stack is in external RAM an additional 3 state times are required.

The maximum number of state times required from the time an interrupt is generated (not acknowledged) until the 8096 begins executing code at the desired location is the time of the longest instruction, NORML (Normalize — 43 state times), plus the 4 state times prior to the end of the previous instruction, plus the response time (21 to 24 state times). Therefore, the maximum response time is 71 (43+4+24) state times. This does not include the 12 state times required for PUSHF if it is used as the first instruction in the interrupt routine or additional latency caused by having the interrupt masked or disabled.

Interrupt latency time can be reduced by careful selection of instructions in areas of code where interrupts are expected. Using 'EI' followed immediately by a long instruction (e.g. MUL, NORML, etc.) will increase the maximum latency by 4 state times, as an interrupt cannot occur between EI and the instruction following EI. The "DI", "PUSHF", "POPF" and "TRAP" instructions will also cause the same situation. Typically the PUSHF, POPF and TRAP instructions would only effect latency when one interrupt routine is already in process, as these instructions are seldom used at other times.

## 2.6. TIMERS

Two 16-bit timers are available for use on the 8096. The first is designated "Timer 1", the second, "Timer 2". Timer 1 is used to synchronize events to real time, while Timer 2 can be clocked externally and synchronizes events to external occurences.

### 2.6.1. Timer 1

Timer 1 is clocked once every eight state times and can be cleared only by executing a reset. The only other way to change its value is by writing to 000CH but this is a test mode which sets both timers to 0FFFXH and should not be used in programs.

### 2.6.2. Timer 2

Timer 2 can be incremented by transitions (one count each transition, rising *and* falling) on either T2CLK or HSI.1. The multiple functionality of the timer is determined by the state of I/O Control Register 0, bit 7 (IOC0.7). To ensure that all CAM entries are checked each count of Timer 2, the maximum transition speed is limited to once per eight state times. Timer 2 can be cleared by: executing a reset, by setting IOC0.1, by triggering HSO channel OEH, or by pulling T2RST or HSI.0 high. The HSO and



### Figure 2-13. Timer 2 Clock and Reset Options

CAM are described in section 2.8. IOC0.3 and IOC0.5 control the resetting of Timer 2. Figure 2-13 shows the different ways of manipulating Timer 2.

### 2.6.3. Timer Interrupts

Both Timer 1 and Timer 2 can be used to trigger a timer overflow interrupt and set a flag in the I/O Status Register 1 (IOS1). The interrupts are controlled by IOC1.2 and IOC1.3 respectively. The flags are set in IOS1.5 and IOS1.4, respectively.

Caution must be used when examining the flags, as any access (including Compare and Jump on Bit) of IOS1 clears the whole byte, including the software timer flags. It is, therefore, recommended to write the byte to a temporary register before testing bits. The general enabling and disabling of the timer interrupts are controlled by the Interrupt Mask Register bit 0. In all cases, setting a bit enables a function, while clearing a bit disables it.





### 2.6.4. Timer Related Sections

The High Speed I/O unit is coupled to the timers in that the HSI records the value on Timer 1 when transitions occur and the HSO causes transitions to occur based on values of either Timer 1 or Timer 2. The Baud rate generator can use the T2CLK pin as input to its counter. A complete listing of the functions of IOS1, IOC0, and IOC1 are in section 2.13.

### 2.7. HIGH SPEED INPUTS

The High Speed Input Unit (HSI), can be used to record the time at which an event occurs with respect to Timer 1. There are 4 lines (HSI.0 through HSI.3) which can be used in this mode and up to a total of 8 events can be recorded. HSI.2 and HSI.3 share pins with HSO.4 and HSO.5. The I/O Control Registers (IOC0 and IOC1) are used to determine the functions of these pins. A block diagram of the HSI unit is shown in Figure 2-14.

### 2.7.1. HSI Modes

There are 4 possible modes of operation for each of the HSI. The HSI mode register is used to control which pins will look for what type of events. The 8-bit register is set up as shown in Figure 2-15.

High and low levels each need to be held for at least 1 state time to ensure proper operation. The maximum input speed is 1 event every 8 state times except when the 8 transition mode is used, in which case it is 1 transition per state time.



Figure 2-15. HSI Mode Register Diagram

The HSI lines can be individually enabled and disabled using bits in IOCO, at location 0015H. Figure 2-16 shows the bit locations which control the HSI pins. If the pin is disabled, transitions will not be entered in the FIFO.





### 2.7.2. HSI FIFO

When an HSI event occurs, a 7x20 FIFO stores the 16 bits of Timer 1 and the 4 bits indicating the state of the 4 HSI lines at the time the status is read. It can take up to 8 state times for this information to reach the holding register. When the FIFO is full, one additional event can be stored by considering the holding register part of the FIFO. If the FIFO and holding register are full any additional events will not be recorded.

### 2.7.3. HSI Interrupts

Interrupts can be generated from the HSI unit in one of two ways, determined by IOC1.7. If the bit is a 0, then an interrupt will be generated every time a value is loaded into the holding register. If it is a 1, an interrupt will only be generated when the FIFO, (independent of the holding register), has six entries in it. Since all interrupts are rising edge triggered, if IOC1.7=1, the processor will not be re-interrupted until the FIFO first contains 5 or less records, then contains six or more. Interrupts can also be generated by pin HSI.0, which has its own interrupt vector.

### 2.7.4. HSI Status

. . . . .

Bits 6 and 7 of the I/O Status register 1 (IOS1) indicate the status of the HSI FIFO. If bit 6 is a 1, the FIFO contains at least six entries. If bit 7 is a 1, the FIFO contains at least 1 entry and the holding register has been loaded. The FIFO may be read after verifying that it contains valid data. Caution must be used when reading or testing bits in IOS1, as this action clears the entire byte, including the software and hardware timer overflow flags. It is best to store the byte and then test the stored value. See Section 3.7.2.

Reading the HSI is done in two steps. First, the HSI Status

register is read to obtain the current state of the HSI pins and which pins had changed at the recorded time. The format of the HSI  $\_$  STATUS Register is shown in Figure 2-17. Second, the HSI Time register is read. Reading the Time register unloads one word of the FIFO, so if the Time register is read before the Status register, the information in the Status register will be lost. The HSI Status register is at location 06H and the HSI Time registers are in locations 04H and 05H.

If the HSI\_TIME and Status register are read without the holding register being loaded, the values read will be undeterminate.

It should be noted that many of the Status register conditions are changed by a reset, see section 2.15.2. A complete listing of the functions of IOŞ0, IOS1, and IOC1 can be found in section 2.13.

### 2.8. HIGH SPEED OUTPUTS

The High Speed Output unit (HSO) is used to trigger events at specific times with minimal CPU overhead. These events include: starting an A to D conversion, resetting Timer 2, setting 4 software flags, and switching up to 6 output lines. Interrupts can be generated whenever one of these events is triggered. Up to 8 events can be pending at any one time.

### 2.8.1. HSIO Shared Pins

Two of the 6 output lines (HSO.0 through HSO.5) are shared with the High Speed Input (HSI) lines. HSO.4 and HSO.5 are shared with HSI.2 and HSI.3, respectively. Bits 4 and 6 of the I/O Control Register 1 (IOC1) are used to enable HSO.4 and HSO.5 as outputs.

### 2.8.2. HSIO CAM

A block diagram of the HSO unit is shown in Figure 2-18. The Content Addressable Memory (CAM) file is the center of control. One CAM register is compared with a time value every state time. Therefore, it takes 8 state times to compare all CAM registers with a timer.



Figure 2-17. HSI Status Register Diagram

### **ARCHITECTURAL OVERVIEW**



Each CAM register is 23 bits wide. Sixteen bits specify the time at which the action is to be carried out and 7 bits specify both the nature of the action and whether Timer 1 or Timer 2 is the reference. The format of the command to the HSO unit is shown in Figure 2-19.

To enter a command into the CAM file, write the 7-bit "Command Tag" into location 0006H followed by the time at which the action is to be carried out into word address 0004H. Writing the time value loads the HSO Holding Register with both the time and the last written command tag. The command does not actually enter the CAM file until an empty CAM register becomes available. It can take up to 8 state times for a command to enter the CAM. For this reason, if Timer 1 is being used as the reference, the minimum time that can be loaded is Timer 1 + 1. A similar restriction applies if Timer 2 is used as the reference.

Care must be taken when writing the command tag for the HSO. If an interrupt occurs during the time between writing the command tag and loading the time value, and the interrupt service routine writes to the HSO time register, the command tag used in the interrupt routine will be written to the CAM at both the time specified by the interrupt routine and the time specified by the main program. The command tag from the main program will not be executed. One way of avoiding this problem would be to disable interrupts when writing commands and times to the HSO unit. See also Section 3.7.3.



Figure 2-19. HSO Command Tag Format

and an and she have

### 2.8.3. HSO Status

Before writing to the HSO, it is desirable to ensure that the Holding Register is empty. If it is not, writing to the HSO will overwrite the value in the Holding Register. I/O Status Register 0 (IOS0) bits 6 and 7 indicate the status of the HSO unit. This register is described in section 2.13.4. If IOS0.6 equals 0, the holding register is empty and at least one CAM register is empty. If IOS0.7 equals 0, the holding register is empty.

One location in the CAM file is checked each state-time. Thus, it takes 8 state-times for the Holding Register to have had access to all 8 CAM registers. Similarly, it takes 8 state-times for the comparator to have had access to all 8 CAM registers. This defines the time-resolution of the HSO unit to be 8 state-times ( $2.0 \ \mu$ sec, if the oscillator frequency is 12 MHz). Note that the comparator does not look at the holding register, so instructions in the holding register do not execute.

### 2.8.4. Clearing The HSO

All 8 CAM locations of the HSO are compared before any action is taken. This allows a pending external event to be cancelled by simply writing the opposite event to the CAM. However, once an entry is placed in the CAM, it cannot be removed until either the specified timer matches the written value or the chip is reset. Internal events are not synchronized to Timer 1, and therefore cannot be cleared. This includes events on HSO channels 8 through F and all interrupts. Since interrupts are not synchronized it is possible to have multiple interrupts at the same time value.

### 2.8.5. Using Timer 2 With The HSO

Timer 1 is incremented only once every 8 state-times. When it is being used as the reference timer for an HSO action, the comparator has a chance to look at all 8 CAM registers before Timer 1 changes its value. Following the same reasoning, Timer 2 has been synchronized to allow it to change at a maximum rate of once per 8 state-times. Timer 2 increments on both edges of the input signal.

When using Timer 2 as the HSO reference, caution must be taken that Timer 2 is not reset prior to the highest value for a Timer 2 match in the CAM. This is because the HSO CAM will hold an event pending until a time match occurs, if that match is to a time value on Timer 2 which is never reached, the event will remain pending in the CAM until the part is reset.

Additional caution must be used when Timer 2 is being reset using the HSO unit, since resetting Timer 2 using the HSO is an internal event and can therefore happen at any time within the eight-state-time window. For this reason, any events scheduled to occur at the same time as a Timer 2 reset should be logged into the CAM with a Timer 2 value of zero. When using this method to make a programmable modulo counter, the count will stay at the maximum Timer 2 value only until the Reset T2 command is recognized. The count will stay at zero for the transition which would have changed the count from "N" to zero, and then change to a one on the next transition.

### 2.8.6. Software Timers

The HSO can be programmed to generate interrupts at preset times. Up to four such "Software Timers" can be in operation at a time. As each preprogrammed time is reached, the HSO unit sets a Software Timer Flag. If the interrupt bit in the command tag was set then a Software Timer Interrupt will also be generated. The interrupt service routine can then examine I/O Status register 1 (IOS1) to determine which software timer expired and caused the interrupt. When the HSO resets Timer 2 or starts an A to D conversion, it can also be programmed to generate a software timer interrupt but there is no flag to indicate that this has occurred. See also Section 3.7.4.

If more than one software timer interrupt occurs in the same time frame it is possible that multiple software timer interrupts will be generated.

Each read or test of any bit in IOS1 will clear the whole byte. Be certain to save the byte before testing it unless you are only concerned with 1 bit. See also Section 3.2.2.

A complete listing of the functions of IOS0, IOS1, and IOC1 can be found in section 2.13. The Timers are described in section 2.6 and the HSI is described in section 2.7.

### 2.9. ANALOG INPUTS

The A to D converter on the 8096 provides a 10-bit result on one of 8 input channels. Conversion is done using successive approximation with a result equal to the ratio of the input voltage divided by the analog supply voltage. If the ratio is 1.00, then the result will be all ones. The A/D converter is available on the 8097, 8397, 8095 and 8395 members of the MCS®-96 family.

### 2.9.1. A/D Accuracy

Each conversion requires 168 state-times  $(42\mu S \text{ at } 12 \text{ MHz})$  independent of the accuracy desired or value of input voltage. The input voltage must be in the range of 0 to VREF, the analog reference and supply voltage. For proper operation, VREF (the reference voltage and analog power supply) must be held at VCC  $\pm$  0.3V with VREF = 5.0  $\pm$  0.5V. The A/D result is calculated from the formula:

### 1023 × (input voltage-ANGND) / (VREF-ANGND)

It can be seen from this formula that changes in VREF or ANGND effect the output of the converter. This can be advantageous if a ratiometric sensor is used since these sensors have an output that can be measured as a proportion of VREF.

If high absolute accuracy is needed it may be desirable to use a separate power supply, or power traces, to operate the A/D converter. There is no sample and hold circuit internal to the chip, so the input voltage must be held constant for the entire 168 state times. Examples of connecting the A/D converter to various devices are given in section 4.3.



Figure 2-20. A/D Command Register

### 2.9.2. A/D Commands

Analog signals can be sampled by any one of the 8 analog input pins (ACH0 through ACH7) which are shared with Port 0. ACH7 can also be used as an external interrupt if IOC1.1 is set (see section 2.5). The A/D Command Register, at location 02H, selects which channel is to be converted and whether the conversion should start immediately or when the HSO (Channel #0FH) triggers it. A to D commands are formatted as shown in Figure 2-20.

The command register is double buffered so it is possible to write a command to start a conversion triggered by the HSO while one is still in progress. Care must be taken when this is done since if a new conversion is started while one is already in progress, the conversion in progress is cancelled and the new one is started. When a conversion is started, the result register is cleared. For this reason the result register must be read before a new conversion is started or data will be lost.

### 2.9.3. A/D Results

Results of the analog conversions are read from the A/D

Result Register at locations 02H and 03H. Although these addresses are on a word boundary, they must be read as individual bytes. Information in the A/D Result register is formatted as shown in Figure 2-21. Note that the status bit may not be set until 8 state times after the go command. Information on using the HSO is in section 2.8.

### 2.10. PULSE WIDTH MODULATION OUT-PUT (D/A)

Digital to analog conversion can be done with the pulse width modulation output; a block diagram of the circuit is shown in Figure 2-22. The 8-bit counter is incremented every state time. When it equals 0, the PWM output is set to a one. When the counter matches the value in the PWM register, the output is switched low. When the counter overflows, the output is once again switched high. A typical output waveform is shown in Figure 2-23. Note that when the PWM register equals 00, the output is always low.

The output waveform is a variable duty cycle pulse which repeats every 256 state times (64  $\mu$ S at 12MHz). Changes





Figure 2-22. Pulse Width Modulated (D/A) Output

in the duty cycle are made by writing to the PWM register at location 17H. There are several types of motors which require a PWM waveform for most efficient operation. Additionally, if this waveform is integrated it will produce a DC level which can be changed in 256 steps by varying the duty cycle.

Details about the hardware required for smooth, accurate D/A conversion can be found in section 4.3.2. Typically,

some form of buffer and integrator are needed to obtain the most usefulness from this feature.

The PWM output shares a pin with Port 2, pin 5 so that these two features cannot be used at the same time. IOC1.0 equal to 1 selects the PWM function instead of the standard port function. More information on IOC1 is in section 2.13.3.

### 2.11. SERIAL PORT

The serial port is compatible with the MCS-51 serial port. It is full duplex, meaning it can transmit and receive simultaneously. It is also receive-buffered, meaning it can commence reception of a second byte before a previously received byte has been read from the receive register. The serial port registers (SBUF) are both accessed at location 07H. A write to this location accesses the transmit register, and a read accesses a physically separate receive register

The serial port can operate in 4 modes (explained below). Selection of these modes is done through the Serial Port Status/Control register at location 11H, shown in Figure 2-27.

### 2.11.1. Serial Port Modes

### MODE 0

Mode 0 is a shift register mode. The 8096 outputs a train of 8 shift pulses to an external shift register to clock 8 bits of data into or out of the register from or to the 8096. Serial data enters and exits the 8096 through RXD. TXD outputs the shift clock. 8 bits are transmitted or received, LSB first. A timing diagram of this mode is shown in Figure 2-24. This mode is useful as an I/O expander in which application external shift registers can be used as additional parallel I/O ports. An example of using the port in this mode is given in section 4.5.



Figure 2-23. Typical PWM Outputs



Figure 2-24. Serial Port Mode 0 Timing





Figure 2-26, Serial Port Frame Modes 2 and 3

### MODE 1

10-bit frames are transmitted through TXD, and received through RXD: a start bit (0), 8 data bits (LSB first), and a stop bit (1). If PEN = 1 then an even parity bit is transmitted instead of the eighth data bit. This mode is the one commonly used for CRT terminals. The data frame for Mode 1 is shown in Figure 2-25.

### MODE 2

11-bit frames are transmitted through TXD and received through RXD: a start bit (0), 8 data bits (LSB first), a programmable 9th data bit, and a stop bit (1). On transmit, the 9th data bit can be assigned the value of 0 or 1 using the TB8 bit. This bit is cleared on each transmission. On receive, the serial port interrupt is not activated unless the received 9th data bit is 1. Parity cannot be enabled in this mode. This mode is commonly used along with mode 3 in a multiprocessor environment.

### MODE 3

11-bit frames are transmitted through TXD and received through RXD: a start bit (0), 8 data bits (LSB first), a programmable 9th data bit, and a stop bit (1). On transmit,

the 9th data bit can be assigned the value of 0 or 1 using the TB8 bit. If PEN = 1 the 9th bit will be parity. On receive, the received 9th data bit is stored and the serial port interrupt is activated regardless of its value. The data frame for Modes 2 and 3 is shown in Figure 2-26.

### 2.11.2. Multiprocessor Communications

Mode 2 and 3 are provided for multiprocessor communications. In mode 2 if the received 9th data bit is not 1, the serial port interrupt is not activated. The way to use this feature in multiprocessor systems is described below.

When the master processor wants to transmit a block of data to one of several slaves, it first sends out an address frame which identifies the target slave. An address frame will differ from a data frame in that the 9th data bit is 1 in an address frame and 0 in a data frame. No slave in mode 2 will be interrupted by a data frame. An address frame, however, will interrupt all slaves so that each slave can examine the received byte and see if it is being addressed. The addressed slave switches to mode 3 to receive the coming data frames, while the slaves that were not addressed stay in mode 2 and go on about their business.

### 2.11.3. Controlling the Serial Port

Control of the Serial Port is done through the Serial Port Control/Status register. The format for the control word is shown in Figure 2-27. Note that reads access only part of the byte, as do writes, and that TB8 is cleared after each byte is transmitted.

In Mode 0, if REN=0, writing to SBUF will start a transmission. Causing a rising edge on REN, or clearing RI with REN=1, will start a reception. Setting REN=0 will stop a reception in progress, and inhibit further receptions. To avoid a partial or complete undesired reception, REN must be set to zero before clearing RI. This can be handled in an interrupt environment by using software flags, or in a straight-line code environment by using the Interrupt Pending register to signal the completion of a receive. In any mode, it is necessary to set IOC1.5 to a 1 to enable the TXD pin. Some examples of the software involved in using the serial port can be found in section 3.8. More information on IOC1 is in section 2.13.3.

### 2.11.4. Determining Baud Rates

Baud rates in all modes are determined by the contents of a 16-bit register at location 000EH. This register must be loaded sequentially with 2 bytes (least significant byte first). The MSB of this register selects one of two sources for the input frequency to the baud rate generator. If it is a 1, the frequency on the XTAL1 pin is selected, if not, the external frequency from the T2CLK pin is used. It should be noted that the maximum speed of T2CLK is one transition every 2 state times, with a minimum period of 16 XTAL1 cycles. The unsigned integer represented by the lower 15 bits of the baud rate register defines a number B, where B has a maximum value of 32767. The baud rate for the four serial modes using either XTAL1 or T2CLK as the clock source is given by:

Mode 0: 
$$\frac{Baud}{Rate} = \frac{XTAL1 \text{ frequency}}{4^*(B+1)}; B \neq 0$$
  
Others: 
$$\frac{Baud}{Rate} = \frac{XTAL1 \text{ frequency}}{64^*(B+1)}$$
  
Using T2CLK:  
Mode 0: 
$$\frac{Baud}{Rate} = \frac{T2CLK \text{ frequency}}{B}; B \neq 0$$

Others:  $\begin{array}{c} \text{Baud} \\ \text{Rate} \end{array} = \frac{\text{T2CLK frequency}}{16^{*}\text{B}}; \text{ B} \neq 0 \end{array}$ 

Note that B cannot equal 0, except when using XTAL1 in other than mode 0.

Common baud rate values, using XTAL1 at 12MHz, are shown below.

| <b>Baud Rate</b> | <b>Baud Register</b> | Value  |
|------------------|----------------------|--------|
|                  | Mode 0               | Others |
| 9600             | 8137H                | 8013H  |
| 4800             | 8270H                | 8026H  |
| 2400             | 84E1H                | 804DH  |
| 1200             | 89C3H                | 809BH  |
| 300              | A70FH                | 8270H  |

The maximum asynchronous baud rate is 187.5 Kbaud, with a 12MHz clock.



Figure 2-27. Serial Port Control/Status Register

### 2.12. I/O PORTS 0, 1, 2, 3, AND 4

There are five 8-bit I/O ports on the 8096. Some of these ports are input only, some output only, some bidirectional and some have alternate functions. Input ports connect to the internal bus through an input buffer. Output ports connect through an output buffer to an internal register that holds the output bits. Bidirectional ports consist of an internal register, an output buffer, and an input buffer.

When an instruction accesses a bidirectional port as a source register, the question often arises as to whether the value that is brought into the CPU comes from the internal port register or from the port pins through the input buffer. In the 8096, the value always comes from the port pins, never from the internal register.

### 2.12.1. Port 0

Port 0 is an input only port which shares its pins with the analog inputs to the A/D Converter. One can read Port 0 digitally, and/or, by writing the appropriate control bits to the A/D Command Register, select one of the lines of this port to be the input to the A/D Converter. While a conversion is in process, the impedance of the selected line is lower than normal. See the data sheet for the specific values.

### 2.12.2. Port 1

Port 1 is a quasi-bidirectional I/O port. "Quasi-bidirectional" means the port pin has a weak internal pullup that is always active and an internal pulldown which can either be on (to output a 0) or off (to output a 1). If the internal pulldown is left off (by writing a 1 to the pin), the pin's logic level can be controlled by an external pulldown which can either be on (to input a 0) or off (to input a 1). From the user's point of view the main distinction is that a quasi-bidirectional input will source current while being externally held low and will pull itself high if left alone.

In parallel with the weak internal pullup, is a much stronger internal pullup that is activated for one state time when the pin is internally driven from 0 to 1. This is done

to speed up the 0-to-1 transition time. See also Sections 3.7.1 and 4.2.2.

### 2.12.3. Port 2

Port 2 is a multi-functional port. Six of its pins are shared with other functions in the 8096, as shown below.

| Port | Function            | Alternate<br>Function          | Controlled by |
|------|---------------------|--------------------------------|---------------|
| P2.0 | output              | TXD (serial port transmit)     | IOC1.5        |
| P2.1 | input               | RXD (serial port receive)      | N/A           |
| P2.2 | input               | EXTINT<br>(external interrupt) | IOC1.1        |
| P2.3 | input               | T2CLK (Timer<br>2 input)       | IOC0.7        |
| P2.4 | input               | T2RST (Timer<br>2 reset)       | IOC0.5        |
| P2.5 | output              | PWM<br>(pulse-width            | IOC1.0        |
|      |                     | modulation)                    | 1             |
| P2.6 | quasi-bidirectional |                                |               |
| P2.7 | quasi-bidirectional |                                |               |

### 2.12.4. Ports 3 and 4

Ports 3 and 4 have two functions. They are either bidirectional ports with open-drain outputs or System Bus pins which the memory controller uses when it is accessing off-chip memory. If the  $\overline{EA}$  line is low, the pins always act as the System Bus. Otherwise they act as bus pins only during a memory access. If these pins are being used as ports and bus pins, ones must be written to them prior to bus operations.

Strong internal pullups are used during external memory read or write cycles when the pins are used as address or data outputs. At any other time, the internal pullups are



Figure 2-28. I/O Control Register 0 (IOC0)

disabled. The port pins and their system bus functions are shown below:

| Port Pin | System Bus Function |
|----------|---------------------|
| P3.0     | AD0                 |
| P3.1     | AD1                 |
| P3.2     | AD2                 |
| P3.3     | AD3                 |
| P3.4     | AD4                 |
| P3.5     | AD5                 |
| P3.6     | AD6                 |
| P3.7     | AD7                 |
| P4.0     | AD8                 |
| P4.1     | AD9                 |
| P4.2     | AD10                |
| P4.3     | AD11                |
| P4.4     | AD12                |
| P4.5     | AD13                |
| P4.6     | AD14                |
| P4.7     | AD15                |

### 2.13. STATUS AND CONTROL REGISTERS

### 2.13.1. I/O Control Registers

There are two I/O Control registers, IOC0 and IOC1. IOC0 controls Timer 2 and the HSI lines. IOC1 controls some pin functions, interrupt sources and 2 HSO pins.

Whenever input lines are switched between two sources, or enabled, it is possible to generate transitions on these lines. This could cause problems with respect to edge sensitive lines such as the HSI lines, Interrupt line, and Timer 2 control lines.

### 2.13.2. I/O Control Register 0 (IOC0)

IOC0 is located at 0015H. The four HSI lines can be enabled or disabled to the HSI unit by setting or clearing bits in IOC0. Timer 2 functions including clock and reset sources are also determined by IOC0. The control bit locations are shown in Figure 2-28.

### 2.13.3. I/O Control Register 1 (IOC1)

IOC1 is used to select some pin functions and enable or disable some interrupt sources. Its location is 0016H. Port pin P2.5 can be selected to be the PWM output instead of a standard output. The external interrupt source can be selected to be either EXTINT (same pin as P2.2) or Analog Channel 7 (ACH7, same pin as P0.7). Timer 1 and Timer 2 overflow interrupts can be individually enabled or disabled. The HSI interrupt can be selected to activate either when there is 1 FIFO entry or 7. Port pin P2.0 can be selected to be the TXD output. HSO.4 and HSO.5 can be enabled or disabled to the HSO unit. More information on interrupts is available in section 2.5. The positions of the IOC1 control bits are shown in Figure 2-29.

### 2.13.4. I/O Status Register 0 (IOS0)

There are two I/O Status registers, IOSO and IOS1. IOSO, located at 0015H, holds the current status of the HSO lines and CAM. The status bits of IOSO are shown in Figure 2-30.

### 2.13.5. I/O Status Register 1 (IOS1)

IOS1 is located at 0016H. It contains status bits for the timers and the HSI. Every access of this register clears all of the timer overflow and timer expired bits. It is, therefore, important to first store the byte in a temporary location before attempting to test any bit unless only one bit will ever be of importance to the program. The status bits of IOS1 are shown in Figure 2-31.

### 2.14. WATCHDOG TIMER (WDT)

This feature is provided as a means of graceful recovery from a software upset. Once the watchdog is initialized, if the software fails to reset the watchdog at least every 64K state times, a hardware reset will be initiated.

The watchdog is initialized by the first write of the clear WDT code to the WDT register. Once the watchdog is initialized it cannot be disabled by software. On reset the watchdog is not active.



Figure 2-29. I/O Control Register 1 (IOC1)







Figure 2-31. HSIO Status Register 1 (IOS1)

The software can be designed so that the watchdog times out if the program does not progress properly. The watchdog will also time-out if the software error was due to ESD (Electrostatic Discharge) or other hardware related problems. This prevents the controller from having a malfunction for longer than 16 mS if a 12 MHz oscillator is used.

The watchdog timer is a 16-bit counter which is incremented every state time. When it overflows it pulls down the RESET pin for at least two state times, resetting the 8096 and any other chips connected to the reset line. To prevent the timer from overflowing and resetting the system, it must be cleared periodically. Clearing the timer is done by writing a "01EH" followed by an "0E1H" to the WDT register at location 000AH.

Use of a large reset capacitor on the  $\overline{\text{RESET}}$  pin will increase the length of time required for a watchdog initiated reset. This is because the capacitor will keep the  $\overline{\text{RESET}}$  pin from responding immediately to the internal pull-ups and pull-downs. A large capacitor on the  $\overline{\text{RESET}}$ pin may also interfere with the reset of other parts connected to the  $\overline{\text{RESET}}$  pin. Under some circumstances, it may be desirable to use an open collector circuit. See section 4.4.

## 2.14.1. Disabling The Watchdog

The watchdog should be disabled by software not initializing it. If this is not possible, such as during program development, the watchdog can be disabled by holding the RESET pin at 2.0 to 2.5 volts. Voltages over 2.5 volts on the pin could quickly damage the part. Even at 2.5 volts, using this technique for other than debugging purposes is not recommended, as it may effect long term reliability. It is further recommended that any part used in this way for more than several seconds, not be used in production versions of products.

## 2.15. RESET

## 2.15.1. Reset Signal

As with all processors, the 8096 must be reset each time the power is turned on. To complete a reset, the RESET pin must be held active (low) for at least 2 state times after VCC, the oscillator, and the back bias generator have stabilized ( $\sim$ 1.0 milliseconds). Then when RESET is brought high again, the 8096 executes a reset sequence that takes 10 state times. (It initializes some registers, clears the PSW and jumps to address 2080H.)

The 8096 can be reset using a capacitor, 1-shot, or any other method capable of providing a pulse of at least 2

state times longer than required for VCC and the oscillator to stabilize.

For best functionality, it is suggested that the reset pin be pulled low with an open collector device. In this way, several reset sources can be wire ored together. Remember, the  $\overrightarrow{RESET}$  pin itself can be a reset source (see section 2.14). Details of hardware suggestions for reset can be found in section 4.4.

## 2.15.2. Reset Status

The I/O lines and control of the 8096 will be in their reset state within 2 state times after reset is low, with VCC and the oscillator stabilized. Prior to that time, the status of the I/O lines is indeterminate. After the 10 state time reset sequence, the Special Function Registers will be set as follows:

| SFR                    | reset value       |
|------------------------|-------------------|
| Port 1                 | 11111111B         |
| Port 2                 | 110XXXX1B         |
| Port 3                 | 11111111 <b>B</b> |
| Port 4                 | 11111111B         |
| PWM Control            | 00H               |
| Serial Port (Transmit) | undefined         |
| Serial Port (Receive)  | undefined         |
| Baud Rate Register     | undefined         |
| Serial Control/Status  | undefined         |
| A/D Command            | undefined         |
| A/D Result             | undefined         |
| Interrupt Pending      | undefined         |
| Interrupt Mask         | 0000000B          |
| Timer 1                | 0000H             |
| Timer 2                | 0000H             |
| Watchdog Timer         | 0000H             |
| HSI Mode               | 11111111B         |
| HSI Status             | undefined         |
| IOS0                   | 0000000B          |
| IOS1                   | 0000000B          |
| IOC0                   | X0X0X0X0B         |
| IOC1                   | X0X0XXX1B         |

Other conditions following a reset are:

| Register        | reset value |
|-----------------|-------------|
| HSI FIFO        | empty       |
| HSO CAM         | empty       |
| HSO lines       | 000000B     |
| PSW             | 0000H       |
| Stack Pointer   | undefined   |
| Program Counter | 2080H       |
| RD              | high        |
| WR              | high        |
| ALE             | low         |
| BHE             | low         |
| INST            | high        |

## NMI

A low to high transition causes a vector to *external* memory location 0000H. Reserved for use in Intel Development systems.

It is important to note that the Stack Pointer and Interrupt Pending Register are undefined, and need to be initialized in software. The Interrupts are disabled by both the mask register and PSW.9 after a reset.

## 2.15.3. Reset Sync Mode

The  $\overline{\text{RESET}}$  line can be used to start the 8096 at an exact state time to provide for synchronization of test equipment and multiple chip systems.  $\overline{\text{RESET}}$  is active low. To synchronize parts,  $\overline{\text{RESET}}$  is brough high on the rising edge of XTAL1. Complete details on synchronizing parts can be found in section 4.1.5.

It is very possible that parts which start in sync may not stay that way. The best example of this would be when a "jump on I/O bit" is being used to hold the processor in a loop. If the line changes during the time it is being tested, one processor may see it as a one, while the other sees it as a zero. The result is that one processor will do an extra loop, thus putting it several states out of sync with the other.

## 2.16. PIN DESCRIPTION

#### VCC

Main supply voltage (5V).

#### VSS

Digital circuit ground (0V). There are two VSS pins, both must be tied to ground.

#### VPD

RAM standby supply voltage (5V). This voltage must be present during normal operation. See section 2.4.2 and 4.

## VREF

Reference voltage and power supply for the analog portion of the A/D converter. Nominally at 5 volts. See section 2.9.1 and 4.

#### ANGND

Reference ground for the A/D converter. Should be held at nominally the same potential as VSS. See section 2.9.1 and 4.

#### VBB

Substrate voltage from the on-chip back-bias generator. This pin should be connected to ANGND through a 0.01 uf capacitor (and not connected to anything else). The capacitor is not required if the A/D converter is not being used.

#### XTAL1

Input of the oscillator inverter and input to the internal clock generator. See sections 2.2 and 4.

## XTAL2

Output of the oscillator inverter. See section 2.2.

#### CLKOUT

Output of the internal clock generator. The frequency of CLKOUT is  $\frac{1}{3}$  the oscillator frequency. It has a 33% duty cycle. CLKOUT can drive one TTL input. See section 2.2.

## RESET

Reset input to the chip, also output to other circuits. Input low for at least 2 state times to reset the chip.  $\overrightarrow{\text{RESET}}$  has a strong internal pullup. See section 2.15 and 4.1.

## TEST

Input low enables a factory test mode. The user should tie this pin to VCC for normal operation.

#### NMI

A low to high transition causes a vector to *external* memory location 0000H. Reserved for use in Intel Development systems.

#### INST

Output high while the address is valid during an external read indicates the read is an instruction fetch. See section 2.3.6 and 4.6.

#### ĒĀ

Input for memory select (External Access).  $\overline{EA} = 1$  causes memory accesses to locations 2000H through 3FFFH to be directed to on-chip ROM.  $\overline{EA} = 0$  causes accesses to these locations to be directed to off-chip memory.  $\overline{EA}$  has an internal pulldown, so it goes to 0 unless driven to 1. See section 2.3.3.

#### ALE

Address Latch Enable output. ALE is activated only during external memory accesses. It is used to latch the address from the multiplexed address/data bus. See section 2.3.5 and 4.6.

#### RD

Read signal output to external memory.  $\overline{\text{RD}}$  is activated only during external memory reads. See section 2.3.5 and 4.6.

## WR

Write signal output to external memory.  $\overline{WR}$  is activated only during external memory writes. See section 2.3.6 and 4.6.

#### BHE

Bus High Enable signal output to external memory.  $\overline{BHE}$  (0/1) selects/deselects the bank of memory that is connected to the high byte of the data bus. See section 2.3.5 and 4.6.

#### READY

The READY input is used to lengthen external memory bus cycles up to the time specified in the data sheet. It has a weak internal pullup. See section 2.3.6 and 4.6.

#### HSI

High impedance inputs to HSI Unit. Four HSI pins are available: HSI.0, HSI.1, HSI.2, and HSI.3. Two of them (HSI.2 and HSI.3) are shared with the HSO Unit. See section 2.7.

#### HSO

Outputs from HSO Unit. Six HSO pins are available: HSO.0, HSO.1, HSO.2, HSO.3, HSO.4, and HSO.5. Two of them (HSO.4 and HSO.5) are shared with the HSI Unit. All HSO pins are capable of driving one TTL input. See section 2.8.

## **PORT 0/ANALOG CHANNEL**

High impedance input-only port. These pins can be used as digital inputs and/or as analog inputs to the on-chip A/D converter. See sections 2.9 and 2.12.1.

#### PORT 1

Quasi-bidirectional I/O port. All pins of P1 are capable of driving one LS TTL input. See section 2.12.2.

#### PORT 2

Multi-functional port. Six of its pins are shared with other functions in the 8096, as shown below.

| Port | Function            | Alternate Function          | Reference<br>section |
|------|---------------------|-----------------------------|----------------------|
| P2.0 | output              | TXD (serial port transmit)  | 2.11.3               |
| P2.1 | input               | RXD (serial port receive)   | 2.11.3               |
| P2.2 | input               | EXTINT (external interrupt) | 2.5                  |
| P2.3 | input               | T2CLK (Timer 2 input)       | 2.6.2                |
| P2.4 | input               | T2RST (Timer 2 reset)       | 2.6.2                |
| P2.5 | output              | PWM (pulse-width modulator) | 2.10                 |
| P2.6 | quasi-bidirectional |                             |                      |
| P2.7 | quasi-bidirectional | · .                         |                      |

The multi-functional inputs are high impedance. See section 2.12.3.

## PORTS 3 AND 4

8-bit bidirectional I/O ports. These pins are shared the multiplexed address/data bus when accessing external memory, with the Port 3 pins accessing the low byte and Port 4 pins accessing the high byte. They are open drain except when being used as system bus pins. See section 2.3.5.

## 2.17. PIN LIST

The following is a list of pins in alphabetical order. Where a pin has two names it has been listed under both names, except for the system bus pins, AD0-AD15, which are listed under Port 3 and Port 4.

| Name        | 68-Pin | 48-Pin |
|-------------|--------|--------|
| ACH0/P0.0   | 4      | _      |
| ACH1/P0.1   | 5      |        |
| ACH2/P0.2   | 3      |        |
| ACH3/P0.3   | 6      |        |
| ACH4/P0.4   | 67     | 43     |
| ACH5/P0.5   | 68     | 42     |
| ACH6/P0.6   | 2      | 40     |
| ACH7/P0.7   | 1      | 41     |
| ALE         | 16     | 34     |
| ANGND       | 66     | 44     |
| BHE         | 37     | 15     |
| CLKOUT      | 13     |        |
| ĒĀ          | 7      | 39     |
| EXTINT/P2.2 | 63     | 47     |
| HSI.0       | 54     | 3      |
| HSI.1       | 53     | 4      |
| HSI.2/HSO.4 | 52     | 5      |
| HSI.3/HSO.5 | 51     | 6      |
| HSO.0       | 50     | 7      |
| HSO.1       | 49     | 8      |
| HSO.2       | 44     | 9      |
| HSO.3       | 43     | 10     |
| HSO.4/HSI.2 | 52     | 5      |
| HSO.5/HSI.3 | 51     | 6      |
| INST        | 15     |        |
| NMI         | 7      |        |
| PWM/P2.5    | 39     | 13     |
| P0.0/ACH0   | 4      |        |
| P0.1/ACH1   | 5      |        |
| P0.'2/ACH2  | 3      |        |
| P0.3/ACH3   | 6      |        |
| P0.4/ACH4   | 67     | 43     |
| P0.5/ACH5   | 68     | 42     |
| P0.6/ACH6   | 2      | 40     |
| P0.7/ACH7   | 1      | 41     |
| P1.0        | 59     |        |

| Name        | 68-Pin | 48-Pin   |
|-------------|--------|----------|
| P1.1        | 58     |          |
| P1.2        | 57     |          |
| P1.3        | 56     | _        |
| P1.4        | 55     | _        |
| P1.5        | 48     |          |
| P1.6        | 47     |          |
| P1.7        | 46     | _        |
| P2.0/TXD    | 60     | 2        |
| P2.1/RXD    | 61     | 1        |
| P2.2/EXTINT | 63     | 47       |
| P2.3/T2CLK  | 34     |          |
| P2.4/T2RST  | 36     |          |
| P2.5/PWM    | 39     | 13       |
| P2.6        | 45     |          |
| P2.7        | 40     | _        |
| P3.0/AD0    | 18     | 32       |
| P3.1/AD1    | 19     | 31       |
| P3.2/AD2    | 20     | 30       |
| P3.3/AD3    | 21     | 29       |
| P3.4/AD4    | 22     | 28       |
| P3.5/AD5    | 23     | 27       |
| P3.6/AD6    | 24     | 26       |
| P3.7/AD7    | 25     | 25       |
| P4.0/AD8    | 26     | 24       |
| P4.1/AD9    | 27     | 23       |
| P4.2/AD10   | 28     | 22       |
| P4.3/AD11   | 29     | 21       |
| P4.4/AD12   | 30     | 20       |
| P4.5/AD13   | 31     | 19       |
| P4.6/AD14   | 32     | 18       |
| P4.7/AD15   | 33     | 17       |
| RD          | 17     | 33       |
| READY       | 35     | 16       |
| RESET       | 62     | 48       |
| RXD/P2.1    | 61     | 1        |
| TEST        | 14     | <u> </u> |
| TXD/P2.0    | 60     | 2        |
| T2CLK/P2.3  | 34     | _        |
| T2RST/P2.4  | 36     |          |
| VBB         | 41     | 12       |
| VCC         | 9      | 38       |
| VPD         | 64     | 46       |
| VREF        | 65     | 45       |
| VSS         | 10     | 11       |
| VSS         | 42     | 37       |
| WR          | 38     | 14       |
| XTAL1       | 11     | 36       |
| XTAL2       | 12     | 35       |
|             |        |          |

The Following pins are not bonded out in the 48-pin package:

P1.0 through P1.7, P0.0 through P0.3, P2.3, P2.4, P2.6, P2.7 CLKOUT, INST, NMI, TEST, T2CLK(P2.3), T2RST(P2.4).

.

# MCS<sup>®</sup>-96 Software Design Information

3

'

## CHAPTER 3 MCS®-96 SOFTWARE DESIGN INFORMATION

## **3.0. INTRODUCTION**

This section provides information which will primarily interest those who must write programs to execute in the 8096. Several other sources of information are currently available which will also be of interest:

#### MCS<sup>®</sup>-96 MACRO ASSEMBLER USER'S GUIDE Order Number 122048-001

MCS-96 UTILITIES USER'S GUIDE Order Number 122049-001

# MCS-96 MACRO ASSEMBLER AND UTILITIES POCKET REFERENCE

Order Number 122050-001

Throughout this chapter short segments of code are used to illustrate the operation of the device. For these sections it has been assumed that a set of temporary registers have been predeclared. The names of these registers have been chosen as follows:

AX, BX, CX, and DX are 16 bit registers.

AL is the low byte of AX, AH is the high byte.

BL is the low byte of BX

CL is the low byte of CX

DL is the low byte of DX

These are the same as the names for the general data registers used in 8086. It is important to note, however, that in the 8096, these are not dedicated registers but merely the symbolic names assigned by the programmer to an eight byte region within onboard register file.

## 3.1. OPERAND TYPES

The MCS<sup>®</sup>-96 architecture provides support for a variety of data types which are likely to be useful in a control application. In the discussion of these operand types that follows, the names adopted by the PLM-96 programming language will be used where appropriate. To avoid confusion the name of an operand type will be capitalized. A "BYTE" is an unsigned eight bit variable; a "byte" is an eight bit unit of data of any type.

## 3.1.1. Bytes

BYTES are unsigned 8-bit variables which can take on the values between 0 and 255. Arithmetic and relational operators can be applied to BYTE operands but the result must be interpreted in modulo 256 arithmetic. Logical operations on BYTES are applied bitwise. Bits within BYTES are labeled from 0 to 7 with 0 being the least significant bit. There are no alignment restrictions for BYTES so they may be placed anywhere in the MCS-96 address space.

#### 3.1.2. Words

WORDS are unsigned 16-bit variables which can take on the values between 0 and 65535. Arithmetic and relational operators can be applied to WORD operands but the result must be interpreted modulo 65536. Logical operations on WORDS are applied bitwise. Bits within words are labeled from 0 to 15 with 0 being the least significant bit. WORDS must be aligned at even byte boundaries in the MCS-96 address space. The least significant byte of the WORD is in the even byte address and the most significant byte is in the next higher (odd) address. The address of a word is the address of its least significant byte.

#### 3.1.3. Short-Integers

SHORT-INTEGERS are 8-bit signed variables which can take on the values between -128 and +127. Arithmetic operations which generate results outside of the range of a SHORT-INTEGER will set the overflow indicators in the program status word. The actual numeric result returned will be the same as the equivalent operation on BYTE variables. There are no alignment restrictions on SHORT-INTEGERS so they may be placed anywhere in the MCS-96 address space.

## 3.1.4. Integers

INTEGERS are 16-bit signed variables which can take on the values between -32,768 and 32,767. Arithmetic operations which generate results outside of the range of an INTEGER will set the overflow indicators in the program status word. The actual numeric result returned will be the same as the equivalent operation on WORD variables. INTEGERS conform to the same alignment and addressing rules as do WORDS.

## 3.1.5. Bits

BITS are single-bit operands which can take on the Boolean values of true and false. In addition to the normal support for bits as components of BYTE and WORD operands, the 8096 provides for the direct testing of any bit in the internal register file. The MCS-96 architecture requires that bits be addressed as components of BYTES or WORDS, it does not support the direct addressing of bits that can occur in the MCS-51 architecture.

## 3.1.6. Double-Words

DOUBLE-WORDS are unsigned 32-bit variables which can take on the values between 0 and 4,294,967,295. The MCS-96 architecture provides direct support for this operand type only for shifts and as the dividend in a 32 by 16 divide and the product of a 16 by 16 multiply. For these operations a DOUBLE-WORD variable must reside in the on-board register file of the 8096 and be aligned at an address which is evenly divisible by 4. A DOUBLE-WORD operand is addressed by the address of its least significant byte. DOUBLE-WORD operations which are not directly supported can be easily implemented with two WORD operations. For consistency with INTEL provided software the user should adopt the conventions for addressing DOUBLE-WORD operands which are discussed in section 3.5.

## 3.1.7. Long-Integers

LONG-INTEGERS are 32-bit signed variables which can take on the values between -2.147.483.648 and 2,147,483,647. The MCS-96 architecture provides direct support for this data type only for shifts and as the dividend in a 32 by 16 divide and the product of a 16 by 16 multiply.

LONG-INTEGERS can also be normalized. For these operations a LONG-INTEGER variable must reside in the onboard register file of the 8096 and be aligned at an

## 3.2. OPERAND ADDRESSING

Operands are accessed within the address space of the 8096 with one of six basic addressing modes. Some of the details of how these addressing modes work are hidden by the assembly language. If the programmer is to take full advantage of the architecture, it is important that these details be understood. This section will describe the addressing modes as they are handled by the hardware. At the end of this section the addressing modes will be de-

#### 3.2.1. Register-direct References

3.2.2. Indirect References

The register-direct mode is used to directly access a register from the 256 byte on-board register file. The register is selected by an 8-bit field within the instruction and

MUL.

INCB

The indirect mode is used to access an operand by placing its address in a WORD variable in the register file. The calculated address must conform to the alignment rules for the operand type. Note that the indirect address can refer to an operand anywhere within the address space of

Examples ADD AX.BX.CX : AX := BX + CX

AX.BX

CL.

| the 8  | 096, includin   | g the register | file. T  | he register  | which   |
|--------|-----------------|----------------|----------|--------------|---------|
| conta  | ins the indire  | ct address is  | selecte  | d by an ei   | ght bit |
| field  | within the in   | struction. An  | instrue  | ction can c  | ontain  |
| only   | one indirect    | reference and  | the rea  | maining op   | erands  |
| of the | instruction (if | f any) must be | register | -direct refe | rences. |

Examples

; AX: = MEM \_\_\_ WORD(AX) LD AX,[AX] ADDB AL,BL,[CX]; AL = BL + MEM - BYTE(CX); MEM \_\_ WORD(AX) := MEM \_\_ WORD(SP), SP. = SP + 2 POP [AX]

AX = AX BX

 $: CL \cdot = CL + 1$ 

## 3.2.3. Indirect with Auto-increment References

This addressing mode is the same as the indirect mode except that the WORD variable which contains the indirect address is incremented after it is used to address the operand. If the instruction operates on BYTES or SHORT-

INTEGERS the indirect address variable will be incremented by one, if the instruction operates on WORDS or INTEGERS the indirect address able will be incremented by two.

Examples ; AX: = MEM \_\_\_ WORD(BX); BX: = BX + 2 LD AX,[BX] +,  $AL := AL + BL + MEM \__BYTE(CX); CX := CX + 1$ ADD AL,BL,[CX] +PUSH [AX]+ : SP := SP - 2:MEM  $\_$  WORD(SP): = MEM  $\_$  WORD(AX) AX: = AX + 2

address which is evenly divisible by 4. A LONG-INTEGER is addressed by the address of its least significant byte.

LONG-INTEGER operations which are not directly supported can be easily implemented with two INTEGER operations. For consistency with Intel provided software, the user should adopt the conventions for addressing LONG operands which are discussed in section 3.5.

scribed as they are seen through the assembly language.

The six basic addressing modes which will be described are termed register-direct, indirect, indirect with auto-in-

crement, immediate, short-indexed, and long-indexed.

Several other useful addressing operations can be achieved

by combining these basic addressing modes with specific

registers such as the ZERO register or the stack pointer.

register address must conform to the alignment rules for the operand type. Depending on the instruction, up to three registers can take part in the calculation.

## 3.2.4. Immediate References

This addressing mode allows an operand to be taken directly from a field in the instruction. For operations on BYTE or SHORT-INTEGER operands this field is eight bits wide, for operations on WORD or INTEGER operands the field is 16 bits wide. An instruction can contain only one immediate reference and the remaining operand(s) must be register-direct references.

| Examples |         | ·                                       |
|----------|---------|-----------------------------------------|
| ADD      | AX,#340 | ; $AX = AX + 340$                       |
| PUSH     | #1234H  | ; $SP = SP - 2$ ; MEM WORD(SP): = 1234H |
| DIVB     | AX,#10  | , $AL: = AX/10$ ; $AH: = AX MOD 10$     |

## 3.2.5. Short-indexed References

In this addressing mode an eight bit field in the instruction selects a WORD variable in the register file which is assumed to contain an address. A second eight bit field in the instruction stream is sign-extended and summed with the WORD variable to form the address of the operand which will take part in the calculation. Since the eight bit field is sign-extended the effective address can be up to 128 bytes before the address in the WORD variable and up to 127 bytes after it. An instruction can contain only one short-indexed reference and the remaining operand(s) must be register-direct references

| Examples |             |                                  |
|----------|-------------|----------------------------------|
| LD       | AX,12[BX]   | , $AX = MEM \_ WORD(BX + 12)$    |
| MULB     | AX,BL,3[CX] | , AX. = $BL*MEM \_ BYTE(CX + 3)$ |

#### 3.2.6. Long-indexed References

This addressing mode is like the short-indexed mode except that a *16-bit* field is taken from the instruction and added to the WORD variable to form the address of the operand. No sign extension is necessary. An instruction can contain only one long-indexed reference and the remaining operand(s) must to register-direct references.

| Examples |                    |                                          |
|----------|--------------------|------------------------------------------|
| AND      | AX, BX, TABLE[CX]  | , $AX: = BX AND MEM \_ WORD(TABLE + CX)$ |
| ST       | AX, TABLE[BX]      | , MEM $\_$ WORD(TABLE + BX) . = AX       |
| ADDB     | AL, BL, LOOKUP[CX] | $AL = BL + MEM \_ BYTE(LOOKUP + CX)$     |

## 3.2.7. ZERO Register Addressing

The first two bytes in the register file are fixed at zero by the 8096 hardware. In addition to providing a fixed source of the constant zero for calculations and comparisons, this register can be used as the WORD variable in a longindexed reference. This combination of register selection and address mode allows any location in memory to be addressed directly.

Examples ADD AX,1234[0] ; AX: = AX + MEM \_\_ WORD(1234) POP 5678[0] , MEM \_\_ WORD(5678): = MEM \_\_ WORD(SP) ; SP: = SP + 2

#### 3.2.8. Stack Pointer Register Addressing

The system stack pointer in the 8096 can be accessed as register 18H of the internal register file. In addition to providing for convenient manipulation of the stack pointer, this also facilitates the accessing of operands in the stack. The top of the stack, for example, can be accessed by using the stack pointer as the WORD variable in an indirect reference. In a similar fashion, the stack pointer can be used in the short-indexed mode to access data within the stack.

| Examples |          | 1                        |
|----------|----------|--------------------------|
| PÜSH     | [SP]     | ; DUPLICATE TOP OF STACK |
| LD       | AX,2[SP] | ; AX: = NEXT TO TOP      |

#### 3.2.9. Assembly Language Addressing Modes

The 8096 assembly language simplifies the choice of addressing modes to be used in several respects:

**Direct Addressing.** The assembly language will choose between register-direct addressing and long-indexed with the ZERO register depending on where the operand is in memory. The user can simply refer to an operand by its symbolic name; if the operand is in the register file, a register-direct reference will be used, if the operand is elsewhere in memory, a long-indexed reference will be generated.

**Indexed Addressing.** The assembly language will choose between short and long indexing depending on the value of the index expression. If the value can be expressed in eight bits then short indexing will be used, if it cannot be expressed in eight bits then long indexing will be used.

The use of these features of the assembly language simplifies the programming task and should be used wherever possible.

## 3.3 PROGRAM STATUS WORD

The program status word (PSW) is a collection of Boolean flags which retain information concerning the state of the user's program. The format of the PSW is shown in figure 3-1. The information in the PSW can be broken down into

two basic categories; interrupt control and condition flags. The PSW can be saved in the system stack with a single operation (PUSHF) and restored in a like manner (POPF).

| 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | Q6                                                                                                  | 05   | 04  | 03  | 02  | 01  | 00 | • |
|----|----|----|----|----|----|----|----|----|-----------------------------------------------------------------------------------------------------|------|-----|-----|-----|-----|----|---|
| Z  | Ν  | v  | VT | С  | _  | Ι  | ST |    | <in< td=""><td>terr</td><td>upt</td><td>Mas</td><td>k R</td><td>eg&gt;</td><td></td><td></td></in<> | terr | upt | Mas | k R | eg> |    |   |

#### Figure 3-1. PSW Register

#### 3.3.1. Interrupt Flags

The lower eight bits of the PSW are used to individually mask the various sources of interrupt to the 8096. A logical 'I' in these bit positions enables the servicing of the corresponding interrupt. These mask bits can be accessed as an eight bit byte (INT\_MASK — address 8) in the onboard register file. Bit 9 in the PSW is the global interrupt enable. If this bit is cleared then all interrupts will be locked out except for the Non Maskable Interrupt (NMI). Note that the various interrupts are collected in the INT \_ PENDING register even if they are locked out. Execution of the corresponding service routines will proceed according to their priority when they become enabled. Further information on the interrupt structure of the 8096 can be found in sections 2.5 and 3.6.

#### 3.3.2. Condition Flags

The remaining bits in the PSW are set as side effects of instruction execution and can be tested by the conditional jump instructions.

**Z.** The Z (Zero) flag is set to indicate that the operation generated a result equal to zero. For the add-with-carry (ADDC) and subtract-with-borrow (SUBC) operations the Z flag is cleared if the result is non-zero but is never set. These two instructions are normally used in conjunction with the ADD and SUB instructions to perform multiple precision arithmetic. The operation of the Z flag for these instructions leaves it indicating the proper result for the entire multiple precision calculation.

N. The N (Negative) flag is set to indicate that the op-

eration generated a negative result. Note that the N flag will be set to the algebraically correct state even if the calculation overflows.

V. The V (oVerflow) flag is set to indicate that the operation generated a result which is outside the range that can be expressed in the destination data type.

VT. The VT (oVerflow Trap) flag is set whenever the V flag is set but can only be cleared by an instruction which explicitly operates on it such as the CLRVT or JVT instructions. The operation of the VT flag allows for the testing for a possible overflow condition at the end of a sequence of related arithmetic operations. This is normally more efficient than testing the V flag after each instruction.

**C.** The C (Carry) flag is set to indicate the state of the arithmetic carry from the most significant bit of the ALU for an arithmetic operation or the state of the last bit shifted out of the operand for a shift. Arithmetic Borrow after a subtract operation is the complement of the C flag (i.e. if the operation generated a borrow then C=0).

**ST.** The ST (STicky bit) set to indicate that during a right shift a 1 has been shifted first into the C flag and then been shifted out. The ST flag is undefined after a multiply operation. The ST flag can be used along with the C flag to control rounding after a right shift. Consider multiplying two eight bit quantities and then scaling the result down to 12 bits:

| MULUB | AX,CL,DL | ; AX: = $CL*DL$        | ` |
|-------|----------|------------------------|---|
| SHR   | AX,#4    | ; Shift right 4 places | ~ |

If the C flag is set after the shift it indicates that the bits shifted off the end of operand were greater-than or equalto one half the least significant bit (LSB) of the result. If the C flag is clear after the shift it indicates that the bits shifted off the end of the operand were less than half the LSB of the result. Without the ST flag, the rounding decision must be made on the basis of this information alone. (Normally the result would be rounded up if the C flag is set.) The ST flag allows a finer resolution in the rounding decision:

| C ST | Value of the bits shifted off                |
|------|----------------------------------------------|
| 0 0  | Value $= 0$                                  |
| 0 1  | $0 < \text{Value} < \frac{1}{2} \text{ LSB}$ |
| 10   | Value = $\frac{1}{2}$ LSB                    |
| 11   | Value > $\frac{1}{2}$ LSB                    |

## Figure 3-2. Rounding Alternatives

Imprecise rounding can be a major source of error in a numerical calculation; use of the ST flag improves the options available to the programmer.

## 3.4 INSTRUCTION SET

The MCS-96 instruction set contains a full set of arithmetic and logical operations for the 8-bit data types BYTE and SHORT INTEGER and for the 16-bit data types WORD and INTEGER. The DOUBLE-WORD and LONG data types (32 bits) are supported for the products of 16 by 16 multiplies and the dividends of 32 by 16 divides and for shift operations. The remaining operations on 32 bit variables can be implemented by combinations of 16 bit operations. As an example the sequence:

| ADD  | AX,CX |
|------|-------|
| ADDC | BX,DX |

performs a 32 bit addition, and the sequence

| SUB  | AX,CX |
|------|-------|
| SUBC | BX,DX |

performs a 32 bit subtraction. Operations on REAL (i.e. floating point) variables are not supported directly by the hardware but are supported by the floating point library for the 8096 (FPAL-96) which implements a single precision subset of the proposed IEEE standard for floating point operations. The performance of this software is significantly improved by the 8096 NORML instruction which normalizes a 32-bit variable and by the existence of the ST flag in the PSW.

In addition to the operations on the various data types, the 8096 supports conversions between these types. LDBZE (load byte zero extended) converts a BYTE to a WORD and LDBSE (load byte sign extended) converts a SHORT-INTEGER into an INTEGER. WORDS can be converted to DOUBLE-WORDS by simply clearing the upper WORD of the DOUBLE-WORD (CLR) and IN-TEGERS can be converted to LONGS with the EXT (sign extend) instruction.

The MCS-96 instructions for addition, subtraction, and comparison do not distinguish between unsigned words and signed integers. Conditional jumps are provided to allow the user to treat the results of these operations as either signed or unsigned quantities. As an example, the CMPB (compare byte) instruction is used to compare both signed and unsigned eight bit quantities. A JH (jump if higher) could be used following the compare if unsigned operands were involved or a JGT (jump if greater-than) if signed operands were involved.

Tables 3-1 and 3-2 summarize the operation of each of the instructions and Tables 3-3 and 3-4 give the opcode, byte count, and timing information for each of the instructions.

## MCS®-96 SOFTWARE DESIGN INFORMATION

|                | Oper- |                                                                                    |               |              | 5            |                      |            |          |       |
|----------------|-------|------------------------------------------------------------------------------------|---------------|--------------|--------------|----------------------|------------|----------|-------|
| Mnemonic       | ands  | Operation (Note 1)                                                                 | Z             | N            | С            | ۷                    | ٧T         | ST       | Notes |
| ADD/ADDB       | 2     | D ← D+A                                                                            | $\checkmark$  | $\checkmark$ | 1            | $\checkmark$         | Î          |          |       |
| ADD/ADDB       | 3     | D ← B+A                                                                            | $\checkmark$  | $\checkmark$ | ✓.           | $\checkmark$         | 1          |          |       |
| ADDC/ADDCB     | 2     | D ← D+A+C                                                                          | Ļ             | $\checkmark$ | $\checkmark$ | $\checkmark$         | ↑          |          |       |
| SUB/SUBB       | 2     | $D \leftarrow D - A$                                                               | $\checkmark$  | $\checkmark$ | 1            | $\checkmark$         | ↑          |          |       |
| SUB/SUBB       | 3     | $D \leftarrow B - A$                                                               | $\checkmark$  | $\checkmark$ | $\checkmark$ | $\checkmark$         | ↑          |          |       |
| SUBC/SUBCB     | 2     | $D \leftarrow D - A + C - 1$                                                       | Ļ             | $\checkmark$ | $\checkmark$ | $\checkmark$         | ↑          | —        |       |
| CMP/CMPB       | 2     | D – A                                                                              | $\checkmark$  | 1            | V            | $\checkmark$         | ↑          |          |       |
| MUL/MULU       | 2     | $D, D + 2 \leftarrow D * A$                                                        | _             |              |              |                      |            | ?        | 2     |
| MUL/MULU       | 3     | $D, D + 2 \leftarrow B * A$                                                        |               |              |              | -                    |            | ?        | 2     |
| MULB/MULUB     | 2     | $D, D + 1 \leftarrow D * A$                                                        |               |              |              | —                    |            | ?        | 3     |
| MULB/MULUB     | 3     | D, D + 1 ← B * Å                                                                   | _             |              |              | _                    |            | ?        | 3     |
| DIV/DIVU       | 2     | $D \leftarrow (D, D + 2)/A$                                                        |               |              |              |                      |            |          | 2     |
|                |       | D + 2 remainder                                                                    |               | <u> </u>     |              | · /                  | <u> </u>   |          |       |
| DIVB/DIVUB     | · 2   | $D \leftarrow (D, D + 1)/A$                                                        |               |              |              |                      |            |          | 2     |
|                |       | D + 1 remainder                                                                    |               | =            | -            | $\frac{1}{\sqrt{2}}$ | <u> </u> ↑ | -        | 3     |
| AND/ANDB       | 2     | $D \leftarrow D$ and $A$                                                           | $-\downarrow$ | $\bigvee$    | Ŭ            | 0                    |            |          |       |
| AND/ANDB       | 3     | $D \leftarrow B \text{ and } A$                                                    | /             | 1            | 0            | 0                    |            |          | ,     |
| OR/ORB         | 2     | $D \leftarrow D$ or A                                                              | $-\downarrow$ | Į√.          | 0            | 0                    |            |          |       |
| XOR/XORB       | 2     | $D \leftarrow D$ (excl. or) A                                                      | /             | $\downarrow$ | 0            | 0                    |            | -        |       |
| LD/LDB         | 2     | $D \leftarrow A$                                                                   |               |              |              |                      |            | -        | ,     |
| ST/STB         | 2     | $A \leftarrow D$                                                                   |               | 1-           | <u> </u>     |                      |            |          |       |
| LDBSE          | 2     | $D \leftarrow A; D + 1 \leftarrow SIGN(A)$                                         |               | <u> </u> _   |              |                      |            |          | 3,4   |
| LDBZE          | 2     | $D \leftarrow A; D + 1 \leftarrow 0$                                               |               | 1=           | -            | 1-                   |            | -        | 3,4   |
| PUSH           | 1     | $SP \leftarrow SP - 2; (SP) A$                                                     |               | -            |              |                      | -          | -        |       |
| POP            | 1     | $A \leftarrow (SP); SP \leftarrow SP + 2$                                          |               | 1-           | -            |                      | -          | -        |       |
| PUSHF          | 0     | $\begin{array}{llllllllllllllllllllllllllllllllllll$                               | 0             | 0            | 0            | 0                    | 0          | 0        |       |
| POPF           | 0     | $PSW \leftarrow (SP); SP \leftarrow SP + 2 \qquad I \leftarrow$                    |               | 1            | 1            | 1                    | 1          |          |       |
| SJMP           | 1     | $PC \leftarrow PC + 11$ -bit offset                                                | <u> </u>      | Ľ            | <u> </u>     | Ľ                    | <u> </u>   | <u> </u> | 5     |
| LJMP           | 1     | $PC \leftarrow PC + 16$ -bit offset                                                | _             | 1_           | 1_           |                      |            |          | 5     |
| BR(indirect)   | 1     | $PC \leftarrow (A)$                                                                | 1_            |              | -            | _                    |            |          |       |
| SCALL          | 1     | $SP \leftarrow SP - 2; (SP) \leftarrow PC;$                                        |               |              |              |                      |            |          | 5     |
| •              |       | $PC \leftarrow PC + 11$ -bit offset                                                |               |              |              |                      |            |          | -     |
| LCALL          | 1     | $SP \leftarrow SP - 2; (SP) \leftarrow PC;$<br>$PC \leftarrow PC + 16$ -bit offset | -             | -            | -            | -                    | -          | -        | 5     |
| RET            | 0     | $PC \leftarrow (SP); SP \leftarrow SP + 2$                                         |               |              | 1            | -                    |            |          |       |
| J(conditional) | 1     | $PC \leftarrow PC + 8$ -bit offset                                                 | 1_            | 1_           | 1_           | 1_                   | 1_         | 1        | 5     |
| JC             | 1     | Jump if $C = 1$                                                                    |               |              | -            | 1                    |            |          | 5     |
| JNC            | 1     | Jump if $C = 0$                                                                    |               | 1_           | 1_           |                      |            |          | 5     |

## Table 3-1. Instruction Summary

#### Note

1. If the mnemonic ends in "B", a byte operation is performed, otherwise a word operation is done Operands D, B, and A must conform to the alignment rules for the required operand type. D and B are locations in the register file; A can be located anywhere in memory.

2. D, D + 2 are consecutive WORDS in memory; D is DOUBLE-WORD aligned.

3. D, D + 1 are consecutive BYTES in memory; D is WORD aligned.

4. Changes a byte to a word.

5. Offset is a 2's complement number.

|                  | Oper- |                                                                                | 1            |              | Fla          | I <b>gs</b>    |          |              |       |
|------------------|-------|--------------------------------------------------------------------------------|--------------|--------------|--------------|----------------|----------|--------------|-------|
| Mnemonic         | ands  | Operation (Note 1)                                                             | Z            | N            | С            | v              | VΤ       | ST           | Notes |
| JE               | 1     | Jump if $Z = 1$                                                                | 1_           | _            | —            |                |          |              | 5     |
| JNE              | 1     | Jump if $Z = 0$                                                                |              |              | —            | —              | —        |              | 5     |
| JGE              | 1     | Jump if $N = 0$                                                                | _            |              |              |                |          |              | 5     |
| JLT              | 1     | Jump if $N = 1$                                                                | <u> </u>     |              |              | —              |          |              | 5     |
| JGT              | 1     | Jump if $N = 0$ and $Z = 0$                                                    | —            | —            | —            | —              | —        | —            | 5     |
| JLE              | 1     | Jump if $N = 1$ or $Z = 1$                                                     | 1_           | —            |              |                | —        | —            | 5     |
| JH               | 1     | Jump if $C = 1$ and $Z = 0$                                                    | _            |              | _            | -              |          |              | 5     |
| JNH              | , 1   | Jump if $C = 0$ or $Z = 1$                                                     | 1-           |              | —            | —              |          |              | 5     |
| JV               | 1     | Jump if $V = 1$                                                                | ]_           |              |              |                | <u> </u> |              | 5     |
| JNV              | 1     | Jump if $V = 0$                                                                |              |              |              | —              |          |              | 5     |
| JVT              | 1     | Jump if $VT = 1$ ; Clear $VT$                                                  | _            |              | _            | _              | 0        |              | 5     |
| JNVT             | 1     | Jump if $VT = 0$ ; Clear $VT$                                                  | -            | ·            | _            |                | 0        |              | 5     |
| JST              | 1     | Jump if $ST = 1$                                                               | _            |              |              | —              | _        | —            | 5     |
| JNST             | 1     | Jump if $ST = 0$                                                               | _            |              | —            | —              |          |              | 5     |
| JBS              | 3     | Jump if Specified Bit $= 1$                                                    | _            |              | -            |                |          | —            | 5,6   |
| JBC              | 3     | Jump if Specified Bit $= 0$                                                    |              | —            |              |                |          |              | 5,6   |
| DJNZ             | • 1   | $D \leftarrow D - 1$ ; if $D \neq 0$ then<br>PC $\leftarrow$ PC + 8-bit offset |              |              |              | _              |          |              | 5     |
| DEC/DECB         | 1     | D ← D − 1                                                                      | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$   | Î        |              |       |
| NEG/NEGB         | 1     | $D \leftarrow 0 - D$                                                           | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$   | <b>↑</b> | —            |       |
| INC/INCB         | 1     | $D \leftarrow D + 1$                                                           | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$   | 1        |              |       |
| EXT              | 1     | $D \leftarrow D; D + 2 \leftarrow Sign (D)$                                    | $\checkmark$ | $\checkmark$ | 0            | 0              |          |              | 2     |
| EXTB             | 1     | $D \leftarrow D; D + 1 \leftarrow Sign (D)$                                    | $\checkmark$ | $\checkmark$ | 0            | 0,             |          |              | 3     |
| NOT/NOTB         | 1     | D ← Logical Not (D)                                                            | $\checkmark$ | $\checkmark$ | 0            | 0              |          | —            |       |
| CLR/CLRB         | 1     | D ← 0                                                                          | 1            | 0            | 0            | 0              |          | —            |       |
| SHL/SHLB/SHLL    | 2     | $C \leftarrow msb lsb \leftarrow 0$                                            | $\checkmark$ | ?            | $\checkmark$ | $\checkmark$   | 1        |              | 7     |
| SHR/SHRB/SHRL    | 2     | $0 \rightarrow \text{msb} \text{lsb} \rightarrow \text{C}$                     | 1            | 0            | $\checkmark$ | 0              | —        | $\checkmark$ | 7     |
| SHRA/SHRAB/SHRAL | 2     | $msb \rightarrow msb lsb \rightarrow C$                                        | 1            | $\checkmark$ | $\checkmark$ | 0              | —        | $\checkmark$ | 7     |
| SETC             | 0     | C ← 1                                                                          | -            |              | 1            | —              | —        |              |       |
| CLRC             | 0     | C ← 0                                                                          | _            |              | 0            |                |          |              |       |
| CLRVT            | 0     | $VT \leftarrow 0$                                                              | 1            | _            |              |                | 0        |              |       |
| RST              | Ô     | PC ← 2080H                                                                     | 0            | 0            | 0            | <sup>-</sup> 0 | 0        | 0            | 8     |
| DI               | 0     | Disable All Interrupts (I ← 0)                                                 | -            |              |              |                |          |              |       |
| EI               | 0     | Enable All Interrupts (I ← 1)                                                  | 1_           |              |              | —              | —        |              |       |
| NOP              | 0     | $PC \leftarrow PC + 1$                                                         | 1_           | —            |              |                |          |              |       |
| SKIP             | 0     | $PC \leftarrow PC + 2$                                                         | <u> </u>     | _            |              | _              |          |              |       |
| NORML            | 2     | Normalize (See sec 3.13.66)                                                    | 1            | 1            | 0            |                | —        |              | 7     |
| TRAP             | 0     | $SP \leftarrow SP - 2; (SP) \leftarrow PC; PC \leftarrow$<br>(2010H)           | _            |              |              |                |          | _            | 9     |

## Table 3-2. Instruction Summary

## Note

7. The "L" (Long) suffix indicates double-word operation.

<sup>1.</sup> If the mnemonic ends in "B", a byte operation is performed, otherwise a word operation is done. Operands D, B and A must conform to the alignment rules for the required operand type. D and B are locations in the register file; A can be located anywhere in memory.

<sup>5.</sup> Offset is a 2's complement number.

<sup>6.</sup> Specified bit is one of the 2048 bits in the register file.

Initiates a Reset by pulling RESET low. Software should re-initialize all the necessary registers with code starting at 2080H.
 The assembler will not accept this mnemonic.

## MCS®-96 SOFTWARE DESIGN INFORMATION

|          |          | ,          |       | ,<br>,         |        |       |                |        | 1     | NDIREC           | ).<br>T⊛ | r                            |            |       | INDEXE           | D®    |                              |
|----------|----------|------------|-------|----------------|--------|-------|----------------|--------|-------|------------------|----------|------------------------------|------------|-------|------------------|-------|------------------------------|
| - 0      | · ,      |            | DIR   | ECT            | IM     | ME    | DIATE          | · N    | ORM   |                  | +        | TO-INC.                      |            |       | ORT              | -     | ONG                          |
| MNEMONIC | OPERANDS | OPCODE     | BYTES | STATE<br>TIMES | OPCODE | BYTES | STATE<br>TIMES | OPCODE | BYTES | STATE()<br>TIMES | BYTES    | STATE <sup>()</sup><br>Times | OPCODE     | BYTES | STATE()<br>Times | BYTES | STATE <sup>()</sup><br>TIMES |
|          |          |            |       |                |        | A     | RITHME         | TIC IN | IST   | RUCTIO           | NS       | ``                           |            |       |                  |       |                              |
| ADD      | 2        | 64         | 3     | 4              | 65     | 4     | 5              | 66     | 3     | 6/11             | 3        | 7/12                         | 67         | 4     | 6/11             | 5     | 7/12                         |
| ADD      | 3        | 44         | 4     | 5              | 45     | 5     | 6              | 46     | 4     | 7/12             | 4        | 8/13                         | 47         | 5     | 7/12             | 6     | 8/13                         |
| ADDB     | 2        | 74         | 3     | 4              | 75     | 3     | 4              | 76     | 3     | 6/11             | 3        | 7/12                         | 77         | 4     | 6/11             | 5     | 7/12                         |
| ADDB     | 3        | 54         | 4     | 5              | 55     | 4     | 5              | 56     | 4     | 7/12             | 4        | 8/13                         | 57         | 5     | 7/12             | 6     | 8/13                         |
| ADDC :   | 2        | A4         | 3     | 4              | A5     | 4     | 5              | A6     | 3     | 6/11             | 3        | 7/12                         | A7         | 4     | 6/11             | 5     | 7/12                         |
| ADDCB    | 2        | <b>B</b> 4 | 3     | .4.            | B5     | 3     | 4              | B6     | 3     | 6/11             | 3        | 7/12                         | B7         | 4     | 6/11             | 5     | 7/12                         |
| SUB      | 2        | 68         | 3     | 4              | 69     | 4     | •5             | 6A     | 3     | 6/11             | 3        | 7/12                         | 6B         | 4     | 6/11             | 5     | 7/12                         |
| SUB      | . 3      | 48         | 4     | 5              | 49     | 5     | 6              | 4A     | 4     | 7/12             | 4        | 8/13                         | 4 <b>B</b> | 5     | 7/12             | 6     | 8/13                         |
| SUBB     | 2        | 78         | 3     | 4              | 79     | 3     | 4              | 7A     | 3     | 6/11             | 3        | 7/12                         | 7B         | 4     | 6/11             | 5     | 7/12                         |
| SUBB     | 3        | 58         | 4     | 5              | 59     | 4     | 5              | 5A     | 4     | 7/12             | 4        | 8/13                         | 5B         | 5     | 7/12             | 6     | 8/13                         |
| SUBC     | 2        | A8         | 3     | 4              | A9     | 4     | 5              | AA     | 3     | 6/11             | 3        | 7/12                         | AB         | 4     | 6/11             | 5     | 7/12                         |
| SUBCB    | 2        | <b>B8</b>  | 3     | 4              | B9     | 3     | 4              | BA     | 3     | 6/11             | 3        | 7/12                         | BB         | 4     | 6/11             | 5     | 7/12                         |
| CMP      | 2        | 88         | 3     | 4              | 89     | 4     | 5              | 8A     | 3     | 6/11             | 3        | 7/12                         | 8B         | 4     | 6/11             | 5     | 7/12                         |
| CMPB     | 2        | 98         | 3     | 4              | 99     | 3     | 4              | 9A     | 3     | 6/11             | 3        | 7/12                         | 9B         | 4     | 6/11             | 5     | 7/12                         |
|          |          |            |       |                |        |       |                |        |       |                  |          |                              |            |       |                  |       | Ì                            |
| MULU     | 2        | 6C         | 3     | 25             | 6D     | 4     | 26             | 6E     | 3     | 27/32            | 3        | 28/33                        | 6F         | 4     | 27/32            | 5     | 28/33                        |
| MULU     | 3        | 4C         | 4     | 26             | 4D     | 5     | 27             | 4E     | 4     | 28/33            | 4        | 29/34                        | 4F         | 5     | 28/33            | 6     | 29/34                        |
| MULUB    | 2        | 7C         | 3     | 17             | 7D     | 3     | 17             | 7E     | 3     | 19/24            | 3        | 20/25                        | 7F         | 4     | 19/24            | 5     | 20/25                        |
| MULUB    | 3        | 5C         | 4     | 18             | 5D     | 4     | 18             | 5E     | 4     | 20/25            | 4        | 21/26                        | 5F         | 5     | 20/25            | 6     | 21/26                        |
| MUL      | 2        | 2          | 4     | 29             | 2      | 5     | 30             | 2      | 4     | 31/36            | 4        | 32/37                        | 2          | 5     | 31/36            | 6     | 32/37                        |
| MUL      | 3        | 2          | 5     | 30             | 2      | 6     | 31             | 2      | 5     | 32/37            | 5        | 33/38                        | 2          | 6     | 32/37            | 7     | 33/38                        |
| MULB     | 2        | 2          | 4     | 21             | 2      | 4     | 21             | 2      | 4     | 23/28            | 4        | 24/29                        | 2          | 5     | 23/28            | 6     | 24/29                        |
| MULB     | 3        | 2          | 5     | 22             | 2      | 5     | 22             | 2      | 5     | 24/29            | 5        | 25/30                        | 2          | 6     | 24/29            | 7     | 25/30                        |
| DIVU     | 2        | 8C         | 3     | 25             | 8D .   | 4     | 26             | 8E     | 3     | 28/32            | 3        | 29/33                        | 8F         | 4     | 28/32            | 5     | 29/33                        |
| DIVUB    | 2        | 9C         | 3     | 17             | 9D     | 3     | 17             | 9E     | 3     | 20/24            | 3        | 21/25                        | 9F         | 4     | 20/24            | 5     | 21/25                        |
| DIV      | 2        | 2 ·        | 4     | 29             | 2      | 5     | 30             | 2      | 4     | 32/36            | 4        | 33/37                        | 2          | 5     | 32/36            | 6     | 33/37                        |
| DIVB     | 2        | 2          | 4     | 21             | 2      | 4     | 21             | 2      | 4     | 24/28            | 4        | 25/29                        | 2          | 5     | 24/28            | 6     | 25/29                        |

## Table 3-3. Opcode and State Time Listing

Notes:

÷

Icong indexed and Indirect + instructions have identical opocodes with Short indexed and Indirect modes, respectively. The second byte of instructions using any indirect or indexed addressing mode specifies the exact mode used. If the second byte is even, use Indirect or Short Indexed. If it is odd, use Indirect + or Long indexed. In all cases the second byte of the instruction always specifies an even (word) location for the address referenced.

① Number of state times shown for internal/external operands.

The opcodes for signed multiply and divide are the opcodes for the unsigned functions with an "FE" appended as a prefix.

| Table | 3-3. | Continued |
|-------|------|-----------|
|-------|------|-----------|

|          |          |            | DIRECT IMMEDIATE |                |        |       | 11             | NDIREC | тœ    |                  |       |                  | INDEXE | D®    |                  |       |                  |
|----------|----------|------------|------------------|----------------|--------|-------|----------------|--------|-------|------------------|-------|------------------|--------|-------|------------------|-------|------------------|
| 2        |          |            | лк               |                | 1101   |       |                | N      | OR    | MAL              | AU    | TO-INC.          |        | SHC   | DRT              | l     | .ONG             |
| MNEMONIC | OPERANDS | OPCODE     | BYTES            | STATE<br>TIMES | OPCODE | BYTES | STATE<br>TIMES | OPCODE | BYTES | STATE()<br>TIMES | BYTES | STATE()<br>TIMES | OPCODE | BYTES | STATE()<br>TIMES | BYTES | STATE()<br>TIMES |
|          |          |            |                  |                |        |       | LOGICA         | L INS  | TRI   | JCTION           | S     |                  |        |       |                  |       |                  |
| AND      | 2        | 60         | 3                | 4              | 61     | 4     | 5              | 62     | 3     | 6/11             | 3     | 7/12             | 63     | 4     | 6/11             | 5     | 7/12             |
| AND      | 3        | 40         | 4                | 5              | 41     | 5     | 6              | 42     | 4     | 7/12             | 4     | 8/13             | 43     | 5     | 7/12             | 6     | 8/13             |
| ANDB     | 2        | 70         | 3                | 4              | 71     | 3     | 4              | 72     | 3     | 6/11             | 3     | 7/12             | 73     | 4     | 6/11             | 5     | 7/12             |
| ANDB     | 3        | 50         | 4                | 5              | 51     | 4     | 5              | 52     | 4     | 7/12             | 4     | 8/13             | 53     | 5     | 7/12             | 6     | 8/13             |
| OR       | 2        | 80         | 3                | 4              | 81     | 4     | 5              | 82     | 3     | 6/11             | 3     | 7/12             | 83     | 4     | 6/11             | 5     | 7/12             |
| ORB      | 2        | 90         | 3                | 4              | 91     | 3     | 4              | 92     | 3     | 6/11             | 3     | 7/12             | 93     | 4     | 6/11             | 5     | 7/12             |
| XOR      | 2        | 84         | 3                | 4              | 85     | 4     | 5              | 86     | 3     | 6/11             | 3     | 7/12             | 87     | 4     | 6/11             | 5     | 7/12             |
| XORB     | 2        | 94         | 3                | 4              | 95     | 3     | 4              | 96     | 3     | 6/11             | 3     | 7/12             | 97     | 4     | 6/11             | 5     | 7/12             |
|          |          |            |                  |                |        | DAT   | A TRAN         | SFER   | INS   | STRUCT           | ION   | S                |        |       |                  |       |                  |
| LD       | 2        | A0         | 3                | 4              | A1     | 4     | 5              | A2     | 3     | 6/11             | 3     | 7/12             | A3     | 4     | 6/11             | 5     | 7/12             |
| LDB      | 2        | <b>B</b> 0 | 3                | 4              | B1     | 3     | 4              | B2     | 3     | 6/11             | 3     | 7/12             | B3     | 4     | 6/11             | 5     | 7/12             |
| ST       | 2        | C0         | 3                | 4              | —      |       |                | C2     | 3     | 7/11             | 3     | 8/12             | C3     | 4     | 7/11             | 5     | 8/12             |
| STB      | 2        | C4         | 3                | 4              | —      | _     |                | C6     | 3     | 7/11             | 3     | 8/12             | C7     | 4     | 7/11             | 5     | 8/12             |
| LDBSE    | 2        | BC         | 3                | 4              | BD     | 3     | 4              | BE     | 3     | 6/11             | 3     | 7/12             | BF     | 4     | 6/11             | 5     | 7/12             |
| LDBZE    | 2        | AC         | 3                | 4              | AD     | 3     | 4              | AE     | 3     | 6/11             | 3     | 7/12             | AF     | 4     | 6/11             | 5     | 7/12             |
|          |          |            |                  |                | S      | TAC   | CK OPE         | RATIO  | NS    | (interna         | l st  | ack)             |        |       |                  |       |                  |
| PUSH     | 1        | C8         | 2                | 8              | C9     | 3     | 8              | CA     | 2     | 11/15            | 2     | 12/16            | CB     | 3     | 11/15            | 4     | 12/16            |
| POP      | 1        | CC         | 2                | 12             |        |       |                | CE     | 2     | 14/18            | 2     | 14/18            | CF     | 3     | 14/18            | 4     | 14/18            |
| PUSHF    | 0        | F2         | 1                | 8              |        |       |                |        |       |                  |       | N                |        | ŀ     |                  |       |                  |
| POPF     | 0        | F3         | 1                | 9              |        |       |                |        |       |                  |       | ,                |        |       |                  |       |                  |
|          |          |            |                  | ,              | S      | TA    | CK OPE         | RATIO  | NS    | (externa         | al si | tack)            |        |       |                  |       |                  |
| PUSH .   | 1        | C8         | 2                | 12             | C9     | 3     | 12             | CA     | 2     | 15/19            | 2     | 16/20            | CB     | 3     | 15/19            | 4     | 16/20            |
| POP      | 1        | CC         | 2                | 14             | —      |       |                | CE     | 2     | 16/20            | 2     | 16/20            | CF     | 3     | 16/20            | 4     | 16/20            |
| PUSHF    | 0        | F2         | 1                | 12             |        |       |                |        |       |                  |       |                  |        |       |                  |       |                  |
| POPF     | 0        | F3         | 1                | 13             |        |       |                |        |       |                  | ,     | 2                |        |       |                  |       |                  |
|          |          |            | v                |                |        |       |                | 1      |       | ALLÓ             |       |                  |        |       |                  |       |                  |

|          | JUMPS AND CALLS |       |        |          |        |       |        |  |  |  |  |  |  |
|----------|-----------------|-------|--------|----------|--------|-------|--------|--|--|--|--|--|--|
| MNEMONIC | OPCODE          | BYTES | STATES | MNEMONIC | OPCODE | BYTES | STATES |  |  |  |  |  |  |
| LJMP     | E7              | 3     | 8      | LCALL    | EF     | 3     | 13/16⑤ |  |  |  |  |  |  |
| SJMP     | 20-27④          | 2     | 8      | SCALL    | 28-2F④ | 2     | 13/16⑤ |  |  |  |  |  |  |
| BR[ ]    | E3              | 2     | 8      | RET      | F0     | 1     | 12/16⑤ |  |  |  |  |  |  |
| Notes:   |                 |       |        | TRAP3    | F7     | 1     |        |  |  |  |  |  |  |

① Number of state times shown for internal/external operands.

3 The assembler does not accept this mnemonic.

The least significant 3 bits of the opcode are concatenated with the following 8 bits to form an 11-bit, 2's complement, offset for the relative call or jump.

<sup>(5)</sup> State times for stack located internal/external.

<sup>®</sup> The assembler uses the generic jump mnemonic (BR) to generate this instruction.

## **MCS®-96 SOFTWARE DESIGN INFORMATION**

| Table 3-4. | CONDITIONAL JUMPS |  |
|------------|-------------------|--|
|------------|-------------------|--|

| All co   | All conditional jumps are 2 byte instructions. They require 8 state times if the jump is taken, 4 if it is not. |          |        |          |        |          |        |  |  |  |  |  |  |  |
|----------|-----------------------------------------------------------------------------------------------------------------|----------|--------|----------|--------|----------|--------|--|--|--|--|--|--|--|
| MNEMONIC | OPCODE                                                                                                          | MNEMONIC | OPCODE | MNEMONIC | OPCODE | MNEMONIC | OPCODE |  |  |  |  |  |  |  |
| JC       | DB                                                                                                              | JE       | DF     | JGE      | D6     | JGT      | D2     |  |  |  |  |  |  |  |
| JNC      | D3                                                                                                              | JNE      | D7     | JLT      | DE     | JLE      | DA     |  |  |  |  |  |  |  |
| JH       | D9                                                                                                              | JV .     | DD     | JVT      | DC     | JST      | D8     |  |  |  |  |  |  |  |
| JNH      | D1                                                                                                              | JNV      | D5     | JNVT     | D4     | JNST     | D0     |  |  |  |  |  |  |  |

#### JUMP ON BIT CLEAR OR BIT SET

| T        | These instructions are 3-byte instructions. They require 9 state times if the jump is taken, 5 if it is not. |    |      |    |    |    |    |    |  |  |  |  |  |  |
|----------|--------------------------------------------------------------------------------------------------------------|----|------|----|----|----|----|----|--|--|--|--|--|--|
|          | BIT NUMBER                                                                                                   |    |      |    |    |    |    |    |  |  |  |  |  |  |
| MNEMONIC | 0                                                                                                            | 1  | 2    | 3  | 4  | 5  | 6  | 7  |  |  |  |  |  |  |
| JBC      | 30                                                                                                           | 31 | 32   | 33 | 34 | 35 | 36 | 37 |  |  |  |  |  |  |
| JBS      | 38                                                                                                           | 39 | 3A · | 3B | 3C | 3D | 3E | 3F |  |  |  |  |  |  |

## LOOP CONTROL

| D 11/7 | ODCODE FO  | 2 DVTCC                 | 5/0 OTATE THATE (NOT TAKENUTAKEN) |
|--------|------------|-------------------------|-----------------------------------|
| DJNZ   | OPCODE EO: | 3 BYTES:                | 5/9 STATE TIMES (NOT TAKEN/TAKEN) |
| 2000   | 0.0000 20, | <i>v</i> <b>=</b> 1120, |                                   |
|        |            |                         |                                   |

| MNEMONIC | OPCODE | BYTES | STATES | MNEMONIC | OPCODE | BYTES | STATES |  |  |
|----------|--------|-------|--------|----------|--------|-------|--------|--|--|
| DEC      | 05     | 2     | 4      | EXT      | 06     | 2     | 4      |  |  |
| DECB     | 15     | 2     | 4      | EXTB     | 16     | 2     | 4      |  |  |
| NEĠ      | 03     | 2     | 4      | NOT      | 02     | 2     | 4      |  |  |
| NEGB     | 13     | 2     | 4      | NOTB     | 12     | 2     | 4      |  |  |
| INC      | 07     | 2     | 4      | CLR      | 01     | 2     | 4      |  |  |
| INCB     | 17     | 2     | 4      | CLRB     | 11     | 2     | 4      |  |  |

## SINGLE REGISTER INSTRUCTIONS

## SHIFT INSTRUCTIONS

| INSTR    | wo | RD | INSTR    | BYTE |   | BYTE     |    | INSTR | DBL               | WD |  |  |
|----------|----|----|----------|------|---|----------|----|-------|-------------------|----|--|--|
| MNEMONIC | OP | В  | MNEMONIC | OP   | В | MNEMONIC | OP | B     | STATE TIMES       |    |  |  |
| SHL      | 09 | 3  | SHLB     | 19 ′ | 3 | SHLL     | 0D | 3     | 7 + 1 PER SHIFT Ø |    |  |  |
| SHR      | 08 | 3  | SHRB     | 18   | 3 | SHRL     | 0C | 3     | 7 + 1 PER SHIFT@  |    |  |  |
| SHRA     | 0A | 3  | SHRAB    | 1A   | 3 | SHRAL    | 0E | 3     | 7 + 1 PER SHIFT   |    |  |  |

| MNEMONIC | OPCODE | BYTES | STATES | MNEMONIC | OPCODE | BYTES | STATES |
|----------|--------|-------|--------|----------|--------|-------|--------|
| SETC     | F9     | 1     | 4      | DI       | FA     | 1     | 4      |
| CLRC     | F8     | 1     | 4      | EI       | • FB   | 1     | 4      |
| CLRVT    | FC     | 1     | 4      | NOP      | FD     | 1.    | 4      |
| RST      | FF     | 1     | 16     | SKIP     | 00     | 2     | 4      |

## SPECIAL CONTROL INSTRUCTIONS

## NORMALIZE

| NORML | ~0F | 3 | 11 + 1 PER SHIFT |  |
|-------|-----|---|------------------|--|
|       |     |   | 1                |  |

Notes:

This instruction takes 2 states to pull RST low, then holds it low for 2 states to initiate a reset The reset takes 12 states, at which time the program restarts at location 2080H.

D Execution will take at least 8 states, even for 0 shift.

## 3.5. SOFTWARE STANDARDS AND CONVENTIONS

For a software project of any size it is a good idea to modularize the program and to establish standards which control the communication between these modules. The nature of these standards will vary with the needs of the final application. A common component of all of these standards, however, must be the mechanism for passing parameters to procedures and returning results from procedures. In the absence of some overriding consideration which prevents their use, it is suggested that the user conform to the conventions adopted by the PLM-96 programing language for procedure linkage. It is a very usable standard for both the assembly language and PLM-96 environment and it offers compatibility between these environments. Another advantage is that it allows the user access to the same floating point arithmetics library that PLM-96 uses to operate on REAL variables.

## 3.5.1. Register Utilization

The MCS-96 architecture provides a 256 byte register file. Some of these registers are used to control register-mapped I/O devices and for other special functions such as the ZERO register and the stack pointer. The remaining bytes in the register file, some 230 of them, are available for allocation by the programmer. If these registers are to be used effectively some overall strategy for their allocation must be adopted. PLM-96 adopts the simple and effective strategy of allocating the eight bytes between addresses ICH and 23H as temporary storage. The starting address of this region is called PLMREG. The remaining area in the register file is treated as a segment of memory which is allocated as required.

## 3.5.2. Addressing 32-bit Operands

These operands are formed from two adjacent 16-bit words in memory. The least significant word of the double word is always in lower address, even when the data is in the stack (which means that the most significant word must be pushed into the stack first). A double word is addressed by the address of its least significant byte. Note that the hardware supports some operations on double words (e.g. normalize and divide). For these operations the double word must be in the internal register file and must have an address which is evenly divisible by four.

## 3.5.3. Subroutine Linkage

Parameters are passed to subroutines in the stack. Parameters are pushed into the stack in the order that they are encountered in the scanning of the source text. Eight-bit parameters (BYTES or SHORT-INTEGERS) are pushed into the stack with the high order byte undefined. Thirtytwo bit parameters (LONG-INTEGERS, DOUBLE-WORDS, and REALS) are pushed into the stack as two 16 bit values; the most significant half of the parameter is pushed into the stack first. As an example, consider the following PLM-96 procedure:

example\_procedure: PROCEDURE (paraml,param2,param3); DECLARE paraml BYTE,

param2 DWORD, param3 WORD;

When this procedure is entered at run time the stack will contain the parameters in the following order:

| ?????? : param1     | .]              |
|---------------------|-----------------|
| high word of param2 | · ·             |
| low word of param2  | ]               |
| param3              | ]               |
| return address      | ← Stack_pointer |

Figure 3-3. Stack Image

If a procedure returns a value to the calling code (as opposed to modifying more global variables) then the result is returned in the variable PLMREG. PLMREG is viewed as either an 8, 16 or 32 bit variable depending on the type of the procedure.

The standard calling convention adopted by PLM-96 has several key features:

a). Procedures can always assume that the eight bytes of register file memory starting at PLMREG can be used as temporaries within the body of the procedure.

b). Code which calls a procedure must assume that the eight bytes of register file memory starting at PLMREG are modified by the procedure.

c). The Program Status Word (PSW-see section 3.3) is not saved and restored by procedures so the calling code must assumed that the condition flags (Z,N,V,VT,C, and ST) are modified by the procedure.

d). Function results from procedures are always returned in the variable PLMREG.

PLM-96 allows the definition of INTERRUPT procedures which are executed when a predefined interrupt occurs. These procedures do not conform to the rules of a normal procedure. Parameters cannot be passed to these procedures and they cannot return results. Since they can execute essentially at any time (hence the term interrupt), these procedures must save the PSW and PLMREG when they are entered and restore these values before they exit.

## 3.6. USING THE INTERRUPT SYSTEM

Processing interrupts is an integral part of almost any control application. The 8096 allows the program to manage interrupt servicing in an efficient and flexible manner. Software running in the 8096 exerts control over the interrupt hardware at several levels.

## 3.6.1. Global Lockout

The processing of interrupts can be enabled or disabled by setting or clearing the I bit in the PSW. This is accomplished by the EI (Enable Interrupts) and DI (Disable Interrupts) instructions. Note that the I bit only controls the actual servicing of interrupts; interrupts that occur during periods of lockout will be held in the pending register and serviced on a prioritized basis when the lockout period ends.

#### 3.6.2. Pending Interrupt Register

When the hardware detects one of the eight interrupts it sets the corresponding bit in the pending interrupt register (INT\_PENDING-register 09H). This register, which has the same bit layout as the interrupt mask register (see next section), can be read or modified as a byte register. This register can be read to determine which of the interrupts are pending at any given time or modified to either clear pending interrupts or generate interrupts under software control. Any software which modifies the INT\_PENDING register should ensure that the entire operation is indivisible. The easiest way of doing this is to use the logical instructions in the two or three operand format, as examples:



If the required modification to INT\_PENDING cannot be accomplished with one instruction then a critical region should be established and the INT\_PENDING register modified from within this region (see section 3.6.5).

#### 3.6.3. Interrupt Mask Register

Individual interrupts can be enabled or disabled by setting or clearing bits in the interrupt mask register (INT\_\_\_\_\_\_ MASK-register 08H). The format of this register is shown in figure 3-4.



Figure 3-4. Interrupt Mask Register

The INT\_\_MASK register can be read or written as a byte register. A one in any bit position will enable the corresponding interrupt source and a zero will disable the source. The individual masks act like the global lockout in that they only control the servicing of the interrupt; the hardware will save any interrupts that occur in the pending register even if the interrupt mask bit is cleared. The INT\_\_MASK register also can be accessed as the lower

eight bits of the PSW so the PUSHF and POPF instructions save and restore the INT\_MASK register as well as the global interrupt lockout and the arithmetic flags.

## 3.6.4. Interrupt Vectors

The 8096 has eight sources of hardware interrupt, each with its own priority and interrupt vector location. Table 3-5 shows the interrupt sources, their priority, and their vector locations. See section 2.5 for a discussion of the various interrupt sources.

**Table 3-5. Interrupt Vector Information** 

| Source             | Priority  | Vector |
|--------------------|-----------|--------|
| Timer Overflow     | 0-Lowest  | 2000H  |
| A/D Completion     | 1         | 2002H  |
| HSI Data Available | 2         | 2004H  |
| HSO Execution      | 3         | 2006H  |
| HSI.O              | 4         | 2008H  |
| Software timers    | 5         | 200AH  |
| Serial I/O         | 6         | 200CH  |
| External Interrupt | 7-Highest | 200EH  |

The programmer must initialize the interrupt vector table with the starting addresses of the appropriate interrupt service routine. It would be a good idea to vector any interrupts that are not used in the system to an error handling routine.

The priorities given in the table give the hardware enforced priorities for these interrupts. This priority controls the order in which pending interrupts are passed to the software via interrupt-calls. The software can implement its own priority structure by controlling the mask register (INT \_\_\_\_\_\_ MASK-register 08H). To see how this is done consider the case of a serial I/O service routine which must run at a priority level which is lower than the HSI data available interrupt but higher than any other source. The "preamble" and exit code for this interrupt service routine would look like this:



Note that location 200CH in the interrupt vector table would have to be loaded with the value of the label serial  $\_$  io  $\_$  isr and the interrupt be enabled for this routine to execute.

There is an interesting chain of instruction side-effects which makes this (or any other) 8096 interrupt service routine execute properly:

a). After the hardware decides to process an interrupt it generates and executes a special interrupt-call instruction which pushes the current program counter onto the stack and then loads the program counter with the contents of the vector table entry corresponding to the interrupt. The hardware will not allow another interrupt to be serviced immediately following the interrupt-call. This guarantees that once the interruptcall starts the first instruction of the interrupt service routine will execute.

b). The PUSHF instruction, which is now guaranteed to execute, saves the PSW in the stack and then clears the PSW. The PSW contains, in addition to the arithmetic flags, the INT\_MASK register and the global enable flag (I). The hardware will not allow an interrupt following a PUSHF instruction and by the time the LD instruction starts all of the interrupt enable flags will be cleared. Now there is guaranteed execution of the LD INT\_MASK instruction.

c). The LD INT\_MASK instruction enables those interrupts that the programmer chooses to allow to interrupt the serial I/O interrupt service routine. In this example only the HSI data available interrupt will be allowed to do this but any interrupt or combination of interrupts could be enabled at this point, even the serial interrupt. It is the loading of the INT\_MASK register which allows the software to establish its own priorities for interrupt servicing independently from those that the hardware enforces.

d). The EI instruction reenables the processing of interrupts.

e). The actual interrupt service routine executes within the priority structure established by the software.

f). At the end of the service routine the POPF instruction restores the PSW to its state when the interruptcall occurred. The hardware will not allow interrupts to be processed following a POPF instruction so the execution of the last instruction (RET) is guaranteed before further interrupts can occur. The reason that this RET instruction must be protected in this fashion is that it is quite likely that the POPF instruction will reenable an interrupt which is already pending. If this interrupt were serviced before the RET instruction. then the return address to the code that was executing when the original interrupt occurred would be left on the stack. While this does not present a problem to the program flow, it could result in a stack overflow if interrupts are occurring at a high frequency. The POPF instruction also pops the INT \_ MASK register (part of the PSW), so any changes made to this register during a routine which ends with a POPF will be lost. Notice that the "preamble" and exit code for the interrupt service routine does not include any code for saving or restoring registers. This is because it has been assumed that the interrupt service routine has been allocated its own private set of registers from the on-board register file. The availability of some 230 bytes of register storage makes this quite practical.

## 3.6.5. Critical Regions

Interrupt service routines must share some data with other routines. Whenever the programmer is coding those sections of code which access these shared pieces of data, great care must be taken to ensure that the integrity of the data is maintained. Consider clearing a bit in the interrupt pending register as part of a non-interrupt routine:

| LDB  | AL, INT_PENDING |
|------|-----------------|
| ANDB | AL,#bit_mask    |
| STB  | AL, INT_PENDING |

This code works if no other routines are operating concurrently, but will cause occasional but serious problems if used in a concurrent environment. (All programs which make use of interrupts must be considered to be part of a concurrent environment.) To demonstrate this problem, assume that the INT\_PENDING register contains 00001111B and bit 3 (HSO event interrupt pending) is to be reset. The code does work for this data pattern but what happens if an HSI interrupt occurs somewhere between the LDB and the STB instructions? Before the LDB instruction INT\_PENDING contains 00001111B and after the LDB instruction so does AL. IF the HSI interrupt service routine executes at this point then INT\_PENDING will change to 00001011B. The ANDB changes AL to 00000111B and the STB changes INT\_PENDING to 00000111B. It should be 00000011B. This code sequence has managed to generate a false HSI interrupt! The same basic process can generate an amazing assortment of problems and headaches. These problems can be avoided by assuring mutual exclusion which basically means that if more than one routine can change a variable, then the programmer must ensure exclusive access to the variable during the entire operation on the variable.

In many cases the instruction set of the 8096 allows the variable to be modified with a single instruction. The code in the above example can be implemented with a single instruction:

#### ANDB INT\_PENDING, #bit \_\_ mask

Instructions are indivisible so mutual exclusion is ensured in this case. For more complex situations, such a simple solution is not available and the programmer must create what is termed a critical region in which it is safe to modify the variable. One way to do this is to simply disable interrupts with a DI instruction, perform the modification, and then re-enable interrupts with an EI instruction. The problem with this approach is that it leaves the interrupts enabled even if they were not enabled at the start. A better solution is to enter the critical region with a PUSHF instruction which saves the PSW and also clears the interrupt enable flags. The region can then be terminated with a POPF instruction which returns the interrupt enable to the state it was in before the code sequence. It should be noted that some system configurations might require more protection to form a critical region. An example is a system in which more than one processor has access to a common resource such as memory or external I/O devices.

## 3.7. I/O PROGRAMMING CONSIDERATIONS

The on-board I/O devices are, for the most part, simple to program. There are some areas of potential confusion which need to be addressed:

## 3.7.1. Programming the I/O Ports

Some of the on-board I/O ports can be used as both input and output pins (e.g. Port 1). When the processor writes to the pins of these ports it actually writes into a register which in turn drives the port pin. When the processor reads these ports, it senses the status of the pin directly. If a port pin is to be used as an input then the software should write a one to that pin, this will cause the lowimpedance pull-down device to turn off and leave the pin pulled up with a relatively high impedance pull-up device which can be easily driven down by the device driving the input. If some pins of a port are to be used as inputs and some are to be used as outputs the programmer should be careful when writing to the port. Consider using P1.0 as an input and then trying to toggle P1.1 as an output:

| ORB  | IOPORT1,#0000001B  | ; Set P1.0 for input |
|------|--------------------|----------------------|
| XORB | IOPORT1,#00000010B | ; Complement P1.1    |

The first instruction will work as expected but two problems can occur when the second instruction executes. The first is that even though P1.1 is being driven high by the 8096 it is possible that it is being held low externally. This typically happens when the port pin is used to drive the base of an NPN transistor which in turn drives whatever there is in the outside world which needs to be toggled. The base of the transistor will clamp the port pin to the transistor's Vbe above ground, typically 0.7 volts. The 8096 will input this value as a zero even if a one has been written to the port pin. When this happens the XORB instruction will always write a one to the port pin and it will not toggle. The second problem, which is related to the first one, is that if P1.0 happens to be driven to a zero when Port 1 is read by the XORB instruction then the XORB will write a zero to P1.0 and it will no longer be useable as an input. The first problem can best be solved by the external driver design. A series resistor between the port pin and the base of the transistor often works. The second problem can be solved in the software fairly easily:

| LDB  | AL, IOPORT1 |
|------|-------------|
| XORB | AL,#010B    |
| ORB  | AL,#001B    |
| STB  | AL, IOPORT1 |

A software solution to both problems is to keep a byte in RAM as an image of the data to be output to the port; any time the software wants to modify the data on the port it can then modify the image byte and then copy it to the port.

#### 3.7.2. Reading the I/O Status Register 1

This status register contains a collection of status flags which relate to the timer and high speed I/O functions (see section 2.12.5). It can be accessed as register 16H in the on-board register file. The layout of this register is shown in figure 3-5.



Figure 3-5. I/O Status Register 1

Whenever the processor reads this register all of the timerelated flags (bits 5 through 0) are cleared. This applies not only to explicit reads such as:

LDB AL,IOS1

but also to implicit reads such as:

JB IOS1.3, somewhere \_\_ else

which jumps to somewhere \_\_else if bit 3 of IOS1 is set. In most cases this situation can best be handled by having a byte in the register file which is used to maintain an image of lower five bits of the register. Any time a hardware timer interrupt or a HSO software timer interrupt occurs the byte can be updated:

ORB IOS1 \_\_ image, IOS1

leaving IOS1 \_\_ image containing all the flags that were set before plus all the new flags that were read and cleared from IOS1. Any other routine which needs to sample the flags can safely check IOS1 \_\_ image. Note that if these routines need to clear the flags that they have acted on then the modification of IOS1 \_\_ image must be done from inside a critical region (see section 3.6.5).

**3.7.3. Sending Commands to the HSO Unit** Commands are sent to the HSO unit via a byte and then a word write operation:

LDB HSO \_\_COMMAND,#what \_\_ to \_\_ do ADD HSO \_\_TIME,TIMER1,#when \_\_ to \_\_ do \_\_ it The command is actually accepted when the HSO\_TIME register is written. It is important to ensure that this code piece is not interrupted by any interrupt service routine which might also send a command to the HSO unit. If this happens the HSO will know when to do it but not know what to do when it's time to do it. In many systems this becomes a null problem because HSO commands are only issued from one place in the code. If this is not the case then a critical region must be established and the two instructions executed from within this region (see section 3.6.5).

Commands in the holding register will not execute even if their time tag is reached. Commands must be in the CAM for this to occur. Flags are available in IOS0 which indicate the holding register is empty (IOS0.7) or that both the holding register is empty *and* the CAM is not full (IOS0.6). The programmer should carefully decide which of these two flags is the best to use for each application.

It is possible to enter commands into the CAM which never execute. This occurs if TIMER2 has been set up as a variable modulo counter and a command is entered with a time tag referenced to TIMER2 which has a value that TIMER2 never reaches. The inaccessible command will never execute and continue to take up room in the CAM until either the system is reset or the program allows TIMER2 increment up to the value stored in the time tag. Note that commands cannot be flushed from the CAM without being executed but that they can be cancelled. This is accomplished by setting the opposite command in the CAM to execute at the same time tag as the command to be cancelled. Since internal events are not synchronized to Timer 1, it is not possible to cancel them. If, as an example, a command has been issued to set HSO.1 when TIMER1 = 1234 then entering a second command which clears HSO.1 when TIMER1 = 1234 will result in a nooperation on HSO.1. Both commands will remain in the CAM until TIMER1 = 1234.

## 3.7.4. High Speed I/O Interrupts

The HSO unit can generate two types of interrupts. The HSO execution interrupt (vector = (2006H)) is generated (if enabled) for HSO commands which operate on one of the six HSO pins. The other HSO interrupt is the Software Timer interrupt (vector = (200AH)) which is generated (if enabled) for any other HSO command (e.g. triggering the A/D, resetting Timer2 or generating a software time delay).

There are also two interrupts associated with the HSI unit. The HSI data available interrupt (vector = (2004H)) is generated if there is data in the HSI FIFO that the program should read. The other HSI related interrupt is the HSI.0 interrupt which occurs whenever High Speed Input pin 0 makes a zero-to-one transition. This interrupt will become pending in the INT\_PENDING register even if the HSI unit is programmed to ignore changes on HSI.0 or look for a one-to-zero transition.

## 3.7.5. Accessing Register Mapped I/O

The on-board I/O devices such as the serial port or the A/D converter are controlled as register mapped I/O. This allows convenient and efficient I/O processing. The implementation of the current members of the MCS-96 family place some restrictions on how these registers can be accessed. While these restrictions are not severe, the programmer must be aware of them. A complete listing of these registers is shown in figure 2-7 and 2-8. The restrictions are as follows:

a). TIMER1, TIMER2 and HSI\_TIME are word read only. They cannot be read as bytes or written to in any format.

b). HSO \_\_TIME is *word write only*. It cannot be written to as individual bytes or read in any format.

c). R0 (the ZERO register) is byte or word read or write but writing to it will not change its value.

d). All of the other I/O registers can be accessed only as bytes. This applies even to the AD\_RESULT which is logically a word operand.

· . .

## 3.8. EXAMPLE-1 PROGRAMMING THE **SERIAL I/O CHANNEL**

MCS-96 MACRO ASSEMBLER SERIAL PORT DEMO PROGRAM

SERIES-III MCS-96 MACRO ASSEMBLER, V1.0

SOURCE FILE: :F1:SPX.SRC OBJECT FILE: :F1:SPX.OBJ CONTROLS SPECIFIED IN INVOCATION COMMAND: NOSB DEBUG

| ERR LOC OBJECT                 | 1 \$TITLE                      | OURCE STAT<br>('SERIAL F<br>INGTH (95) |                    | O PROGRAM'               | )                   |                                                     |
|--------------------------------|--------------------------------|----------------------------------------|--------------------|--------------------------|---------------------|-----------------------------------------------------|
| <b>,</b>                       | 4 ;<br>5 ;<br>6                | This pro<br>characte                   |                    |                          | the seri            | al port and echos any                               |
| 0007                           | 7                              |                                        |                    |                          |                     | с. , ,                                              |
| 000E<br>0011                   | 8 BAUD RE<br>9 SPCON           | G                                      | equ<br>equ         | 0EH<br>11H               |                     |                                                     |
| 0011                           | 10 SPSTAT                      |                                        | equ                | 11H                      |                     |                                                     |
| 0016                           | 11 10C1                        | ,                                      | equ                | 16H                      |                     |                                                     |
| 0015                           | 12 1000                        |                                        | equ                | 15H                      |                     |                                                     |
| 0007                           | 13 SBUF                        |                                        | equ                | 07H                      |                     |                                                     |
| 0009                           | 14 INT_PEN                     | DING                                   | equ                | 09н                      |                     |                                                     |
| 0018                           | 15 SP                          |                                        | equ                | 18H                      |                     |                                                     |
|                                | 16<br>17                       |                                        |                    |                          |                     |                                                     |
| 0000                           | 18 rseg                        |                                        |                    |                          |                     |                                                     |
|                                | 19                             |                                        |                    |                          |                     |                                                     |
| 0000                           | 20                             | CHR:                                   | dsb                | 1                        |                     |                                                     |
| 0001                           | 21                             | TEMP0:                                 | dsb                | 1                        |                     |                                                     |
| 0002                           | 22                             | TEMP1:                                 | dsb                | 1                        |                     |                                                     |
| 0003                           | 23 ·<br>24                     | RCV_FLAC                               | 3:                 | dsb 1                    |                     |                                                     |
|                                | 24                             |                                        |                    |                          |                     |                                                     |
| 0000                           | 26 cseq                        |                                        |                    |                          | *                   |                                                     |
|                                | 27                             |                                        |                    |                          |                     |                                                     |
| 0000 A1B00018                  | 28                             | LD                                     | SP, #0B            | OH                       |                     | ,                                                   |
| 0004 B12016                    | 29<br>30                       | LDB                                    | TOC1 #             | 00100000B                |                     | ; Set P2.0 to TXD                                   |
| 0004 B12016                    | 30                             | LDB                                    | 1001, #            | 001000008                |                     | ; Set P2.0 to 1xD                                   |
|                                | 32 33                          |                                        | ; Baud<br>; baud   | rate = inp<br>val = (in  | out frequ           | ency / (64*baud_val)<br>uency/64) / baud rate       |
|                                | 34                             |                                        |                    |                          |                     |                                                     |
| 0027                           | 35<br>36 baud_va               |                                        | equ                | 39 ;                     | 2400 ba             | ud at 6.0 MHz                                       |
|                                | 37                             |                                        | - 4                |                          |                     | •                                                   |
| 0080<br>0026                   | 38 BAUD HI<br>39 BAUD_LC<br>40 | GH<br>W                                | equ<br>equ         | ((baud_va<br>(baud_val   | 1-1)/256<br>-1) MOD | ) OR 80H ; Set MSB to 1<br>256                      |
| 0007 B1260E<br>000A B1800E     | 41<br>42<br>43<br>44           | LDB<br>LDB                             |                    | G, #BAUD_L<br>G, #BAUD_H |                     |                                                     |
| 000D B14911                    | 45                             | LDB                                    | SPCON,             | #01001001B               | ;                   | Enable receiver, Mode 1                             |
|                                | 46<br>47                       |                                        |                    | . The cor                | ial nort            | is now initialized                                  |
|                                | 48                             |                                        |                    | , the set                | iui port            | 15 now interactived                                 |
|                                | 49                             |                                        |                    |                          |                     |                                                     |
| 0010 C40007 R<br>0013 B12001 R |                                | STB<br>LDB                             | SBUF, C            | HR<br>#00100000B         |                     | Clear serial Port<br>Set TI-temp                    |
| 0015 B12001 K                  | 52                             | 600                                    | ILMEO,             | #00100000                | · ·                 | bee ii-cemp                                         |
| 0016 3609FD<br>0019 71BF09     | 53 wait:<br>54<br>55           | JBC<br>ANDB                            | INT_PEN<br>INT_PEN | DING, 6, w<br>DING, #101 | ait ;<br>.11111B ;  | Wait for pending bit to be set<br>Clear pending bit |
| 001C 901101 R                  |                                | ORB                                    | TEMP0,             | SPCON                    | :                   | Put SPCON into temp register                        |
|                                | 57                             |                                        |                    |                          |                     | This is necessary becase reading                    |
|                                | 58                             |                                        |                    |                          | ;                   | SPCON clears TI and RI                              |
| 0017                           | 59                             |                                        |                    |                          |                     |                                                     |
| 001F<br>001F 360109 R          | 60 get_byt<br>61               | JBC                                    | TEMDO              | 6, put byt               |                     | If RI-temp is not set                               |
| 0022 C40007 R                  |                                | STB                                    | SBUF, C            | HR DUC_DYC               | .е ;                | Store byte                                          |
| 0025 71BF01 R                  |                                | ANDB                                   |                    | #10111111B               |                     | CLR RI-temp                                         |
| 0028 B1FF03 R                  | 64                             | LDB                                    |                    | G, #OFFH                 |                     | Set bit-received flag                               |
|                                | 65                             |                                        |                    |                          |                     |                                                     |
| 002B                           | 66 put_byt                     |                                        |                    | C 0 005                  | inue                | If receive flag is closed                           |
| 002B 30030C R<br>002E 350109 R |                                | JBC<br>JBC                             | TEMPO              | G, 0, cont<br>5, continu | inne ;              | If receive flag is cleared<br>If TI was not set     |
| 0031 B00007 R                  |                                | LDB                                    | SBUF, C            |                          |                     | Send byte                                           |
| 0034 71DF01 R                  |                                | ANDB                                   | TEMPO,             | #11011111B               |                     | CLR TI-temp                                         |
| 0037 B10003 R                  | 71                             | LDB                                    | RCV_FLA            |                          |                     | Clear bit-received flag                             |
| 0000                           | 72                             |                                        |                    |                          |                     |                                                     |
| 003A                           | 73 continu                     |                                        | wait               |                          |                     |                                                     |
| 003A 27DA                      | 74<br>75                       | BR                                     | wait               |                          |                     |                                                     |
| 003C                           | 76                             | END                                    |                    |                          |                     | 1                                                   |
|                                |                                |                                        |                    |                          |                     |                                                     |

ASSEMBLY COMPLETED, NO ERROR(S) FOUND.

## 3.9. EXAMPLE-2 GENERATING A PWM WITH THE HSO UNIT

MCS-96 MACRO ASSEMBLER HSO EXAMPLE PROGRAM FOR PWM OUTPUTS

SERIES-III MCS-96 MACRO ASSEMBLER, V1.0

SOURCE FILE: :F1:HSO2X.SRC OBJECT FILE: :F1:HSO2X.OBJ CONTROLS SPECIFIED IN INVOCATION COMMAND: NOSB DEBUG

| ERR | LOC                  | OBJECT                         | LINE<br>1<br>2                                           | <b>\$TITLE</b> | URCE STA<br>('HSO EX                                                   | AMPLE PROGRAM FOR PWM OUTPUTS')                                                                                                                                                                                                    |                                                                                                        |
|-----|----------------------|--------------------------------|----------------------------------------------------------|----------------|------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|
|     |                      |                                | 3<br>4<br>5<br>6                                         |                |                                                                        | will provide 4 PWM outputs on HSG<br>ameters passed to the program are                                                                                                                                                             |                                                                                                        |
|     |                      |                                | 7<br>8                                                   | ;              |                                                                        | HSO_ON_N HSO on time for pin<br>HSO_OFF_N HSO off time for pin                                                                                                                                                                     |                                                                                                        |
|     |                      |                                | 9<br>10<br>11                                            | ;              | Where:                                                                 | Times are in timerl cycles<br>N takes values from 0 to 3                                                                                                                                                                           |                                                                                                        |
|     |                      |                                | 12<br>13<br>14                                           | ,,,,,,,        | ,,,,,,,,,                                                              | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,                                                                                                                                                                                            | ,,,,,,,,,,,,,,                                                                                         |
|     | 0000                 |                                | 15<br>16<br>17                                           | dseg           |                                                                        |                                                                                                                                                                                                                                    |                                                                                                        |
|     | 0000                 |                                | 18<br>19<br>20<br>21<br>22<br>23<br>24<br>25<br>25<br>26 |                | D_STAT:<br>extrn<br>extrn<br>extrn<br>extrn<br>extrn<br>extrn<br>extrn | DS8 1<br>HSO ON 0 :word , HSO OFF 0 :word<br>HSO ON 1 :word , HSO OFF 1 :word<br>HSO ON 2 :word , HSO OFF 1 :word<br>HSO ON 3 :word , HSO OFF 3 :word<br>HSO TIME :word , HSO COMMAND :by<br>TIMERI :word , IOSO :byto<br>SP :word | 3<br>3<br>9<br>yte                                                                                     |
|     | 0000                 |                                | 27<br>28<br>29                                           | rseg           |                                                                        |                                                                                                                                                                                                                                    |                                                                                                        |
|     | 0000<br>0001         |                                | 30<br>31<br>32                                           |                | public<br>OLD_STA<br>NEW_STA                                           | OLD_STAT<br>T: dsb l<br>T: dsb l                                                                                                                                                                                                   | -                                                                                                      |
|     | 0000                 |                                | 33<br>34<br>35                                           | cseg           |                                                                        |                                                                                                                                                                                                                                    |                                                                                                        |
|     |                      |                                | 36<br>37<br>38                                           |                | PUBLIC                                                                 | wait                                                                                                                                                                                                                               |                                                                                                        |
|     | 0000<br>0003<br>0004 |                                | 39<br>E 40<br>41<br>42                                   | wait:          | JBS<br>NOP<br>NOP                                                      | IOSO, 6, wait                                                                                                                                                                                                                      | ; Loop until HSO holding register<br>; is empty                                                        |
| ,   |                      | C701000000                     | E 43<br>44                                               |                | STB                                                                    | IOSO, D_STAT                                                                                                                                                                                                                       | ; Load byte to external RAM                                                                            |
|     |                      | x                              | 45<br>46<br>47<br>48                                     |                |                                                                        | <pre>; For opperation with interrupts<br/>; entry point of the routine.<br/>; Note that a DI or PUSHF might</pre>                                                                                                                  |                                                                                                        |
|     | A000<br>A000         | 510F0001                       | 40<br>49<br>E 50                                         | store_s        | tat:<br>ANDB                                                           | NEW STAT, IOSO, #OFH                                                                                                                                                                                                               | ; Store new status of HSO                                                                              |
|     | 0011                 | 980100<br>DFED                 | R 51<br>52                                               |                | CMPB<br>JE                                                             | OLD_STAT, NEW_STAT                                                                                                                                                                                                                 | ; If status hasn't changed                                                                             |
|     | 0013                 | 940100                         | R 53<br>54<br>55                                         |                | XORB                                                                   | OLD_STAT, NEW_STAT                                                                                                                                                                                                                 | ,                                                                                                      |
|     | 0019                 | 300017<br>38010B               | 56<br>R 57<br>R 58<br>59                                 | check_0        | J BC<br>J BS                                                           | OLD_STAT, 0, check 1<br>NEW_STAT, 0, set_off_0                                                                                                                                                                                     | ; Jump if OLD_STAT(0)=NEW_STAT(0)                                                                      |
|     |                      | B13000<br>470100000000<br>2009 | 60<br>E 61<br>E 62<br>63<br>64                           | set_on_        | D:<br>LDB -<br>ADD<br>BR                                               | HSO_COMMAND, #00110000B<br>HSO_TIME, TIMER1, HSO_OFF_0<br>check_1                                                                                                                                                                  | ; Set HSO for timerl, set pin 0<br>; Time to set pin = Timerl value<br>; + Time for pin to be low      |
|     |                      | B11000<br>470100000000         | 65<br>E 66<br>E 67<br>68<br>69                           | set_off        | _0:<br>LDB<br>ADD                                                      | HSO_COMMAND, #00010000B<br>HSO_TIME, TIMER1, HSO_ON_0                                                                                                                                                                              | ; Set HSO for timerl, clear pin 0<br>; Time to clear pin = Timerl value<br>; + Time for pin to be high |
|     |                      | 310017<br>39010B               | 89<br>70<br>R 71<br>R 72<br>73                           | check_1        | JBC<br>JBS                                                             | OLD_STAT, 1, check 2<br>NEW_STAT, 1, set_off_1                                                                                                                                                                                     | ; Jump if OLD_STAT(1)=NEW_STAT(1)                                                                      |
|     |                      | B13100<br>470100000000<br>2009 | 74<br>E 75<br>E 76<br>77<br>78                           | set_on_        | LDB<br>ADD<br>BR                                                       | HSO_COMMAND, #00110001B<br>HSO_TIME, TIMER1, HSO_OFF_1<br>check_2                                                                                                                                                                  | ; Set HSO for timerl, set pin 1<br>; Time to set pin = Timerl value<br>; + Time for pin to be low      |
|     | 0041<br>0041<br>0044 | B11100<br>470100000000         | 79<br>E 80<br>E 81<br>82<br>83                           | set_off        | _l:<br>LDB<br>ADD                                                      | HSO_CCMMAND, #00010001B<br>HSO_TIME, TIMER1, HSO_ON_1                                                                                                                                                                              | ; Set HSO for timerl, clear pin l<br>; Time to clear pin = Timerl value<br>; + Time for pin to be high |
|     |                      |                                | 84                                                       | \$EJECT        |                                                                        |                                                                                                                                                                                                                                    |                                                                                                        |

## MCS®-96 SOFTWARE DESIGN INFORMATION

| MCS-96 MACRO ASSEMBLER         HSO EXAMPLE PROGRAM FOR FWM OUTPUTS           DERR LC         OBL         SOURCE         SOURCE STATEMENT           004A         86         check_2:         JBS         OLD STAT, 2, check 3         ; Jump if OLD_STAT(2)=NEW_STAT(2)           0040         3A010B         R         87         JBS         NEW_STAT, 2, set_off_2         ; Jump if OLD_STAT(2)=NEW_STAT(2)           0050         0050         90         set_on_2:         BP         HSO COMMAND, #00110010B         ; Set HSO for timer1, set pin 2           0051         91         ADD         HSO TIME, TIMER1, HSO_OFP_2         ; Fine to set pin = Timer1 value           0052         90         set_off_2:         ADD         HSO COMMAND, #00110010B         ; Set HSO for timer1, clear pin 2           0058         91         95         set_off_2:         NDB         HSO_COMMAND, #0010010B         ; Set HSO for timer1, clear pin 2           0058         910         check_3:         100         check_3:         100         100           0064         101         check_3:         0067         3B010B         101         set_off_3:           0064         1020         006         set_on_3:         NEW_STAT, 3, check done         ; Jump if OLD_STAT(3)=NEW_STAT(3)                                                                                                                                                                                                                                                                                                          |           |               |     |         |             |     |                            |     |                                         |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------------|-----|---------|-------------|-----|----------------------------|-----|-----------------------------------------|
| 004A<br>004A 320017         85<br>87<br>88<br>87<br>0050         check_2:<br>88<br>98<br>90<br>0050         0LD STAT, 2, check 3<br>98<br>90<br>90<br>91         ; Jump if OLD_STAT(2)=NEW_STAT(2)           0050<br>0050<br>0050         89<br>90<br>90         set_on_2:<br>90<br>93         HSO COMMAND, #00110010B<br>93         ; Set HSO for timerl, set pin 2<br>93         ; Set HSO for timerl, set pin 2<br>93           0059<br>0059<br>0059         80<br>93         set_off_2:<br>1DB         HSO COMMAND, #00010010B<br>94         ; Set HSO for timerl, clear pin 2<br>95           0058<br>0058         91200<br>9058         55         set_off_2:<br>1DD         HSO COMMAND, #00010010B<br>95         ; Set HSO for timerl, clear pin 2<br>95           0058<br>0058         91200<br>9058         200         200         100         HSO COMMAND, #00010010B<br>95         ; Set HSO for timerl, clear pin 2<br>95           0054<br>0054         910         Check_3:<br>100         DB         HSO COMMAND, #0011001B<br>96         ; Set HSO for timerl, set pin 3<br>97           0064<br>0064         101         check_3:<br>100         JBC         OLD_STAT, 3, check done<br>100         ; Jump if OLD_STAT(3)=NEW_STAT(3)           0064<br>0064         101         check_3:<br>100         JBC         OLD_STAT, 3, check done<br>100         ; Jump if OLD_STAT(3)=NEW_STAT(3)           006A<br>0075         100         E         101         check_done<br>111         ; Time to set pin = Timerl value<br>113         ; Time to clear pin = Timerl value<br>114         ; Ti | MCS-96 MA | CRO ASSEMBLER | HSO | EXAMPLE | PROGRAM FOR | PWM | OUTPUTS                    |     | 1 - X                                   |
| 004A         86         check_2:         JBC         OLD STAT, 2, check 3         ; Jump if OLD_STAT(2)=NEW_STAT(2)           004D 3A010B         R         88         JBS         NEW_STAT, 2, set_off_2         ; Jump if OLD_STAT(2)=NEW_STAT(2)           0050         90         set_on_2:         LDB         HSO COMMAND, #00110010B         ; Set HSO for timerl, set pin 2           0053         470100000000         E         91         BR         check_3         ; Time to set pin = Timerl value           0058         91200         E         91         BR         check_3         ; Time to set pin = Timerl value           0058         91200         E         91         BR         check_3         ; Time to clear pin = Timerl value           0058         91200         E         97         ADD         HSO_COMMAND, #0010010B         ; Set HSO for timerl, clear pin 2           0058         91200         E         97         ADD         HSO_TIME, TIMERI, HSO_ON_2         ; Time to clear pin = Timerl value           0054         100         check_3:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ERR LOC   | OBJECT        |     |         | SOURCE      | STA | TEMEN T                    |     |                                         |
| 004A 320017         R         87         JEC         OLD STAT, 2, check 3         ; Jump if OLD_STAT(2)=NEW_STAT(2)           004D 3A010B         R         88         JBS         NEW_STAT, 2, set_off_2         ; Jump if OLD_STAT(2)=NEW_STAT(2)           0050         90         set_on_2;         1         LDB         HSO COMMAND, #0011001B         ; Set HSO for timerl, set pin 2           0053         47010000000         E         91         BR         check_3         ; Time to set pin = Timerl value           0058         90         Set_off_2;         IDB         HSO COMMAND, #00010010B         ; Set HSO for timerl, clear pin 2           0058         91         Set_off_2;         IDB         HSO COMMAND, #00010010B         ; Set HSO for timerl, clear pin 2           0058         91         Set_off_2;         IDB         HSO_COMMAND, #00010010B         ; Set HSO for timerl, clear pin 2           0059         90         95         set_off_2;         IDB         HSO_TIME, TIMERI, HSO_ON_2         ; Time to clear pin = Timerl value           0054         101         check_3:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |           |               |     |         |             |     |                            |     |                                         |
| 044D 3A010BR88JBSNEW_STAT, 2, set_off_2005090set_on_2:0050900053 470100000000E91JDBHSO_COMMAND, #0011010B0059 20099393BR0058 B11200E0058 B11200E0058 B11200E0058 C47010000000E94950058 C47010000000E95950058 C47010000000E961000064101006410100641030064103006510300664105006641050066410500664105006641050067 3B010BR103JBS0066 47010000000E10661050067 3B010BR10661030067 470100000000E107ADD108BR0075110109111111LDB112ADD1131141141150075116017117118007120075119010011111211311411411511611711811800712                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |           |               |     |         | check_2:    |     |                            |     |                                         |
| 0050         005         set_on_2:           0050         90         set_on_2:         1           0053         100000000         E         91         ADD         HSO_COMMAND, #00110010B         ; Set HSO for timerl, set pin 2           0053         2009         93         BR         check_3         ; + Time for pin to be low           0058         95         set_off_2:         DBB         HSO_COMMAND, #00010010B         ; Set HSO for timerl, clear pin 2           0058         95         set_off_2:         DBB         HSO_COMMAND, #00010010B         ; Set HSO for timerl, clear pin 2           0058         95         set_off_2:         DBB         HSO_COMMAND, #00010010B         ; Set HSO for timerl, clear pin 2           0058         95         set_off_2:         DBB         HSO_TIME, TIMER, TIMER1, HSO_ON_2         ; Time to clear pin = Timerl value           0054         101         check_3:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |           |               |     |         |             |     |                            | ;   | Jump if OLD_STAT(2)=NEW_STAT(2)         |
| 0050         90         set_on_2:         HSO COMMAND, #00110010B         ; Set HSO for timer1, set pin 2           0053 47010000000         E         92         ADD         HSO CTIME, TIMER1, HSO_OFF_2         ; Time to set pin = Timer1 value           0059 2009         93         BR         check_3         ; + Time to reaction to be low           0058 0059 2009         95         set_off_2:         DDB         HSO COMMAND, #0001001B         ; Set HSO for timer1, clear pin 2           0058 0058 000000         E         96         LDB         HSO COMMAND, #0001001B         ; Set HSO for timer1, clear pin 2           0058 0052 470100000000         E         97         ADD         HSO_TIME, TIMER1, HSO_ON_2         ; Time to clear pin = Timer1 value           0064         101         check_3:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 004D      | 3A010B        | R   |         | JBS         |     | NEW_STAT, 2, set_off_2     |     |                                         |
| 0050         B13200         E         91          LDB         HSO COMMAND, #0010010B         ; Set HSO for timer1, set pin 2           0053         470100000000         E         92         ADD         HSO TIME, TIMERI, HSO_OFF_2         ; Time to set pin = Timer1 value           0058         93         BR         check_3         ; + Time for pin to be low           0058         95         set_off_2:         interview         ; Time to set pin = Timer1 value           0058         95         set_off_2:         interview         ; Time to clear pin = Timer1 value           0058         96         ADD         HSO_COMMAND, #00010010B         ; Set HSO for timer1, clear pin 2           0058         97         ADD         HSO_TIME, TIMERI, HSO_ON_2         ; Time to clear pin = Timer1 value           0058         101         check_3:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |           |               |     |         |             |     |                            |     |                                         |
| 0053         470100000000         E         92         ADD         HSO_TIME, TIMER1, HSO_OFF_2         ; time to set pin = Timer1 value           0059         2009         93         BR         check_3         ; time to set pin = Timer1 value           0059         2009         93         BR         check_3         ; time to set pin = Timer1 value           0058         5         set_off_2:         DBH         HSO_COMMAND, #00010010B         ; Set HSO for timer1, clear pin 2           0052         470100000000         E         97         ADD         HSO_TIME, TIMER1, HSO_ON_2         ; Time to clear pin = Timer1 value           0054         101         check_3:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |           |               |     |         |             |     |                            |     |                                         |
| 0059 2009       93       BR       cheCk_3       ; + Time for pin to be low         0058       95       set_off_2;       ;       ; + Time for pin to be low         0058       95       set_off_2;       ; ibs       ; ibs       ; ibs       ; ibs         0058       95       set_off_2;       ; ibs       ; ibs<                                                                                                                                                                                                                                                                                                                                                                                                                          |           |               |     |         |             |     |                            |     |                                         |
| 005B         94         -         -           005B         95         set_off_2:         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |           |               | Е   |         |             |     |                            |     |                                         |
| 005B         95         set_off_2;           005B         95         set_off_2;           005B         96         96           005E         97         ADD         HSO_TIME, TIMER1, HSO_ON_2         ; Time to clear pin = Timer1 value           0054         98         99         100         ; Time to clear pin = Timer1 value           0064         101         check_3:         ; Jump if OLD_STAT(3)=NEW_STAT(3)           0064         103         JBS         NEW_STAT, 3, check done         ; Jump if OLD_STAT(3)=NEW_STAT(3)           0064         103         JBS         NEW_STAT, 3, set_off_3         ; Time to set pin = Timer1 value           0064         103         JBS         NEW_STAT, 3, set_off_3         ; Time to set pin = Timer1 value           006A         105         set_on_3:         interior         ; Set HSO for timer1, set pin 3           006A         105         set_on_3:         interior         ; Set HSO for timer1, set pin 3           006A         106         BR         check_done         ; Time to set pin = Timer1 value           0073         2009         108         BR         check_done         ; Time to clear pin 10 be high           0075         110         set_off_3:         interiof clear pin 13                                                                                                                                                                                                                                                                                                                                   | 0059      | 2009          |     |         | BR          |     | check_3                    | ;   | + Time for pin to be low                |
| 005B B11200         E         96         -         LDB         HSO_COMMAND, #00010010B         ; Set HSO for timer1, clear pin 2           005E 470100000000         E         97         ADD         HSO_TIME, TIMER1, HSO_ON_2         ; Time to clear pin 3           005E 470100000000         E         98         99         ; Time to clear pin 3         ; Time to clear pin 4           0064         101         check_3:         ; Jump if OLD_STAT(3)=NEW_STAT(3)         ; Jump if OLD_STAT(3)=NEW_STAT(3)           0064         105         set_on_3:         ; Time to set pin 5         ; Time to set pin 7           006A B13300         E         106         BR         check_done         ; Time to set pin 7           0065 470100000000         E         107         ADD         HSO_COMMAND, #0011011B         ; Set HSO for timer1, set pin 3           0065 470100000000         E         107         ADD         HSO_TIME, TIMER1, HSO_OFF_3         ; Time to set pin = Timer1 value           0075         100         set_off_3:         ;         itime to clear pin 3         ;           0075 b11300         E         111         LDB         HSO_COMMAND, #00010011B         ; Ster SO for timer1, clear pin 3           0075 b0100         R         112         ADD         HSO_TIME, TIMER1, HS                                                                                                                                                                                                                                                                             |           |               |     |         |             |     |                            |     |                                         |
| 005E 47010000000       E       97       ADD       HSO_TIME, TIMER1, HSO_ON_2       ; Time to clear pin = Timer1'value         99       100       101       check_3:       ; Time to clear pin = timer1'value         0064       101       check_3:       intertify       ; Jump if OLD_STAT(3)=NEW_STAT(3)         0064       101       check_3:       intertify       ; Jump if OLD_STAT(3)=NEW_STAT(3)         0067       3B010B       R       intertify       ; Set HSO for timer1, set pin 3         0068       105       set_on_3:       ; Time to set pin = timer1 value         0064       105       set_on_3:       ; Time to set pin = timer1 value         0073       2009       108       BR       check_done       ; Time to set pin = timer1 value         0075       110       set_off3:       intertify       ; Time to set pin = timer1 value         0075       110       set_off3:       ; Time to clear pin = timer1 value       ; Time to clear pin 3         0075       110       set_off3:       ; Time to clear pin = timer1 value       ; Time to clear pin = timer1 value         0078       110       set_off3:       ; Time to clear pin = timer1 value       ; Time to clear pin = timer1 value         0078       110       set_off3:       ; Time to clear pin                                                                                                                                                                                                                                                                                                                       |           |               |     |         |             |     |                            |     |                                         |
| 98       -       -       -       ; + Time for pin to be high         99       100         0064       101       check_3:       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |           |               |     |         |             |     | HSO_COMMAND, #00010010B    |     |                                         |
| 99         100           0064         101         check_3:           0064         101         check_3:           0064         101         check_3:           0064         103         JBC         OLD STAT, 3, check done         ; Jump if OLD_STAT(3)=NEW_STAT(3)           0067         3B010B         R         103         JBC         NEW_STAT, 3, set_off_3           006A         105         set_on_3:         104                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 005E      | 470100000000  | E   |         | ADD         |     | HSO_TIME, TIMER1, HSO_ON_2 | ;   | Time to clear pin = Timeri value        |
| 100         101         check_3:         101         check_3:         101         check_3:         101         check_3:         101         check_3:         101         check_3:         102         JEC         OLD STAT, 3, check done         ; Jump if OLD_STAT(3)=NEW_STAT(3)           0064         103         JES         NEW_STAT, 3, set_off_3         ; Jump if OLD_STAT(3)=NEW_STAT(3)           0064         105         set_on_3:         104         ; Time to set pin = Timerl, set pin 3           0060         47010000000         E         107         ADD         HSO_CMMAND, #00110011B         ; Set HSO for timerl, set pin 3           0060         470100000000         E         107         ADD         HSO_CMMAND, #00010011B         ; Time to set pin = Timerl value           0075         110         set_off_3:         ;         ime to set pin = Timerl value           0075         110         set_off_3:         ;         ;         ime to clear pin = Timerl value           0075         110         set_off_3:         ;         ;         ;         set so for timerl, clear pin 3           0076         112         ADD         HSO_TIME, TIMERL, HSO_ON_3         ;         time to clear pin = Timerl value           113         114                                                                                                                                                                                                                                                                                                                             |           |               |     |         |             |     |                            | ;   | + Time for pin to be high               |
| 0064         101         check_3:         JBC         OLD STAT, 3, check done         ; Jump if OLD_STAT(3)=NEW_STAT(3)           0067         3B010B         R         103         JBS         NEW_STAT, 3, set_off_3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |           |               |     |         |             |     | 1                          |     |                                         |
| 0064         330017         R         102         JEC         OLD STAT, 3, check done         ; Jump if OLD_STAT (3)=NEW_STAT (3)           0067         3B010B         R         103         JES         NEW_STAT, 3, set_off_3         ;         jump if OLD_STAT (3)=NEW_STAT (3)           006A         105         set_on_3:         104         ;         jump if OLD_STAT (3)=NEW_STAT (3)           006A         105         set_on_3:         104         ;         set_star (3)           006A         105         set_on_3:         105         set_on_3:         ;         jump if OLD_STAT (3)=NEW_STAT (3)           0060         470100000000         E         107         ADD         HSO_COMMAND, #0010011B         ;         set HSO for timerl, set pin 3           0075         110         set_off_3:         ;         ime to set pin = Timerl value         ;           0075         110         set_off_3:         ;         ;         set hSO for timerl, clear pin 3           0075         110         set_off_3:         ;         ;         set hSO for timerl, clear pin 3           0076         111         ADD         HSO_TIME, TIMERI, HSO_ON_3         ;         time to clear pin = Timerl value           107         ADD         HSO_TIME, TIMERI                                                                                                                                                                                                                                                                                                                          |           |               |     |         |             |     |                            |     |                                         |
| 0067 3B010B         R         103         JES         NEW_STAT, 3, set_off_3           006A         104           006A         105           006A         105           006A         105           006A         105           006A         105           006A         105           006B         106           006D         47010000000           0073         2009           108         BR           0075         110           0075         110           0075         110           0078         470100000000           E         111           LDB         HSO_COMMAND, #00010011B           7         Time to set pin = Timerl value           0075         110           0078         470100000000           E         111           LDB         HSO_COMMAND, #00010011B           Y         Time to set pin = Timerl value           107         112           ADD         HSO_TIME, TIMER1, HSO_ON_3           Y         Time to clear pin = Timerl value           114         114           115           007E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           | 220017        |     |         |             |     | OTD GRAM 2 shash days      |     | Tune . 6 OID (010 (2)-NTM (0500 (2)     |
| 104       104       104         006A       105       Set_on 3:         006D 470100000000       E       106       LDB       HSO COMMAND, #0011001LB       ; Set HSO for timerl, set pin 3         006D 470100000000       E       107       ADD       HSO TIME, TIMER1, HSO_OFF_3       ; Time to set pin = Timerl value         0073       108       BR       check_done       ; + Time for pin to be low         0075       110       set_off_3:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |           |               |     |         |             |     |                            | ;   | Jump IF OLD_STAT(3)=NEW_STAT(3)         |
| 006A         105         set_on_3:           006A         105         set_on_3:         LDB         HSO_COMMAND, #00110011B         ; Set HSO for timer1, set pin 3           006D 470100000000         E         107         ADD         HSO_TIME, TIMER1, HSO_OFF_3         ; Time to set pin = Timer1 value           0073 2009         108         BR         check_done         ; + Time for pin to be low           0075         100         set_off_3:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0067      | 380108        | R   |         | 0.85        | `   | NEW_STAT, 3, Set_OIL_3     |     |                                         |
| 006A B13300         E         106         - LDB         HSO COMMAND, #00110011B         ; Set HSO for timer1, set pin 3           006D 470100000000         E         107         ADD         HSO TIME, TIMER1, HSO_OFF_3         ; Time to set pin = Timer1 value           0073 2009         108         BR         check_done         ; + Time for pin to be low           109         100         set_off_3:         ;         ; Time to clear pin 3           0075 B11300         E         111         LDB         HSO_COMMAND, #00010011B         ; Set HSO for timer1, clear pin 3           0078 470100000000         E         112         ADD         HSO_TIME, TIMER1, HSO_ON_3         ; Time to clear pin = Timer1 value           113         114         114         ;         ; + Time for pin to be high           0075         116         check_done:         ;         ; Store current status and           007E         116         check_done:         ; wait for interrupt flag           0081 F0         119         RET         ; 20           120         121         121         121                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0000      |               |     |         |             |     |                            |     |                                         |
| 006D         470100000000         E         107         ADD         HSO_TIME, TIMER1, HSO_OFF_3         ; Time to set pin = Timer1 value           0073         2009         108         BR         check_done         ; + Time for pin to be low           0075         110         set_off_3;         ;         * Time for pin to be low           0075         110         set_off_3;         ;         * Time for pin to be low           0075         111         LDB         HSO_COMMAND, #00010011B         ; Set HSO for timer1, clear pin 3           0078         470100000000         E         112         ADD         HSO_TIME, TIMER1, HSO_ON_3         ; Time to clear pin = Timer1 value           113         114                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |           | B12200        | P   |         |             |     | HSO COMMAND #00110011B     |     | Sat WSO for timerl set pip 3            |
| 0073 2009         108         DR         cheCk_done         -         -         + Time for pin to be low           0075         110         set_off_3:         -         -         -         + Time for pin to be low           0075         110         set_off_3:         -         -         -         + Time for pin to be low           0075         110         set_off_3:         -         -         -         + Time for pin to be low           0075         110         set_off_3:         -         -         -         + Time for pin to be low           0075         111         LDB         HSO_COMMAND, #00010011B         ; Set HSO for timerl, clear pin 3           0078         470100000000         E         112         ADD         HSO_TIME, TIMERI, HSO_ON_3         ; Time to clear pin = Timerl value           113         114         115         -         -         + Time for pin to be high           114         115         -         -         -         -         -           007E         100         R         117         LDB         OLD_STAT, NEW_STAT         -         Store current status and           120         121         120         -         -         -         -                                                                                                                                                                                                                                                                                                                                                                                         |           |               |     |         |             |     | HOO TIME TIMERI HOO OFF 3  | · ' | Time to set pin - Timerl value          |
| 109         -           0075         110         set_off_3;           0075         111         LDB         HSO_COMMAND, #00010011B         ; Set HSO for timerl, clear pin 3           0078         470100000000         E         112         ADD         HSO_TIME, TIMERl, HSO_ON_3         ; Time to clear pin = Timerl value           113         114         114         ; + Time for pin to be high           114         115         check_done:         007E           007E         116         check_done:         ; store current status and           007E         119         RET         ; wait for interrupt flag           120         121         121         121                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |           |               | 5   |         |             |     |                            |     | + Time for pin to be low                |
| 0075         110         set_off_3;           0075         111         LDB         HSO_COMMAND, #000101LB         ; Set HSO for timerl, clear pin 3           0078         470100000000         112         ADD         HSO_TIME, TIMER1, HSO_ON_3         ; Time to clear pin = Timerl value           113         114         115         ;         item for pin to be high           007E         116         check_done:         ;         store current status and           007E         118         ; wait for interrupt flag           0081 F0         119         RET         ;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0073      | 2009          |     |         | DK          |     | check_done                 | '   | · Time for pin to be tow                |
| 0075         B11300         E         111         LDB         HSO COMMAND, #00010011B         ; Set HSO for timer1, clear pin 3           0078         470100000000         E         112         ADD         HSO_TIME, TIMER1, HSO_ON_3         ; Time to clear pin = Timer1 value           113         114         115         ; + Time for pin to be high           007E         116         check_done:         ; + Time for pin to be high           007E         116         check_done:         ; Store current status and           007E         118         ; wait for interrupt flag           120         121         121         121                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0075      |               |     |         | set off 3.  |     |                            |     |                                         |
| 0078         470100000000         E         112         ADD         HSO_TIME, TIMER1, HSO_ON_3         Time to clear pin = Timer1 value<br>113           113         ;         + Time for pin to be high           114         115           007E         116         check_done:           007E         117         LDB         OLD_STAT, NEW_STAT         ;           007E         118         ; wait for interrupt flag           0081 F0         119         RET           120         121                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |           | B11300        | R   |         |             |     | HSO COMMAND, #00010011B    |     | Set HSO for timerl, clear pin 3         |
| 113       -       -       ; + Time for pin to be high         114       114         115       115         007E       116       check_done:         007E       116       check_done:         007E       117       LDB         007E       118       ; Store current status and         118       ; wait for interrupt flag         0081 F0       119       RET         120       121                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |           |               |     |         |             |     |                            |     |                                         |
| 114         107E         116         007E         116         007E         007E         116         007E         117         LDB         018         119         120         121                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |           |               | 2   |         | 1100        |     |                            |     |                                         |
| 115           007E         116           007E B00100         R           117         LDB           LDB         OLD_STAT, NEW_STAT           118         ; wait for interrupt flag           0081 F0         119           120         121                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |               |     |         |             |     |                            |     | ····· • • • • • • • • • • • • • • • • • |
| 007E         116         check_done:           007E         007E         117         LDB         OLD_STAT, NEW_STAT         ; Store current status and           118         ; wait for interrupt flag         ; wait for interrupt flag           0081 F0         119         RET           120         121                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |           |               |     |         |             |     |                            |     |                                         |
| 007E B00100         R         117         _ LDB         OLD_STAT, NEW_STAT         ; Store current status and           118         ; wait for interrupt flag         ; wait for interrupt flag           0081 F0         119         RET           120         121                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 007E      |               |     |         | check done: |     |                            |     |                                         |
| 118 ; wait for interrupt flag<br>0081 F0 119 RET<br>120<br>121                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 007E      | B00100        | R   |         |             |     | OLD STAT, NEW STAT         | ;   | Store current status and                |
| 120<br>121                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |           |               |     | 118     |             |     |                            | ;   | wait for interrupt flag                 |
| 121                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0081      | FO            |     | 119     | RET         |     |                            |     |                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |           |               |     | 120     |             |     |                            |     |                                         |
| 0082 122 END                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |           |               |     | 121     |             |     |                            |     |                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0082      |               |     | 122     | END         |     |                            |     |                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |           |               |     |         |             |     |                            |     | ,                                       |

ASSEMBLY COMPLETED, NO ERROR(S) FOUND.

## 3.10. EXAMPLE-3 MEASURING PULSES WITH THE HSI UNIT

MCS-96 MACRO ASSEMBLER MEASURING PULSES USING THE HSI UNIT

SERIES-III MCS-96 MACRO ASSEMBLER, V1.0

# SOURCE FILE: :Fl:PULSEX.SRC OBJECT FILE: :Fl:PULSEX.OBJ CONTROLS SPECIFIED IN INVOCATION COMMAND: NOSB DEBUG

| ERR LOC OF                    | BJECT   | LINE<br>1<br>2                 |                |                                |                              | S USING 1                    | THE HSI U              | NIT')                                                             |
|-------------------------------|---------|--------------------------------|----------------|--------------------------------|------------------------------|------------------------------|------------------------|-------------------------------------------------------------------|
|                               |         | 3<br>4<br>5<br>6<br>7          | ;              |                                |                              |                              | ulsewidth<br>n externa | s in TIMERl cycles<br>l RAM.                                      |
| 0018<br>0003                  |         | 8<br>9                         | SP<br>HSI_MODI |                                | equ<br>equ                   | 18H<br>03H                   |                        |                                                                   |
| 0006<br>0004<br>000A          |         | 10<br>11<br>12<br>13           | HSI STAT       |                                | equ<br>equ<br>equ            | 06H<br>04H<br>0AH            |                        | ,                                                                 |
| 0015<br>0016                  |         | 13<br>14<br>15<br>16           | 10C0<br>10S1   |                                | equ<br>equ                   | 15H<br>16H                   |                        |                                                                   |
| 0000                          |         | 17<br>18                       | rseg           |                                |                              |                              |                        |                                                                   |
| 0000<br>0002<br>0004          |         | 19<br>20<br>21                 |                | HIGH TIM<br>LOW TIM<br>PERIOD: | E:                           | dsw<br>dsw<br>dsw            | 1<br>1<br>1            |                                                                   |
| 0006<br>0008                  |         | 22<br>23<br>24                 |                | HI_EDGE:<br>LO_EDGE:           |                              | dsw<br>dsw                   | 1                      |                                                                   |
| 000A<br>000A<br>000B          |         | 25<br>26<br>27<br>28           |                | AX:<br>AL<br>AH                | dsw<br>equ<br>equ            | 1<br>AX<br>(AX+1)            | :byte<br>:byte         |                                                                   |
| 0000                          |         | 29<br>30                       |                | BX:                            | dsw                          | 1                            | 10100                  |                                                                   |
| 000C<br>000D                  |         | 31<br>32<br>33<br>34           |                | BL<br>BU                       | equ<br>equ                   | BX<br>(BX+1)                 |                        | ; Note that 'BH' is an opcode so it<br>; can't be used as a label |
| 0000                          |         | 35<br>36                       | cseg           |                                |                              |                              |                        |                                                                   |
| 0000 A<br>0004 B<br>0007 B    |         | 37<br>38<br>39<br>40           |                | LD<br>LDB<br>LDB               |                              | 0H<br>00000001H<br>E, #00003 |                        | ; Enable HSI 0<br>; HSI 0 look for either edge                    |
| 000A 44                       | 4020004 | R 41<br>42                     | wait:          | ADD                            | PERIOD,                      | HIGH_TIM                     | ME, LOW_T              | IME                                                               |
| 000E 3                        | 716F9   | 43<br>44                       |                | JBC                            | 1051, 7                      | , wait                       | ; Wait w               | hile no pulse is entered                                          |
| 0011 B                        | 0060A   | R 45<br>46<br>47               |                | LDB                            | AL, HSI                      | STATUS                       |                        | ; Load status; Note that reading<br>; HSI_TIME clears HSI_STATUS  |
| 0014 A                        | 0040C   | R 48<br>49                     |                | LD                             | BX, HSI                      | TIME                         |                        | ; Load the HSI_TIME                                               |
| 0017 39                       |         | R 50<br>51                     |                | JBS                            | AL, 1,                       | -                            |                        | ; Jump if HSI.0 is high                                           |
| 001A C0<br>001D 48<br>0021 27 | 8060800 | R 52<br>R 53<br>54<br>55<br>56 | hsi_lo:        | ST<br>SUB<br>BR                | BX, LO I<br>HIGH_TIN<br>wait |                              | DGE, HI_E              | DGE                                                               |
| 0023 C                        |         | R 57<br>R 58                   | hsi_hi:        | ST<br>SUB                      | BX, HI I                     |                              | GE, LO ED              | CF                                                                |
| 0026 48<br>002A 27            |         | к 58<br>59<br>60<br>61         |                | BR                             | wait                         | 5, n1_5DC                    | 50, LO_ED              | 50<br>1                                                           |
| 0020                          |         |                                |                | 2.10                           |                              |                              |                        |                                                                   |

ASSEMBLY COMPLETED, NO ERROR(S) FOUND.

3-19

.

## 3.11. EXAMPLE-4 SCANNING THE A/D CHANNELS

MCS-96 MACRO ASSEMBLER SCANNING THE A TO D CHANNELS

SERIES-III MCS-96 MACRO ASSEMBLER, V1.0

SOURCE FILE: :F1:ATODX.SRC OBJECT FILE: :F1:ATODX.OBJ CONTROLS SPECIFIED IN INVOCATION COMMAND: NOSB DEBUG

| ERR LOC OBJECT                                        | 1 \$TITLE<br>2 \$PAGEL                               | OURCE STATEMENT<br>('SCANNING THE<br>ENGTH (95)            |                                  | S')                                                   |
|-------------------------------------------------------|------------------------------------------------------|------------------------------------------------------------|----------------------------------|-------------------------------------------------------|
|                                                       | 3<br>4 ; (<br>5 ;                                    | This program<br>results in RE                              |                                  | ines 0 through 3 and stores the                       |
| 0002<br>0003<br>0002<br>0018                          | 6<br>7 AD_RES<br>8 AD_RES<br>9 AD_COM<br>10 SP<br>11 | ULT_HI equ                                                 | 02<br>03<br>02<br>18H            |                                                       |
| 0000                                                  | 12<br>13 dseg<br>14                                  |                                                            |                                  |                                                       |
| 0000<br>0000<br>0002<br>0004<br>0006                  |                                                      | TABLE:<br>RESULT_1:<br>RESULT_2:<br>RESULT_3:<br>RESULT_4: | dsw l<br>dsw l<br>dsw l<br>dsw l |                                                       |
| 0000                                                  | 20<br>21 rseg<br>22                                  | ,                                                          |                                  |                                                       |
| 0000<br>0000<br>0001                                  | 23<br>24<br>25<br>26                                 | AX: dsw<br>AL equ<br>AH equ                                | l<br>AX :by<br>(AX+1) :by        |                                                       |
| 0002<br>0002<br>0003                                  | 27<br>28<br>29<br>30<br>31                           | BX: dsw<br>BL equ<br>BU equ                                | l<br>BX :by<br>(BX+l) :by        |                                                       |
| 0004<br>0004<br>0005                                  | 32<br>33<br>34<br>35<br>36<br>37                     | DX: dsw<br>DL equ<br>DH equ                                | l<br>DX :by<br>(DX+1) :by        |                                                       |
| 0000                                                  | 38 cseg<br>39                                        |                                                            |                                  | · · · ·                                               |
| 0000 A1C00018<br>0004 A00002 R                        | 40<br>41 start:<br>42<br>43                          | LD SP, #<br>LD BX, (                                       |                                  | et Stack Pointer<br>se the zero register              |
| 0007 910802 R<br>000A B00202 R<br>000D 710702 R       | 44 next:<br>45                                       | LDB AD CC                                                  |                                  | tart conversion on channel<br>ndicated by BL register |
| 0010 FD                                               | 47<br>48<br>49                                       | NOP                                                        | ; Wait for                       | conversion to start                                   |
| 0011 3B02FD                                           | 50 check:<br>51                                      | JBS AD_RE                                                  | SULT_LO, 3, ch                   | eck ; Wait while A to D is busy                       |
| 0014 B00200 R<br>0017 B00301 R                        |                                                      |                                                            | AD_RESULT_LO<br>AD_RESULT_HI     | ; Load low order result<br>; Load high order result   |
| 001A 54020204 R<br>001E AC0404 R<br>0021 C304000000 R | 55<br>56<br>57                                       | LDBZE DX, I                                                | BL, BL<br>DL<br>RESULT_TABLE[DX  | ; DL=BL*2<br>] ; Store result indexed by BL*2         |
| 0026 1702 R<br>0028 710302 R                          | 60                                                   | INCB BL<br>ANDB BL, 4                                      | 0 3H                             |                                                       |
| 002B 27DA                                             | 61<br>62<br>63                                       | BR next                                                    |                                  |                                                       |
| 002D                                                  | 63                                                   | END                                                        |                                  |                                                       |
| ASSEMBLY COMPLETED, NO ER                             | ROR(S) FOUND.                                        |                                                            |                                  |                                                       |

## 3.12. EXAMPLE-5 TABLE LOOKUP-AND INTERPOLATION

MCS-96 MACRO ASSEMBLER TABLE LOOKUP AND INTERPOLATION

SERIES-III MCS-96 MACRO ASSEMBLER, V1.0

SOURCE FILE: :Fl:INTERX.SRC OBJECT FILE: :Fl:INTERX.OBJ CONTROLS SPECIFIED IN INVOCATION COMMAND: NOSB DEBUG

| ERR | LOC                                                                  | OBJECT                               | LINE<br>1<br>2<br>3                          | \$TITLE ( | URCE STA<br>'TABLE L<br>NGTH (95)                                      | OOKUP AN                              | D INTERPO                              | OLATION'                           | )                                                                                                                      |
|-----|----------------------------------------------------------------------|--------------------------------------|----------------------------------------------|-----------|------------------------------------------------------------------------|---------------------------------------|----------------------------------------|------------------------------------|------------------------------------------------------------------------------------------------------------------------|
|     |                                                                      |                                      | 5<br>4<br>5<br>6<br>7                        | ;;        | This pr<br>using 8<br>A linea                                          | ogram us<br>-bit inp<br>ir interp     | es a loo<br>ut value<br>olation        | kup table<br>s. The i<br>is made u | e to generate 12-bit function values<br>table is 16 bytes long and 16 bits wide.<br>using the following fomula:        |
|     |                                                                      |                                      | ,<br>8<br>9                                  | ÷         |                                                                        | Table_St                              | ep                                     | IN_VAL                             | - TABLE_LOW                                                                                                            |
|     |                                                                      |                                      | 10<br>11                                     | ;         | TABLE_H                                                                | IGH - TA                              | BLE_LOW                                | OUT -                              | TABLE_LOW                                                                                                              |
|     |                                                                      |                                      | 12<br>13                                     | ;         | 16                                                                     | IN_D                                  | IF                                     |                                    |                                                                                                                        |
|     |                                                                      |                                      | 14<br>15                                     | ;         | TAB_DIF                                                                | OUT_D                                 | IF                                     |                                    |                                                                                                                        |
|     |                                                                      |                                      | 16<br>17<br>18                               | ;         | Cross M                                                                | ultiplic                              | ation is                               | used to                            | solve for OUT_DIF                                                                                                      |
|     | 00                                                                   | 18                                   | 19<br>20                                     | SP        | equ                                                                    | 18H                                   |                                        |                                    | •                                                                                                                      |
|     |                                                                      |                                      | 21<br>22                                     | -         |                                                                        |                                       |                                        |                                    |                                                                                                                        |
|     | 0000                                                                 |                                      | 23<br>24                                     | dseg      |                                                                        |                                       |                                        |                                    | <i>i</i>                                                                                                               |
|     | 0000                                                                 |                                      | 25<br>26<br>27<br>28                         | RESULT_   | TABLE:<br>RESULT:                                                      |                                       | dsw                                    | 1                                  |                                                                                                                        |
|     | 0000                                                                 |                                      | 29<br>30                                     | rseg      |                                                                        |                                       |                                        |                                    |                                                                                                                        |
|     | 0000                                                                 |                                      | 31<br>32                                     |           | AX:<br>AL                                                              | dsw<br>equ                            | 1<br>AX                                | :byte                              |                                                                                                                        |
|     | 000                                                                  |                                      | 33<br>34                                     |           | AH                                                                     | equ                                   | (AX+1)                                 | :byte                              |                                                                                                                        |
|     | 0002                                                                 | 0.2                                  | 35                                           |           | BX:<br>BL                                                              | dsw<br>equ                            | 1<br>BX                                | :byte                              | ,                                                                                                                      |
|     | 000                                                                  |                                      | 37<br>38<br>39                               |           | BU                                                                     | equ                                   | (BX+1)                                 | :byte                              | ; Note that 'BH' is an opcode so it<br>; can't be used as a label                                                      |
| 1   | 0004<br>0006<br>0008<br>000A<br>0000<br>000C<br>000C<br>000E<br>0010 | DA 、                                 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47 |           | IN VAL:<br>TABLE L<br>TABLE H<br>IN DIF:<br>IN DIFB<br>TAB DIF<br>OUT: | OW:<br>IGH:<br>:                      | dsb<br>dsw<br>dsw<br>equ<br>dsw<br>dsw | 1<br>1<br>1<br>IN_DIF<br>1<br>1    | :byte                                                                                                                  |
|     | 0000                                                                 |                                      | 48<br>49                                     | cseg      | OUT_DIF                                                                |                                       | dsl                                    | 1                                  |                                                                                                                        |
|     |                                                                      |                                      | 50<br>51<br>52                               |           |                                                                        |                                       |                                        |                                    |                                                                                                                        |
|     | 0000                                                                 | A1C00018                             | 53<br>54<br>55                               | start:    | LD                                                                     | SP, #0C                               | OH                                     | ; Set Si                           | tack Pointer                                                                                                           |
|     | 0007<br>000a                                                         | B00400<br>180300<br>71FE00<br>AC0000 | R 56<br>R 57<br>R 58<br>R 59                 | look:     | LDB<br>SHRB<br>ANDB<br>LDBZE                                           | AL, IN<br>AL, #3<br>AL, #11<br>AX, AL | -                                      |                                    | 2 times the upper nibble in byte<br>AL is a word address                                                               |
|     | 0010                                                                 | A 300 4 2000 6                       | 60<br>R 61<br>62<br>63                       |           | LD                                                                     | TABLE_L                               | OW, TABLI                              | E [AX]                             | ; TABLE LOW is table output value<br>; of IN_VAL rounded down to the<br>; nearest multiple of 10H.                     |
|     | 0015                                                                 | A 300440008                          | 64<br>R 65<br>66<br>67<br>68                 |           | LD                                                                     | TABLE_H                               | IGH, (TA)                              | BLE+2) [1                          | AX] ; TABLE HIGH is the table output<br>; value of $\overline{IN}$ VAL rounded up to the<br>; nearest multiple of 10H. |
|     | 001A                                                                 | 48 06 08 OC                          | 69<br>R 70                                   |           | SUB                                                                    | TAB_DIF                               | , TABLE_                               | HIGH, TAN                          | BLE_LOW                                                                                                                |
|     |                                                                      | 510F040A<br>BC0A0A                   | R 71<br>R 72<br>R 73<br>74                   |           | ANDB<br>LDBSE                                                          | IN_DIFB<br>IN_DIF,                    | , IN_VAL<br>IN_DIFB                    | , <b>#</b> 0FH                     | ; Make input difference into a word                                                                                    |
|     |                                                                      | EE4C0C0A10<br>FE8D100010             | R 75<br>R 76                                 |           | MUL<br>DIV                                                             | OUT_DIF<br>OUT_DIF                    | , IN_DIF<br>, #16                      | , TAB_DII                          | F                                                                                                                      |
|     | 002F                                                                 | 4406100E                             | 77<br>R 78<br>79                             | labl:     | ADD                                                                    | OUT, OU                               | T_DIF, TA                              | ABLE_LOW                           | ; Add output difference to output<br>; generated with truncated IN VAL                                                 |
|     | 0033                                                                 | 08040E                               | 80<br>R 81                                   |           | SHR                                                                    | OUT, #4                               |                                        | ,                                  | ; as input<br>; Round to 12-bit answer                                                                                 |

## MCS®-96 SOFTWARE DESIGN INFORMATION

| R LOC | OBJECT<br>D 307  |   | LINE<br>82     |        | SOURCE S | TATEMENT<br>lab2 |        |        |        |       | 1 <b>1</b> 11 | · ·          |
|-------|------------------|---|----------------|--------|----------|------------------|--------|--------|--------|-------|---------------|--------------|
|       | 07 0E            | R | 83             |        | INC      | OUT              |        |        | ; RO   | und u | up if Carry   | / = 1        |
| 00 3A | C 30100000E      | R | 84<br>85       |        | ST       | OUT, R           | esult  |        |        |       |               |              |
| 003F  | 27C 3            |   | 86<br>87<br>88 | lab2:  | BR       | look             |        |        |        | `     |               |              |
| 0041  |                  |   | 89<br>90       | cseg   |          |                  |        |        |        | ,     |               |              |
|       | 000000200034004C |   | 91             | table: | DCW      | 0000н,           | 2000н, | 3400H, | 4C 00H | ,     | A random      | non-monotoni |
| 004A  | 005D006A00720078 |   | 92             |        | DCW      | 5D00H,           | 6A00H, | 7200H, | 7800H  | ;     | function      |              |
| 0052  | 007B007D0076006D |   | 93             |        | DCW      | 7B00H,           | 7D00H, | 7600H, | 6D00H  |       |               |              |
| 005A  | 005D004B00340022 |   | 94             |        | DCW      | 5D00H,           | 4B00H, | 3400H, | 2200H  |       |               |              |
| 0062  | 0010             |   | 95<br>96       |        | DCW      | 1000H            |        |        |        |       | -             |              |
| 0064  |                  |   | 97             |        | END      |                  |        |        |        |       |               |              |

3-22

## 3.13. DETAILED INSTRUCTION SET DESCRIPTION

This section gives a description of each instruction recognized by the 8096 sorted alphabetically by the mnemonic used in the assembly language for the 8096. Note that the effect on the program counter (PC) is not always shown in the instruction descriptions. All instructions increment the PC by the number of bytes in the instruction. Several acronyms are used in the instruction set descriptions which are defined here:

**aa.** A two bit field within an opcode which selects the basic addressing mode user. This field is only present in those opcodes which allow address mode options. The encoding of the field is as follows:

| aa | Addressing mode |
|----|-----------------|
| 00 | Register direct |
| 01 | Immediate       |
| 10 | Indirect        |
| 11 | Indexed         |

The selection between indirect and indirect with auto-increment or between short and long indexing is done based on the least significant bit of the instruction byte which follows the opcode. This type selects the 16-bit register which is to take part in the address calculation. Since the 8096 requires that words be aligned on even byte boundaries this bit would be otherwise unused.

**breg.** A byte register in the internal register file. When confusion could exist as to whether this field refers to a source or a destination register it will be prefixed with an "S" or a "D."

**baop.** A byte operand which is addressed by any of the address modes discussed in section 3.2.

**bitno.** A three bit field within an instruction op-code which selects one of the eight bits in a byte.

wreg. A word register in the internal register file. When confusion could exist as to whether this field refers to a source register or a destination register it will be prefixed with an "S" or a "D." waop. A word operand which is addressed by any of the address modes discussed in section 3.2.

Lreg. A 32-bit register in the internal register file.

**BEA.** Extra bytes of code required for the address mode selected.

CEA. Extra state times (cycles) required for the address mode selected.

cadd An address in the program code.

**Flag Settings.** The modification to the flag setting is shown for each instruction. A checkmark ( $\checkmark$ ) means that the flag is set or cleared as appropriate. A hyphen means that the flag is not modified. A one or zero (1) or (0) indicates that the flag will be in that state after the instruction. An up arrow ( $\uparrow$ ) indicates that the instruction may set the flag if it is appropriate but will not clear the flag. A down arrow ( $\downarrow$ ) indicates that the flag can be cleared but not set by the instruction. A question mark (?) indicates that the flag will be left in an indeterminant state after the operation.

Generic Jumps and Calls. The assembler for the 8096 provides for generic jumps and calls. For all of the conditional jump instructions a "B" can be substituted for the "J" and the assembler will generate a code sequence which is logically equivalent but can reach anywhere in the memory. A JH can only jump about 128 locations from the current program counter; a BH can jump anywhere in memory. In a like manner a BR will cause a SJMP or LJMP to be generated as appropriate and a CALL will cause a SCALL or LCALL to be generated. The assembler user guide (see section 3.0) should be consulted for the algorithms used by the assembler to convert these generic instructions into actual machine instructions.

## 3.13.1. ADD (Two Operands) - ADD WORDS

**Operation:** The sum of the two word operands is stored into the destination (leftmost) operand.

×1 - 2

 $(DEST) \leftarrow (DEST) + (SRC)$ 

**Assembly Language Format:** 

DST SRC ADD wreg, waop

Object Code Format: [ 011001aa ][ waop ][ wreg ]

Bytes: 2+BEA States: 4+CEA

| <b></b>      | Flags Affected |              |              |    |    |  |  |  |  |
|--------------|----------------|--------------|--------------|----|----|--|--|--|--|
| Ζ            | Ν              | С            | v            | VT | ST |  |  |  |  |
| $\checkmark$ | $\checkmark$   | $\checkmark$ | $\checkmark$ | 1  | -  |  |  |  |  |

## 3.13.2. ADD (Three Operands) - ADD WORDS

**Operation:** The sum of the second and third word operands is stored into the destination (leftmost) operand.

 $(DEST) \leftarrow (SRC1) + (SRC2)$ 

**Assembly Language Format:** 

DST SRC1 SRC2 ADD Dwreg, Swreg, waop

Object Code Format: [ 010001aa ] [ waop ] [ Swreg ] [ Dwreg ]

Bytes: 3+BEA States: 5+CEA

| Z     N     C     V     VT     ST       /     /     /     /     /     /     - |              |              |              |    |    | Ľ. |
|-------------------------------------------------------------------------------|--------------|--------------|--------------|----|----|----|
| Z                                                                             | Ν            | С            | v            | VT | ST |    |
| $\checkmark$                                                                  | $\checkmark$ | $\checkmark$ | $\checkmark$ | .1 | -  |    |

## 3.13.3. ADDB (Two Operands) — ADD BYTES

 Operation:
 The sum of the two byte operands is stored into the destination (leftmost) operand.

 (DEST) ← (DEST) + (SRC)

 Assembly Language Format:
 DST SRC

 ADDB
 breg, baop

 Object Code Format:
 011101aa ][ baop ][ breg ]

 Bytes:
 2+BEA

States: 4+CEA

| Г            | Flags Affected |              |              |    |    |  |  |  |  |
|--------------|----------------|--------------|--------------|----|----|--|--|--|--|
| Z            | Ν              | С            | V            | VT | ST |  |  |  |  |
| $\checkmark$ | $\checkmark$   | $\checkmark$ | $\checkmark$ | 1  | -  |  |  |  |  |

3.13.4. ADDB (Three Operands) — ADD BYTES

| Operation:                 | The sum of the second and third byte operands is stored into the destination (leftmost) operand. |  |  |  |  |  |  |
|----------------------------|--------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|                            | $(DEST) \leftarrow (SRC1) + (SRC2)$                                                              |  |  |  |  |  |  |
| Assembly Language Format:  | DST SRC1 SRC2<br>ADDB Dbreg, Sbreg, baop                                                         |  |  |  |  |  |  |
| <b>Object Code Format:</b> | : [ 010101aa ][ baop ][ Sbreg ][ Dbreg ]                                                         |  |  |  |  |  |  |
|                            | Bytes: 3+BEA<br>States: 5+CEA                                                                    |  |  |  |  |  |  |
|                            | Flags Affected                                                                                   |  |  |  |  |  |  |
|                            | ZNCVVTST $\checkmark$ $\checkmark$ $\checkmark$ $\uparrow$ $-$                                   |  |  |  |  |  |  |

## 3.13.5. ADDC - ADD WORDS WITH CARRY

**Operation:** The sum of the two word operands and the carry flag (0 or 1) is stored into the destination (leftmost) operand.

1

 $(DEST) \leftarrow (DEST) + (SRC) + C$ 

Assembly Language Format:

DST SRC ADDC wreg, waop

Object Code Format: [ 101001aa ][ waop ][ wreg ]

Bytes: 2+BEA States: 4+BEA

|   | Flags Affected |              |                         |    |    |  |  |  |  |
|---|----------------|--------------|-------------------------|----|----|--|--|--|--|
| Ζ | Ν              | C            | , <b>V</b> <sup>1</sup> | VT | ST |  |  |  |  |
| ↓ | $\checkmark$   | $\checkmark$ | $\checkmark$            | 1  | -  |  |  |  |  |

## 3.13.6. ADDCB — ADD BYTES WITH CARRY

**Operation:** The sum of the two byte operands and the carry flag (0 or 1) is stored into the destination (leftmost) operand.

 $(DEST) \leftarrow (DEST) + (SRC) + C$ 

Assembly Language Format: DST SRC ADDCB breg, baop

Object Code Format: [ 101101aa ][ baop ][ breg ]

Bytes: 2+BEA States: 4+CEA

|   | Flags Affected |              |              |    |    |  |  |  |  |  |
|---|----------------|--------------|--------------|----|----|--|--|--|--|--|
| Z | Ν              | С            | ۷            | VT | ST |  |  |  |  |  |
| ↓ | $\checkmark$   | $\checkmark$ | $\checkmark$ | 1  | -  |  |  |  |  |  |

## 3.13.7. AND (Two Operands) — LOGICAL AND WORDS

**Operation:** The two word operands are ANDed, the result having a 1 only in those bit positions where both operands had a 1, with zeroes in all other bit positions. The result is stored into the destination (leftmost) operand.

 $(DEST) \leftarrow (DEST) AND (SRC)$ 

**Assembly Language Format:** 

DST SRC AND wreg, waop

Object Code Format: [ 011000aa ][ waop ][ wreg ]

Bytes: 2+BEA States: 4+CEA

| Flags Affected |              |   |   |    |    |  |
|----------------|--------------|---|---|----|----|--|
| Z              | Ν            | С | ۷ | VT | ST |  |
| $\checkmark$   | $\checkmark$ | 0 | 0 | -  | -  |  |

## 3.13.8. AND (Three Operands) - LOGICAL AND WORDS

| Operation:                | The second and third word operands are ANDed, the result having<br>a 1 only in those bit positions where both operands had a 1, with<br>zeroes in all other bit positions. The result is stored into the des-<br>tination (leftmost) operand. |
|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ,                         | (DEST) ← (SRC1) AND (SRC2)                                                                                                                                                                                                                    |
| Assembly Language Format: | DST SRC1 SRC2<br>AND Dwreg, Swreg, waop                                                                                                                                                                                                       |
| Object Code Format:       | [ 010000aa ][ waop ][ Swreg ][ Dwreg ]                                                                                                                                                                                                        |
|                           | Bytes: 3 + BEA<br>States: 5 + CEA                                                                                                                                                                                                             |
| · ·                       | Z         N         C         V         VT         ST           ✓         ✓         0         0         -         -                                                                                                                           |
|                           |                                                                                                                                                                                                                                               |

## 3.13.9. ANDB (Two Operands) — LOGICAL AND BYTES

**Operation:** The two byte operands are ANDed, the result having a 1 only in those bit positions where both operands had a 1, with zeroes in all other bit positions. The result is stored into the destination (leftmost) operand.

 $(DEST) \leftarrow (DEST) AND (SRC)$ 

Assembly Language Format:

DST SRC ANDB breg, baop

Object Code Format: [ 011100aa ][ baop ][ breg ]

Bytes: 2+BEA States: 4+CEA

| Flags Affected |              |   |   |    |    |  |
|----------------|--------------|---|---|----|----|--|
| Z              | Ν            | С | v | VT | ST |  |
| $\checkmark$   | $\checkmark$ | 0 | 0 | -  | -  |  |

## 3.13.10. ANDB (Three Operands) — LOGICAL AND BYTES

**Operation:** The second and third byte operands are ANDed, the result having a 1 only in those bit positions where both operands had a 1, with zeroes in all other bit positions. The result is stored into the destination (leftmost) operand.

 $(DEST) \leftarrow (SRC1) \text{ AND } (SRC2)$ 

Assembly Language Format: DST SRC1 SRC2 ANDB Dbreg, Sbreg, baop

Object Code Format: [ 010100aa ][ baop ][ Sbreg ][ Dbreg ]

Bytes: 3+BEA States: 5+CEA

| Flags Affected |     |   |   |    |    |  |
|----------------|-----|---|---|----|----|--|
| Z              | Ν   | C | V | VΤ | ST |  |
| $\checkmark$   | - 🗸 | 0 | 0 | -  | -  |  |

## 3.13.11. BR (Indirect) - BRANCH INDIRECT

**Operation:** The execution continues at the address specified in the operand word register.

PC ← (DEST)

Assembly Language Format: BR wreg

Object Code Format: [ 11100011 ] [wreg]

Bytes: 2 States: 8

| Flags Affected |   |   |   |    |    |  |
|----------------|---|---|---|----|----|--|
| z              | Ν | С | ۷ | VT | ST |  |
| _              | 1 | - | - | -  | -  |  |

## 3.13.12. CLR --- CLEAR WORD

**Operation:** The value of the word operand is set to zero.

 $(DEST) \leftarrow 0$ 

Assembly Language Format: CLR wreg

Object Code Format: [ 00000001 ][ wreg ]

Bytes: 2 States: 4

| I | Flags Affected |   |   |   |    |    |  |
|---|----------------|---|---|---|----|----|--|
|   | Ζ              | Ν | С | ۷ | VT | ST |  |
|   | 1              | 0 | 0 | 0 | -  | -  |  |

# 3.13.13. CLRB — CLEAR BYTE

**Operation:** The value of the byte operand is set to zero.

. :

 $(DEST) \leftarrow 0$ 

Assembly Language Format: CLRB breg

Object Code Format: [ 00010001 ][ breg ]

Bytes: 2 States: 4

| Flags Affected |   |   |   |    |    |  |  |
|----------------|---|---|---|----|----|--|--|
| z              | Ν | С | v | VΤ | ST |  |  |
| 1              | 0 | 0 | 0 | -  | ·  |  |  |

# 3.13.14. CLRC --- CLEAR CARRY FLAG

**Operation:** The value of the carry flag is set to zero.

C ← 0

Assembly Language Format: CLRC

Object Code Format: [ 11111000 ]

Bytes: 1 States: 4

| Flags Affected |   |   |   |    |    |  |  |  |
|----------------|---|---|---|----|----|--|--|--|
| Z              | Ν | С | v | VT | ST |  |  |  |
| -              | - | 0 | - | -  | -  |  |  |  |

## 3.13.15. CLRVT — CLEAR OVERFLOW TRAP

**Operation:** The value of the overflow-trap flag is set to zero.

VT ← 0

Assembly Language Format: CLRVT

Object Code Format: [ 11111100 ]

Bytes: 1 States: 4

| Flags Affected |   |   |   |    |    |  |  |  |
|----------------|---|---|---|----|----|--|--|--|
| z              | Ν | С | v | VT | ST |  |  |  |
| -              | - | - | - | 0  | -  |  |  |  |

## 3.13.16. CMP — COMPARE WORDS

**Operation:** The source (rightmost) word operand is subtracted from the destination (leftmost) word operand. The flags are altered but the operands remain unaffected. The carry flag is set as complement of borrow.

(DEST) - (SRC)

DST

Assembly Language Format:

CMP wreg, waop

SRC

Object Code Format: [ 100010aa ] [ waop ] [ wreg ]

Bvtes: 2+BEA

States: 4+CEA

| Flags Affected |              |              |              |    |    |  |  |  |
|----------------|--------------|--------------|--------------|----|----|--|--|--|
| Z              | Ν            | С            | V            | VT | ST |  |  |  |
| $\checkmark$   | $\checkmark$ | $\checkmark$ | $\checkmark$ | 1  | -  |  |  |  |

## 3.13.17. CMPB — COMPARE BYTES

**Operation:** The source (rightmost) byte operand is subtracted from the destination (leftmost) byte operand. The flags are altered but the operands remain unaffected. The carry flag is set as complement of borrow.

(DEST) - (SRC)

Assembly Language Format:

DST SRC CMPB breg, baop

Object Code Format: [ 100110aa ][ baop ][ breg ]

Bytes: 2+BEA States: 4+CEA

| 1 | Flags Affected |              |              |              |    |    |  |  |  |
|---|----------------|--------------|--------------|--------------|----|----|--|--|--|
| 1 | Ζ              | Ν            | С            | ۷            | VT | ST |  |  |  |
|   | $\checkmark$   | $\checkmark$ | $\checkmark$ | $\checkmark$ | 1  | -  |  |  |  |

## 3.13.18. DEC - DECREMENT WORD

**Operation:** The value of the word operand is decremented by one.

 $(DEST) \leftarrow (DEST) - 1$ 

Assembly Language Format: DEC wreg

Object Code Format: [ 00000101 ] [ wreg ]

Bytes: 2 States: 4

| Flags Affected |              |              |              |    |    |  |  |
|----------------|--------------|--------------|--------------|----|----|--|--|
| z              | Ν            | С            | ۷            | VT | ST |  |  |
| $\checkmark$   | $\checkmark$ | $\checkmark$ | $\checkmark$ | 1  | -  |  |  |

### 3.13.19. DECB — DECREMENT BYTE

**Operation:** The value of the byte operand is decremented by one.

(DEST) ← (DEST) - 1

Assembly Language Format: DECB breg

Object Code Format: [ 00010101 ] [ breg ]

Bytes: 2 States: 4

| Flags Affected |              |     |              |    |    |  |  |
|----------------|--------------|-----|--------------|----|----|--|--|
| Ζ              | Ν            | С   | v            | VT | ST |  |  |
| $\checkmark$   | $\checkmark$ | · 🗸 | $\checkmark$ | 1  | -  |  |  |

## 3.13.20. DI — DISABLE INTERRUPTS

**Operation:** Interrupts are disabled. Interrupt-calls will not occur after this instruction.

. . . . . . . . . .

Interrupt Enable (PSW.9)  $\leftarrow 0$ 

### Assembly Language Format: DI

Object Code Format: [ 11111010 ]

Bytes: 1 States: 4

| Flags Affected |   |   |   |    |    |  |  |
|----------------|---|---|---|----|----|--|--|
| Z              | Ν | С | V | VT | ST |  |  |
| -              | - | - |   | -  | -  |  |  |

### 3.13.21. DIV — DIVIDE INTEGERS

**Operation:** This instruction divides the contents of the destination LONG-INTEGER operand by the contents of the INTEGER word operand, using signed arithmetic. The low order word of the destination (i.e., the word with the lower address) will contain the quotient; the high order word will contain the remainder.

> (low word DEST)  $\leftarrow$  (DEST) / (SRC) (high word DEST)  $\leftarrow$  (DEST) MOD (SRC) The above two statements are performed concurrently.

| Assembly Language Format: |     | DST   | SRC  |
|---------------------------|-----|-------|------|
|                           | DIV | Irea. | waop |

Object Code Format: [ 11111110 ][ 100011aa ][ waop ][ Ireq ]

Bytes: 2+BEA States: 29 + CEA

| Flags Affected |   |   |              |    |    |  |  |
|----------------|---|---|--------------|----|----|--|--|
| Ζ              | Ν | С | V            | VT | ST |  |  |
| -              | - | - | $\checkmark$ | 1  | -  |  |  |

### 3.13.22. DIVB — DIVIDE SHORT-INTEGERS

¢ '

**Operation:** This instruction divides the contents of the destination INTEGER operand by the contents of the source SHORT-INTEGER operand, using signed arithmetic. The low order byte of the destination (i.e. the byte with the lower address) will contain the quotient; the high order byte will contain the remainder.

(low byte DEST)  $\leftarrow$  (DEST) / (SRC) (high byte DEST)  $\leftarrow$  (DEST) MOD (SRC) The above two statements are performed concurrently.

Object Code Format: [ 11111110 ][ 100111aa ][ baop ][ wreg ]

Bytes: 2+BEA States: 21 + CEA

| Flags Affected |   |   |              |    |    |  |  |
|----------------|---|---|--------------|----|----|--|--|
| Z              | Ν | С | V            | VT | ST |  |  |
| -              | - | - | $\checkmark$ | 1  | -  |  |  |

# 3.13.23. DIVU - DIVIDE WORDS

| Operation:                            | This instruction divides the contents of the destination DOUBLE-<br>WORD operand by the contents of the source WORD operand,<br>using unsigned arithmetic. The low order word will contain the<br>quotient; the high order byte will contain the remainder. |  |  |  |
|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| · · · · · · · · · · · · · · · · · · · | low word DEST) ← (DEST) / (SRC)<br>high word DEST) ← MOD (SRC)<br>"he above two statements are performed concurrently.                                                                                                                                      |  |  |  |
| Assembly Language Format:             | DST SRC<br>DIVU Ireg, waop                                                                                                                                                                                                                                  |  |  |  |
| Object Code Format:                   | [ 100011aa ][ waop ][ Ireq ]                                                                                                                                                                                                                                |  |  |  |
|                                       | Bytes: 2+BEA<br>States: 25 + CEA                                                                                                                                                                                                                            |  |  |  |
|                                       | Z     N     C     V     VT     ST       -     -     -     √     ^↑     -                                                                                                                                                                                    |  |  |  |

## 3.13.24. DIVUB — DIVIDE BYTES

.

| Operation:                | This instruction divides the contents of the destination WORD<br>operand by the contents of the source BYTE operand, using un-<br>signed arithmetic. The low order byte of the destination (i.e., the<br>byte with the lower address) will contain the quotient; the high<br>order byte will contain the remainder. |  |  |  |  |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                           | ow byte DEST) ← (DEST) / (SRC)<br>high byte DEST) ← (DEST) MOD (SRC)<br>'he above two statements are performed concurrently.                                                                                                                                                                                        |  |  |  |  |
| Assembly Language Format: | DST SRC<br>DIVUB wreg, baop                                                                                                                                                                                                                                                                                         |  |  |  |  |
| Object Code Format:       | [ 100111aa ][ baop ][ wreg ]<br>Bytes: 2+BEA<br>States: 17 + CEA                                                                                                                                                                                                                                                    |  |  |  |  |
|                           | Flags Affected           Z         N         C         V         VT         ST           -         -         -         √         ↑         -                                                                                                                                                                        |  |  |  |  |
|                           |                                                                                                                                                                                                                                                                                                                     |  |  |  |  |

### 3.13.25. DJNZ — DECREMENT AND JUMP IF NOT ZERO

**Operation:** The value of the byte operand is decremented by 1. If the result is not equal to 0, the distance from the end of this instruction to the target label is added to the program counter, effecting the jump. The offset from the end of this instruction to the target label must be in the range of -128 to +127. If the result of the decrement is zero then control passes to the next sequential instruction.

 $(COUNT) \leftarrow (COUNT) - 1$ if (COUNT) < > 0 then  $PC \leftarrow PC + disp$  (sign-extended to 16 bits) end\_if

Assembly Language Format: DJNZ breg,cadd

Object Code Format: [ 11100000 ][ breg ][ disp ]

Bytes: 3 States: Jump Not Taken: 5 Jump Taken: 9

| Flags Affected |   |   |   |    |    | 1 |
|----------------|---|---|---|----|----|---|
| z              | Ν | С | V | VT | ST |   |
| -              | - | - | - | -  | -  |   |

### 3.13.26. EI - ENABLE INTERRUPTS

**Operation:** Interrupts are enabled following the execution of the next statement. Interrupt-calls cannot occur immediately following this instruction.

Interrupt Enable (PSW.9) ← 1

#### Assembly Language Format: El

Object Code Format: [ 11111011 ]

Bytes: 1 States: 4

| I | Flags Affected |   |   |   |    |    |  |
|---|----------------|---|---|---|----|----|--|
|   | Ž              | Ν | С | V | VT | ST |  |
|   | -              | - | 4 | - | -  | -  |  |

## 3.13.27. EXT — SIGN EXTEND INTEGER INTO LONG-INTEGER

**Operation:** The low order word of the operand is sign-extended throughout the high order word of the operand.

if (low word DEST)<8000H then (high word DEST) ← 0 else (high word DEST) ← 0FFFFH end \_ if

## Assembly Language Format: EXT Ireg

Object Code Format: [ 00000110 ] [ lreg ]

Bytes: 2 States: 4

| Flags Affected |              |   |   |    |    |
|----------------|--------------|---|---|----|----|
| Ζ              | Ν            | С | V | VT | ST |
| $\checkmark$   | $\checkmark$ | 0 | 0 | -  | -  |

### 3.13.28. EXTB — SIGN EXTEND SHORT-INTEGER INTO INTEGER

**Operation:** The low order byte of the operand is sign-extended throughout the high order byte of the operand.

if (low byte DEST)<80H then (high byte DEST) ← 0 else (high byte DEST) ← 0FFH end \_ if

## Assembly Language Format: EXTB wreg

Object Code Format: [ 00010110 ][ wreg ]

Bytes: 2 States: 4

| Flags Affected |              |   |   |    |    |
|----------------|--------------|---|---|----|----|
| Z              | Ν            | С | V | VT | ST |
| $\checkmark$   | $\checkmark$ | 0 | 0 | -  | -  |

## 3.13.29. INC — INCREMENT WORD

**Operation:** The value of the word operand is incremented by 1.

 $(DEST) \leftarrow (DEST) + 1$ 

Assembly Language Format: INC wreg

Object Code Format: [ 00000111 ] [ wreg ]

Bytes: 2 States: 4

| Flags Affected |              |              |              |    |    |
|----------------|--------------|--------------|--------------|----|----|
| z              | . N          | С            | V            | VT | ST |
| $\checkmark$   | $\checkmark$ | $\checkmark$ | $\checkmark$ | 1  | -  |

## 3.13.30. INCB — INCREMENT BYTE

**Operation:** The value of the byte operand is incremented by 1.

 $(DEST) \leftarrow (DEST) + 1$ 

Assembly Language Format: INCB breg

Object Code Format: [ 00010111 ][ breg ]

Bytes: 2 States: 4

| Flags Affected |              |              |              |    |    |
|----------------|--------------|--------------|--------------|----|----|
| z              | Ν            | С            | V            | VT | ST |
| $\checkmark$   | $\checkmark$ | $\checkmark$ | $\checkmark$ | 1  | -  |

## 3.13.31. JBC — JUMP IF BIT CLEAR

**Operation:** The specified bit is tested. If it is clear (i.e., 0), the distance from the end of this instruction to the target label is added to the program counter, effecting the jump. The offset from the end of this instruction to the target label must be in the range of -128 to +127. If the bit is set (i.e., 1), control passes to the next sequential instruction.

if (specified bit) = 0 then  $PC \leftarrow PC + disp$  (sign-extended to 16 bits)

## Assembly Language Format: JBC breg,bitno,cadd

Object Code Format: [ 00110bbb ][ breg ][ disp ]

where bbb is the bit number within the specified register.

| I | Flags Affected |   |   |   |    |    |
|---|----------------|---|---|---|----|----|
|   | Ζ              | N | С | V | VT | ST |
|   | +              | - | - | - | -  | -  |

## 3.13.32. JBS — JUMP IF BIT SET

**Operation:** The specified bit is tested. If it is set (i.e., 1), the distance from the end of this instruction to the target label is added to the program counter, effecting the jump. The offset from the end of this instruction to the target label must be in the range of -128 to +127. If the bit is clear (i.e., 0), control passes to the next sequential instruction.

if (specified bit) = 1 then  $PC \leftarrow PC + \text{disp}$  (sign-extended to 16 bits)

Assembly Language Format: JBS breg, bitno, cadd

Object Code Format: [ 00111bbb ] [ breg ] [ disp ]

where bbb is the bit number within the specified register.

Bytes: 3 States: Jump Not Taken: 5 Jump Taken: 9

| Flags Affected |   |   |   |    |    |
|----------------|---|---|---|----|----|
| Z              | Ν | С | V | VT | ST |
| -              | - | - | - | -  | -  |

## 3.13.33. JC — JUMP IF CARRY FLAG IS SET

**Operation:** If the carry flag is set (i.e., 1), the distance from the end of this instruction to the target label is added to the program counter, effecting the jump. The offset from the end of this instruction to the target label must be in the range of -128 to +127. If the carry flag is clear (i.e., 0), control passes to the next sequential instruction.

if C = 1 then PC  $\leftarrow$  PC + disp (sign-extended to 16 bits)

Assembly Language Format: JC cadd

Object Code Format: [ 11011011 ][ disp ]

| 1 | Flags Affected |   |   |   |    |    |
|---|----------------|---|---|---|----|----|
|   | Ζ              | Ν | С | V | VT | ST |
|   | -              | - | - | - | -  | -  |

| 3.13.34. JE — JUMP IF EQUA | Letter and the state of the sta |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | If the zero flag is set (i.e., 1), the distance from the end of this instruction to the target label is added to the program counter, effecting the jump. The offset from the end of this instruction to the target label must be in the range of $-128$ to $+127$ . If the zero flag is clear (i.e., 0), control passes to the next sequential instruction.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                            | if $Z = 1$ then<br>PC $\leftarrow$ PC + disp (sign-extended to 16 bits)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Assembly Language Format:  | JE cadd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Object Code Format:        | [ 11011111 ][ disp ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                            | Bytes: 2<br>States: Jump Not Taken: 4<br>Jump Taken: 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                            | Z     N     C     V     VT     ST       -     -     -     -     -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

## 3.13.35. JGE - JUMP IF SIGNED GREATER THAN OR EQUAL

**Operation:** If the negative flag is clear (i.e., 0), the distance from the end of this instruction to the target label is added to the program counter, effecting the jump. The offset from the end of this instruction to the target label must be in the range of -128 to +127. If the negative flag is set (i.e., 1), control passes to the next sequential instruction.

÷. .

s. 1

if N = 0 then PC  $\leftarrow$  PC + disp (sign-extended to 16 bits)

Assembly Language Format: JGE cadd

Object Code Format: [ 11010110 ][ disp ]

|   | Flags Affected<br>Z   N   C   V   VT   ST |   |   |    |    |
|---|-------------------------------------------|---|---|----|----|
| Z | Ν                                         | С | ۷ | VT | ST |
| - | -                                         | - | - |    | -  |

### 3.13.36. JGT --- JUMP IF SIGNED GREATER THAN

**Operation:** If both the negative flag and the zero flag are clear (i.e., 0), the distance from the end of this instruction to the target label is added to the program counter, effecting the jump. The offset from the end of this instruction to the target label must be in the range of -128 to +127. If either the negative flag or the zero flag are set (i.e., 1,) control passes to the next sequential instruction.

if N = 0 AND Z = 0 then PC  $\leftarrow$  PC + disp (sign-extended to 16 bits)

#### Assembly Language Format: JGT cadd

Object Code Format: [ 11010010 ] [ disp ]

Bytes: 2 States: Jump Not Taken: 4 Jump Taken: 8

| Flags Affected |   |   |   |    |    |  |
|----------------|---|---|---|----|----|--|
| Z              | Ν | С | v | VT | ST |  |
| -              | - | - | - | -  | -  |  |

## 3.13.37. JH — JUMP IF HIGHER (UNSIGNED)

**Operation:** If the carry flag is set (i.e., 1), but the zero flag is not, the distance from the end of this instruction to the target label is added to the program counter, effecting the jump. The offset from the end of this instruction to the target label must be in the range of -128 to +127. If either the carry flag is clear or the zero flag is set, control passes to the next sequential instruction.

if C = 1 and Z = 0 then PC  $\leftarrow$  PC + disp (sign-extended to 16 bits)

#### Assembly Language Format: JH cadd

Object Code Format: [ 11011001 ][ disp ]

| Г |   | —Fla | ags A | Affect | ed |    |
|---|---|------|-------|--------|----|----|
|   | Ζ | N    | С     | V      | ٧T | ST |
|   | - | -    |       | -      |    | -  |

## 3.13.38. JLE — JUMP IF SIGNED LESS THAN OR EQUAL

**Operation:** If either the negative flag or the zero flag are set (i.e., 1), the distance from the end of this instruction to the target label is added to the program counter, effecting the jump. The offset from the end of this instruction to the target label must be in the range of -128 to +127. If both the negative flag and the zero flag are clear (i.e., 0), control passes to the next sequential instruction.

if N = 1 OR Z = 1 then PC  $\leftarrow$  PC + disp (sign-extended to 16 bits)

### Assembly Language Format: JLE cadd

Object Code Format: [ 11011010 ] [ disp ]

Bytes: 2 States: Jump Not Taken: 4 Jump Taken: 8

| Г |   | Fla | ags A | \ffect | ed |    |
|---|---|-----|-------|--------|----|----|
|   | Ζ | Ν   | С     | ۷      | VT | ST |
|   | - |     | -     | -      | -  | -  |

## 3.13.39. JLT - JUMP IF SIGNED LESS THAN

**Operation:** If the negative flag is set (i.e., 1), the distance from the end of this instruction to the target label is added to the program counter, effecting the jump. The offset from the end of this instruction to the target label must be in the range of -128 to +127. If the negative flag is clear (i.e., 0), control passes to the next sequential instruction.

if N = 1 then PC  $\leftarrow$  PC + disp (sign-extended to 16 bits)

Assembly Language Format: JLT cadd

Object Code Format: [ 11011110 ][ disp ]

| ١ |   | —Fla | ags / | \ffect | ed |    | 1 |
|---|---|------|-------|--------|----|----|---|
|   | Ζ | Ν    | С     | ۷      | VT | ST |   |
|   | - | -    | -     | -      | -  | -  |   |

## 3.13.40. JNC — JUMP IF CARRY FLAG IS CLEAR

**Operation:** If the carry flag is clear (i.e., 0), the distance from the end of this instruction to the target label is added to the program counter, effecting the jump. The offset from the end of this instruction to the target label must be in the range of -128 to +127. If the carry flag is set (i.e., 1), control passes to the next sequential instruction.

if C = 0 then PC  $\leftarrow$  PC + disp (sign-extended to 16 bits)

### Assembly Language Format: JNC cadd

Object Code Format: [ 11010011 ][ disp ]

Bytes: 2 States: Jump Not Taken: 4 Jump Taken: 8

| Г | Fla                                                                                                                                          | ags A | Affect | ed |   | 1 |
|---|----------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|----|---|---|
| Z | Flags Affected           Z         N         C         V         VT         ST           -         -         -         -         -         - |       |        | •  |   |   |
| - | -                                                                                                                                            | -     | -      | -  | - |   |

## 3.13.41. JNE --- JUMP IF NOT EQUAL

**Operation:** If the zero flag is clear (i.e., 0), the distance from the end of this instruction to the target label is added to the program counter, effecting the jump. The offset from the end of this instruction to the target label must be in the range of -128 to +127. If the zero flag is set (i.e., 1), control passes to the next sequential instruction.

if Z = 0 then PC  $\leftarrow$  PC + disp (sign-extended to 16 bits)

Assembly Language Format: JNE cadd

Object Code Format: [ 11010111] [ disp ]

| ſ |   | Fla | ags A | Affect | ed |    |
|---|---|-----|-------|--------|----|----|
|   | Ζ | Ν   | С     | V      | VT | ST |
| I |   | -   | -     | -      | -  | -  |

## 3.13.42. JNH — JUMP IF NOT HIGHER (UNSIGNED)

Operation: If either the carry flag is clear (i.e., 0), or the zero flag is set (i.e., 1), the distance from the end of this instruction to the target label is added to program counter, effecting the jump. The offset from the end of this instruction to the target label must be in the range of -128 to +127. If the carry flag is set (i.e., 1), or the zero flag is not, control passes to the next sequential instruction.

if C = 0 OR Z = 1 then PC  $\leftarrow$  PC + disp (sign-extended to 16 bits)

#### Assembly Language Format: JNH cadd

Object Code Format: [ 11010001 ][ disp ]

Bytes: 2 States: Jump Not Taken: 4 Jump Taken: 8

| Flags Affected |   |   |   |    |    |  |
|----------------|---|---|---|----|----|--|
| Ζ              | Ν | С | v | VΤ | ST |  |
| -              | - | - |   | -  | -  |  |

## 3.13.43. JNST — JUMP IF STICKY BIT IS CLEAR

**Operation:** If the sticky bit flag is clear (i.e., 0), the distance from the end of this instruction to the target label is added to the program counter, effecting the jump. The offset from the end of this instruction to the target label must be in the range of -128 to +127. If the sticky bit flag is set (i.e., 1), control passes to the next sequential instruction.

if ST = 0 then  $PC \leftarrow PC$  + disp (sign-extended to 16 bits)

Assembly Language Format: JNST cadd

Object Code Format: [ 11010000 ][ disp ]

| Ī |   | —Fla | ags / | Affect | ed— |    |
|---|---|------|-------|--------|-----|----|
|   | Ζ | Ν    | С     | ۷      | VT  | ST |
|   | - | -    | ŀ     | -      | -   | -  |

## 3.13.44. JNV - JUMP IF OVERFLOW FLAG IS CLEAR

**Operation:** If the overflow flag is clear (i.e., 0), the distance from the end of this instruction to the target label is added to the program counter, effecting the jump. The offset from the end of this instruction to the target label must be in the range of -128 to +127. If the overflow flag is set (i.e., 1), control passes to next sequential instruction.

if V = 0 then PC  $\leftarrow$  PC + disp (sign-extended to 16 bits)

## Assembly Language Format: JNV cadd

Object Code Format: [ 11010101 ][ disp ]

Bytes: 2 States: Jump Not Taken: 4 Jump Taken: 8

| 1 |   | Fla | ags A | Affect | ed |    | 1 |
|---|---|-----|-------|--------|----|----|---|
|   | Ζ | Ν   | С     | V      | VΤ | ST |   |
|   | - | -   | -     | -      | -  |    |   |

## 3.13.45. JNVT --- JUMP IF OVERFLOW TRAP IS CLEAR

**Operation:** If the overflow trap flag is clear (i.e., 0), the distance from the end of this instruction to the target label is added to the program counter, effecting the jump. The offset from the end of this instruction to the target label must be in the range of -128 to +127. If the overflow trap flag is set (i.e., 1), control passes to the next sequential instruction.

if VT = 0 then PC  $\leftarrow$  PC + disp (sign-extended to 16 bits)

Assembly Language Format: JNVT cadd

Object Code Format: [ 11010100 ] [ disp ]

| Bytes:                 | 2   |
|------------------------|-----|
| States: Jump Not Taken | : 4 |
| Jumps Taken:           | 8   |

| Г |   | —Fla | ags A | Affect | ed |    |
|---|---|------|-------|--------|----|----|
|   | Ζ | Ν    | С     | V      | VT | ST |
|   | _ | -    | -     | -      | 0  | -  |

## 3.13.46. JST - JUMP IF STICKY BIT IS SET

Operation: If the sticky bit flag is set (i.e., 1), the distance from the end of this instruction to the target label is added to the program counter, effecting the jump. The offset from the end of this instruction to the target label must be in the range of -128 to +127. If the sticky bit flag is clear (i.e., 0), control passes to the next sequential instruction.
if ST = 1 then
PC ← PC + disp (sign-extended to 16 bits)

#### Assembly Language Format: JST cadd

Object Code Format: [ 11011000 ][ disp ]

Bytes: 2 States: Jump Not Taken: 4 Jump Taken: 8

| Г | Flags Affected |   |   |   |    |    |  |  |
|---|----------------|---|---|---|----|----|--|--|
|   | Ζ              | Ν | С | V | VT | ST |  |  |
| Γ | -              | - | - | - | -  | -  |  |  |

### 3.13.47. JV --- JUMP IF OVERFLOW FLAG IS SET

**Operation:** If the overflow flag is set (i.e., 1), the distance from the end of this instruction to the target label is added to the program counter, effecting the jump. The offset from the end of this instruction to the target label must be in the range of -128 to +127. If the overflow flag is clear (i.e., 0), control passes to the next sequential instruction.

if V = 1 then PC  $\leftarrow$  PC + disp (sign-extended to 16 bits)

#### Assembly Language Format: JV cadd

Object Code Format: [ 11011101 ][ disp ]

| 1 | Flags Affected |   |   |   |    |    |  |
|---|----------------|---|---|---|----|----|--|
|   | Ζ              | Ν | С | ۷ | VT | ST |  |
|   |                | - | - | - | -  | -  |  |

## 3.13.48. JVT --- JUMP IF OVERFLOW TRAP IS SET

**Operation:** If the overflow flag is set (i.e., 1), the distance from the end of this instruction to the target label is added to the program counter, effecting the jump. The offset from the end of this instruction to the target label must be in the range of -128 to +127. If the overflow trap flag is clear (i.e., 0), control passes to the next sequential instruction.

if VT = 1 then PC  $\leftarrow$  PC + disp (sign-extended to 16 bits)

### Assembly Language Format: JVT cadd

Object Code Format: [ 11011100 ][ disp ]

Bytes: 2 States: Jump Not Taken: 4 Jump Taken: 8

| Flags Affected |            |   |   |    |    |  |  |
|----------------|------------|---|---|----|----|--|--|
| Z              | <b>N</b> ' | С | V | VT | ST |  |  |
| -              | -          | - | - | 0  | -  |  |  |

## 3.13.49. LCALL — LONG CALL

**Operation:** The contents of the program counter (the return address) is pushed onto the stack. Then the distance from the end of this instruction to the target label is added to the program counter, effecting the call. The operand may be any address in the entire address space.

 $SP \leftarrow SP - 2$  $(SP) \leftarrow PC$  $PC \leftarrow PC + disp$ 

### Assembly Language Format: LCALL cadd

Object Code Format: [ 11101111 ][ disp-low ][ disp-hi ]

Bytes: 3 States: Onchip stack: 13 Offchip stack: 16

| Γ | Flags Affected |   |    |   |    |    |  |  |
|---|----------------|---|----|---|----|----|--|--|
|   | Ż              | N | С  | V | VT | ST |  |  |
| I | -              | - | 1. | - | -  | -  |  |  |

| 3.13.50. LD LOAD WORD     |                                                                                                     |
|---------------------------|-----------------------------------------------------------------------------------------------------|
| Operation:                | The value of the source (rightmost) word operand is stored into the destination (leftmost) operand. |
|                           | $(DEST) \leftarrow (SRC)$                                                                           |
| Assembly Language Format: | DST SRC<br>LD wreg, waop                                                                            |
| Object Code Format:       | [ 101000aa ][ waop ][ wreg ]                                                                        |
|                           | Bytes: 2+BEA<br>States: 4+CEA                                                                       |
|                           | Flags Affected       Z     N     C     V     VT     ST       -     -     -     -     -              |

## 3.13.51. LDB -- LOAD BYTE

| Operation:                | The value of the source (rightmost) byte operand is stored into the destination (leftmost) operand. |
|---------------------------|-----------------------------------------------------------------------------------------------------|
|                           | $(DEST) \leftarrow (SRC)$                                                                           |
| Assembly Language Format: | DST SRC<br>LDB breg, baop                                                                           |
| Object Code Format:       | [ 101100aa ][ baop ][ breg ]                                                                        |
|                           | Bytes: 2+BEA<br>States: 4+CEA                                                                       |
|                           | Flags Affected                                                                                      |
|                           | Z N C V VT ST                                                                                       |
| 1                         |                                                                                                     |
|                           |                                                                                                     |

## 3.13.52. LDBSE — LOAD INTEGER WITH SHORT-INTEGER

**Operation:** The value of the source (rightmost) byte operand is sign-extended and stored into the destination (leftmost) word operand.

(low byte DEST) ← (SRC) if (SRC) < 80H then (high byte DEST) ← 0 else (high byte DEST) ← 0FFH end \_ if

Assembly Language Format: DST SRC LDBSE wreg, baop

Object Code Format: [ 101111aa ][ baop ][ wreg ]

Bytes: 2+BEA States: 4+CEA

| 1 | Flags Affected |   |   |   |    |    |  |  |
|---|----------------|---|---|---|----|----|--|--|
|   | Ζ              | Ν | С | v | VΤ | ST |  |  |
|   | -              | - | - | - | -  | -  |  |  |

# 3.13.53. LDBZE --- LOAD WORD WITH BYTE

**Operation:** The value of the source (rightmost) byte operand is zero-extended and stored into the destination (leftmost) word operand.

(low byte DEST)  $\leftarrow$  (SRC) (high byte DEST)  $\leftarrow$  0

Assembly Language Format: DST SRC LDBZE wreg, baop

Object Code Format: [ 101011aa ][ baop ][ wreg ]

Bytes: 2+BEA States: 4+CEA

| I | Flags Affected |   |   |   |    |    |  |  |
|---|----------------|---|---|---|----|----|--|--|
|   | Ζ              | Ν | С | ۷ | VT | ST |  |  |
|   | 1              | - | - | - | -  | -  |  |  |

#### 3.13.54. LJMP --- LONG JUMP

**Operation:** The distance from the end of this instruction to the target label is added to the program counter, effecting the jump. The operand may be any address in the entire address space.

 $PC \leftarrow PC + disp$ 

Assembly Language Format: LJMP cadd

Object Code Format: [ 11100111 ][ disp-low ][ disp-hi ]

Bytes: 3 States: 8

| Flags Affected |   |   |   |    |    |  |  |  |
|----------------|---|---|---|----|----|--|--|--|
| Ζ              | Ν | С | V | VT | ST |  |  |  |
| -              | - | - | - | -  | -  |  |  |  |

## 3.13.55. MUL (Two Operands) — MULTIPLY INTEGERS

 Operation:
 The two INTEGER operands are multiplied using signed arithmetic and the 32-bit result is stored into the destination (leftmost) LONG-INTEGER operand. The sticky bit flag is undefined after the instruction is executed.

 (DEST) ← (DEST) \* (SRC)

 Assembly Language Format:
 DST

 DST
 SRC

 MUL
 Ireg,

 Waop
 Object Code Format:

 [ 11111110 ][ 011011aa ][ waop ][ Ireg ]

 Bytes: 3+BEA

 States: 29 + CEA

| Flags Affected |   |   |   |    |    |  |  |
|----------------|---|---|---|----|----|--|--|
| Z              | Ν | С | ۷ | VT | ST |  |  |
| -              | - | - | ١ | -  | ?  |  |  |

#### 3.13.56. MUL (Three Operands) — MULTIPLY INTEGERS

**Operation:** The second and third INTEGER operands are multiplied using signed arithmetic and the 32-bit result is stored into the destination (leftmost) INTEGER operand. The sticky bit flag is undefined after the instruction is executed.

 $(DEST) \leftarrow (SRC1) * (SRC2)$ 

**Assembly Language Format:** 

DST SRC1 SRC2 MUL Ireg, wreg, waop

Object Code Format: [ 11111110 ][ 010011aa ][ waop ][ wreg ][ lreg ]

Bytes: 4+BEA States: 30 + CEA

|   | Flags Affected |   |   |    |    |  |  |  |
|---|----------------|---|---|----|----|--|--|--|
| Z | N              | С | ۷ | VT | ST |  |  |  |
| - | -              | - | - | -  | ?  |  |  |  |

### 3.13.57. MULB (Two Operands) — MULTIPLY SHORT-INTEGERS

**Operation:** The two SHORT-INTEGER operands are multiplied using signed arithmetic and the 16-bit result is stored into the destination (leftmost) INTEGER operand. The sticky bit flag is undefined after the instruction is executed.

 $(DEST) \leftarrow (DEST) * (SRC)$ 

Assembly Language Format: DST SRC MULB wreg, baop

Object Code Format: [ 11111110 ][ 011111aa ][ baop ][ wreg ]

Bytes: 3+BEA States: 21 + CEA

| Flags Affected |   |    |   |    |    |  |  |
|----------------|---|----|---|----|----|--|--|
| Ζ              | Ν | С  | ۷ | VT | ST |  |  |
| -              | - | .— | - | -  | ?  |  |  |

## 3.13.58. MULB (Three Operands) — MULTIPLY SHORT-INTEGERS

Operation: The second and third SHORT-INTEGER operands are multiplied using signed arithmetic and the 16-bit result is stored into the destination (leftmost) INTEGER operand. The sticky bit flag is undefined after the instruction is executed.

 $(DEST) \leftarrow (SRC1) * (SRC2)$ 

**Assembly Language Format:** 

DST SRC1 SRC2 MULB wreg, baop breg

Object Code Format: [ 11111110 ][ 010111aa ][ baop ][ breg ][ wreg ]

Bytes: 4+BEA States: 22 + CEA

|   | Flags Affected |   |   |    |    |  |  |  |  |
|---|----------------|---|---|----|----|--|--|--|--|
| Z | Ν              | С | V | VT | ST |  |  |  |  |
| - | -              | - | - | -  | ?  |  |  |  |  |

## 3.13.59. MULU (Two Operands) — MULTIPLY WORDS

| Operation:                | The two WORD operands are multiplied using unsigned arithmetic<br>and the 32-bit result is stored into the destination (leftmost) DOU-<br>BLE-WORD operand. The sticky bit flag is undefined after the<br>instruction is executed. |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ,                         | $(DEST) \leftarrow (DEST) * (SRC)$                                                                                                                                                                                                 |
| Assembly Language Format: | DST SRC<br>MULU Ireg, waop                                                                                                                                                                                                         |
| Object Code Format:       | [ 011011aa ][ waop ][ Ireg ]                                                                                                                                                                                                       |
|                           | Bytes: 2+BEA<br>States: 25 + CEA                                                                                                                                                                                                   |
|                           | Z     N     C     V     VT     ST       -     -     -     -     ?                                                                                                                                                                  |
|                           |                                                                                                                                                                                                                                    |

## 3.13.60. MULU (Three Operands) — MULTIPLY WORDS

**Operation:** The second and third WORD operands are multiplied using unsigned arithmetic and the 32-bit result is stored into the destination (leftmost) DOUBLE-WORD operand. The sticky bit flag is undefined after the instruction is executed.

(DEST) < --- (SRC1) \* (SRC2)

Assembly Language Format:

DST SRC1 SRC2 MULU ireg, wreg, waop

Object Code Format: [ 010011aa ][ waop ][ wreg ][ Ireg ]

Bytes: 3+BEA States: 26 + CEA

------Flags Affected-------

| z | Ν | С | v | VT | ST |
|---|---|---|---|----|----|
| - | - | - | I | -  | ?  |

## 3.13.61. MULUB (Two Operands) — MULTIPLY BYTES

**Operation:** The two BYTE operands are multiplied using unsigned arithmetic and the WORD result is stored into the destination (leftmost) operand. The sticky bit flag is undefined after the instruction is executed.

 $(DEST) \leftarrow (DEST) * (SRC)$ 

Assembly Language Format: DST SRC MULUB wreg, baop

Object Code Format: [ 011111aa ][ baop ][ wreg ]

Bytes: 2+BEA States: 17 + CEA

|   | Fla | ags A | Affect | ed— |    |  |
|---|-----|-------|--------|-----|----|--|
| Z | . N | С     | V      | VT  | ST |  |
| - | -   | -     | -      | -   | ?  |  |
|   |     |       |        | 3   |    |  |

## 3.13.62. MULUB (Three Operands) - MULTIPLY BYTES

**Operation:** The second and third BYTE operands are multiplied using unsigned arithmetic and the WORD result is stored into the destination (leftmost) operand. The sticky bit flag is undefined after the instruction is executed.

 $(DEST) \leftarrow (SRC1) * (SRC2)$ 

**Assembly Language Format:** 

DST SRC1 SRC2 MULUB wreg, breg, baop

Object Code Format: [ 010111aa ][ baop ][ breg ][ wreg ]

Bytes: 3+BEA

States: 18 + CEA

| <u> </u> | Flags Affected |   |   |    |    |  |  |  |  |  |
|----------|----------------|---|---|----|----|--|--|--|--|--|
| Z        | Ν              | С | v | VT | ST |  |  |  |  |  |
| -        | -              | - | - | -  | ?  |  |  |  |  |  |

## 3.13.63. NEG - NEGATE INTEGER

**Operation:** The value of the INTEGER operand is negated.

 $(DEST) \leftarrow -(DEST)$ 

Assembly Language Format: NEG wreg

Object Code Format: [ 00000011 ] [ wreg ]

Bytes: 2 States: 4

| Flags Affected |              |              |              |    |    |  |  |  |
|----------------|--------------|--------------|--------------|----|----|--|--|--|
| Z              | Ν            | С            | ۷            | VT | ST |  |  |  |
| $\checkmark$   | $\checkmark$ | $\checkmark$ | $\checkmark$ | 1  | -  |  |  |  |

## 3.13.64. NEGB --- NEGATE SHORT-INTEGER

**Operation:** The value of the SHORT-INTEGER operand is negated.

 $(DEST) \leftarrow -(DEST)$ 

Assembly Language Format: NEGB breg

Object Code Format: [ 00010011 ][ breg ]

Bytes: 2 States: 4

| Flags Affected |              |              |              |    |    |  |  |  |
|----------------|--------------|--------------|--------------|----|----|--|--|--|
| Z              | Ν            | С            | ۷            | VT | ST |  |  |  |
| $\checkmark$   | $\checkmark$ | $\checkmark$ | $\checkmark$ | ↑  | -  |  |  |  |

# 3.13.65. NOP -- NO OPERATION

Operation: Nothing is done. Control passes to the next sequential instruction.

Assembly Language Format: NOP

Object Code Format: [ 11111101 ]

Bytes: 1 States: 4

| Flags Affected |   |   |   |    |    |  |  |  |
|----------------|---|---|---|----|----|--|--|--|
| Ζ              | Ν | С | ۷ | VT | ST |  |  |  |
| -              | - | - | - | -  | -  |  |  |  |

## 3.13.66. NORML - NORMALIZE LONG-INTEGER

**Operation:** The LONG-INTEGER operand is normalized; i.e., it is shifted to the left until its most significant bit is 1. If the most significant bit is still 0 after 31 shifts, the process stops and the zero flag is set. The number of shifts actually performed is stored in the second operand.

 $\begin{array}{l} (\text{COUNT}) \leftarrow 0 \\ \text{do while (MSB(DEST) = 0) AND ((COUNT) < 31)} \\ (\text{DEST}) \leftarrow (\text{DEST}) * 2 \\ (\text{COUNT}) \leftarrow (\text{COUNT}) + 1 \\ \text{end \_ while} \end{array}$ 

Assembly Language Format: NORML lreg,breg

Object Code Format: [ 00001111 ][ breg ][ lreg ]

Bytes: 3 States: 8 + No. of shifts performed

|              | Flags Affected |   |   |    |    |  |  |  |  |
|--------------|----------------|---|---|----|----|--|--|--|--|
| Z            | Ν              | С | ۷ | VΤ | ST |  |  |  |  |
| $\checkmark$ | 1              | 0 | - | -  | -  |  |  |  |  |

## 3.13.67. NOT — COMPLEMENT WORD

**Operation:** The value of the WORD operand is complemented: each 1 is replaced with a 0, and each 0 with a 1.

 $(DEST) \leftarrow NOT(DEST)$ 

Assembly Language Format: NOT wreg

Object Code Format: [ 00000010 ] [ wreg ]

Bytes: 2 States: 4

| Flags Affected |              |   |   |    |    |  |  |  |
|----------------|--------------|---|---|----|----|--|--|--|
| Ζ              | Ν            | С | ۷ | VΤ | ST |  |  |  |
| $\checkmark$   | $\checkmark$ | 0 | 0 | -  | -  |  |  |  |

## MCS®-96 SOFTWARE DESIGN INFORMATION

## 3.13.68. NOTB -- COMPLEMENT BYTE

;

**Operation:** The value of the BYTE operand is complemented: each 1 is replaced with a 0, and each 0 with a 1.

S. . . .

1.3 21

 $(DEST) \leftarrow NOT (DEST)$ 

Assembly Language Format: NOTB breg

Object Code Format: [ 00010010 ][ breg ]

Bytes: 2 States: 4

| j | Flags Affected |              |   |              |    |    |  |  |  |  |
|---|----------------|--------------|---|--------------|----|----|--|--|--|--|
|   | Ζ              | Ν            | C | ί <b>ν</b> ΄ | VT | ST |  |  |  |  |
|   | $\checkmark$   | $\checkmark$ | 0 | 0            | -  | -  |  |  |  |  |

3.13.69. OR --- LOGICAL OR WORDS

**Operation:** The source (rightmost) WORD is ORed with the destination (leftmost) WORD operand. Each bit is set to 1 if the corresponding bit in either the source operand or the destination operand is 1. The result replaces the original destination operand.

 $(DEST) \leftarrow (DEST) OR (SRC)$ 

Assembly Language Format:

)

DST SRC

OR wreg, waop

Object Code Format: [ 100000aa ] [ waop ] [ wreg ]

Bytes: 2+BEA States: 4+CEA

|              | Fla          | ags / | Affect | ed  | ,  | 1 |
|--------------|--------------|-------|--------|-----|----|---|
| Ζ            | Ν            | С     | V      | VT. | ST |   |
| $\checkmark$ | $\checkmark$ | 0     | 0      | -   | -  |   |

## 3.13.70. ORB --- LOGICAL OR BYTES

**Operation:** The source (rightmost) BYTE operand is ORed with the destination (leftmost) BYTE operand. Each bit is set to 1 if the corresponding bit in either the source operand or the destination operand was 1. The result replaces the original destination operand.

 $(DEST) \leftarrow (DEST) OR (SRC)$ 

#### Assembly Language Format: ORB breg,baop

Object Code Format: [ 100100aa ][ baop ][ breg ]

Bytes: 2+BEA

States: 4+CEA

| Flags Affected |              |   |   |    |    |  |  |
|----------------|--------------|---|---|----|----|--|--|
| Z              | Ν            | С | V | VT | ST |  |  |
| $\checkmark$   | $\checkmark$ | 0 | 0 | -  | -  |  |  |

## 3.13.71. POP --- POP WORD

| Operation:                 | The word on top of the stack is popped and placed at the destination operand.          |
|----------------------------|----------------------------------------------------------------------------------------|
|                            | $(DEST) \leftarrow (SP)$<br>$SP \leftarrow SP + 2$                                     |
| Assembly Language Format:  | POP waop                                                                               |
| <b>Object Code Format:</b> | [ 110011aa ][ waop ]                                                                   |
|                            | Bytes: 1 + BEA<br>States: Onchip Stack: 12 + CEA<br>Offchip Stack 14 + CEA             |
|                            | Flags Affected       Z     N     C     V     VT     ST       -     -     -     -     - |

## 3.13.72. POPF — POP FLAGS

**Operation:** The word on top of the stack is popped and placed in the PSW. Interrupt calls cannot occur immediately following this instruction.

 $(PSW) \leftarrow (SP)$  $SP \leftarrow SP + 2$ 

Assembly Language Format: POPF

Object Code Format: [ 11110011 ]

Bytes: 1 States: Onchip Stack: 9 Offchip Stack: 13

| Flags Affected |              |              |              |              |              |  |  |
|----------------|--------------|--------------|--------------|--------------|--------------|--|--|
| Z              | Ν            | С            | V            | VT           | ST           |  |  |
| $\checkmark$   | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |  |  |

## 3.13.73. PUSH --- PUSH WORD

**Operation:** The specified operand is pushed onto the stack.

 $SP \leftarrow SP - 2$ (SP)  $\leftarrow$  (DEST)

Assembly Language Format: PUSH waop

Object Code Format: [ 110010aa ] [ waop ]

Bytes: 1+BEA States: Onchip Stack: 8+CEA Offchip Stack: 12+CEA

| Flags Affected |   |   |   |    |    |  |  |
|----------------|---|---|---|----|----|--|--|
| Ζ              | Ν | С | ۷ | VT | ST |  |  |
| -              | - | - | ł | -  | -  |  |  |

## 3.13.74. PUSHF — PUSH FLAGS

**Operation:** The PSW is pushed on top of the stack, and then set to all zeroes. This implies that all interrupts are disabled. Interrupt-calls cannot occur immediately following this instruction.

 $\begin{array}{l} \mathsf{SP} \leftarrow \mathsf{SP} \ - \ 2 \\ (\mathsf{SP}) \leftarrow \mathsf{PSW} \\ \mathsf{PSW} \leftarrow \mathbf{0} \end{array}$ 

Assembly Language Format: PUSHF

Object Code Format: [ 11110010 ]

Bytes: 1 States: Onchip Stack: 8 Offchip Stack: 12

| 1 | Flags Affected |   |   |   |    |    |  |  |
|---|----------------|---|---|---|----|----|--|--|
|   | Ζ              | Ν | С | V | VT | ST |  |  |
|   | 0              | 0 | 0 | 0 | 0  | 0  |  |  |

## 3.13.75. RET - RETURN FROM SUBROUTINE

Operation: The PC is popped off the top of the stack.

 $\begin{array}{l} \mathsf{PC} \leftarrow (\mathsf{SP}) \\ \mathsf{SP} \leftarrow \mathsf{SP} + 2 \end{array}$ 

Assembly Language Format: RET

Object Code Format: [ 11110000 ]

Bytes: 1 States: Onchip Stack: 12 Offchip Stack: 16

| Flags Affected |    |   |   |    |    |  |  |
|----------------|----|---|---|----|----|--|--|
| Z              | Ν  | С | V | VT | ST |  |  |
| -              | .— | - | - | _  | -  |  |  |

### 3.13.76. RST — RESET SYSTEM

and the second second

**Operation:** The PSW is initialized to zero, and the PC is initialized to 2080H. The I/O registers are set to their initial value (see section 2.15.2, "Reset Status"). Executing this instruction will cause a pulse to appear on the reset pin of the 8096.

> PSW ← 0 PC ← 2080H

### Assembly Language Format: RST

Object Code Format: [ 11111111 ]

Bytes: 1 States: 16

| Flags Affected |   |   |   |    |    |  |  |
|----------------|---|---|---|----|----|--|--|
| Z              | Ν | С | V | VT | ST |  |  |
| 0              | 0 | 0 | 0 | 0  | 0  |  |  |

### 3.13.77. SCALL - SHORT CALL

**Operation:** The contents of the program counter (the return address) is pushed onto the stack. Then the distance from the end of this instruction to the target label is added to the program counter, effecting the call. The offset from the end of this instruction to the target label must be in the range of -1024 to +1023 inclusive.

 $SP \leftarrow SP - 2$ (SP)  $\leftarrow PC$  $PC \leftarrow PC + disp$  (sign-extended to 16 bits)

### Assembly Language Format: SCALL cadd

Object Code Format: [ 00101xxx ] [ disp-low ]

where xxx holds the three high-order bits of displacement.

Bytes: 2 States: Onchip Stack: 13 Offchip Stack: 16

| Flags Affected |   |   |   |    |    |  |  |
|----------------|---|---|---|----|----|--|--|
| z              | Ν | С | ۷ | VT | ST |  |  |
| -              | - | - | - | -  | -  |  |  |

#### 3.13.78. SETC — SET CARRY FLAG

Contract to the state of the second

J. . . .

| Operation:                | The carry flag is set.                                                                       | e kara e     |
|---------------------------|----------------------------------------------------------------------------------------------|--------------|
|                           | C←1                                                                                          |              |
| Assembly Language Format: | SETC                                                                                         |              |
| Object Code Format:       | [ 11111001 ]                                                                                 |              |
|                           | Bytes: 1<br>States: 4                                                                        |              |
|                           | Flags Affected       Z     N     C     V     VT     ST       -     -     1     -     -     - | at and a sec |

## 3.13.79. SHL - SHIFT WORD LEFT

**Operation:** The destination (leftmost) word operand is shifted left as many times as specified by the count (rightmost) operand. The count may be specified either as an immediate value in the range of 0 to 15 inclusive, or as the content of any register, the address of which is 16 to 255. The right bits of the result are filled with zeroes. The last bit shifted out is saved in the carry flag.

Temp  $\leftarrow$  (COUNT) do while Temp <>0 $C \leftarrow$  High order bit of (DEST) (DEST)  $\leftarrow$  (DEST)\*2 Temp  $\leftarrow$  Temp — 1 end \_ while

Assembly Language Format: SHL wreg,#count

or

SHL wreg,breg

Object Code Format: [ 00001001 ][ cnt/breg ][ wreg ]

Bytes: 3

States: 7 + No. of shifts performed note: 0 place shifts take 8 states.

|  | Flags Affected |   |              |              |    |    |  |
|--|----------------|---|--------------|--------------|----|----|--|
|  | Ζ              | Ν | С            | ۷            | VT | ST |  |
|  | $\checkmark$   | ? | $\checkmark$ | $\checkmark$ | 1  | -  |  |

## 3.13.80. SHLB - SHIFT BYTE LEFT

| Operation: | The destination (leftmost) byte operand is shifted left as many times as specified by the count (rightmost) operand. The count |
|------------|--------------------------------------------------------------------------------------------------------------------------------|
|            | may be specified either as an immediate value in the range of 0                                                                |
|            | to 15 inclusive, or as the content of any register, the address of                                                             |
|            | which is 16 to 255. The right bits of the result are filled with zeroes.                                                       |
|            | The last bit shifted out is saved in the carry flag.                                                                           |

Temp  $\leftarrow$  (COUNT) do while Temp <> 0 $C \leftarrow$  High order bit of (DEST) (DEST)  $\leftarrow$  (DEST)\*2 Temp  $\leftarrow$  Temp - 1end \_ while

Assembly Language Format: SHLB breg,#count

SHLB breg,breg

Object Code Format: [ 00011001 ][ cnt/breg ][ breg ]

Bytes: 3

or

States: 7 + No. of shifts performed note: 0 place shifts take 8 states.

| Flags Affected |   |              |              |    |    |  |  |
|----------------|---|--------------|--------------|----|----|--|--|
| Z              | Ν | С            | ٠V           | VΤ | ST |  |  |
| $\checkmark$   | ? | $\checkmark$ | $\checkmark$ | 1  | -  |  |  |

## 3.13.81. SHLL - SHIFT DOUBLE-WORD LEFT

**Operation:** The destination (leftmost) double-word operand is shifted left as many times as specified by the count (rightmost) operand. The count may be specified either as an immediate value in the range of 0 to 15 inclusive, or as the content of any register, the address of which is 16 to 255. The right bits of the result are filled with zeroes. The last bit shifted out is saved in the carry flag.

Temp  $\leftarrow$  (COUNT) do while Temp <> 0C  $\leftarrow$  High order bit of (DEST) (DEST)  $\leftarrow$  (DEST)\*2 Temp  $\leftarrow$  Temp - 1end \_ while

**Assembly Language Format:** 

SHLL Ireq,#count

or

SHLL Ireg,breg

Object Code Format: [ 00001101 ][ cnt/breg ][ Ireg ]

Bytes: 3

States: 7 + No. of shifts performed note: 0 place shifts take 8 states.

| 1 | Flags Affected |   |              |              |    |    |  |
|---|----------------|---|--------------|--------------|----|----|--|
|   | Ζ              | Ň | С            | Ŷ۷           | VT | ST |  |
|   | $\checkmark$   | ? | $\checkmark$ | $\checkmark$ | 1  | -  |  |

بالمراجع والمراجع

۰,

| 3.13.82. SHR — LOGICAL RIG |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation:                 | The destination (leftmost) word operand is shifted right as many<br>times as specified by the count (rightmost) operand. The count<br>may be specified either as an immediate value in the range of 0<br>to 15 inclusive, or as the content of any register, the address of<br>which is 16 to 255. The left bits of the result are filled with zeroes.<br>The last bit shifted out is saved to the carry. The sticky bit flag<br>is cleared at the beginning of the instruction, and set if at any time<br>during the shift a 1 is shifted first into the carry flag, and a further<br>shift cycle occurs. |
|                            | Temp $\leftarrow$ (COUNT)<br>do while Temp $<> 0$<br>$C \leftarrow$ Low order bit of (DEST)<br>(DEST) $\leftarrow$ (DEST) / 2 where / is unsigned division<br>Temp $\leftarrow$ Temp $- 1$<br>end _ while                                                                                                                                                                                                                                                                                                                                                                                                  |
| Assembly Language Format:  | SHR wreg,#count<br>or<br>SHR wreg,breg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Object Code Format:        | [ 00001000 ][ cnt/breg ][ wreg ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                            | Bytes: 3<br>States: 7 + No. of shifts performed<br>note: 0 place shifts take 8 states.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                            | Z         N         C         V         VT         ST           ✓         0         ✓         0         –         ✓                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

ł

,

.

### 3.13.83. SHRA — ARITHMETIC RIGHT SHIFT WORD

| Operation:                            | The destination (leftmost) word operand is shifted right as many<br>times as specified by the count (rightmost) operand. The count<br>may be specified either as an immediate value in the range of 0<br>to 15 inclusive, or as the content of any register, the address of<br>which is 16 to 255. If the original high order bit value was 0, zeroes<br>are shifted in. If the value was 1, ones are shifted in. The last bit<br>shifted out is saved in the carry. The sticky bit flag is cleared at<br>the beginning of the instruction, and set if at any time during the<br>shift a 1 is shifted first into the carry flag, and a further shift cycle<br>occurs. |
|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                       | $\begin{array}{l} \text{Temp} \leftarrow (\text{COUNT}) \\ \text{do while Temp} <> 0 \\  C \leftarrow \text{Low order bit of (DEST)} \\  (\text{DEST}) \leftarrow (\text{DEST}) / 2 \text{ where } / \text{ is signed division} \\  \text{Temp} \leftarrow \text{Temp} - 1 \\ \text{end} \_ \text{while} \end{array}$                                                                                                                                                                                                                                                                                                                                                 |
| Assembly Language Format:             | SHRA wreg,#count<br>or<br>SHRA wreg,breg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Object Code Format:                   | [ 00001010 ][ cnt/breg ][ wreg ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| · · · · · · · · · · · · · · · · · · · | Bytes: 3<br>States: 7 + No. of shifts performed<br>note: 0 place shifts take 8 states.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

۶

| Flags Affected |              |              |   |    |              |
|----------------|--------------|--------------|---|----|--------------|
| Z              | Ν            | С            | V | VT | ST           |
| /              | $\checkmark$ | $\checkmark$ | 0 | -  | $\checkmark$ |

.

#### 3.13.84. SHRAB - ARITHMETIC RIGHT SHIFT BYTE

Operation: The destination (leftmost) byte operand is shifted right as many times as specified by the count (rightmost) operand. The count may be specified either as an immediate value in the range of 0 to 15 inclusive, or as the content of any register, the address of which is 16 to 255. If the original high order bit value was 0, zeroes are shifted in. If that value was 1, ones are shifted in. The last bit shifted out is saved in the carry. The sticky bit flag is cleared at the beginning of the instruction, and set if at any time during the shift a 1 is shifted first into the carry flag, and a further shift cycle occurs.

> Temp ← (COUNT) do while Temp <> 0

 $C_{i} = Low order bit of (DEST)$ 

 $(DEST) \leftarrow (DEST) / 2$  where /is signed division

Temp ← Temp - 1

end \_\_ while

or

**Assembly Language Format:** 

SHRAB breg,#count

SHRAB breg,breg

Object Code Format: [ 00011010 ] [ cnt/breg ] [ breg ]

Bytes: 3

| Flags Affected |   |              |   |    |              | I |
|----------------|---|--------------|---|----|--------------|---|
| Z              | Ν | С            | V | VT | ST           |   |
| $\checkmark$   | 1 | $\checkmark$ | 0 | -  | $\checkmark$ |   |

#### 3.13.85. SHRAL — ARITHMETIC RIGHT SHIFT DOUBLE-WORD

**Operation:** The destination (leftmost) double-word operand is shifted right as many times as specified by the count (rightmost) operand. The count may be specified either as an immediate value in the range of 0 to 15 inclusive, or as the content of any register, the address of which is 16 to 255. If the original high order bit value was 0, zeroes are shifted in. If the value was 1, ones are shifted in. The sticky bit is cleared at the beginning of the instruction, and set if at any time during the shift a 1 is shifted first into the carry flag, and a further shift cycle occurs.

Temp  $\leftarrow$  (COUNT) do while Temp < > 0 $C \leftarrow$  Low order bit of (DEST) (DEST)  $\leftarrow$  (DEST) / 2 where/is signed division Temp  $\leftarrow$  Temp - 1 end \_ while :: SHRAL lreg,#count

**Assembly Language Format:** 

or

SHRAL Ireg,breg

Object Code Format: [ 00001110 ][ cnt/breg ][ Ireg ]

Bytes: 3

| 1 | Flags Affected |   |              |            |    |              |  |
|---|----------------|---|--------------|------------|----|--------------|--|
|   | Ζ              | Ν | ĴC,          | . <b>V</b> | VT | ST           |  |
|   | $\checkmark$   | V | $\checkmark$ | 0          | -  | $\checkmark$ |  |

#### 3.13.86. SHRB — LOGICAL RIGHT SHIFT BYTE

**Operation:** The destination (leftmost) byte operand is shifted right as many times as specified by the count (rightmost) operand. The count may be specified either as an immediate value in the range of 0 to 15 inclusive, or as the content of any register, the address of which is 16 to 255. The left bits of the result are filled with zeroes. The last bit shifted out is saved in the carry. The sticky bit flag is cleared at the beginning of the instruction, and set if at any time during the shift a 1 is shifted first into the carry flag, and a further shift cycle occurs.

Temp  $\leftarrow$  (COUNT) do while Temp < > 0C  $\leftarrow$  Low order bit of (DEST)

 $(DEST) \leftarrow (DEST) / 2$  where/is unsigned division Temp  $\leftarrow$  Temp - 1

end \_ while

Assembly Language Format:

SHRB breg,#count

or

SHRB breg,breg

Object Code Format: [ 00011000 ][ cnt/breg ][ breg ]

Bytes: 3

| Flags Affected |               |              |   |   |   |  |  |
|----------------|---------------|--------------|---|---|---|--|--|
| Z              | Z N C V VT ST |              |   |   |   |  |  |
| $\checkmark$   | 0             | $\checkmark$ | 0 | - | V |  |  |

#### 3.13.87. SHRL - LOGICAL RIGHT SHIFT DOUBLE-WORD

**Operation:** The destination (leftmost) double-word operand is shifted right as many times as specified by the count (rightmost) operand. The count may be specified either as an immediate value in the range of 0 to 15 inclusive, or as the content of any register, the address of which is 16 to 255. The left bits of the result are filled with zeroes. The last bit shifted out is saved in the carry. The sticky bit flag is cleared at the beginning of the instruction, and set if at any time during the shift a 1 is shifted first into the carry flag, and a further shift cycle occurs.

Temp ← (COUNT)

do while Temp < > 0

 $C \leftarrow Low order bit of (DEST)$ 

(DEST) ← (DEST) / 2 where/is unsigned division Temp ← Temp - 1

end \_ while

or

**Assembly Language Format:** 

SHRL Ireg,#count SHRL Ireg, breg

Object Code Format: [ 00001100 ][ cnt/breg ][ lreg ]

Bytes: 3

| 1 | Flags Affected |   |              |   |    |              |  |
|---|----------------|---|--------------|---|----|--------------|--|
|   | Ζ              | Ν | С            | ۷ | VT | ST           |  |
|   | $\checkmark$   | 0 | $\checkmark$ | 0 | -  | $\checkmark$ |  |

#### 3.13.88. SJMP --- SHORT JUMP

**Operation:** The distance from the end of this instruction to the target label is added to the program counter, effecting the jump. The offset from the end of this instruction to the target label must be in the range of -1024 to +1023 inclusive.

 $PC \leftarrow PC + disp$  (sign-extended to 16 bits)

#### Assembly Language Format: SJMP cadd

Object Code Format: [ 00100xxx ] [ disp-low ]

where xxx holds the three high order bits of the displacement.

Bytes: 2 States: 8

| Flags Affected |   |   |   |    | ſ  |  |
|----------------|---|---|---|----|----|--|
| Z              | Ν | С | ۷ | VТ | ST |  |
| -              | - | - | - | -  | -  |  |

#### 3.13.89. SKIP - TWO BYTE NO-OPERATION

**Operation:** Nothing is done. This is actually a two-byte NOP where the second byte can be any value, and is simply ignored. Control passes to the next sequential instruction.

Assembly Language Format: SKIP breg

Object Code Format: [ 00000000 ] [ breg ]

Bytes: 2 States: 4

| Flags Affected |   |   |   |    |    |
|----------------|---|---|---|----|----|
| Z              | N | С | ۷ | VT | ST |
| -              | - | - | - | -  | -  |

۰.

#### 3.13.90. ST --- STORE WORD

| Operation:                | The value of the leftmost word operand is stored into the rightmost operand. |
|---------------------------|------------------------------------------------------------------------------|
|                           | (DEST) ← (SRC)                                                               |
| Assembly Language Format: | SRC DST<br>ST wreg, waop                                                     |
| Object Code Format:       | [ 110000aa ][ waop ][ wreg ]                                                 |
|                           | Bytes: 2+BEA<br>States: 4+CEA                                                |
|                           | Flags Affected                                                               |
|                           | Z N C V VT ST                                                                |
| 1                         |                                                                              |

#### 3.13.91. STB --- STORE BYTE

| Operation:                 | The value of the leftmost byte operand is stored into the rightmost operand. |  |  |
|----------------------------|------------------------------------------------------------------------------|--|--|
| ,<br>,                     | (DEST) ← (SRC)                                                               |  |  |
| Assembly Language Format:  | SRC DST<br>STB breg, baop                                                    |  |  |
| <b>Object Code Format:</b> | [ 110001aa ][ baop ][ breg ]                                                 |  |  |
|                            | Bytes: 2+BEA<br>States: 4+CEA                                                |  |  |
| r                          | Fiags Affected                                                               |  |  |
|                            | Z N C V VT ST                                                                |  |  |
|                            |                                                                              |  |  |
|                            |                                                                              |  |  |

#### 3.13.92. SUB (Two Operands) — SUBTRACT WORDS

**Operation:** The source (rightmost) word operand is subtracted from the destination (leftmost) word operand, and the result is stored in the destination. The carry flag is set as complement of borrow.

 $(DEST) \leftarrow (DEST) - (SRC)$ 

SRC

**Assembly Language Format:** 

SUB wreg, waop

DST

Object Code Format: [ 011010aa ] [ waop ] [ wreg ] .

Bytes: 2+BEA States: 4+CEA

| Flags Affected |              |              |              |    |    |
|----------------|--------------|--------------|--------------|----|----|
| Z              | Ν            | С            | V            | VT | ST |
| $\checkmark$   | $\checkmark$ | $\checkmark$ | $\checkmark$ | 1  | -  |

#### 3.13.93. SUB (Three Operands) — SUBTRACT WORDS

**Operation:** The source (rightmost) word operand is subtracted from the second word operand, and the result is stored in the destination (the leftmost operand). The carry flag is set as complement of borrow.

 $(DEST) \leftarrow (SRC1) - (SRC2)$ 

Assembly Language Format: DST SRC1 SRC2,

SUB wreg, wreg, waop

Object Code Format: [ 010010aa ][ waop ][ Swreg ][ Dwreg ]

Bytes: 3+BEA States: 5+CEA

| Γ | Flags Affected |              |              |              |    |    |  |
|---|----------------|--------------|--------------|--------------|----|----|--|
|   | Ζ              | Ν            | С            | V            | VT | ST |  |
| I | $\checkmark$   | $\checkmark$ | $\checkmark$ | $\checkmark$ | 1  | -  |  |

#### 3.13.94. SUBB (Two Operands) — SUBTRACT BYTES

**Operation:** The source (rightmost) byte is subtracted from the destination (leftmost) byte operand, and the result is stored in the destination. The carry flag is set as complement of borrow.

 $(DEST) \leftarrow (DEST) - (SRC)$ 

Assembly Language Format: DST SRC

•

SUBB breg, baop

Object Code Format: [ 011110aa ][ baop ][ breg ]

Bytes: 2+BEA States: 4+CEA

| Flags Affected |              |              |              |    |    |
|----------------|--------------|--------------|--------------|----|----|
| z              | Ν            | С            | ۷            | VT | ST |
| $\checkmark$   | $\checkmark$ | $\checkmark$ | $\checkmark$ | 1  | -  |

#### 3.13.95. SUBB (Three Operands) — SUBTRACT BYTES

| Operation:                | The source (rightmost) byte operand is subtracted from the des-<br>tination (leftmost) byte operand, and the result is stored in the<br>destination. The carry flag is set as complement of borrow. |  |  |  |  |  |
|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| · · ·                     | DEST) ← (SRC1) — (SRC2)                                                                                                                                                                             |  |  |  |  |  |
| Assembly Language Format: | DST SRC1 SRC2<br>SUBB breg, Sbreg baop                                                                                                                                                              |  |  |  |  |  |
| Object Code Format:       | [ 010110aa ][ baop ][Sbreg ][ Dbreg ]                                                                                                                                                               |  |  |  |  |  |
|                           | Bytes: 3 + BEA<br>States: 5 + CEA                                                                                                                                                                   |  |  |  |  |  |
|                           | Flags Affected                                                                                                                                                                                      |  |  |  |  |  |
|                           | Z     N     C     V     VT     ST       √     √     √     √     ↑     -                                                                                                                             |  |  |  |  |  |
|                           |                                                                                                                                                                                                     |  |  |  |  |  |

#### 3.13.96. SUBC - SUBTRACT WORDS WITH BORROW

**Operation:** The source (rightmost) word operand is subtracted from the destination (leftmost) word operand. If the carry flag was clear, 1 is subtracted from the above result. The result replaces the original destination operand. The carry flag is set as complement of borrow.

(DEST) ← (DEST) — (SRC) — (1-C)

The of a state

Assembly Language Format: DST SRC SUBC wred waop

Object Code Format: [ 101010aa ][`waop ][ wreg ]

Bytes: 2+BEA States: 4+CEA

| Flags Affected |              |              |              |    |    |  |
|----------------|--------------|--------------|--------------|----|----|--|
| Z              | Ν            | С            | V            | VT | ST |  |
| ↓              | $\checkmark$ | $\checkmark$ | $\checkmark$ | 1  | -  |  |

#### 3.13.97. SUBCB — SUBTRACT BYTES WITH BORROW

**Operation:** The source (rightmost) byte operand is subtracted from the destination (leftmost) byte operand. If the carry flag was clear, 1 is subtracted from the above result. The result replaces the original destination operand. The carry flag is set as complement of borrow.

 $(DEST) \leftarrow (DEST) - (SRC) - (1-C)$ 

SRC

Assembly Language Format: DST

SUBCB breg, baop

Object Code Format: [ 101110aa ][ baop ][ breg ]

Bytes: 2+BEA States: 4+CEA

| Flags Affected |              |              |              |    |    |   |
|----------------|--------------|--------------|--------------|----|----|---|
| Ζ              | Ν            | С            | V            | VT | ST | , |
| ↓ .            | $\checkmark$ | $\checkmark$ | $\checkmark$ | 1  | -  |   |

#### 3.13.98. TRAP — SOFTWARE TRAP

**Operation:** This instruction causes an interrupt-call which is vectored through location 2010H. The operation of this instruction is not effected by the state of the interrupt enable flag in the PSW (I). Interrupt-calls cannot occur immediately following this instruction. This instruction is intended for use by Intel provided development tools. These tools will not support user-application of this instruction.

· ···

 $SP \leftarrow SP - 2$  $(SP) \leftarrow PC$  $PC \leftarrow (2010H)$ 

Assembly Language Format: This instruction is not supported by revision 1.0 of the 8096 assembly language.

Object Code Format: [ 11110111 ]

Bytes: 1 States: Onchip Stack: 21 Offchip Stack: 24

| Flags Affected |   |   |   |    |    |  |
|----------------|---|---|---|----|----|--|
| Ζ              | Ν | С | V | VT | ST |  |
| -              | - | - | - | -  | -  |  |

#### 3.13.99. XOR — LOGICAL EXCLUSIVE-OR WORDS

Operation: The source (rightmost) word operand is XORed with the destination (leftmost) word operand. Each bit is set to 1 if the corresponding bit in either the source operand or the destination operand was 1, but not both. The result replaces the original destination operand.  $(DEST) \leftarrow (DEST) XOR (SRC)$ DST SRC **Assembly Language Format:** XOR wreg, waop Object Code Format: [ 100001aa ] [ waop ] [ wreg ] Bytes: 2+BEA States: 4+CEA Flags Affected С v Z Ν VT ST 0 0

#### 3.13.100. XORB - LOGICAL EXCLUSIVE-OR BYTES

**Operation:** The source (rightmost) byte operand is XORed with the destination (leftmost) byte operand. Each bit is set to 1 if the corresponding bit in either the source operand or the destination operand was 1, but not both. The result replaces the original destination operand.

 $(DEST) \leftarrow (DEST) XOR (SRC)$ 

**Assembly Language Format:** 

DST SRC XORB breg, baop

Object Code Format: [ 100101aa ][ baop ][ breg ]

Bytes: 2+BEA States: 4+CEA

| I | Flags Affected |              |   |   |    |    |  |
|---|----------------|--------------|---|---|----|----|--|
|   | Ζ              | Ν            | С | ۷ | VT | ST |  |
|   | $\checkmark$   | $\checkmark$ | 0 | 0 | -  | -  |  |

# MCS<sup>®</sup>-96 Hardware Design Information

Δ

And a long of the long of the Annual Control of the Control of the State of the Control of the Annual Control of the Control o te and the state to a state of the state of



.

## CHAPTER 4 MCS®-96 HARDWARE DESIGN INFORMATION

#### 4.0. HARDWARE INTERFACING OVERVIEW

This section of the manual is devoted to the hardware engineer. All of the information you need to connect the correct pin to the correct external circuit is provided. Many of the special function pins have different characteristics which are under software control, therefore, it is necessary to define the system completely before the hardware is wired-up.

Frequently within this section a specification for a current, voltage, or time period is referred to; the values provided are to be used as an approximation only. The exact specification can be found in the latest data sheet for the particular part and temperature range that is being used.

#### 4.1. REQUIRED HARDWARE CONNECTIONS

Although the 8096 is a single-chip microcontroller, it still requires several external connections to make it work. Power must be applied, a clock source provided, and some form of reset circuitry must be present. We will look at each of these areas of circuitry separately. Figure 4-5 shows the connections that are needed for a single-chip system.

#### 4.1.1. Power Supply Information

Power for 8096 flows through 6 pins; one VCC pin, two VSS pins, one VREF (analog VCC), one ANGND (Analog VSS), and one VPD (V Power Down) pin. All six of these pins must be connected to the 8096 for normal operation. The VCC pin, VREF pin and VPD pin should

Figure 4-1. 8096 Oscillator Circuit

be tied to 5 volts. When the analog to digital converter is being used it may be desirable to connect the VREF pin to a separate power supply, or at least a separate power supply line.

The two VSS pins should be connected together with as short a lead as possible to avoid problems due to voltage drops across the wiring. There should be no measurable voltage difference between VSS1 and VSS2. The 2 VSS pins and the ANGND pin should all be nominally at 0 volts. The maximum current drain of the 8096 is around 200mA, with all lines unloaded.

When the analog converter is being used, clean, stable power must be provided to the analog section of the chip to assure highest accuracy. To achieve this, it may be desirable to separate the analog power supply from the digital power supply. The VREF pin supplies 5 volts to the analog circuitry and the ANGND pin is the ground for this section of the chip. More information on the analog power supply is in section 4.3.1.

#### 4.1.2. Other Needed Connections

Several of the pins on the 8096 are used to configure the mode of operation. In normal operation the following pins should be tied directly to the indicated power supply.

| PIN  | POWER | SUPPLY |
|------|-------|--------|
| NMI  | VCC   |        |
| TLOT | VCC   |        |

| 1631 | VLL |
|------|-----|
|      |     |

EA VCC (to allow internal execution) VSS (to force external execution)



Figure 4-2. Crystal Oscillator Circuit

Although the  $\overline{EA}$  pin has an internal pulldown, it is best to tie this pin to the desired level if it is not left completely disconnected. This will prevent induced noise from disturbing the system.

#### 4.1.3. Oscillator Information

The 8096 requires a clock source to operate. This clock can be provided to the chip through the XTAL1 input or the on-chip oscillator can be used. The frequency of operation is from 6.0 MHz to 12 MHz.

The on-chip circuitry for the 8096 oscillator is a single stage linear inverter as shown in Figure 4-1. It is intended for use as a crystal-controlled, positive reactance oscillator with external connections as shown in Figure 4-2. In this application, the crystal is being operated in its fundamental



Figure 4-3. External Clock Drive

response mode as an inductive reactance in parallel resonance with capacitance external to the crystal.

The crystal specifications and capacitance values (C1 and C2 in Figure 4-2) are not critical. 30 pF can be used in these positions at any frequency with good quality crystals. For 0.5% frequency accuracy, the crystal frequency can be specified at series resonance or for parallel resonance with any load capacitance. (In other words, for that degree of frequency accuracy, the load capacitance simply doesn't matter.) For 0.05% frequency accuracy the crystal frequency the trystal frequency should be specified for parallel resonance with 25 pF load capacitance, if C1 and C2 are 30 pF.

A more in-depth discussion of crystal specifications and the selection of values for C1 and C2 can be found in the Intel Application Note, AP-155, "Oscillators for Microcontrollers."

To drive the 8096 with an external clock source, apply the external clock signal to XTAL1 and let XTAL2 float. An example of this circuit is shown in Figure 4-3. The required voltage levels on XTAL1 are specified in the data sheet. The signal on XTAL1 must be clean with good solid levels. It is important that the minimum high and low times are met.

There is no specification on rise and fall times, but they should be reasonably fast (on the order of 30 nanoseconds) to avoid having the XTAL1 pin in the transition range for long periods of time. The longer the signal is in the transition region, the higher the probability that an external noise glitch could be seen by the clock generator circuitry. Noise glitches on the 8096 internal clock lines will cause unreliable operation.

The clock generator provides a 3 phase clock output from the XTAL1 pin input. Figure 4-4 shows the waveforms of the major internal timing signals.



Figure 4-4. Internal Timings

#### 4.1.4. Reset Information

In order for the 8096 to function properly it must be reset. This is done by holding the reset pin low for at least 2 state times after the power supply is within tolerance, the oscillator has stabilized, and the back-bias generator has stabilized. Typically, the back-bias generator requires one millisecond to stabilize.

There are several ways of doing this, the simplest being just to connect a capacitor from the reset pin to ground. The capacitor should be on the order of 1 to 2 microfarads for every millisecond of reset time required. This method will only work if the rise time of VCC is fast and the total reset time is less than around 50 milliseconds. It also may not work if the reset pin is to be used to reset other parts on the board. An 8096 with the minimum required connections is shown in Figure 4-5.

The 8096  $\overline{\text{RESET}}$  pin can be used to allow other chips on the board to make use of the watchdog timer or the RST instruction. When this is done the reset hardware should be a one-shot with an open-collector output. The reset pulse going to the other parts may have to be buffered and lengthened with a one-shot, since the RESET low duration is only two state times. If this is done, it is possible that the 8096 will be reset and start running before the other parts on the board are out of reset. The software must account for this possible problem.

A capacitor directly connected to **RESET** cannot be used to reset the part if the pin is to be used as an output. If a large capacitor is used, the pin will pull down more slowly than normal. It will continue to pull down until the 8096 is reset. It could fall so slowly that it never goes below the internal switch point of the reset signal (1 to 1.5 volts), a voltage which may be above the guaranteed switch point of external circuitry connected to the pin. Several circuit examples are shown in Figure 4-6.

#### 4.1.5. Sync Mode

If **RESET** is brought high at the same time as or just after the rising edge of XTAL1, the part will start executing the 10 state time RST instruction exactly 6<sup>1</sup>/<sub>2</sub> XTAL1 cycles later. This feature can be used to synchronize several MCS-96 devices. A diagram of a typical connection is shown in Figure 4-7. It should be noted that parts that start in sync may not stay that way, due to propagation delays which may cause the synchronized parts to receive signals at slightly different times.



Figure 4-5. Minimum Hardware Connections



Figure 4-6. Multiple Chip Reset Circuits



Figure 4-7. Reset Sync Mode

#### 4.1.6. Disabling the Watchdog Timer

The watchdog timer will pull the RESET pin low when it overflows. If the pin is being externally held above the low going threshold, the pull-down transistor will remain on indefinitely. This means that once the watchdog overflows, the part must be reset or RESET must be held high indefinitely. Just resetting the watchdog timer will not clear the flip-flop which keeps the RESET pull-down on.

The pull-down is capable of sinking on the order of 30 milliamps if it is held at 2.0 volts. This amount of current

may cause some long term reliability problems due to localized chip heating. For this reason, parts that will be used in production should never have had the watchdog timer over-ridden for more than a second or two.

Whenever the reset pin is being pulled high while the pulldown is on, it <u>should</u> be through a resistor that will limit the voltage on  $\overrightarrow{RESET}$  to 2.5 volts and the current through the pin to 40 milliamps. Figure 4-8 shows a circuit which will provide the desired results. Using the LED will provide the additional benefit of having a visual indicator that the part is trying to reset itself, although this circuit only works at room temperature and VCC = 5 Volts.

If it is necessary to disable the watchdog timer for more than a brief test the software solution of never initiating the times should be used. See Section 2.14.

#### 4.1.7. Power Down Circuitry

Battery backup can be provided on the 8096 with a 1 mA current drain at 5 volts. This mode will hold locations 0F0H through 0FFH valid as long as the power to the VPD pin remains on. The required timings to put the part into power-down and an overview of this mode are given in section 2.4.2.

A 'key' can be written into power-down RAM while the part is running. This key can be checked on reset to determine if it is a start-up from power-down or a complete cold start. In this way the validity of the power-down RAM can be verified. The length of this key determines the probability that this procedure will work, however, there is always a statistical chance that the RAM will power up with a replica of the key.

Under most circumstances, the power-fail indicator which is used to initiate a power-down condition must come from the unfiltered, unregulated section of the power supply. The power supply must have sufficient storage capacity to operate the 8096 until it has completed its reset operation.

#### 4.2. DRIVE AND INTERFACE LEVELS

There are 5 types of I/O lines on the 8096. Of these, 2 are inputs and 3 are outputs. All of the pins of the same type have the same current/voltage characteristics. Some of the control input pins, such as XTAL1 and RESET, may have slightly different characteristics. These pins are discussed in section 4.1.

While discussing the characteristics of the I/O pins some approximate current or voltage specifications will be given. The exact specifications are available in the latest version of the 8096 Data Sheet.

#### 4.2.1. Quasi-Bidirectional Ports

The quasi-bidirectional port is both an input and an output port. It has three states, low impedance current sink, low impedance current source, and high impedance current source. As a low impedance current sink, the pin has a specification of sinking up to around .4 milliamps, while staying below 0.45 volts. The pin is placed in this condition by writing a '0' to the SFR (Special Function Register) controlling the pin.

When a '1' is written to the SFR location controlling the pin, a low impedance current source is turned on for one state time, then it is turned off and the depletion pull-up holds the line at a logical '1' state. The low-impedance pull-up is used to shorten the rise time of the pin, and has current source capability on the order of 100 times that of the depletion pull-up. The configuration of a quasibidirectional port pin is shown in Figure 4-9.

While the depletion mode pull-up is the only device on, the pin may be used as an input with a leakage of around



Figure 4-8. Disabling the WDT



#### Figure 4-9. Quasi-Bidirectional Port

100 microamps from 0.45 volts to VCC. It is ideal for use with TTL or CMOS chips and may even be used directly with switches, however if the switch option is used certain precautions should be taken. It is important to note that any time the pin is read, the value returned will be the value on the pin, not the value placed in the control register. This could prevent logical operations on these pins while they are being used as inputs.

#### 4.2.2. Quasi-Bidirectional Hardware Connections

When using the quasi-bidirectional ports as inputs tied to switches, series resistors should be used if the ports will be written to internally after the part is initialized. Every time any quasi-bidirectional pin is written from a zero to a one, the low impedance pull-up is turned on. If many of the pins are tied directly to ground, a large currentspike will be generated when all of these low impedance devices are turned on at once.

For this reason, a series resistor is recommended to limit

the current to a maximum of 0.2 milliamps per pin. If several pins are connected to a common ground through switches, it should be sufficient to limit the current through the common ground to 0.2 milliamps times the maximum number of pins that could be switched to ground. Many switches require a minimum amount of current flow through them to keep them clean. This could cause problems in long term reliability if it is not considered when designing a system.

If a switch is used on a long line connected to a quasibidirectional pin, a pull-up resistor is recommended to reduce the possibility of noise glitches and to decrease the rise time of the line. On extremely long lines that are handling slow signals a capacitor may be helpful in addition to the resistor to reduce noise.

#### 4.2.3. Input Ports, Analog and Digital

The high impedance input ports on the 8096 have an input leakage of a few microamps and are predominantly capacitive loads on the order of 10 pf. The Port 0 pins have an additional function when the A to D converter is being used. These pins are the input to the A to D converter, and as such, are required to provide current to the comparator when a conversion is in process. This means that the input characteristics of a pin will change if a conversion is being done on that pin. See section 4.3.1.

#### 4.2.4. Open Drain Ports

Ports 3 and 4 on the 8096 are open drain ports. There is no pull-up when these pins are used as I/O ports. These pins have different characteristics when used as bus pins as described in the next section. A diagram of the output buffers connected to ports 3 and 4 and the Bus pins is shown in Figure 4-10.

When Ports 3 and 4 are to be used as inputs, or as Bus pins, they must first be written with a '1', this will put the ports in a high impedance mode. When they are used as outputs, a pull-up resistor must be used externally. The sink capability of these pins is on the order of 0.4 milliamps so the total pull-up current to the pin must be less than this. A 15k pull-up resistor will source a maximum of 0.33 milliamps, so it would be a reasonable value to choose if no other circuits with pullups were connected to the pin.

# 4.2.5. HSO Pins, Control Outputs and Bus Pins

The control outputs and HSO pins have output buffers with the same output characteristics as those of the bus pins. Included in the category of control outputs are: TXD, RXD (in mode 0), PWM, CLKOUT, ALE, BHE, RD, and WR. The bus pins have 3 states: output high, output low, and high impedance input. As a high output, the pins are specified to source around 200  $\mu$ A to 2.4 volts, but the pins can source on the order of ten times that value in order to provide fast rise times. When used as a low output, the pins can sink around 2 mA at .45 volts, and considerably more as the voltage increases. When in the high impedance state, the pin acts as a capacitive load with a few microamps of leakage. Figure 4-10 shows the internal configuration of a bus pin.



Figure 4-10. Bus and Port 3 and 4 Pins

#### 4.3. ANALOG INTERFACE

Interfacing the 8096 to analog signal can be done in several ways. If the 8096 needs to measure an analog signal the A to D converter can be used. Creation of analog outputs can be done with either the PWM output or the HSO unit.

#### 4.3.1. Analog Inputs

The 8096 can have 8 analog inputs and can convert one input at a time into a digital value. Each conversion takes 42 microseconds with a 12 MHz signal on XTAL1. The input signal is applied to one of the Port 0/Analog Channel inputs. Since there is no sample and hold on the A to D, the input signal must remain constant over the sampling period.

When a conversion takes place, the 8096 compares the external signal to that of its internal D to A. Based on the result of the comparison it adjusts the D to A and compares again. Each comparison takes 8 state times and requires the input to the comparator to be charged up. 20 comparisons are made during a conversion, two times for each bit of resolution. An additional 8 states are used to load and store values. The total number of state times required is 168 for a 10-bit conversion. Attempting to do other than a 10-bit conversion is not recommended.

Since the capacitance of the comparator input is around 0.5pf, the sample and hold circuit must be able to charge. a 10pf (20\*0.5pf) capacitor without a significant voltage change. To keep the effect of the sample and hold circuit below  $\pm \frac{1}{2}$  lsb on a 10-bit converter, the voltage on the

sample and hold circuit may vary no more than 0.05% (1/2048).

The effective capacitance of the sample and hold must, therefore, be at least 20000pf or 0.02 uf. If there is external leakage on the capacitor, its value must be increased to compensate for the leakage. At 10 $\mu$ A leakage, 2.5 mV (5/2048) will be lost from a 0.17 uf capacitor in 42  $\mu$ S. The capacitor connected externally to the pin should, therefore, be at least 0.2 uf for best results. If the external signal changes slowly relative to 42  $\mu$ S, then a larger capacitor will work well and also filter out unwanted noise.

The converter is a 10-bit, successive approximation, ratiometric converter, so the numerical value obtained from the conversion will be:

#### 1023 \* (VIN-ANGND) / (VREF-ANGND)

It can be seen that the power supply levels strongly influence the absolute accuracy of the conversion. For this reason, it is recommended that the ANGND pin be tied to a clean ground, as close to the power supply as possible. VREF should be well regulated and used only for the A to D converter. If ratiometric information is desired, VREF can be connected to VCC, but this should be done at the power supply not at the chip. It needs to be able to source around 15 milliamps. Bypass capacitors should be within about a tenth of a volt of VSS and VREF should be within a few tenths of a volt of VCC. A 0.01 uf capacitor should be connected between the ANGND and



Figure 4-11. D/A Buffer Block Diagram

VBB pins to reduce the noise on VBB and provide the highest possible accuracy. Figure 4-5 shows all of these connections.

#### 4.3.2. Analog Output Suggestions

Analog outputs can be generated by two methods, either by using the PWM output or the HSO. Either device will generate a rectangular pulse train that varies in duty cycle and (for the HSO only) period. If a smooth analog signal is desired as an output, the rectangular waveform must be filtered.

In most cases this filtering is best done after the signal is buffered to make it swing from 0 to 5 volts since both of the outputs are guaranteed only to TTL levels. A block diagram of the type of circuit needed is shown in Figure 4-11. By proper selection of components, accounting for temperature and power supply drift, a highly accurate 8bit D to A converter can be made using either the HSO or the PWM output. If the HSO is used the accuracy could be theoretically extended to 16-bits, however the temperature and noise related problems would be extremely hard to handle.

When driving some circuits it may be desirable to use unfiltered Pulse Width Modulation. This is particularly true for motor drive circuits. The PWM output can be used to generate these waveforms if a fixed period on the order of 64 uS is acceptable. If this is not the case then the HSO unit can be used. The HSO can generate a variable waveform with a duty cycle variable in up to 65536 steps and a period of up to 131 milliseconds. Both of these outputs produce TTL levels.

#### 4.4. I/O TIMINGS

The I/O pins on the 8096 are sampled and changed at specific times within an instruction cycle. The timings shown in this section are idealized; no propagation delay factors have been taken into account. Designing a system that depends on an I/O pin to change within a window of less than 50 nanoseconds using the information in this section is not recommended.

#### 4.4.1. HSO Outputs

Changes in the HSO lines are synchronized to Timer 1. All of the external HSO lines due to change at a certain value of a timer will change just prior to the incrementing of Timer 1. This corresponds to an internal change during Phase C, every eight state times. From an external perspective the HSO pin should change around the rising edge of CLKOUT and be stable by its falling edge. Internal events can occur anytime during the 8 state time window.

Timer 2 is synchronized to increment no faster than Timer 1, so there will always be at least one incrementing of Timer 1 while Timer 2 is at a specific value.

#### 4.4.2. HSI Input Sampling

The HSI pins are sampled internally once each state time. Any value on these pins must remain stable for at least 1 full state time to guarantee that it is recognized. This restriction applies even if the divide by eight mode is being used. If two events occur on the same pin within the same 8 state time window, only one of the events will be recorded. If the events occur on different pins they will always be recorded, regardless of the time difference. The 8 state time window, (ie. the amount of time during which Timer 1 remains constant), is stable to within about 20 nanoseconds. The window starts roughly around the rising edge of CLKOUT, however this timing is very approximate due to the amount of internal circuitry involved.

#### 4.4.3. Standard I/O Port Pins

Port 0 is different from the other digital ports in that it is actually part of the A to D converter. The port is sampled once every 8 state times, the same frequency at which the comparator is charged-up during an A to D conversion. This 8 state times counter is not synchronized with Timer 1. If this port is used the input signal on the pin must be stable 8 state times prior to reading the SFR.

Port 1 and Port 2 have quasi-bidirectional I/O pins. When used as inputs the data on these pins must be stable one state time prior to reading the SFR. This timing is also valid for the input-only pins of Port 2. When used as outputs, the quasi-bidirectional pins will change state shortly after CLKOUT falls. If the change was from '0' to a '1' the low impedance pull-up will remain on for one state time after the change.

Ports 3 and 4 are addressed as off-chip memory-mapped I/O. The port pins will change state shortly after the rising edge of CLKOUT. When these pins are used as Ports 3 and 4 they are open drain, their structure is different when they are used as part of the bus. See Section 2.12.4.

#### 4.5. SERIAL PORT TIMINGS

The serial port on the 8096 was designed to be compatible with the 8051 serial port. Since the 8051 uses a divide by 2 clock and the 8096 uses a divide by 3, the serial port on the 8096 had to be provided with its own clock circuit to maximize its compatibility with the 8051 at high baud rates. This means that the serial port itself does not know about state times. There is circuitry which is synchronized to the serial port and to the rest of the 8096 so that information can be passed back and forth.

The baud rate generator is clocked by either XTAL1 or T2CLK, because T2CLK needs to be synchronized to the XTAL1 signal its speed must be limited to  $V_{16}$  that of XTAL1. The serial port will not function during the time between the consecutive writes to the baud rate register. Section 2.11.4 discusses programming the baud rate generator.

#### 4.5.1. Mode 0

Mode 0 is the shift register mode. The TXD pin sends out a clock train, while the RXD pin transmits or receives the data. Figure 4-12 shows the waveforms and timing. Note that the port starts functioning when a '1' is written to the REN (Receiver Enable) bit in the serial port control register. If REN is already high, clearing the RI flag will start a reception.

A schematic of a typical circuit is shown in Figure 4-13. This circuit inverts the data coming in, so it must be reinverted in software. The enable and latch connections to the shift registers can be driven by decoders, rather than directly from the low speed I/O ports, if the software and hardware are properly designed.

In this mode the serial port can be used to expand the I/O capability of the 8096 by simply adding shift registers.



Figure 4-12. Serial Port Timings in Mode 0



Figure 4-13. Mode 0 Serial Port Example

#### 4.5.2. Mode 1 Timings

Mode 1 operation of the serial port makes use of 10-bit data packages, a start bit, 8 data bits and a stop bit. The transmit and receive functions are controlled by separate shift clocks. The transmit shift clock starts when the baud rate generator is initialized, the receive shift clock is reset when a '1 to 0' transition (start bit) is received. The transmit clock may therefore not be in sync with the receive clock, although they will both be at the same frequency.

The TI (Transmit Interrupt) and RI (Receive Interrupt) flags are set to indicate when operations are complete. TI



Figure 4-14. Bus Signal Timings

is set when the last data bit of the message has been sent, not when the stop bit is sent. If an attempt to send another byte is made before the stop bit is sent the port will hold off transmission until the stop bit is complete. RI is set when 8 data bits are received, not when the stop bit is received. Note that when the serial port status register is read both TI and RI are cleared.

Caution should be used when using the serial port to connect more than two devices in half-duplex, (ie. one wire for transmit *and* receive). If the receiving processor does

Tosc — Oscillator Period, one cycle time on XTAL1.

#### **Timings The Memory System Must Meet**

TLLYH — ALE low to READY high: Maximum time after ALE falls until READY is brought high to ensure no more wait states. If this time is exceeded unexpected wait states may result. Nominally 1 Tosc + 3 Tosc\* number of wait states desired.

TLLYV — ALE low to READY VALID: Maximum time after ALE falls until READY must be valid. If this time is exceded the part could malfunction necessitating a chip reset. Nominally 2 Tosc periods.

TYLYH — READY low to READY high: Maximum time the part can be in the not-ready state. If it is exceeded, the 8096 dynamic nodes which hold the current instruction may 'forget' how to finish the instruction.

TAVDV — ADDRESS valid to DATA valid: Maximum time that the memory has to output valid data after the 8096 outputs a valid address. Nominally, a maximum of 5 Tosc periods.

TRLDV —  $\overline{\text{READ}}$  low to DATA valid: Maximum time that the memory has to output data after  $\overline{\text{READ}}$  goes low. Nominally, a maximum of 3 Tosc periods.

 $\frac{\text{TRXDZ}}{\text{READ}} = \frac{\text{READ}}{\text{READ}} \text{ not low to DATA float: Time after READ is no longer low until the memory must float the bus. The memory signal can be removed as soon as READ is not low, and must be removed within the specified maximum time.}$ 

Nominally, a maximum of 1 Tosc period.

#### Timings the 8096 Will Provide

TCHCH — CLKOUT high to CLKOUT high: The period of CLKOUT and the duration of one state time. Always 3 Tosc average, but individual periods could vary by a few nanoseconds.

TCHCL — CLKOUT high to CLKOUT low: Nominally 1 Tosc period.

not wait for one bit time after RI is set before starting to transmit, the stop bit on the link could be squashed. This could cause a problem for other devices listening on the link.

#### 4.5.3. Mode 2 and 3 Timings

Modes 2 and 3 operate in a manner similar to that of mode 1. The only difference is that the data is now made up of 9 bits, so 11-bit packages are transmitted and received. This means that TI and RI will be set on the 9th data bit

TCLLH — CLKOUT low to ALE high: A help in deriving other timings, typically plus or minus 5 to 10 ns.

TLLCH — ALE low to CLKOUT high: Used to derive other timings, nominally 1 Tosc period.

TLHLL — ALE high to ALE low: ALE pulse width. Useful in determining ALE rising edge to ADDRESS valid time. Nominally 1 Tosc period.

TAVLL — ADDRESS valid to ALE low: Length of time ADDRESS is valid before ALE falls. Important timing for address latch circuitry. Nominally 1 Tosc period.

TLLAX — ALE low to ADDRESS invalid: Length of time ADDRESS is valid after ALE falls. Important timing for address latch circuitry. Nominally 1 Tosc period.

TLLRL — ALE low to  $\overline{READ}$  or  $\overline{WRITE}$  low: Length of time after ALE falls before  $\overline{RD}$  or  $\overline{WR}$  fall. Could be needed to ensure that proper memory decoding takes place before it is output enabled. Nominally 1 Tosc period.

TRLRH —  $\overline{\text{READ}}$  low to  $\overline{\text{READ}}$  high:  $\overline{\text{RD}}$  pulse width, nominally 1 Tosc period.

TRHLH —  $\overline{READ}$  high to ALE high: Time between  $\overline{RD}$  going inactive and next ALE, also used to calculate time between  $\overline{RD}$  inactive and next ADDRESS valid. Nominally 1 Tosc period.

TWLWH —  $\overline{\text{WRITE}}$  low to  $\overline{\text{WRITE}}$  high: Write pulse width, nominally 2 Tosc periods.

TQVWX — OUTPUT valid to  $\overline{\text{WRITE}}$  not low: time that the OUTPUT data is valid before  $\overline{\text{WR}}$  starts to go high. Nominally 2 Tosc periods.

TWXQX —  $\overline{\text{WRITE}}$  not low to OUTPUT not valid: Time that the OUTPUT data is valid after  $\overline{\text{WR}}$  starts to rise. Nominally 1 Tosc period.

TWXLH —  $\overline{WRITE}$  not low to ALE high: Time between write starting to rise and next ALE, also used to calculate the time between  $\overline{WR}$  starting to rise and next ADDRESS valid. Nominally 2 Tosc periods.

Figure 4-15. Timing Specification Explanations

rather than the 8th. The 9th bit can be used for parity or multiple processor communications (see section 2.11).

#### 4.6. BUS TIMING AND MEMORY INTERFACE

#### 4.6.1. Bus Functionality

The 80% has a multiplexed (address/data) 16 bit bus. There are control lines provided to demultiplex the bus (ALE), indicate reads or writes ( $\overline{RD}$ ,  $\overline{WR}$ ), indicate if the access is for an instruction (INST), and separate the bus into high and low bytes ( $\overline{BHE}$ , AD0). Section 2.3.5 contains an overview of the bus operation.

#### 4.6.2. Timing Specifications

Figure 4-14 shows the timing of the bus signals and data lines. Since this is a new part, the exact timing specifications are subject to change, please refer to the latest 8096 data sheet to ensure that your system is designed to the proper specifications. The major timing specifications are described in Figure 4-15.

#### 4.6.3. READY Line Usage

When the processor has to address a memory location that cannot respond within the standard specifications it is necessary to use the READY line to generate wait states. When the READY line is held low the processor waits in a loop for the line to come high. There is a maximum time that the READY line can be held low without risking a processor malfunction due to dynamic nodes that have not been refreshed during the wait states. This time is shown as TYLYH in the data sheet.

In most cases the READY line is brought low after the address is decoded and it is determined that a wait state is needed. It is very likely that some addresses, such as those addressing memory mapped peripherals, would need wait states, and others would not. The READY line must be stable within the TLLYV specification after ALE falls (or the TYVCL before CLKOUT falls) or the processor could lock-up. There is no requirement as to when READY may go high, as long as the maximum READY low time (TYLYH) is not violated. To ensure that only one wait state is inserted it is necessary to bring READY high TLLYH after the falling edge of ALE.

#### 4.6.4. INST Line Usage

The INST (Instruction) line is high during the output of an address that is for an instruction stream fetch. It is low during the same time for any other memory access. At any other time it is not valid. This pin is not present on the 48-pin versions. The INST signal can be used with a logic analyzer to debug a system. In this way it is possible to determine if the fetch was for instructions or data, making the task of tracing the program much easier.

#### 4.6.5. Address Decoding

The multiplexed bus of the 8096 must be demultiplexed before it can be used. This ca be done with 2 74LS373 transparent latches. As explained in section 2.3.5, the latched address signal will be referred to as MA0 through MA15. (Memory Address), and the data lines will be called MD0 through MD15, (Memory Data).

Since the 8096 can make accesses to memory for either bytes or words it is necessary to have a way of determining the type of access desired. The  $\overline{BHE}$  and MAO lines are used for this purpose.  $\overline{BHE}$  must be latched, as it is valid only when the address is valid. The memory system is typically set up as 32K by 16, instead of 64K by 8. When the  $\overline{BHE}$  line is low, the upper byte is enabled. When MAO is low, the lower byte is enabled when MAO is high  $\overline{BHE}$  will be low, and the upper byte is enabled.

When external RAM and EPROM are both used in the system the control logic can be simplified a little to some of the addresses. The 8096 will always output BHE to indicate if a read is of the high byte or the low byte, but it discards the byte it is not going to use. It is therefore possible to use the  $\overline{BHE}$  and MA0 lines only to control



Figure 4-16. Memory Wiring Example—EPROM Only System

memory writes, and to ignore these lines during memory reads. Figure 4-16 and 4-17 show block diagrams of two memory systems, an external EPROM only system and a RAM/ROM system.

#### 4.6.6. System Verification Example

To verify that a system such as the one in Figure 4-17 will work with the 8096, it is necessary to check all of the timing parameters. Let us examine this system one parameter at a time using the proposed 8096 specifications. These specifications are subject to change, refer to the latest 8096 data sheet for the current specifications.

The timings of signals that the processor and memory use are effected by the latch and buffer circuitry. The timings of the signal provided by the processor are delayed by various amounts of time. Similarly, the signals coming back from the memory are also delayed. The calculations involved in verifying this system follow:

#### Address Valid Delay - 20 nanoseconds

The address lines are delayed by passing them through the 74LS373s, this delay is specified at 18ns after Address is valid or 30ns after ALE is high. Since the signal may be limited by either the ALE timing or the Address timing, these two cases must be considered.

#### If Limited by ALE:

| Minimum ALE pulse width =            | Tosc-10<br>(TLHLL) |
|--------------------------------------|--------------------|
| Minimum Addr set-up to ALE falling = | Tosc-20<br>(TAVLL) |

Therefore ALE could occur 10 ns before Address valid.

Total delay from 8096 Address stable to MA (Memory Address) stable would be:

| ALE delay from address  | -10            |   |
|-------------------------|----------------|---|
| 74LS373 clock to output | 30             |   |
|                         | 20 nanoseconds | 5 |

#### If Limited by Address Valid:

#### 74LS373 Data Valid to Data Output = 18 nanoseconds

In the worst case, the delay in Address valid is controlled by ALE and has a value of 20 nano-seconds.



#### Figure 4-17. RAM/ROM Memory System

# Delay of Data Transfer to/from Processor — 12 nanoseconds

The  $\overline{RD}$  low to Data valid specification (TRLDV) is 3 Tosc-50, (200 ns at 12 MHz). The 74LS245 is enabled by  $\overline{RD}$  and has a delay of 40 ns from enable. The enable delay is clearly not a problem.

The 74LS245 is enabled except during a read, so there is no enable delay to consider for write operaions.

The Data In to Data Out delay of the 74LS245 is 12 ns.

#### Delay of WR signal to memory - 15 nanoseconds

Latched  $\overline{BHE}$  is delayed by the inverter on ALE and the 74LS74.

| 74LS04 delay (Output low to high)     | = 22   |
|---------------------------------------|--------|
| 74LS74 delay (Clock to Output)        | = 40   |
| Delay of Latched BHE from ALE falling | = 62   |
| nanose                                | econds |

The 74LS74 requires data valid for 20 ns prior to the clock, the 8096 will have  $\overline{BHE}$  stable Tosc-20 ns (TAVLL, 63 ns at 12 MHz) prior to ALE falling. There is no problem here.

MA0 is valid prior to ALE falling, since the 20 ns Address Delay is less than TAVLL.

 $\overline{WR}$  will fall no sooner than Tosc-20 ns (TLLRL, 63 ns at 12 MHz) after ALE goes low. It will therefore be valid just after the Latched  $\overline{BHE}$  is valid, so it is the controlling signal.

 $\overline{WR}$  High and  $\overline{WR}$  Low are valid 15 ns after MA0, Latched  $\overline{BHE}$  and  $\overline{WR}$  are valid. Since  $\overline{WR}$  is the last signal to go valid, the delay of  $\overline{WR}$  (High and Low) to memory is 15 ns.

| Delay Summary — | Address Delay | = 20  ns |
|-----------------|---------------|----------|
|                 | Data Delay    | = 12 ns  |
|                 | WR Delay      | = 15 ns  |
|                 | RD Delay      | = 0  ns  |

# Characteristics of a 12 MHz 8096 system with latches:

Required by system:

Address valid to Data in;

| TAVDV         | : 386.6 ns maximum  |
|---------------|---------------------|
| Address Delay | : - 20.0 ns maximum |
| Data Delay    | : - 12.0 ns maximum |
|               | 354.6 ns maximum    |

Read low to Data in;

| TRLDV      | : 200.0 ns maximum  |
|------------|---------------------|
| RD Delay   | : - 00.0 ns maximum |
| Data Delay | : - 12.0 ns maximum |
|            | 188 0 ns maximum    |

Provided by System:

Address valid to Control;

| TLLRL         | : 63.3 ns minimum            |
|---------------|------------------------------|
| TAVLL         | : 63.3 ns minimum            |
| Address Delay | : - 20.0 ns maximum          |
| WR Delay      | = -00.0 ns minimum (no spec) |
|               | 101.6 ns minimum             |

Write Pulse Width;

| TWLWH :            | 151.6 ns minimum          |
|--------------------|---------------------------|
| Rising WR Delay :  | - 15.0 ns maximum         |
| Falling WR Delay : | 00.0 ns minimum (no spec) |
|                    | 146.6 ns minimum          |

Data Setup to WR rising;

| TQVWX      | : 136.6 ns minimum          |
|------------|-----------------------------|
| Data Delay | : - 12.0 ns maximum         |
| WR Delay   | : 00.0 ns minimum (no spec) |
|            | 124.6 ns minimum            |

Data Hold after WR;

| TWXQX      | : | 58.3 ns minimum          |
|------------|---|--------------------------|
| Data Delay | : | 0.0 ns minimum (no spec) |
| WR Delay   | : | 15.0 ns maximum          |
|            |   | 43.3 ns minimum          |

The two memory devices which are expected to be used most often with the 8096 are the 2764 EPROM and the 2128 RAM. The system verification for the 2764 is simple.

#### 2764 Tac

#### 2764 Toe

(Output Enable to Output)  $< \overline{\text{Read}}$  low to Data in 100 ns < 188 ns O.K.

These calculations assume no address decoder delays and no delays on the  $\overline{RD}$  (OE) line. If there are delays in these signals the delays must be added to the 2764's timing.

The read calculations for the 2128 are similar to those for the 2764.

2128-20 Tac < Address valid to Data in 200 ns < 354 ns O.K.

2128-20 Toe < Read low to Data in 65 ns < 188 ns O.K. The write calculations are a little more involved, but still straight-forward.

2128 Twp (Write Pulse) < Write Pulse Width 100 ns < 146 ns O.K.</li>
2128 Tds (Data Setup) < Data Setup to WR rising 65 ns < 124 ns O.K.</li>
2128 Tdh (Data Hold) < Data Hold after WR 0 ns < 43 ns</li>

All of the above calculations have been done assuming that no components are in the circuit except for those shown in Figure 4-17. If additional components are added, as may be needed for address decoding or memory bank switching, the calculations must be updated to reflect the actual circuit.

#### 4.6.7. I/O Port Reconstruction

When a single-chip system is being designed using a multiple chip system as a prototype, it may be necessary to reconstruct I/O ports 3 and 4 using a memory-mapped I/O technique. The circuit shown in Figure 4-18 provides this function on the iSBE-96 emulator board. It can be attached to any 8096 system which has the required address decoding and bus demultiplexing.

The output circuitry is basically just a latch that operates when 1FFEH or 1FFFH are placed on the MA lines. The inverters surrounding the latch create an open-collector output to emulate the open-drain output found on the 8096. The 'reset' line is used to set the ports to all 1's when the 8096 is reset. It should be noted that the voltage and current characteristics of this port will differ from those of the 8096, but the basic functionality will be the same.

The input circuitry is just a bus transceiver that is addressed at 1FFEH or 1FFFH. If the ports are going to be used for either input or output, but not both, some of the circuitry can be eliminated.

#### 4.7. NOISE PROTECTION TIPS

Designing controllers differs from designing other computer equipment in the area of noise protection. A microcontroller circuit under the hood of a car, in a photocopier, CRT terminal, or a high speed printer is subject



Figure 4-18. I/O Port Reconstruction

to many types of electrical noise. Noise can get to the processor directly through the power supply, or it can be induced onto the board by electromagnetic fields. It is also possible for the pc board to find itself in the path of electrostatic discharges. Glitches and noise on the pc board can cause the processor to act unpredictably, usually by changing either the memory locations or the program counter.

There are both hardware and software solutions to noise problems, but the best solution is good design practice and a few ounces of prevention. The 8096 has a watchdog timer which will reset the part if it fails to execute the software properly. The software should be set up to take advantage of this feature.

It is also recommended that unused areas of code be filled with NOPs and periodic jumps to an error routine or RST (reset chip) instructions. This is particularly important in the code around lookup tables, since if lookup tables are executed all sorts of bad things can happen. Wherever space allows, each table should be surrounded by 7 NOPs (the longest 8096 instruction has 7 bytes) and a RST or jump to error routine instruction. This will help to ensure a speedy recovery should the processor have a glitch in the program flow.

Many hardware solutions exist for keeping pc board noise to a minimum. Ground planes, gridded ground and VCC structures, bypass capacitors, transient absorbers and power busses with built-in capacitors can all be of great help. It is much easier to design a board with these features than to try to retrofit them later. Proper pc board layout is probably the single most important and, unfortunately, least understood aspect of project design. Minimizing loop areas and inductance, as well as providing clean grounds are very important. More information on protecting against noise can be found in the Intel Application Note AP-125, "Designing Microcontroller Systems For Noisy Environments."

#### 4.8. PACKAGING PINOUTS AND ENVIRONMENT

The MCS-96 family of products is offered in many versions. They are available in 48-pin or 68-pin packages, with or without ROM, and with or without an A to D converter. A summary of the available options is shown in Figure 4-19.

The 48-pin versions are available in a 48-pin DIP (Dual In-Line) package, in either ceramic or plastic.

The 68-pin versions are available in a ceramic pin grid array, and a plastic flatpack. A plastic pin grid array will be available in the near future.

|                | ROMLESS |        | WITH ROM |        |
|----------------|---------|--------|----------|--------|
|                | 68-pin  | 48-pin | 68-pin   | 48-pin |
| Without A to D | 8096    | 8094   | 8396     | 8394   |
| With A to D    | 8097    | 8095   | 8397     | 8395   |

Figure 4-19. The MCS®-96 Family of Products

• 

# MCS<sup>®</sup>-96 Data Sheets

5

en ja menen ander antig en eigen ander och en en etter Broche och statiska som etter att som etter att som ette Antigen ander att som etter som etter att Antigen

# intel

## 8094/8095/8096/8097 8394/8395/8396/8397 16-BIT MICROCONTROLLERS

- 839X: an 809X with 8K Bytes of On-chip ROM
- High Speed Pulse I/O
- 10-bit A/D Converter
- 8 Interrupt Sources
- Pulse-Width Modulated Output
- Four 16-bit Software Timers

- 232 Byte Register File
- Memory-to-Memory Architecture
- Full Duplex Serial Port
- Five 8-bit I/O Ports
- Watchdog Timer

The MCS-96 family of 16-bit microcontrollers consists of 8 members, all of which are designed for high-speed control functions.

The CPU supports bit, byte, and word operations. 32-bit double-words are supported for a subset of the instruction set. With a 12 MHz input frequency the 8096 can do a 16-bit addition in 1.0  $\mu$ sec and a 16 x 16-bit multiply or 32/ 16-bit divide in 6.5  $\mu$ sec. Instruction execution times average 1 to 2  $\mu$ sec in typical applications.

Four high-speed trigger inputs are provided to record the times at which external events occur. Six high-speed pulse generator outputs are provided to trigger external events at preset times. The high-speed output unit can simultaneously perform timer functions. Up to four such 16-bit Software Timers can be in operation at once.

An on-chip A/D Converter converts up to 4 (in the 48-pin version) or 8 (in the 68-pin version) analog input channels to 10-bit digital values. This feature is only available on the 8095, 8395, 8097 and 8397.

Also provided on-chip are a serial port, a watchdog timer, and a pulse-width modulated output signal.





|  | RXD P2.1<br>TXD P2.0<br>HSI0<br>HSI1<br>HSI2 HSO4<br>HSO3<br>HSO3<br>HSO3<br>VSB<br>PWM P2.5<br>WR<br>BHE<br>READY<br>AD15 P4.7<br>AD14 P4.6<br>AD13 P4.5<br>AD12 P4.4<br>AD11 P4.3<br>AD10 P4.2<br>AD9 P4.1<br>AD8 P4 0 | 1<br>2<br>3<br>4<br>5<br>1<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>10<br>11<br>12<br>13<br>14<br>15<br>10<br>11<br>12<br>13<br>14<br>15<br>10<br>11<br>12<br>13<br>14<br>15<br>10<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>16<br>17<br>16<br>17<br>17<br>18<br>19<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>16<br>17<br>17<br>18<br>19<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18<br>19<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18<br>19<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18<br>19<br>19<br>10<br>11<br>12<br>12<br>13<br>14<br>15<br>16<br>17<br>18<br>19<br>19<br>20<br>10<br>21<br>22<br>23<br>24<br>14<br>15<br>16<br>17<br>17<br>17<br>17<br>18<br>19<br>19<br>10<br>10<br>10<br>10<br>10<br>10<br>10<br>10 | 8094<br>8095<br>8394<br>8395 | 48<br>47<br>46<br>45<br>44<br>43<br>42<br>41<br>40<br>39<br>37<br>36<br>37<br>36<br>37<br>36<br>33<br>31<br>30<br>29<br>28<br>27<br>26<br>25 | RESET           EXTINT P2.2           VPD           VREF           ANGND           ACH4 P0 4           ACH5 P0 5           ACH7 P0 7           ACH6 P0.6           EÃ           VCC           VSS           XTAL1           XTAL2           ALE           AD           AD2 P3 0           AD2 P3 2           AD3 P3 3           AD4 P3 4           AD5 P3 5           AD6 P3 6           AD7 P3 7 |  |
|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|

Figure 2. 48-Pin Package

Figure 1 shows a block diagram of the MCS-96 parts, generally referred to as the 8096. The 8096 is available in 48-pin and 68-pin packages, with and without A/D, and with and without on-chip ROM. The MCS-96 numbering system is shown below:

| OP             | rions   | 68 PIN | 48 PIN |
|----------------|---------|--------|--------|
| DIGITAL        | ROMLESS | 8096   | 8094   |
| I/O            | ROM     | 8396   | .8394  |
| ANALOG<br>AND  | ROMLESS | 8097   | 8095   |
| DIGITAL<br>I/O | ROM     | 8397   | 8395   |

Figures 2, 3 & 4 show the pinouts for the 48- and 68-pin packages. The 48-pin version is offered in Dual-In-Line package while the 68-pin version comes in a Flat-pack and a Pin Grid Array.



Figure 3. 68-Pin Package (Flat Pack-Top View)

|     |          |          |          | Pins     | Fac         | ing l    | ļΡ       |          |          |             |    |          |          | F        | Pins I   | Facir       | ig Do    | wn       |          |          |    |
|-----|----------|----------|----------|----------|-------------|----------|----------|----------|----------|-------------|----|----------|----------|----------|----------|-------------|----------|----------|----------|----------|----|
| 68  | 1        | 3<br>4   | 5<br>6   | 7<br>8   | 9<br>10     | 11<br>12 | 13<br>14 | 15<br>16 | 17<br>19 | 18          | 18 | 17<br>19 | 15<br>16 | 13<br>14 |          | 9<br>10     | 7<br>8   | 5<br>6   | 3        | 1<br>2   | 68 |
| 66  | 67       |          |          |          |             |          |          |          | 21       | 20          | 20 | 21       |          |          |          |             |          |          |          | 67       | 66 |
| 64  | 65       |          |          |          |             |          |          |          | 23       | 22          | 22 | 23       |          |          |          |             |          |          |          | 65       | 64 |
| 62  | 63       |          |          |          | CS®<br>8 Pi |          |          |          | 25       | 24          | 24 | 25       |          |          |          | CS®<br>i8 P |          |          |          | 63       | 62 |
| 60  | 61       |          | (        | GRIC     |             |          | Y        |          | 27       | 26          | 26 | 27       |          | (        |          |             | RRA      | Y        |          | 61       | 60 |
| 58  | 59       |          |          |          |             |          |          |          | 29       | 28          | 28 | 29       |          |          |          | ,           |          |          |          | 59       | 58 |
| 56  | 57       |          |          |          |             |          |          |          | 31       | <b>30</b> . | 30 | 31       |          |          |          | ,           |          |          |          | 57       | 56 |
| 54  | 55       |          |          |          |             |          |          |          | 33       | 32          | 32 | 33       |          |          |          |             |          |          |          | 55       | 54 |
| 52, | 53<br>51 | 50<br>49 | 48<br>47 | 46<br>45 | 44<br>43    | 42<br>41 | 40<br>39 | 38<br>37 | 36<br>35 | 34          | 34 | 36<br>35 | 38<br>37 | 40<br>39 | 42<br>41 | 44<br>43    | 46<br>45 | 48<br>47 | 50<br>49 | 53<br>51 | 52 |

## Figure 4. Pin Grid Array

#### Note

1. When the pin grid array package is mounted on the PC board, the pins are numbered counterclockwise as seen from the component side of the board, just like the flatpack when it's mounted in the contactor. Consequently, the PC board layout for pin grid array is compatible with the flat pack in a contactor except for the footprint size. The pin functions (from -1 to -68) on both packages are identical. Refer to Intel's Microcontroller handbook for mechanical dimensions on these packages.

| Table | 3.1  | Instruction | Summary |
|-------|------|-------------|---------|
| Iable | 3-1. | instruction | Summary |

|                | Oper- |                                                                                         |              |              |              | igs          |            |    |       |
|----------------|-------|-----------------------------------------------------------------------------------------|--------------|--------------|--------------|--------------|------------|----|-------|
| Mnemonic       | ands  | Operation (Note 1)                                                                      | Z            | N            | Ċ            | V            | VT         | ST | Notes |
| ADD/ADDB       | 2     | $D \leftarrow D + A$                                                                    | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | 1          | —  | ^     |
| ADD/ADDB       | 3 .   | $D \leftarrow B + A$                                                                    | $\checkmark$ | $\checkmark$ | 1            | $\checkmark$ | . ↑        | —  | v     |
| ADDC/ADDCB     | 2     | D ← D+A+C                                                                               | Ļ            | $\checkmark$ | $\checkmark$ | $\checkmark$ | ↑          |    |       |
| SUB/SUBB       | 2     | $D \leftarrow D - A$                                                                    | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | 1          |    |       |
| SUB/SUBB       | 3     | $D \leftarrow B - A$                                                                    | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | ↑          |    |       |
| SUBC/SUBCB     | 2     | $D \leftarrow D - A + C - 1$                                                            | 1.1          | ·            | $\checkmark$ | $\checkmark$ | 1          | _  |       |
| CMP/CMPB       | 2     | D – A                                                                                   | Ĵ.           | V.           | $\checkmark$ | $\checkmark$ | ↑          | _  | ι.    |
| MUL/MULU       | 2     | $D, D + 2 \leftarrow D * A$                                                             |              | —            |              |              | —          | ?  | 2     |
| MUL/MULU       | 3     | $D, D + 2 \leftarrow B * A$                                                             |              |              |              |              |            | ?  | 2     |
| MULB/MULUB     | 2     | $D, D + 1 \leftarrow D * A$                                                             |              |              |              | —            |            | ?  | 3     |
| MULB/MULUB     | 3     | $D, D + 1 \leftarrow B * A$                                                             |              | —            |              | —            |            | ?  | 3     |
| DIV/DIVU       | 2     | $D \leftarrow (D, D + 2)/A$<br>D + 2 remainder                                          |              | _            | _            |              | ↑          | -  | 2     |
| DIVB/DIVUB     | 2     | $D \leftarrow (D, D + 1)/A$<br>D + 1 remainder                                          |              | _            | _            |              | <b>I</b> ↑ |    | 3     |
| AND/ANDB       | 2     | $D \leftarrow D$ and A                                                                  | 1            | 1            | 0            | 0            |            | _  | , ,   |
| AND/ANDB       | 3     | $D \leftarrow B$ and A                                                                  | T.           | 1            | 0            | 0            |            |    |       |
| OR/ORB         | 2     | $D \leftarrow D \text{ or } A$                                                          | V            | V            | 0            | 0            |            |    |       |
| XOR/XORB       | 2     | $D \leftarrow D$ (excl. or) A                                                           | 1            | V            | 0            | 0            |            |    | 1     |
| LD/LDB         | 2     | D ← A                                                                                   | 1            |              |              |              | -          |    |       |
| ST/STB         | 2     | A ← D                                                                                   | -            |              |              |              |            |    | 1     |
| LDBSE          | 2     | $D \leftarrow A; D + 1 \leftarrow SIGN(A)$                                              |              |              |              |              | —          |    | 3,4   |
| LDBZE          | 2     | $D \leftarrow A; D + 1 \leftarrow 0$                                                    |              |              | -            |              | —          |    | 3,4   |
| PUSH           | · 1   | $SP \leftarrow SP - 2; (SP) = A$                                                        | -            |              |              |              |            |    |       |
| POP            | 1     | $A \leftarrow (SP); SP \leftarrow SP + 2$                                               | 1-           | -            |              |              |            |    |       |
| PUSHF          | 0     | $SP \leftarrow SP - 2; (SP) \leftarrow PSW; PSW \leftarrow 0000H \qquad I \leftarrow 0$ | 0            | 0            | 0            | 0            | 0          | 0  |       |
| POPF           | 0     | $PSW \leftarrow (SP); SP \leftarrow SP + 2 \qquad I \leftarrow $                        | 1            | 17           | 17           | 1            | 1          | 1  |       |
| SJMP           | 1     | $PC \leftarrow PC + 11$ -bit offset                                                     | 1_           |              |              |              | _          | 1  | 5     |
| LJMP           | 1     | $PC \leftarrow PC + 16$ -bit offset                                                     | 1_           |              |              | -            | _          |    | 5     |
| BR(indirect)   | 1     | $PC \leftarrow (A)$                                                                     | 1            | -            | -            | -            |            |    |       |
| SCALL          | 1     | $SP \leftarrow SP - 2; (SP) \leftarrow PC;$<br>$PC \leftarrow PC + 11$ -bit offset      | 1-           | -            | -            | -            | -          | -  | 5     |
| LCALL          | 1     | $SP \leftarrow SP - 2; (SP) \leftarrow PC;$<br>$PC \leftarrow PC + 16$ -bit offset      | 1-           | -            | -            | -            | -          | -  | 5     |
| RET            | 0     | $PC \leftarrow (SP); SP \leftarrow SP + 2$                                              | 1            | 1_           | 1            | 1            | <u> -</u>  | 1  |       |
| J(conditional) | 1     | $PC \leftarrow PC + 8$ -bit offset                                                      | 1_           | 1_           | -            |              | 1_         | 1_ | 5     |
| JC             | 1     | Jump if $C = 1$                                                                         | 1            | 1_           |              |              |            | -  | 5     |
| JNC            | 1     | $\begin{array}{c} \text{Jump if } C = 0 \end{array}$                                    | +            | 1            |              | †            | +          | 1  | 5     |

Note

1. If the mnemonic ends in "B", a byte operation is performed, otherwise a word operation is done. Operands D, B, and A must conform to the alignment rules for the required operand type. D and B are locations in the register file; A can be located anywhere in memory. 2. D, D + 2 are consecutive WORDS in memory; D is DOUBLE-WORD aligned. 3. D, D + 1 are consecutive BYTES in memory; D is WORD aligned.

,

4. Changes a byte to a word.

5. Offset is a 2's complement number.

|                  | Oper-       |                                                                      | 1            |              | Fla          | Igs          |          |              |       |
|------------------|-------------|----------------------------------------------------------------------|--------------|--------------|--------------|--------------|----------|--------------|-------|
| Mnemonic         | ands        | Operation (Note 1)                                                   | Z            | Ν            | С            | V            | VT       | ST           | Notes |
| JE               | 1           | Jump if $Z = 1$                                                      | -            |              | —            |              | —        | _            | 5     |
| JNE              | 1           | Jump  if  Z = 0                                                      | _            |              |              |              | —        |              | 5     |
| JGE              | 1           | Jump  if  N = 0                                                      |              |              | —            | _            | -        |              | 5     |
| JLT              | 1           | Jump if $N = 1$                                                      | -            | -            | -            | —            | _        |              | 5     |
| JGT              | 1           | Jump if $N = 0$ and $Z = 0$                                          |              | -            |              | —            |          |              | 5     |
| JLE              | 1.          | Jump if $N = 1$ or $Z = 1$                                           | _            | _            | _            |              |          |              | 5     |
| JH               | 1           | Jump if $C = 1$ and $Z = 0$                                          | -            | -            |              |              | -        |              | 5     |
| JNH              | 1           | Jump if $C = 0$ or $Z = 1$                                           |              | —            |              |              | _        |              | 5 '   |
| JV               | 1 ´         | Jump if $V = 1$                                                      | -            | —            | _            | _            | —        |              | 5     |
| JNV              | 1           | Jump  if  V = 0                                                      |              |              |              |              |          |              | 5     |
| JVT              | 1           | Jump if VT = 1; Clear VT                                             | -            | -            |              |              | 0        | —            | 5     |
| JNVT             | 1           | Jump if $VT = 0$ ; Clear $VT$                                        |              | —            |              |              | 0        |              | 5     |
| JST              | 1           | Jump if $ST = 1$                                                     | -            |              |              |              | _        |              | 5     |
| JNST             | 1           | Jump  if  ST = 0                                                     | -            | -            | —            | —            | _        |              | 5     |
| JBS              | 3           | Jump if Specified Bit = 1                                            | -            | -            | —            |              |          | _            | 5,6   |
| JBC              | 3           | Jump if Specified Bit $= 0$                                          | -            | -            |              |              |          |              | 5,6   |
| DJNZ             | 1           | $D \leftarrow D - 1$ ; if $D \neq 0$ then                            |              |              |              |              |          |              |       |
|                  | · · · · · · | $PC \leftarrow PC + 8$ -bit offset                                   |              | <u> </u>     | _            | _            | _        | —            | 5     |
| DEC/DECB         | 1           | $D \leftarrow D - 1$                                                 | $\bigvee$    | $\downarrow$ | $\checkmark$ | $\bigvee$    | 1        |              |       |
| NEG/NEGB         | 1           | $D \leftarrow 0 - D$                                                 | 1            | $\bigvee$    | $\checkmark$ | $\checkmark$ | ٠٢       | —            |       |
| INC/INCB         | 1           | $D \leftarrow D + 1$                                                 | $\checkmark$ | $\bigvee$    | $\checkmark$ | $\checkmark$ | <b>↑</b> | -            |       |
| EXT              | 1           | $D \leftarrow D; D + 2 \leftarrow Sign (D)$                          | $\bigvee$    | $\checkmark$ | 0            | 0            |          | -            | 2     |
| EXTB             | 1           | $D \leftarrow D; D + 1 \leftarrow Sign (D)$                          | $\bigvee$    | $\checkmark$ | 0            | 0            | —        |              | 3     |
| NOT/NOTB         | 1           | $D \leftarrow Logical Not (D)$                                       | $\checkmark$ | $\checkmark$ | 0            | 0            | _        |              | ,     |
| CLR/CLRB         | 1           | D ← 0                                                                | 1            | 0            | 0            | 0            |          |              |       |
| SHL/SHLB/SHLL    | 2           | $C \leftarrow msb lsb \leftarrow 0$                                  | $\bigvee$    | ?            | $\checkmark$ | $\checkmark$ | <b>↑</b> |              | 7     |
| SHR/SHRB/SHRL    | 2           | $0 \rightarrow \text{msb} \text{lsb} \rightarrow C$                  | $\checkmark$ | 0            | $\checkmark$ | 0            |          | $\checkmark$ | 7     |
| SHRA/SHRAB/SHRAL | 2           | $msb \rightarrow msb lsb \rightarrow C$                              | $\bigvee$    | $\checkmark$ | $\checkmark$ | 0            | —        | $\checkmark$ | 7     |
| SETC             | 0           | C ← 1                                                                |              |              | 1            | 5            |          |              |       |
| CLRC             | 0           | C ← 0                                                                | _            | _            | 0            | _            |          |              |       |
| CLRVT            | 0           | VT ← 0                                                               |              |              |              |              | 0        |              |       |
| RST              | 0           | PC ← 2080H                                                           | 0            | 0            | 0            | 0            | 0        | 0            | 8     |
| DI               | 0           | Disable All Interrupts (I ← 0)                                       | _            | _            |              |              |          |              |       |
| EI               | 0           | Enable All Interrupts (I ← 1)                                        | -            | _            | —            | _            |          |              |       |
| NOP              | 0           | $PC \leftarrow PC + 1$                                               |              | _            | _            | _            |          |              |       |
| SKIP             | 0           | $PC \leftarrow PC + 2$                                               |              | —            |              |              |          |              |       |
| NORML            | • 2         | Normalize (See sec 3.13.66)                                          | $\checkmark$ | 1            | 0            |              | '        |              | 7     |
| TRAP             | 0           | $SP \leftarrow SP - 2; (SP) \leftarrow PC; PC \leftarrow$<br>(2010H) |              |              |              |              |          |              | 9     |

## Table 3-2. Instruction Summary

Note

1. If the mnemonic ends in "B", a byte operation is performed, otherwise a word operation is done. Operands D, B and A must conform to the alignment rules for the required operand type. D and B are locations in the register file; A can be located anywhere in memory.

5. Offset is a 2's complement number.

6. Specified bit is one of the 2048 bits in the register file.
7. The "L" (Long) suffix indicates double-word operation.

8. Initiates a Reset by pulling RESET low. Software should re-initialize all the necessary registers with code starting at 2080H.

9. The assembler will not accept this mnemonic.

|          |          |            |       | ECT            |        |       |                |        | I     | NDIREC          | T⊛    |                  |        |       | D⊛               |          |                              |
|----------|----------|------------|-------|----------------|--------|-------|----------------|--------|-------|-----------------|-------|------------------|--------|-------|------------------|----------|------------------------------|
|          |          |            |       |                | IM     | ME    | DIATE          | N      | ORM   | AL              | AU    | TO-INC.          |        | SHO   | ORT              | ī        | .ONG                         |
| MNEMONIC | OPERANDS | OPCODE     | BYTES | STATE<br>TIMES | OPCODE | BYTES | STATE<br>TIMES | OPCODE | BYTES | STATE®<br>TIMES | BYTES | STATE()<br>TIMES | OPCODE | BYTES | STATE()<br>TIMES | BYTES    | STATE <sup>()</sup><br>TIMES |
|          |          |            |       |                |        | AF    | RITHME         | TIC IN | IST   | RUCTIO          | NS    |                  |        |       |                  | <b>.</b> |                              |
| ADD      | 2        | 64         | 3     | 4              | 65     | 4     | 5              | 66     | 3     | 6/11            | 3     | 7/12             | 67     | 4     | 6/11             | 5        | 7/12                         |
| ADD      | 3        | 44         | 4     | 5              | 45     | 5     | 6              | 46     | 4     | 7/12            | 4     | 8/13             | 47     | 5     | 7/12             | 6        | 8/13                         |
| ADDB     | 2        | 74         | 3     | 4              | 75     | 3     | 4              | 76     | 3     | 6/11            | 3     | 7/12             | 77     | 4     | 6/11             | 5        | 7/12                         |
| ADDB     | 3        | 54         | 4     | 5              | 55     | 4     | 5              | 56     | 4     | 7/12            | 4     | 8/13             | 57     | 5     | 7/12             | 6        | 8/13                         |
| ADDC     | 2        | A4         | 3     | 4              | A5     | 4     | 5              | A6     | 3     | 6/11            | 3     | 7/12             | A7     | 4     | 6/11             | 5        | 7/12                         |
| ADDCB    | 2        | <b>B</b> 4 | 3     | 4              | B5     | 3     | 4              | B6     | 3     | 6/11            | 3     | 7/12             | B7     | 4     | 6/11             | 5        | 7/12                         |
| SUB      | 2        | 68         | 3     | 4              | 69     | 4     | 5              | 6A     | 3     | 6/11            | 3     | 7/12             | 6B     | 4     | 6/11             | 5        | 7/12                         |
| SUB      | 3        | 48         | 4     | 5              | 49     | 5     | 6              | 4A     | 4     | 7/12            | 4     | 8/13             | 4B     | 5     | 7/12             | 6        | 8/13                         |
| SUBB     | 2        | 78         | 3     | 4              | 79     | 3     | 4              | 7A     | 3     | 6/11            | 3     | 7/12             | 7B     | 4     | 6/11             | 5        | 7/12                         |
| SUBB     | 3        | 58         | 4     | 5              | 59     | 4     | 5              | 5A     | 4     | 7/12            | 4     | 8/13             | 5B     | 5     | 7/12             | 6        | 8/13                         |
| SUBC     | 2        | A8         | 3     | 4              | A9     | 4     | 5              | AA     | 3     | 6/11            | 3     | 7/12             | AB     | 4     | 6/11             | 5        | 7/12                         |
| SUBCB    | 2        | <b>B</b> 8 | 3     | 4              | B9     | 3     | 4              | BA     | 3     | 6/11            | 3     | 7/12             | BB     | 4     | 6/11             | 5        | 7/12                         |
| СМР      | 2        | 88         | 3     | 4              | 89     | 4     | 5              | 8A     | 3     | 6/11            | 3     | 7/12             | 8B     | 4     | 6/11             | 5        | 7/12                         |
| CMPB     | 2        | 98         | 3     | 4              | 99     | 3     | 4              | 9A     | 3     | 6/11            | 3     | 7/12             | 9B     | 4     | 6/11             | 5        | 7/12                         |
|          |          |            |       |                |        |       |                |        |       |                 |       |                  |        |       |                  |          |                              |
| MULU     | 2        | 6C         | 3     | 25             | 6D     | 4     | 26             | 6E     | 3     | 27/32           | 3     | 28/33            | 6F     | 4     | 27/32            | 5        | 28/33                        |
| MULU     | 3        | 4C         | 4     | 26             | 4D     | 5     | 27             | 4E     | 4     | 28/33           | 4     | 29/34            | 4F     | 5     | 28/33            | 6        | 29/34                        |
| MULUB    | 2        | 7C         | 3     | 17             | 7D     | 3     | 17             | 7E     | 3     | 19/24           | 3     | 20/25            | 7F     | 4     | 19/24            | 5        | 20/25                        |
| MULUB    | 3        | 5C         | 4     | 18             | 5D     | 4     | 18             | 5E     | 4     | 20/25           | 4     | 21/26            | 5F     | 5     | 20/25            | 6        | 21/26                        |
| MUL      | 2        | 2          | 4     | 29             | 2      | 5     | 30             | 2      | 4     | 31/36           | 4     | 32/37            | 2      | 5     | 31/36            | 6        | 32/37                        |
| MUL      | 3        | 2          | 5     | 30             | 2      | 6     | 31             | 2      | 5     | 32/37           | 5     | 33/38            | 2      | 6     | 32/37            | 7        | 33/38                        |
| MULB     | 2        | 2          | 4     | 21             | 2      | 4     | 21             | 2      | 4     | 23/28           | 4     | 24/29            | 2      | 5     | 23/28            | 6        | 24/29                        |
| MULB     | 3        | 2          | 5     | 22             | 2      | 5     | 22             | 2      | 5     | 24/29           | 5     | 25/30            | 2      | 6     | 24/29            | 7        | 25/30                        |
| DIVU     | 2        | 8C         | 3     | 25             | 8D     | 4     | 26             | 8E     | 3     | 28/32           | 3     | 29/33            | 8F     | 4     | 28/32            | 5        | 29/33                        |
| DIVUB    | . 2      | 9C         | 3     | 17             | 9D     | 3     | 17             | 9E     | 3     | 20/24           | 3     | 21/25            | 9F     | 4     | 20/24            | 5        | 21/25                        |
| DIV.     | 2        | 2          | 4     | 29             | 2      | 5     | 30             | 2      | 4     | 32/36           | 4     | 33/37            | 2      | 5     | 32/36            | 6        | 33/37                        |
| DIVB     | 2        | 2          | 4     | 21             | 2      | 4     | 21             | 2      | 4     | 24/28           | 4     | 25/29            | 2      | 5     | 24/28            | 6        | 25/29                        |

## Table 3-3. Opcode and State Time Listing

Notes:

Dong indexed and Indirect + instructions have identical opocodes with Short indexed and Indirect modes, respectively. The second byte of instructions using any indirect or indexed addressing mode specifies the exact mode used. If the second byte is even, use Indirect or Short Indexed. If it is odd, use Indirect + or Long indexed. In all cases the second byte of the instruction always specifies an even (word) location for the address referenced.

1 Number of state times shown for internal/external operands.

1.

2 The opcodes for signed multiply and divide are the opcodes for the unsigned functions with an "FE" appended as a prefix.

|          |          | `.         | DIRE  | OT             |        |       |                |          | 11    | DIREC            | т⊛    |                  |            |       | INDEXE           | D®    |                  |
|----------|----------|------------|-------|----------------|--------|-------|----------------|----------|-------|------------------|-------|------------------|------------|-------|------------------|-------|------------------|
|          |          | L          | лке   |                | IN     | ME    | DIATE          | N        | _     | AL               |       | TO-INC.          | :          | SHC   | DRT              | L     | .ONG             |
| MNEMONIC | OPERANDS | OPCODE     | BYTES | STATE<br>TIMES | OPCODE | BYTES | STATE<br>TIMES | OPCODE   | BYTES | STATE()<br>TIMES | BYTES | STATE()<br>TIMES | OPCODE     | BYTES | STATE()<br>TIMES | BYTES | STATE()<br>TIMES |
|          |          |            |       |                |        |       | LOGICA         | L INS    | TRL   | ICTION           | S     |                  |            |       |                  |       |                  |
| AND      | 2        | 60         | 3     | 4              | 61     | 4     | 5              | 62       | 3     | 6/11             | 3     | 7/12             | 63         | 4     | 6/11             | 5     | 7/12             |
| AND      | 3        | 40         | 4     | 5              | 41     | 5     | 6              | 42       | 4     | 7/12             | 4     | 8/13             | 43         | 5     | 7/12             | 6     | 8/13             |
| ANDB     | 2        | 70         | 3     | 4              | 71     | 3     | 4              | 72       | 3     | 6/11             | 3     | 7/12             | 73         | 4     | 6/11             | 5     | 7/12             |
| ANDB     | 3        | 50         | 4     | 5              | 51     | 4     | 5              | 52       | 4     | 7/12             | 4     | 8/13             | 53         | 5     | 7/12             | 6     | .8/13            |
| OR       | 2        | 80         | 3     | 4              | 81     | 4.    | 5              | 82       | 3     | 6/11             | 3     | 7/12             | 83         | 4     | 6/11             | 5     | 7/12             |
| ORB      | 2        | 90         | 3     | 4              | 91     | 3     | 4              | 92       | 3     | 6/11             | 3     | 7/12             | 93         | 4     | 6/11             | 5     | 7/12             |
| XOR      | 2        | 84         | 3     | 4              | 85     | 4     | 5              | 86       | 3     | 6/11             | 3     | 7/12             | 87         | 4     | 6/11             | 5     | 7/12             |
| XORB     | 2        | 94         | 3     | 4              | 95     | 3     | 4              | 96       | 3     | 6/11             | 3     | 7/12             | 97         | 4     | 6/11             | 5     | 7/12             |
|          |          |            |       |                | I      | DAT   | A TRAN         | SFER     | INS   | STRUCT           | ION   | S                |            |       |                  |       |                  |
| LD       | 2        | A0         | 3     | 4              | A1     | · 4,  | 5              | A2       | 3     | 6/11             | 3     | 7/12             | A3         | 4     | 6/11             | 5     | 7/12             |
| LDB      | 2        | <b>B</b> 0 | 3     | 4              | B1     | 3     | 4              | B2       | 3     | 6/11             | 3     | 7/12             | <b>B</b> 3 | 4     | 6/11             | 5     | 7/12             |
| ST       | 2        | C0         | 3     | 4              | _      |       |                | C2       | 3     | 7/11             | 3     | 8/12             | C3         | 4     | 7/11             | 5     | 8/12             |
| STB      | 2        | C4         | 3     | . 4            |        |       |                | C6       | 3     | 7/11             | 3     | 8/12             | C7         | 4     | 7/11             | 5     | 8/12             |
| LDBSE    | 2        | BC         | 3     | 4              | BD     | • 3   | 4              | BE       | 3     | 6/11             | 3     | 7/12             | BF         | 4     | 6/11             | 5     | 7/12             |
| LDBZE    | 2        | AC         | 3     | 4              | AD     | 3     | 4              | AE       | 3     | 6/11             | 3     | 7/12             | AF         | 4     | 6/11             | 5     | 7/12             |
|          |          |            |       |                | S      | TAC   | CK OPE         | RATIO    | NS    | (interna         | l st  | ack)             |            |       |                  |       |                  |
| PUSH     | 1        | C8         | 2     | 8              | C9     | 3     | 8-             | CA       | 2     | 11/15            | 2     | 12/16            | CB         | 3     | 11/15            | 4     | 12/16            |
| POP      | 1        | CC         | 2     | ´ 12           | —      |       |                | CE       | 2     | 14/18            | 2     | 14/18            | CF         | 3     | 14/18            | 4     | 14/18            |
| PUSHF    | 0        | F2         | 1     | 8              |        |       |                |          |       |                  |       |                  |            |       |                  |       |                  |
| POPF     | 0        | F3         | 1     | 9              |        | .,    | 4              |          |       |                  |       |                  |            |       |                  |       |                  |
|          |          | •          |       |                | S      | TA    | СК ОРЕ         | RATIC    | ÍNS   | (extern          | al s  | tack)            |            |       |                  |       |                  |
| PUSH     | 1        | C8         | 2     | 12             | C9     | 3     | 12             | CA       | 2     | 15/19            | 2     | 16/20            | CB         | 3     | 15/19            | 4     | 16/20            |
| POP      | 1        | CC         | 2     | 14             |        | —     |                | CE       | 2     | 16/20            | 2     | 16/20            | CF         | 3     | 16/20            | 4     | 16/20            |
| PUSHF    | 0        | F2         | 1     | 12             |        |       |                | <u>`</u> |       |                  |       |                  |            |       |                  |       |                  |
| POPF     | 0        | F3         | 1     | 13             |        |       |                |          |       |                  |       |                  |            |       |                  |       |                  |
| r        |          |            |       |                |        |       |                |          |       |                  |       |                  |            |       |                  |       |                  |

| Table 3-3. Continu | led |
|--------------------|-----|
|--------------------|-----|

|          | •      |       | JUMPS A | ND CALLS |        |       |        |
|----------|--------|-------|---------|----------|--------|-------|--------|
| MNEMONIC | OPCODE | BYTES | STATES  | MNEMONIC | OPCODE | BYTES | STATES |
| LJMP     | E7     | 3     | 8       | LCALL    | EF     | 3     | 13/16⑤ |
| SJMP     | 20-27④ | 2     | 8       | SCALL    | 28-2F④ | 2     | 13/16⑤ |
| BR[]     | E3     | 2     | 8       | RET      | F0     | - 1   | 12/16⑤ |
| Notos    |        |       |         | TRAP3    | F7     | 1 .   |        |

#### Notes:

① Number of state times shown for internal/external operands.

3 The assembler does not accept this mnemonic.

The least significant 3 bits of the opcode are concatenated with the following 8 bits to form an 11-bit, 2's complement, offset for the relative call or jump.

5 State times for stack located internal/external.

<sup>®</sup> The assembler uses the generic jump mnemonic (BR) to generate this instruction.

| All co   | nditional jumps | are 2 byte instruc | tions. They req | uire 8 state times | if the jump is | aken, 4 if it is no | et.    |
|----------|-----------------|--------------------|-----------------|--------------------|----------------|---------------------|--------|
| MNEMONIC | OPCODE          | MNEMONIC           | OPCODE          | MNEMONIC           | OPCODE         | MNEMONIC            | OPCODE |
| JC       | DB              | JE                 | DF              | JGE                | D6             | JGT                 | D2     |
| JNC      | D3              | JNE                | Ď7              | JLT                | DE             | JLE                 | DA     |
| JH ,     | D9              | JV .               | DD              | JVT                | DC             | JST                 | D8 `   |
| JNH      | D1              | JNV                | D5              | JNVT               | D4             | JNST                | D0     |

## Table 3-4. CONDITIONAL JUMPS

## JUMP ON BIT CLEAR OR BIT SET

| T        | hese instruction | ns are 3-byte in | structions. The | y require 9 stat | e times if the j | ump is taken, | 5 if it is not |    |
|----------|------------------|------------------|-----------------|------------------|------------------|---------------|----------------|----|
|          |                  |                  |                 | BIT NU           | MBER             |               |                |    |
| MNEMONIC | 0                | 1                | 2               | 3                | 4                | 5             | 6 '            | 7  |
| JBC      | 30               | 31               | 32              | 33               | 34               | 35            | 36             | 37 |
| JBS      | 38               | 39               | 3A              | 3B               | 3C               | 3D            | 3E             | 3F |

|      |            | LOOP     | CONTROL                           |
|------|------------|----------|-----------------------------------|
| DINZ | OPCODE EO: | 3 BYTES: | 5/9 STATE TIMES (NOT TAKEN/TAKEN) |

| SINGLE REGISTER INSTRUCTIONS |        |       |        |          |        |       |        |
|------------------------------|--------|-------|--------|----------|--------|-------|--------|
| MNEMONIC                     | OPCODE | BYTES | STATES | MNEMONIC | OPCODE | BYTES | STATES |
| DEC                          | • 05   | 2     | 4      | EXT      | 06     | 2     | 4      |
| DECB                         | 15     | 2     | 4      | EXTB     | 16     | 2     | 4      |
| NEG                          | 03     | 2     | 4      | NOT      | 02     | 2     | 4      |
| NEGB                         | 13     | 2     | 4      | NOTB     | 12     | 2     | 4      |
| INC                          | 07     | 2     | 4      | CLR      | 01     | 2     | 4      |
| INCB                         | 17     | 2     | 4      | CLRB ,   | 11     | 2     | 4      |

## SHIFT INSTRUCTIONS

| INSTR    | wo | RD | INSTR    | BY | TE | INSTR    | DBL | WD |                              |
|----------|----|----|----------|----|----|----------|-----|----|------------------------------|
| MNEMONIC | OP | В  | MNEMONIC | OP | В  | MNEMONIC | OP  | В  | STATE TIMES                  |
| SHL      | 09 | 3  | SHLB     | 19 | 3  | SHLL     | 0D  | 3  | 7 + 1 PER SHIFT <sup>®</sup> |
| SHR      | 08 | 3  | SHRB     | 18 | 3  | SHRL     | 0C  | 3  | 7 + 1 PER SHIFT 7            |
| SHRA     | 0A | 3  | SHRAB    | 1A | 3  | SHRAL    | 0E  | 3  | 7 + 1 PER SHIFT              |

|          | SPECIAL CONTROL INSTRUCTIONS |       |        |          |        |       |        |
|----------|------------------------------|-------|--------|----------|--------|-------|--------|
| MNEMONIC | OPCODE                       | BYTES | STATES | MNEMONIC | OPCODE | BYTES | STATES |
| SETC     | F9                           | 1     | 4      | DI       | FA     | 1     | . 4    |
| CLRC     | F8                           | 1     | 4      | EI .     | FB     | 1     | 4      |
| CLRVT    | FC                           | 1 -   | 4      | NOP      | FD     | 1     | 4      |
| RST      | FF                           | 1     | 16     | SKIP     | 00     | 2     | 4      |

## SPECIAL CONTROL INSTRUCTIONS

## **NORMALIZE** 11 + 1 PER SHIFT

#### Notes:

NORML

(© This instruction takes 2 states to pull RST low, then holds it low for 2 states to initiate a reset. The reset takes 12 states, at which time the program restarts at location 2080H.

D Execution will take at least 8 states, even for 0 shift.

0F

3

## **ELECTRICAL CHARACTERISTICS**

## ABSOLUTE MAXIMUM RATINGS

 \*NOTICE Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied Exposure to absolute maximum rating conditions for extended periods may affect device reliability

## **OPERATING CONDITIONS**

| Symbol | Parameter                      | Min              | Max              | Units  |
|--------|--------------------------------|------------------|------------------|--------|
| ТА     | Ambient Temperature Under Bias | · 0              | +70              | С      |
| VCC    | Digital Supply Voltage         | 4 50             | 5 50             | V      |
| VREF   | Analog Supply Voltage          | 4 5<br>VCC - 0.3 | 5 5<br>VCC + 0 3 | v<br>v |
| fOSC   | Oscillator Frequency           | 60               | 12               | MHz    |
| VPD    | Power-Down Supply Voltage      | 4 50             | 5 50             | V      |

VBB should be connected to ANGND through a 0.01 µF capacitor ANGND and VSS should be nominally at the same potential

## **DC CHARACTERISTICS**

| Symbol           | Parameter                                                          | Min  | Max     | Units | Test Conditions                     |
|------------------|--------------------------------------------------------------------|------|---------|-------|-------------------------------------|
| VIL              | Input Low Voltage                                                  | -0.3 | +0.8    | v     |                                     |
| VIH              | Input High Voltage (Except RESET)                                  | 2.0  | VCC+0.5 | v     |                                     |
| VIH1             | Input High Voltage, RESET Rising                                   | 2.4  | VCC+0.5 | v     |                                     |
| VIH2             | Input High Voltage, RESET Falling                                  | 2.0  | VCC+0.5 | v     | 4                                   |
| VOL              | Output Low Voltage                                                 |      | 0.45    | v     | See Note 1.                         |
| VOH              | Output High Voltage                                                | 2.4  |         | v     | See Note 2.                         |
| ICC              | VCC Supply Current                                                 |      | 200     | mA    | All outputs disconnected.           |
| IPD <sup>7</sup> | VPD Supply Current                                                 | ,    | 1       | mA    | Normal operation<br>and Power-Down. |
| IREF             | VREF Supply Current                                                |      | 15      | mA    |                                     |
| ILI              | Input Leakage Current to all pins of HSI, P0, P3, P4, and to P2.1. |      | ±10     | μA    | Vin = 0 to VCC<br>See Note 3        |
| IIH              | Input High Current to EA                                           |      | 100     | μA    | VIH=2.4V                            |
| IIL              | Input Low Current to all pins of P1, and to P2.6, P2.7.            |      | - 100   | μΑ    | VIL = 0.45V                         |
| IIL1             | Input Low Current to RESET                                         |      | -2      | mA    | VIL = 0.45V                         |
| IIL2             | Input Low Current P2.2, P2.3, P2.4, READY                          |      | - 50    | μA    | VIL = 0.45V                         |
| Cs               | Pin Capacitance (Any Pin to VSS)                                   |      | 10      | pF    | fTEST = 1MHz                        |

#### NOTES:

1 IOL = 0.36 mA for all pins of P1, for P2 6 and P2 7, and for all pins of P3 and P4 when used as ports

IOL = 2 0 mA for TXD, RXD (in serial port mode 0), PWM, CLKOUT, ALE, BHE, RD, WR, and all pins of HSO and P3 and P4 when used as external memory bus (AD0-AD15)

2 IOH =  $-20 \ \mu$ A for all pins of P1, for P2 6 ad P2 7

IOH = - 200  $\mu$ A for TXD, RXD (in serial port mode 0), PWM, CLKOUT, ALE, BHE, WR, and all pins of HSO and P3 and P4 when used as external memory bus (AD0-AD15)

P3 and P4, when used as ports, have open-drain outputs

3 Analog Conversion not in process

Test Con

## A/D CONVERTER SPECIFICATIONS

A/D Converter operation is verified only on the 8097, 8397, 8095, 8395.

The absolute conversion accuracy is dependent on the accuracy of VREF. The specifications given below assume adherence to the Operating Conditions section of these data sheets. Testing is done at VREF = 5.120 volts.

| AC CHARACTERISTICS |
|--------------------|
|--------------------|

 Resolution
 ± 0.001 VREF

 Accuracy
 ± 0.004 VREF

 Differential nonlinearity
 ± 0.002 VREF max

 Integral nonlinearity
 ± 0.004 VREF max

 Channel-to-chanel matching
 ± 1 LSB

 Crosstalk (DC to 100kHz)
 - 60dB max

| nditions: | Load capacitance on output pins = 80pf                          |
|-----------|-----------------------------------------------------------------|
|           | Oscillator Frequency = 12.00 MHz                                |
|           | 4.50 Volts , = VCC , = 5.50 Volts; 0 C , = Temperature , = 70 C |

Timing Requirements (other system components must meet these specs)

| Symbol | Parameter                            | Min   | Max            | Units |
|--------|--------------------------------------|-------|----------------|-------|
| TCLYX  | READY Hold after CLKOUT falling edge | 0 (1) |                | nsec  |
| TLLYV  | End of ALE to READY Setup            |       | 2Tosc - 60     | nsec  |
| TLLYH  | End of ALE to READY high             |       | 4Tosc - 60 (2) | nsec  |
| TYLYH  | Non-ready time                       |       | 1000           | nsec  |
| TAVDV  | Address Valid to Input Data Valid    |       | 5Tosc - 80     | nsec  |
| TRLDV  | RD/ Active to Input Data Valid       | ,     | 3Tosc - 60     | nsec  |
| TRXDZ  | End of RD/ to Input Data Float       | Q     | Tosc-20        | nsec  |

Timing Responses (MCS®-96 parts meet these specs)

| Symbol | Parameter                         | Min        | Max                                   | Units |
|--------|-----------------------------------|------------|---------------------------------------|-------|
| FXTAL  | Oscillator Frequency              | 6.00       | 12.00                                 | MHz   |
| Tosc   | Oscillator Period                 | 83         | 166                                   | nsec  |
| TCHCH  | CLKOUT Period                     | 3Tosc (3)  | 3Tosc (3)                             | nsec  |
| TCHCL  | CLKOUT High Time                  | Tosc – 20  | Tosc+20                               | nsec  |
| TCLLH  | CLKOUT Low to ALE High            | -5         | 20                                    | nsec  |
| TLLCH  | ALE Low to CLKOUT High            | Tosc-20    | Tosc+40                               | nsec  |
| TLHLL  | ALE Pulse Width                   | Tosc – 25  | Tosc+15                               | nsec  |
| TAVLL  | Address Setup to End of ALE       | Tosc – 50  |                                       | nsec  |
| TLLRL  | End of ALE to RD/ or WR/ active   | Tosc-20    |                                       | nsec  |
| TLLAX  | Address hold after End of ALE     | Tosc-20    |                                       | nsec  |
| TWLWH  | WR/ Pulse Width                   | 2Tosc - 35 |                                       | nsec  |
| ΤΩνωχ  | Output Data Setup to End of WR/   | 2Tosc - 60 |                                       | nsec  |
| TWXQX  | Output Data Hold after End of WR/ | Tosc-25    |                                       | nsec  |
| TWXLH  | End of WR/ to next ALE            | 2Tosc - 30 |                                       | nsec  |
| TRLRH  | RD/ Pulse Width                   | 3Tosc-30   |                                       | nsec  |
| TRHLH  | End of RD/ to next ALE            | Tosc-25    | · · · · · · · · · · · · · · · · · · · | nsec  |

#### NOTES:

1. If the 48-pin part is being used then this timing can be generated by assuming that the CLKOUT falling edge has occurred at 2Tosc+55 (TLLCH(max) + TCHCL(max)) after the falling edge of ALE.

2. If more than one wait state is desired, add 3Tosc for each additional wait state.

3. CLKOUT is directly generated as a divide by 3 of the oscillator. The period will be 3Tosc ± 5 nsec if Tosc is constant and the rise and fall times on XTAL 1 are less than 10 nsec.

intel®



8096

5-11

# MCS<sup>®</sup>-96 Article Reprint

6

|           | <i>i</i> |   | ·  |   |
|-----------|----------|---|----|---|
|           |          |   | 1  |   |
|           |          |   |    |   |
| -         |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           | ,        |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           | -        |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           | κ.       |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          | , |    |   |
|           |          |   |    |   |
|           | ,        |   |    |   |
|           |          |   |    |   |
|           |          |   |    | , |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    | - |
|           |          |   | ×. |   |
|           |          |   |    |   |
| -         |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
|           |          |   |    |   |
| · · · · · |          |   |    |   |

.

. . .



AR-321

February 1984



Reprinted from DIGITAL DESIGN © February 1984, Morgan-Grampian Publishing Company

Order Number. 231040-001

## High-Performance Event Interface For A Microcomputer

As silicon technology advances to provide denser geometries, timer structures have become more elegant and powerful.

Microcontrollers are microprocessors specially configured to monitor and control mechanisms and processes rather than manipulate data. The systems they are imbedded in are often called real time control systems; microcontrollers always incorporate some form of timer structure to allow synchronization with the outside or 'real' world. As silicon technology advances to provide denser geometries, these structures have become more elegant and powerful.

This trend can be seen in the Intel 8048, the Motorola 6801, and the Intel 8051 which were introduced at approximately two and a half year intervals starting in 1976. The 8048 has a single 8-bit timer; the 6801 has a 16-bit timer, and the 8051 has two 16-bit timers. The new 16-bit microcontroller from Intel, the 8096, has an independent High Speed I/O subsystem which provides the functionality of four to eight 16-bit timers. While this subsystem is designed to provide an integrated approach to measuring and controlling time modulated signals, it is easier to describe as separate input and output units.

### **High Speed Input Unit**

The purpose of the High Speed Input unit is to allow the measurement of the periods of incoming pulse or frequency modulated inputs with high resolution and minimal software overhead. A block diagram of the hardware used to accomplish this goal is shown in **Figure 1**. The heart of this unit is a programmable change detector which monitors the four 1/O pins of the 8096 which are designated as "High Speed Inputs" (HSI.0-HSI.3).

The operating mode of the change detector is controlled by a byte register which can be written as register 3 of the onboard register file. This register has the predeclared name HSL\_MODE in the 8096 assembly language. The register contains a separate field for each of the four HSI pins. There are two bits in each of these fields and they are encoded as follows:

- 00 Capture every eighth positive transition
- 01 Capture positive transitions only
- 10 Capture negative transitions only
- 11 Capture both positive and negative transitions

It is also possible to disconnect one or more of the HSI pins from the change detector by writing into one of the two I/O control registers. This register, known to the assembly language as IOCO is addressed as register 15H of the on-board register file. HSI pins that



Figure 1: Diagram shows the High-Speed Input Unit which is used to measure incoming pulse or frequency modulated inputs.



Figure 2: Block diagram of the High Speed Output hardware.

have to be disconnected from the change detector are available for use as normal digital inputs and two of them (HSI.2 and HSI.3) can be used by the High Speed Output unit.

When a change (or changes) of the required type occurs, four bits of change information, along with the current value of TIMER1, are loaded into a FIFO (first-in, first-out memory). Each set bit in this field indicates that a change occurred on the corresponding input pin.

The time reference for the HSI unit is TIMER1, a sixteen bit counter which is incremented every eight state times by the CPU clock. With a 12 MHz crystal this gives a resolution of 2.0 microseconds. TIMER1 is cleared by reset and then starts incrementing. It cannot be written to by the software but can be read as a sixteen bit word at any time. When its count goes from all ones to zero a flag is set and an interrupt generated. The software can use this flag and/or interrupt to extend the measurement range of the HSI unit.

The FIFO that is used to store the change and time information is eight levels deep (including the holding register) and 20 bits wide. The oldest entry in the FIFO is placed in the holding register. When the holding register is read then the next oldest entry will drop into it and another cell of the FIFO will become available for input data. An interrupt can be generated either when one or more entries exist in the FIFO or when seven or more entries exist. The choice is made by the software by setting a bit in I/O control register 1 (IOC1).

The 8096 only supports byte and word operands for most operations. The holding register is 20 bits wide hence the holding register is broken down into two registers. The 16-bit time field is read as a word register and is known as HSL\_TIME to the assembler. The change information is read as an eight-bit byte known as HSL\_STATUS. The four extra bits in this byte are used to report the state of the HSI pins at the time the register is read (not at the time the reported change occurred). The holding register is cleared after the HSL TIME is read so that HSLSTATUS can be read at any time to monitor the actual state of the HSI pins without losing data from the FIFO.

#### **High Speed Output Unit**

The High Speed Output unit serves the output requirements of the system in the same way as the HSI unit serves the input. It allows the generation of pulse and frequency modulated signals with high resolution and minimal software overhead. It can also be used to generate time delays for the operating software and to trigger the A/ID converter at precise time intervals for signal processing algorithms. A block diagram of the HSO hardware is shown in **Figure 2**.

The HSO unit is driven by a Content Addressable Memory (CAM) which is 23 bits wide and eight levels deep The (continued on page 120)



Figure 3: Diagram shows format of Command Tag. The lower four bits specify the basic operation and the remaining three bits are options to the basic operation.



Figure 4 Figure shows the clock and reset options of TIMER2 used by the High Speed Output unit

23 bits are broken into a 16 bit time tag and a seven bit command tag. The command tag tells it when to do it. The format of the command tag is shown in **Figure 3.** The lower four bits of the tag specify the basic operation and the remaining three bits specify options to the basic operation. The basic operations supported are:

- Write to one of the six pins controlled by the HSO unit (HSO.0-HSO.5).
- Write to HSO.0 and HSO.1 with a single command.
- Write to HSO.2 and HSO.3 with a single command.
- Set one of four software timer flags.
- Reset Timer 2.
- Trigger an A/D conversion.

If an operation on an HSO pin is specified, then the value to be written to the pin is taken from bit five of the command tag. Note that if two HSO pins are to be modified with the same command then both will be set to the same state. Bit five of the command tag is ignored for the other HSO operations. Bit four of the command tag enables the generation of an interrupt which occurs when the command is executed.

There are two interrupts generated by the HSO unit. One of them indicates that an operation involving a HSO pin has occurred, and the other is used to signal that one of the internal HSO functions (such as setting a software timer flag) has been completed. Bit six of the command tag controls which one of the two timers available to the HSO unit will be used as a time base for the command. If bit six is a zero then the command tag will be executed when TIMER1 becomes equal to the time tag stored in the CAM. If bit six is a one then the command tag is executed based on TIMER2. In either case the command is flushed from the CAM as soon as it is executed.

One of the timers (TIMER1) used by the HSO unit is the same timer that is used by the HSI unit. The other (TIMER2) is used only by the HSO unit. TIMER2 allows HSO events to be generated on a time base that is different from that of the CPU. Like TIMER1 it is a 16 bit counter that can be read but not written to by the software. It also has an overflow flag and interrupt to indicate that it has incremented from a source external to the 8096 and can be reset by a number of paths in addition to system reset. The options available are shown in **Figure 4**.

The clock input can come either from a specific pin designated as the T2CLK or it can come from HSI.1 depending on the state of IOC0.7 which is set by the software. In either case the counter is incremented on both edges of the clock signal. TIMER2 can be reset by a specific pin designated as T2RST or it can be reset by HSO.0. It is also possible for the software to lock out external sources of reset (by clearing IOC0.3) and/or reset TIMER2 directly (via IOC0.1) or indirectly via a command stored in the CAM. Note that this last possibility allows TIMER2 to be configured as a modulation counter since the software can command the HSO unit to clear TIMER2 when it reaches a given value.

Commands are loaded into the CAM from the 23 bit wide holding register which, like the holding register for the HSI unit, is actually made up of a byte register (HSO\_COMMAND) which stores the command tag and a word register is considered loaded after HSO\_ TIME is loaded so the software must always load HSO\_COMMAND and then load HSO\_TIME.

The software must also ensure that the loading of the two registers is not interrupted by an interrupt service routine which uses the HSO unit. If such an interrupt occurs immediately following the loading of HSO\_COMMAND then the subsequent loading of HSO\_TIME will reload the command tag written into the holding register by the interrupt service routine. The safest procedure is to lockout interrupts during the loading of the holding registers, however a careful examination of the control flow of the program may show this to be unnecessary.

If there is an empty cell in the CAM when the holding register is loaded then the command and its time tag will be loaded into the CAM within seven state times (1.75 microseconds at 12 MHz). It is important to note that a command will not execute from the holding register, it must be loaded into the CAM. If the CAM is full then the command will remain in the holding register until one of the commands already in the CAM is executed and flushed.

Two status flags are available to help the software manage the CAM. One of them indicates that the holding register is full or the CAM is full. Once a command is loaded into the CAM it cannot be read or overwritten, it can only be flushed after it is executed. To support those situations where the software wishes to cancel a command after it has been loaded, the HSO unit is configured so that two operations to a HSO pin which cancel each other will not effect the setting of the pin if they are executed with identical time tags.

#### **Application Example**

Since the 8096 incorporates a full duplex asynchronous serial port in its hardware it may seem strange that one would want to implement a software driven serial port using the high speed I/O features. There are, however, many useful configurations of microcontroller systems which in fact require more than a single serial port. An obvious example would be a network of 8096 controllers which use the hardware serial port for interprocessor communications. One (or more) of these controllers might also be required to communicate with a CRT terminal used to supervise or monitor





The serial output process is simpler than the receive process because there is no need to synchronize with the outside world.

the system. Another example would be a simple CRT terminal design based on an 8096 which needs one serial port for communication and another for driving a slave printer. It may also be true that this is, in fact, a strange requirement. In any case it is an excellent example to show how the high speed I/O features of the 8096 might be used.

The objective is to add a software driven asynchronous serial port to the 8096 that provides full duplex seriai communication at 2400 baud. A standard frame consisting of a START bit, eight data bits and a STOP bit will be assumed. A high speed input pin (HSI.0) will be used for received data and a high speed output pin (HSI.0) for transmit data.

A standard 10-bit asynchronous frame is shown in **Figure 5**. The figure also shows the points in time where the receive process must sample the incoming data stream and take some action. The first timing point (labeled T-0) is the leading edge of the start bit, the accurate sensing of this edge is important because all subsequent sample times are relative to this edge. This event also places the highest burden on the sampling algorithm because it can occur at any point in time. The rest of the sampling events occur at some multiple of one-half a bit period relative to the edge of the start bit. The diagram uses the symbol B to represent a bit period.

At the second sample, which occurs half way through the start bit, the data must be checked to make sure it is still a SPACE. If it is not, a noise pulse has caused a false start and the receive process must be reinitialized. The next eight samples are used to shift in the serial data stream. The last sample, which occurs 19 one-half bit times after the leading edge of the start bit, is used to verify that the stop bit is valid (i.e. it is in the MARK state). If it is not the a framing error must be reported since it is likely that the receiver is not properly synchronized with the transmitter.

The HSI unit is an ideal mechanism for detecting the leading edge of the start bit. All that needs to be done is to set the mode register to detect negative going edges on HSI.0.

The software timer interrupt service routine implements a simple state machine based on the variable count. The routine also arranges for the next sample by issuing a command to the HSO unit to generate another software timer interrupt at the appropriate time. This is done in all states unless the reception of the character is complete or a false START bit has been detected. Under these conditions the receive process must be reinitialized by enabling HSI.0 into the event FIFO (by setting IOCO.0) instead of retriggering the software timer.

The serial output process is simpler than the receive process because there is no need to synchronize with the outside world. A transmission can be started at any time by setting the TxD line to a space for one bit time to form the START bit. Following the START bit are the eight data bits and the STOP bit. The HSO interrupt service routine can be used to transmit the data and the stop bit but the transmit process must be initialized.

The only real complication in the HSO interrupt service routine is that there are no flags available in the 8096 which indicate which of the HSO outputs caused the interrupt. In many systems this does not represent a problem because the HSO unit can be treated as a write only device. It is given commands which are to be executed at the proper time but no feedback is required to indicate when the proper time has been reached. In this case, however, the feedback is required since the CAM isn't deep enough to hold all of the transitions required for a character. Even if it were big enough it is unlikely that so many CAM locations would be dedicated to serial output. П et an anna an Arran Arran an Arr Arran an Arr

> на сула 14 19 — 19 — 14 — 14 14

· · · ·

. . . . می میشند است. ایکی میکند است از این میکند ا ایکی میکند ایکی میکو ایکی میکو ایکی میکو ایکی میکو ایکی میکو ایکی میکو ایکی میگو ایکی ایکی ایکی

• • •

## MCS<sup>®</sup>-51 Architecture



. . . .

## CHAPTER 7 MCS®-51 ARCHITECTURE

## 7.0 INTRODUCTION

The MCS<sup>®</sup>-51 family of 8-bit microcontrollers consists of the devices listed in Table 1, all of which are based on the MCS-51 architecture shown in Figure 7-1. The original 8051 was built in HMOS I technology. The HMOS II version, which is the device currently in production, is called the 8051AH. The term "8051," however, is still often used to generically refer to all of the MCS-51 family members. This is the case throughout this manual, except where specifically stated otherwise. Also for brevity, the term "8052" is used to refer to both the 8052 and the 8032, unless otherwise noted.



Figure 7-1. MCS-51 Architectural Block Diagram

The newest MCS-51 members, the 8032 and 8052, have more on-chip memory and an additional 16-bit timer/ counter. The new timer can be used as a timer, a counter, or to generate baud rates for the serial port. As a timer/ counter, it operates in either a 16-bit auto-reload mode or a 16-bit 'capture' mode. This new feature is described in Section 7.6.2.

Pinouts are shown in the individual data sheets and on the inside back cover of this handbook.

| PART  | TECHNOLOGY | PROGRAM    | ON-CHIP<br>DATA<br>MEMORY |
|-------|------------|------------|---------------------------|
| 8051  | HMOS       | 4K — ROM   | 128                       |
| 8031  | HMOS       | NONE       | 128                       |
| 8751H | HMOS I     | 4K — EPROM | 128                       |
| 80C51 | CHMOS      | 4K — ROM   | 128                       |
| 80C31 | CHMOS      | NONE       | 128                       |
| 8052  | HMOS       | 8K — ROM   | 256                       |
| 8032  | HMOS       | NONE       | 256                       |

Table 1. MCS®-51 Family Members

The major MCS®-51 features are:

- 8-Bit CPU
- On-Chip oscillator and clock circuitry
- 32 I/O lines
- 64K address space for external data memory
- 64K address space for external program memory
- Two 16-bit timer/counters (three on 8032/8052)
- A five-source interrupt structure (six sources on 8032/8052) with two priority levels
- Full duplex serial port
- Boolean processor

#### 7.1 MEMORY ORGANIZATION

The 8051 has separate address spaces for Program Memory and Data Memory. The Program Memory can be up to 64K bytes long. The lower 4K (8K for 8052) may reside on-chip. The Data Memory can consist of up to 64K bytes of off-chip RAM, in addition to which it includes 128 bytes of on-chip RAM (256 bytes for the 8052), plus a number of "SFRs" (Special Function Registers) as listed below.

| Symbol | Name                                         | Address    |
|--------|----------------------------------------------|------------|
| *ACC   | Accumulator                                  | 0E0H       |
| *В     | B Register                                   | 0F0H       |
| *PSW   | Program Status Word                          | 0D0H       |
| SP     | Stack Pointer                                | 81H        |
| DPTR   | Data Pointer (con-<br>sisting of DPH and DPL | 83H<br>82H |
| *P0    | Port 0                                       | 80H        |
| *P1    | Port 1                                       | 90H        |

| Symbol  | Name                                            | Address    |
|---------|-------------------------------------------------|------------|
| *P2     | Port 2                                          | 0A0H       |
| *P3     | Port 3                                          | 0B0H       |
| *IP     | Interrupt Priority Control                      | 0B8H       |
| tE.     | Interrupt Enable Control                        | 0A8H       |
| TMOD    | Timer/Counter Mode                              |            |
|         | Control                                         | 89H        |
| *TCON   | Timer/Counter Control                           | 88H        |
| +*T2CON | Timer/Counter 2 Control                         | 0C8H       |
| TH0     | Timer/Counter 0<br>(high byte)                  | 8CH        |
| TL0     | Timer/Counter 0<br>(low byte)                   | 8AH        |
| TH1     | Timer/Counter 1<br>(high byte)                  | 8DH        |
| TL1     | Timer/Counter 1<br>(low byte)                   | 8BH        |
| + TH2   | Timer/Counter 2<br>(high byte)                  | 0CDH       |
| + TL2   | Timer/Counter 2<br>(low byte)                   | OCCH       |
| +RCAP2H | Timer/Counter 2 Capture<br>Register (high byte) | 0CBH       |
| +RCAP2L | Timer/Counter 2 Capture<br>Register (low byte)  | 0CAH       |
| *SCON   | Serial Control                                  | 98H        |
| SBUF    | Serial Data Buff                                | 99H        |
| PCON    | Power Control                                   | 99H<br>87H |
| FUUN    |                                                 | 0/11       |

The SFRs marked with an asterisk (\*) are both bit- and byte-addressable. The SFRs marked with a plus sign (+) are present in the 8052 only. The functions of the SFRs are described as follows.

#### ACCUMULATOR

ACC is the Accumulator register. The mnemonics for accumulator-specific instructions, however, refer to the accumulator simply as A.

#### **B REGISTER**

The B register is used during multiply and divide operations. For other instructions it can be treated as another scratch pad register.

#### **PROGRAM STATUS WORD**

The PSW register contains program status information as detailed in Figure 7-2.

#### STACK POINTER

The Stack Pointer register is 8 bits wide. It is incremented before data is stored during PUSH and CALL executions. While the stack may reside anywhere in on-chip RAM,

the Stack Pointer is initialized to 07H after a reset. This causes the stack to begin at location 08H.

#### DATA POINTER

The Data Pointer (DPTR) consists of a high byte (DPH) and a low byte (DPL). Its intended function is to hold a 16-bit address. It may be manipulated as a 16-bit register or as two independent 8-bit registers.

## PORTS 0 to 3

P0, P1, P2 and P3 are the SFR latches of Ports 0, 1, 2 and 3, respectively.

## SERIAL DATA BUFFER

The Serial Data Buffer is actually two separate registers, a transmit buffer and a receive buffer register. When data is moved to SBUF, it goes to the transmit buffer where it is held for serial transmission. (Moving a byte to SBUF is what initiates the transmission.) When data is moved from SBUF, it comes from the receive buffer.

## TIMER REGISTERS

Register pairs (TH0, TL0), (TH1, TL1), and (TH2, TL2) are the 16-bit counting registers for Timer/Counters 0, 1, and 2, respectively.

## **CAPTURE REGISTERS**

The register pair (RCAP2H, RCAP2L) are the capture registers for the Timer 2 "capture mode." In this mode, in response to a transition at the 8052's T2EX pin, TH2 and TL2 are copied into RCAP2H and RCAP2L. Timer

2 also has a 16-bit auto-reload mode, and RCAP2H and RCAP2L hold the reload value for this mode. More about Timer 2's features in Section 7.6.2.

#### **CONTROL REGISTERS**

Special Function Registers IP, IE, TMOD, TCON, T2CON, SCON, and PCON contain control and status bits for the interrupt system, the timer/counters, and the serial port. They are described in later sections.

## 7.2 OSCILLATOR AND CLOCK CIRCUIT

XTAL1 and XTAL2 are the input and output of a singlestage on-chip inverter, which can be configured with offchip components as a Pierce oscillator, as shown in Figure 7-3. The on-chip circuitry, and selection of off-chip components to configure the oscillator are discussed in Section



Figure 7-3. Crystal/Ceramic Resonator Oscillator

|        |          | (MSB)                                                                  |        |                                 | (LSB)                                                                                                                                                           |
|--------|----------|------------------------------------------------------------------------|--------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |          | CY AC F0 RS1                                                           | RSO    | ov                              | P                                                                                                                                                               |
| Symbol | Position | Name and Significance                                                  | Symbol | Position                        | Name and Significance                                                                                                                                           |
| СҮ     | PSW.7    | Carry flag.                                                            | ov     | PSW.2                           | Overflow flag.                                                                                                                                                  |
| AC     | PSW.6    | Auxiliary Carry flag.<br>(For BCD operations.)                         | -      | PSW.1                           | (reserved)                                                                                                                                                      |
| FO     | P\$W.5   | Flag 0<br>(Available to the user for general<br>purposes.)             | P      | PSW.0                           | Parity flag.<br>Set/cleared by hardware each instruc-<br>tion cycle to indicate an odd/even<br>number of "one" bits in the accumu-<br>lator, i.e., even parity. |
| RS1    | PSW.4    | Register bank Select control bits 1 & 0.                               |        | e contents of<br>Inks as follow |                                                                                                                                                                 |
| RS0    | PSW.3    | Set/cleared by software to determine working register bank (see Note). |        |                                 | (0.0)—Bank 0 (00H-07H)<br>(0.1)—Bank 1 (08H-0FH)<br>(1.0)—Bank 2 (10H-17H)<br>(1.1)—Bank 3 (18H-1FH)                                                            |

Figure 7-2. PSW: Program Status Word Register

7.13. A more detailed discussion will be found in Application Note AP-155, "Oscillators for Microcontrollers," which is included in this manual.

The oscillator, in any case, drives the internal clock generator. The clock generator provides the internal clocking signals to the chip. The internal clocking signals are at half the oscillator frequency, and define the internal phases, states, and machine cycles, which are described in the next section.

## 7.3 CPU TIMING

A machine cycle consists of 6 states (12 oscillator periods). Each state is divided into a Phase 1 half, during which the Phase 1 clock is active, and a Phase 2 half,





7-4

during which the Phase 2 clock is active. Thus, a machine cycle consists of 12 oscillator periods, numbered S1P1 (State 1, Phase 1), through S6P2 (State 6, Phase 2). Each phase lasts for one oscillator period. Each state lasts for two oscillator periods. Typically, arithmetic and logical operations take place during Phase 1 and internal register-to-register transfers take place during Phase 2.

The diagrams in Figure 7-4 show the fetch/execute timing referenced to the internal states and phases. Since these internal clock signals are not user accessible, the XTAL2 oscillator signal and the ALE (Address Latch Enable) signal are shown for external reference. ALE is normally activated twice during each machine cycle: once during S1P2 and S2P1, and again during S4P2 and S5P1.

Execution of a one-cycle instruction begins at S1P2, when the opcode is latched into the Instruction Registér. If it is a two-byte instruction, the second byte is read during S4 of the same machine cycle. If it is a one-byte instruction, there is still a fetch at S4, but the byte read (which would be the next opcode), is ignored, and the Program Counter is not incremented. In any case, execution is complete at the end of S6P2. Figures 7-4A and 7-4B show the timing for a 1-byte, 1-cycle instruction and for a 2-byte, 1-cycle instruction.

Most 8051 instructions execute in one cycle. MUL (multiply) and DIV (divide) are the only instructions that take more than two cycles to complete. They take four cycles.

Normally, two code bytes are fetched from Program Memory during every machine cycle. The only exception to this is when a MOVX instruction is executed. MOVX is a 1-byte 2-cycle instruction that accesses external Data Memory. During a MOVX, two fetches are skipped while the external Data Memory is being addressed and strobed. Figures 7-4C and 7-4D show the timing for a normal 1byte, 2-cycle instruction and for a MOVX instruction.

## 7.4 PORT STRUCTURES AND OPERATION

All four ports in the 8051 are bidirectional. Each consists of a latch (Special Function Registers P0 through P3), an output driver, and an input buffer.



Figure 7-5. 8051 Port Bit Latches and I/O Buffers \*See Figure 7-6 for details of the internal pullup.

The output drivers of Ports 0 and 2, and the input buffers of Port 0, are used in accesses to external memory. In this application, Port 0 outputs the low byte of the external memory address, time-multiplexed with the byte being written or read. Port 2 outputs the high byte of the external memory address when the address is 16 bits wide. Otherwise the Port 2 pins continue to emit the P2 SFR content.

All the Port 3 pins, and (in the 8052) two Port 1 pins are multifunctional. They are not only port pins, but also serve the functions of various special features as listed below:

| PORT PIN | ALTERNATE FUNCTION  |
|----------|---------------------|
| *P1.0    | T2 (Timer/Counter 2 |

| 1.0 | Т | 2 | (1 | [ir | ne | r/C | ounter | 2 |
|-----|---|---|----|-----|----|-----|--------|---|
|     |   |   | •  |     |    |     |        |   |

- \*P1.1 T2EX (Timer/Counter 2 capture/reload trigger)
- P3.0 RXD (serial input port)
- P3.1 TXD (serial output port)
- P3.2 INTO (external interrupt)
- P3.3 INT1 (external interrupt)
- P3.4 T0 (Timer/Counter 0 external input)
- P3.5 T1 (Timer/Counter 1 external input)
- P3.6 WR (external Data memory write strobe)
- P3.7 RD (external Data memory read strobe)

\*P1.0 and P1.1 serve these alternate functions only on the 8052.

The alternate functions can only be activated if the corresponding bit latch in the port SFR contains a 1. Otherwise the port pin is stuck at 0.

## 7.4.1 I/O Configurations

Figure 7-5 shows a functional diagram of a typical bit latch and I/O buffer in each of the four ports. The bit latch (one bit in the port's SFR) is represented as a Type D flip-flop, which will clock in a value from the internal bus in response to a "write to latch" signal from the CPU. The Q output of the flip-flop is placed on the internal bus in response to a "read latch" signal from the CPU. The level of the port pin itself is placed on the internal bus in response to a "read placed" signal from the CPU. Some instructions that read a port activate the "read latch" signal, and others activate the "read pin" signal. More about that in Section 7.4.4.

As shown in Figure 7-5, the output drivers of Ports 0 and 2 are switchable to an internal ADDR and ADDR/DATA bus by an internal CONTROL signal for use in external memory accesses. During external memory accesses, the P2 SFR remains unchanged, but the P0 SFR gets 1s written to it.

Also shown in Figure 7-5, is that if a P3 bit latch contains a 1, then the output level is controlled by the signal labeled "alternate output function." The actual P3.X pin level is always available to the pin's alternate input function, if any.

Ports 1, 2, and 3 have internal pull-ups. Port 0 has opendrain outputs. Each I/O line can be independently used as an input or an output. (Ports 0 and 2 may not be used as general purpose I/O when being used as the ADDR/DATA BUS). To be used as an input, the port bit latch must contain a 1, which turns off the output driver FET. Then, for Ports 1, 2, and 3, the pin is pulled high by the internal pull-up, but can be pulled low by an external source.

Port 0 differs in not having internal pullups. The pullup FET in the P0 output driver (see Figure 7-5A) is used only when the Port is emitting 1s during external memory accesses. Otherwise the pullup FET is off. Consequently P0 lines that are being used as output port lines are open drain. Writing a 1 to the bit latch leaves both output FETs off, so the pin floats. In that condition it can be used as a high-impedance input.

Because Ports 1, 2, and 3 have fixed internal pullups they are sometimes called "quasi-bidirectional" ports. When configured as inputs they pull high and will source current (IIL, in the data sheets) when externally pulled low. Port 0, on the other hand, is considered "true" bidirectional, because when configured as an input it floats.

All the port latches in the 8051 have 1s written to them by the reset function. If a 0 is subsequently written to a port latch, it can be reconfigured as an input by writing a 1 to it.

## 7.4.2 Writing to a Port

In the execution of an instruction that changes the value in a port latch, the new value arrives at the latch during S6P2 of the final cycle of the instruction. However, port latches are in fact sampled by their output buffers only during Phase 1 of any clock period. (During Phase 2 the output buffer holds the value it saw during the previous Phase 1). Consequently, the new value in the port latch won't actually appear at the output pin until the next Phase 1, which will be at S1P1 of the next machine cycle.

If the change requires a 0-to-1 transition in Port 1, 2, or 3, an additional pull-up is turned on during S1P1 and S1P2 of the cycle in which the transition occurs. This is done to increase the transition speed. The extra pull-up can source about 100 times the current that the normal pull-up can. It should be noted that the internal pull-ups are field-effect transistors, not linear resistors. The pull-up arguments are shown in Figure 7-6.

In HMOS versions of the 8051, the fixed part of the pullup is a depletion-mode transistor with the gate wired to the source. This transistor will allow the pin to source



## Figure 7-6. Ports 1 and 3 HMOS and CHMOS Internal Pull-up Configurations. Port 2 is similar except that it holds the strong pullup on while emitting 1s that are address bits. (See text, "Accessing External Memory.")

about 0.25 mA when shorted to ground. In parallel with the fixed pull-up is an enhancement-mode transistor, which is activated during S1 whenever the port bit does a 0-to-1 transition. During this interval, if the port pin is shorted to ground, this extra transistor will allow the pin to source an additional 30 mA.

In the CHMOS versions, the pull-up consists of three pFETs. It should be noted that an n-channel FET (nFET) is turned on when a logical 1 is applied to its gate, and is turned off when a logical 0 is applied to its gate. A p-channel FET (pFET) is the opposite: it is on when its gate sees a  $\theta$ , and off when its gate sees a 1.

pFET 1 in Figure 7-6B is the transistor that is turned on for 2 oscillator periods after a 0-to-1 transition in the port latch. While it's on, it turns on pFET 3 (a weak pull-up), through the inverter. This inverter and pFET form a latch which hold the 1.

Note that if the pin is emitting a 1, a negative glitch on the pin from some external source can turn off pFET 3, causing the pin to go into a float state, pFET 2 is a very weak pull-up which is on whenever the nFET is off, in traditional CMOS style. It's only about 1/10 the strength of pFET3. Its function is to restore a 1 to the pin in the event the pin had a 1 and lost it to a glitch.

## 7.4.3 Port Loading and Interfacing

The output buffers of Ports 1, 2, and 3 can each drive 4 LS TTL inputs. These ports on HMOS versions can be driven in a normal manner by any TTL or NMOS circuit. Both HMOS and CHMOS pins can be driven by open-collector and open-drain outputs, but note that 0-to-1 transitions will not be fast. In the HMOS device, if the pin is driven by an open collector output, a 0-to-1 transition will have to be driven by the relatively weak depletion mode FET in Figure 7-6(A). In the CHMOS device, an input 0 turns off pull-up pFET3, leaving only the very weak pull-up pFET2 to drive the transition.

Port 0 output buffers can each drive 8 LS TTL inputs. They do, however, require external pull-ups to drive NMOS inputs, except when being used as the ADDRESS/ DATA bus.

## 7.4.4 Read-Modify-Write Feature

Some instructions that read a port read the latch and others read the pin. Which ones do which? The instructions that read the latch rather than the pin are the ones that read a value, possibly change it, and then rewrite it to the latch. These are called "read-modify-write" instructions. The instructions listed below are read-modify-write instructions. When the destination operand is a port, or a port bit, these instructions read the latch rather than the pin:

| ANL        | (logical AND, e.g., ANL P1,A)                             |
|------------|-----------------------------------------------------------|
| ORL        | (logical OR, e.g., ORL P2,A)                              |
| XRL        | (logical EX-OR, e.g., XRL<br>P3,A)                        |
| JBC        | (jump if bit = 1 and clear bit,<br>e.g., JBC P1.1, LABEL) |
| CPL        | (complement bit, e.g., CPL<br>P3.0)                       |
|            | (increment, e.g., INC P2)                                 |
| DEC        | (decrement, e.g., DEC P2)                                 |
| DJNZ       | (decrement and jump if not zero, e.g., DJNZ P3, LABEL)    |
| MOV PX.Y,C | (move carry bit to bit Y of<br>Port X)                    |
| CLR PX.Y   | (clear bit Y of Port X)                                   |
| SET PX.Y   | (set bit Y of Port X)                                     |

It is not obvious that the last three instructions in this list are read-modify-write instructions, but they are. They read the port byte, all 8 bits, modify the addressed bit, then write the new byte back to the latch.

The reason that read-modify-write instructions are directed to the latch rather than the pin is to avoid a possible misinterpretation of the voltage level at the pin. For example, a port bit might be used to drive the base of a transistor. When a 1 is written to the bit, the transistor is turned on. If the CPU then reads the same port bit at the pin rather than the latch, it will read the base voltage of the transistor and interpret it as a 0. Reading the latch rather than the pin will return the correct value of 1.

## 7.5 ACCESSING EXTERNAL MEMORY

Accesses to external memory are of two types: accesses to external Program Memory and accesses to external Data Memory. Accesses to external Program Memory use signal  $\overrightarrow{PSEN}$  (program store enable) as the read strobe. Accesses to external Data Memory use  $\overrightarrow{RD}$  or  $\overrightarrow{WR}$  (alternate functions of P3.7 and P3.6) to strobe the memory.

Fetches from external Program Memory always use a 16bit address. Accesses to external Data Memory can use either a 16-bit address (MOVX @DPTR) or an 8-bit address (MOVX @Ri).

Whenever a 16-bit address is used, the high byte of the address comes out on Port 2, where it is held for the duration of the read or write cycle. Note that the Port 2 drivers use the strong pullups during the entire time that they are emitting address bits that are 1s. This is during the execution of a MOVX @DPTR instruction. During this time the Port 2 latch (the Special Function Register) does not have to contain 1s, and the contents of the Port 2 SFR are not modified. If the external memory cycle is not immediately followed by another external memory cycle, the undisturbed contents of the Port 2 SFR will reappear in the next cycle.

If an 8-bit address is being used (MOVX @Ri), the contents of the Port 2 SFR remain at the Port 2 pins throughout the external memory cycle. This will facilitate paging.

In any case, the low byte of the address is time-multiplexed with the data byte on Port 0. The ADDR/DATA signal drives both FETs in the Port 0 output buffers. Thus, in this application the Port 0 pins are not open-drain outputs, and do not require external pull-ups. Signal ALE (address latch enable) should be used to capture the address byte into an external latch. The address byte is valid at the negative transition of ALE. Then, in a write cycle, the data byte to be written appears on Port 0 just before WR is activated, and remains there until after  $\overline{WR}$  is deactivated. In a read cycle, the incoming byte is accepted at Port 0 just before the read strobe is deactivated.

During any access to external memory, the CPU writes OFFH to the Port 0 latch (the Special Function Register), thus obliterating whatever information the Port 0 SFR may have been holding.

External Program Memory is accessed under two conditions:

- 1) Whenever signal  $\overline{EA}$  is active; or
- 2) Whenever the program counter (PC) contains a number that is larger than 0FFFH (1FFFH for the 8052).

This requires that the ROMless versions have  $\overline{EA}$  wired

low to enable the lower 4K (8K for the 8032) program bytes to be fetched from external memory.

When the CPU is executing out of external Program Memory, all 8 bits of Port 2 are dedicated to an output function and may not be used for general purpose I/O. During external program fetches they output the high byte of the PC. During this time the Port 2 drivers use the strong pullups to emit PC bits that are 1s.

## 7.5.1 PSEN

The read strobe for external fetches is  $\overrightarrow{PSEN}$ .  $\overrightarrow{PSEN}$  is not activated for internal fetches. When the CPU is accessing external Program Memory,  $\overrightarrow{PSEN}$  is activated twice every cycle (except during a MOVX instruction) whether or not the byte fetched is actually needed for the current instruction. When  $\overrightarrow{PSEN}$  is activated its timing is not the same as  $\overrightarrow{RD}$ . A complete  $\overrightarrow{RD}$  cycle, including activation and deactivation of ALE and  $\overrightarrow{RD}$ , takes 12 oscillator periods. A complete  $\overrightarrow{\text{PSEN}}$  cycle, including activation and deactivation of ALE and  $\overrightarrow{\text{PSEN}}$ , takes 6 oscillator periods. The execution sequence for these two types of read cycles are shown in Figure 7-7 for comparison.

## 7.5.2 ALE

The main function of ALE is to provide a properly timed signal to latch the low byte of an address from P0 to an external latch during fetches from external Program Memory. For that purpose ALE is activated twice every machine cycle. This activation takes place even when the cycle involves no external fetch. The only time an ALE pulse doesn't come out is during an access to external Data Memory. The first ALE of the second cycle of a MOVX instruction is missing (see Figure 7-7). Consequently, in any system that does not use external Data Memory, ALE is activated at a constant rate of 1/6 the oscillator frequency, and can be used for external clocking or timing purposes.



Figure 7-7. External Program Memory Execution

#### 7.5.3 Overlapping External Program and Data Memory Spaces

In some applications it is desirable to execute a program from the same physical memory that is being used to store data. In the 8051, the external Program and Data Memory spaces can be combined by ANDing PSEN and  $\overline{RD}$ . A positive-logic AND of these two signals produces an active-low read strobe that can be used for the combined physical memory. Since the  $\overline{PSEN}$  cycle is faster than the  $\overline{RD}$  cycle, the external memory needs to be fast enough to accommodate the  $\overline{PSEN}$  cycle.

## 7.6 TIMER/COUNTERS

The 8051 has two 16-bit timer/counter registers: Timer 0 and Timer 1. The 8052 has these two plus one more: Timer 2. All three can be configured to operate either as timers or event counters.

In the "timer" function, the register is incremented every machine cycle. Thus, one can think of it as counting machine cycles. Since a machine cycle consists of 12 oscillator periods, the count rate is 1/12 of the oscillator frequency.

In the "counter" function, the register is incremented in response to a 1-to-0 transition at its corresponding external input pin, T0, T1 or (in the 8052) T2. In this function, the external input is sampled during S5P2 of every machine cycle. When the samples show a high in one cycle and a low in the next cycle, the count is incremented. The new count value appears in the register during S3P1 of the cycle following the one in which the transition was detected. Since it takes 2 machine cycles (24 oscillator periods) to recognize a 1-to-0 transition, the maximum count rate is 1/24 of the oscillator frequency. There are

no restrictions on the duty cycle of the external input signal, but to ensure that a given level is sampled at least once before it changes, it should be held for at least one full machine cycle.

In addition to the "timer" or "counter" selection, Timer 0 and Timer 1 have four operating modes from which to select. Timer 2, in the 8052, has three modes of operation: "capture," "auto-reload" and "baud rate generator."

## 7.6.1 Timer 0 and Timer 1

These timer/counters are present in both the 8051 and the 8052. The "timer" or "counter" function is selected by control bits  $C/\overline{T}$  in the Special Function Register TMOD (Figure 6-8). These two timer/counters have four operating modes, which are selected by bit-pairs (M1, M0) in TMOD. Modes 0, 1, and 2 are the same for both timer/ counters. Mode 3 is different. The four operating modes are described below.

#### MODE 0

Putting either Timer into mode 0 makes it look like an 8048 Timer, which is an 8-bit counter with a divide-by-32 prescaler. Figure 7-9 shows the mode 0 operation as it applies to Timer 1.

In this mode, the timer register is configured as a 13-bit register. As the count rolls over from all 1s to all 0s, it sets the timer interrupt flag TF1. The counted input is enabled to the Timer when TR1 = 1 and either GATE = 0 or  $\overline{INT1} = 1$ . (Setting GATE = 1 allows the Timer to be controlled by external input  $\overline{INT1}$ , to facilitate pulse width measurements.) TR1 is a control bit in the Special Function Register TCON (Figure 7-10). GATE is in TMOD.



#### Figure 7-8. TMOD: Timer/Counter Mode Control Register

The 13-bit register consists of all 8 bits of TH1 and the lower 5 bits of TL1. The upper 3 bits of TL1 are indeterminate and should be ingored. Setting the run flag (TR1) does not clear the registers.

Mode 0 operation is the same for Timer 0 as for Timer 1. Substitute TR0, TF0 and INT0 for the corresponding Timer 1 signals in Figure 7-9. There are two different GATE bits, one for Timer 1 (TMOD.7) and one for Timer 0 (TMOD.3).

### MODE 1

Mode 1 is the same as Mode 0, except that the Timer register is being run with all 16 bits.

### MODE 2

Mode 2 configures the timer register as an 8-bit counter (TL1) with automatic reload, as shown in Figure 7-11. Overflow from TL1 not only sets TF1, but also reloads TL1 with the contents of TH1, which is preset by software. The reload leaves TH1 unchanged.

Mode 2 operation is the same for Timer/Counter 0.

## MODE 3

Timer 1 in Mode 3 simply holds its count. The effect is the same as setting TR1 = 0.



Figure 7-9. Timer/Counter 1 Mode 0: 13-bit Counter

|        |          | (MSB)                                                                                                                            |                         |                              |     |        |                                                                                                                      |                                                                                                                       | (LSB)       |                                                                     |
|--------|----------|----------------------------------------------------------------------------------------------------------------------------------|-------------------------|------------------------------|-----|--------|----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|-------------|---------------------------------------------------------------------|
|        |          | TF1                                                                                                                              | TR1                     | TFO                          | TRO | IE1    | IT1                                                                                                                  | IEO ITO                                                                                                               |             |                                                                     |
| Symbol | Position | Name and                                                                                                                         | l Significan            | ce                           |     | Symbol | Position                                                                                                             | Name and                                                                                                              | i Significa | ance                                                                |
| TF1    | TCON.7   | <ul> <li>Timer 1 overflow Flag. Set by hardware<br/>on timer/counter overflow. Cleared<br/>by hardware when processor</li> </ul> |                         |                              |     | IE1    | TCON.3                                                                                                               | Interrupt 1 Edge flag. Set by hardware<br>when external interrupt edge detected.<br>Cleared when interrupt processed. |             |                                                                     |
| TR1    | TCON.6   | vectors to interrupt routine.<br>Timer 1 Run control bit. Set/cleared<br>by software to turn timer/counter                       |                         |                              |     | IT1    | TCON.2                                                                                                               | by softwa                                                                                                             | re to spec  | ntrol bit. Set/cleared<br>cify falling edge/low<br>rnal interrupts. |
| TF0    | TCON.5   | on/off.<br>Timer 0 overflow Flag. Set by hardware<br>on timer/counter overflow. Cleared                                          |                         |                              | IEO | TCON.1 | Interrupt 0 Edge flag. Set by hardwark<br>when external interrupt edge detector<br>Cleared when interrupt processed. |                                                                                                                       |             |                                                                     |
|        |          | vectors t                                                                                                                        | are when p<br>interrupt | routine.                     |     | ITO    | TCON.0                                                                                                               | by softwa                                                                                                             | re to spec  | ntrol bit. Set/cleared<br>cify falling edge/low leve                |
| TR0    | TCON.4   |                                                                                                                                  |                         | bit. Set/clea<br>r/counter o |     |        |                                                                                                                      | triggerea                                                                                                             | external i  | nterrupts.                                                          |

### Figure 7-10. TCON: Timer/Counter Control Register

Timer 0 in Mode 3 establishes TL0 and TH0 as two separate counters. The logic for Mode 3 on Timer 0 is shown in Figure 7-12. TL0 uses the Timer 0 control bits:  $C\overline{T}$ , GATE, TR0, INTO, and TF0. TH0 is locked into a timer function (counting machine cycles) and takes over the use of TR1 and TF1 from Timer 1. Thus, TH0 now controls the "Timer 1" interrupt.

Mode 3 is provided for applications requiring an extra 8bit timer or counter. With Timer 0 in Mode 3, an 8051 can look like it has three timer/counters, and an 8052, like it has four. When Timer 0 is in Mode 3, Timer 1 can be turned on and off by switching it out of and into its own Mode 3, or can still be used by the serial port as a baud rate generator, or in fact, in any application not requiring an interrupt.

## 7.6.2 Timer 2

Timer 2 is a 16-bit timer/counter which is present only in the 8052. Like Timers 0 and 1, it can operate either as a timer or as an event counter. This is selected by bit  $C/\overline{12}$  in the Special Function Register T2CON (Figure 7-13). It has three operating modes: "capture;" "auto-



Figure 7-11. Timer/Counter 1 Mode 2: 8-bit Auto-reload





| (MSB)  |          |                            |                                                   |                                                                       |                            |                                | (LSB)                             |
|--------|----------|----------------------------|---------------------------------------------------|-----------------------------------------------------------------------|----------------------------|--------------------------------|-----------------------------------|
| TF2    | EXF2     | RCLK                       | TCLK                                              | EXEN2                                                                 | TR2                        | C/T2                           | CP/RL2                            |
| Symbol | Position |                            |                                                   | Name and                                                              | Significance               | •                              |                                   |
| TF2    | T2CON.7  |                            |                                                   | t by a Timer 2<br>when either P                                       |                            |                                | leared by sof                     |
| EXF2   | T2CON.6  | transition o               | n T2 EX and I<br>he CPU to v                      | when either a<br>EXEN2 = 1. Wh<br>ector to the T                      | en Timer 2 i               | nterrupt is en                 | abled, EXF2 =                     |
| RCLK   | T2CON.5  | pulses for it              |                                                   | en set, causes<br>ok in modes 1 :<br>e clock.                         |                            |                                |                                   |
| TCLK   | T2CON.4  | pulses for i               | ts transmit cl                                    |                                                                       | 1 and 3. TC                |                                | mer 2 overflo<br>s Timer 1 ove    |
| EXEN2  | T2CON.3  | result of a n              | egative trans                                     |                                                                       | if Timer 2 is              | not being u                    | ad to occur as<br>sed to clock th |
| TR2    | T2CON.2  | Start/stop c               | ontrol for Ti                                     | ner 2. A logic                                                        | 1 starts the t             | imer.                          |                                   |
| C/T2   | T2CON.1  | 0 = Intern                 | unter select.<br>al timer (OS)<br>nal event cou   |                                                                       | dge triggere               | d).                            |                                   |
| CP/RL2 | T2CON.0  | T2EX if EXI<br>overflows o | EN2 = 1. Whe<br>r negative tra<br>K = 1, this bit | hen set, captu<br>n cleared, au<br>Insitions at T2<br>I is ignored ar | to reloads w<br>EX when EX | ill occur eith<br>(EN2 = 1. Wh | er with Timer<br>en either RCL    |

#### Figure 7-13. T2CON: Timer/Counter 2 Control Register

load" and "baud rate generator," which are selected by bits in T2CON as shown in Table 2.

**Table 2. Timer 2 Operating Modes** 

| RCLK+TCLK | CP/RL2 | TR2 | MODE                |
|-----------|--------|-----|---------------------|
| 0         | 0      | 1   | 16-bit auto-reload  |
| 0         | 1      | 1   | 16-bit capture      |
| 1         | Х      | 1   | baud rate generator |
| X         | Х      | 0   | (off)               |

In the capture mode there are two options which are selected by bit EXEN2 in T2CON. If EXEN2 = 0, then Timer 2 is a 16-bit timer or counter which upon overflowing sets bit TF2, the Timer 2 overflow bit, which can be used to generate an interrupt. If EXEN2 = 1, then Timer 2 still does the above, but with the added feature that a 1-to-0 transition at external input T2EX causes the current value in the Timer 2 registers, TL2 and TH2, to be captured into registers RCAP2L and RCAP2H, respectively. (RCAP2L and RCAP2H are new Special Function Registers in the 8052.) In addition, the transition at T2EX causes bit EXF2 in T2CON to be set, and EXF2, like TF2, can generate an interrupt.

The capture mode is illustrated in Figure 7-14.

In the auto-reload mode there are again two options, which are selected by bit EXEN2 in T2CON. If EXEN2 = 0, then when Timer 2 rolls over it not only sets TF2 but also causes the Timer 2 registers to be reloaded with the 16bit value in registers RCAP2L and RCAP2H, which are preset by software. If EXEN2 = 1, then Timer 2 still does the above, but with the added feature that a 1-to-0 transition at external input T2EX will also trigger the 16bit reload and set EXF2.

The auto-reload mode is illustrated in Figure 7-15.

The baud rate generator mode is selected by RCLK = 1 and/or TCLK = 1. It will be described in conjunction with the serial port.

#### 7.7 SERIAL INTERFACE

The serial port is full duplex, meaning it can transmit and receive simultaneously. It is also receive-buffered, meaning it can commence reception of a second byte before a previously received byte has been read from the receive register. (However, if the first byte still hasn't been read by the time reception of the second byte is complete, one of the bytes will be lost). The serial port receive and transmit registers are both accessed at Special Function Register SBUF. Writing to SBUF loads the transmit reg-

#### MCS®-51: ARCHITECTURE:



Figure 7-14. Timer 2 in Capture Mode

ister, and reading SBUF accesses a physically separate receive register.

The serial port can operate in 4 modes:

**Mode 0:** Serial data enters and exits through RXD. TXD outputs the shift clock. 8 bits are transmitted/received: 8 data bits (LSB first). The baud rate is fixed at 1/12 the oscillator frequency.

**Mode 1:** 10 bits are transmitted (through TXD) or received (through RXD): a start bit (0), 8 data bits (LSB first), and a stop bit (1). On receive, the stop bit goes into RB8 in Special Function Register SCON. The baud rate is variable.

Mode 2: 11 bits are transmitted (through TXD) or received (through RXD): a start bit (0), 8 data bits (LSB first), a programmable 9th data bit, and a stop bit (1). On transmit, the 9th data bit (TB8 in SCON) can be assigned the value of 0 or 1. Or, for example, the parity bit (P, in the PSW) could be moved into TB8. On receive, the 9th data bit goes into RB8 in Special Function Register SCON, while the stop bit is ignored. The baud rate is programmable to either 1/32 or 1/64 the oscillator frequency.

**Mode 3:** 11 bits are transmitted (through TXD) or received (through RXD): a start bit (0), 8 data bits (LSB first), a programmable 9th data bit and a stop bit (1). In fact, Mode 3 is the same as Mode 2 in all respects except the baud rate. The baud rate in Mode 3 is variable.

In all four modes, transmission is initiated by any instruction that uses SBUF as a destination register. Reception is initiated in Mode 0 by the condition RI = 0 and REN = 1. Reception is initiated in the other modes by the incoming start bit if REN = 1.

## 7.7.1 Multiprocessor Communications

Modes 2 and 3 have a special provision for multiprocessor communications. In these modes, 9 data bits are received. The 9th one goes into RB8. Then comes a stop bit. The port can be programmed such that when the stop bit is received, the serial port interrupt will be activated only if RB8 = 1. This feature is enabled by setting bit SM2 in SCON. A way to use this feature in multiprocessor systems is as follows.

When the master processor wants to transmit a block of data to one of several slaves, it first sends out an address byte which identifies the target slave. An address byte differs from a data byte in that the 9th bit is 1 in an address byte and 0 in a data byte. With SM2 = 1, no slave will be interrupted by a data byte. An address byte, however, will interrupt all slaves, so that each slave can examine the received byte and see, if it is being addressed. The addressed slave will clear its SM2 bit and prepare to receive the data bytes that will be coming. The slaves that weren't being addressed leave their SM2s set and go on about their business, ignoring the coming data bytes.

SM2 has no effect in Mode 0, and in Mode 1 can be used to check the validity of the stop bit. In a Mode 1 reception, if SM2 = 1, the receive interrupt will not be activated unless a valid stop bit is received.

10 00 1 1

#### 7.7.2 Serial Port Control Register

The serial port control and status register is the Special Function Register SCON, shown in Figure 7-16. This register contains not only the mode selection bits, but also the 9th data bit for transmit and receive (TB8 and RB8), and the serial port interrupt bits (TI and RI).



Figure 7-15. Timer 2 in Auto-Reload Mode

| (M\$B)   |       |           |                   |                            |       | (LSB) |        |                                                                                                          |  |  |
|----------|-------|-----------|-------------------|----------------------------|-------|-------|--------|----------------------------------------------------------------------------------------------------------|--|--|
|          |       |           | SM0               | SM1 SM                     | 2 REN | TB8   | RB8    | TI RI                                                                                                    |  |  |
| ere SM0, | SM1   | specify t | the serial port n | node, as follov            | /s:   |       | • TE   | 38 is the 9th data bit that will be                                                                      |  |  |
| SM0      | SM1   | Mode      | Description       | Baud Rate                  |       | •     |        | transmitted in modes 2 and 3. Set<br>or clear by software as desired.                                    |  |  |
| 0        | 0     | 0         | shift register    | fosc./12                   |       |       |        | -                                                                                                        |  |  |
| 0        | 1     | 1         | 8-bit UART        | variable                   |       |       | • RE   | 38 in modes 2 and 3, is the 9th data bit                                                                 |  |  |
| 1        | Ó     | 2         | 9-bit UART        | fosc./64<br>or<br>fosc./32 |       |       |        | that was received. In mode 1, if<br>SM2 = 0, RB8 is the stop bit that<br>was received. In mode 0, RB8 is |  |  |
| 1        | 1     | 3         | 9-bit UART        |                            |       |       |        | not used.                                                                                                |  |  |
| •        | •     | •         | J-DIL OANT        | Variabio                   |       |       | • TI   | is transmit interrupt flag. Set by                                                                       |  |  |
| • SM3    | 2 en  | ables th  | ne multiproces    | sor com-                   |       |       |        | hardware at the end of the 8th bit                                                                       |  |  |
|          |       |           | n feature in mo   |                            |       |       |        | time in mode 0, or at the beginning                                                                      |  |  |
|          | 3.    | In mode   | 2 or 3, if SM2    | is set to 1                |       |       |        | of the stop bit in the other modes,                                                                      |  |  |
|          | the   | en Ri wi  | Il not be activa  | ted if the                 |       |       |        | in any serial transmission. Must be                                                                      |  |  |
|          | rec   | ceived 9  | th data bit (RB   | 8) is 0. In                |       |       |        | cleared by software.                                                                                     |  |  |
|          | mo    | ode 1, i  | fSM2 = 1 the      | n RI will                  |       |       |        | -                                                                                                        |  |  |
|          | no    | t be act  | ivated if a valid | stop bit                   |       |       | : • RI |                                                                                                          |  |  |
|          |       |           | ceived. In mod    | le 0, SM2                  |       |       |        | hardware at the end of the 8th bit                                                                       |  |  |
|          | sh    | ould be ( | 0.                |                            |       |       |        | time in mode 0, or halfway through the stop bit time in the other                                        |  |  |
| + REF    | vl en | ables s   | erial reception   | . Set by                   |       |       |        | modes, in any serial reception (ex-                                                                      |  |  |
|          |       |           | enable recept     |                            |       |       |        | cept see SM2). Must be cleared                                                                           |  |  |
|          |       |           | e to disable rec  |                            |       |       |        | by software.                                                                                             |  |  |

## Figure 7-16. SCON: Serial Port Control Register

## 7.7.3 Baud Rates

The baud rate in Mode 0 is fixed:

Mode 0 Baud Rate = 
$$\frac{\text{Oscillator Frequency}}{12}$$

The baud rate in Mode 2 depends on the value of bit SMOD in Special Function Register PCON. If SMOD = 0 (which is its value on reset), the baud rate is 1/64 the oscillator frequency. If SMOD = 1, the baud rate is 1/32 the oscillator frequency.

Mode 2 Baud Rate =  $\frac{2^{\text{SMOD}}}{64}$  x (Oscillator Frequency)

In the 8051, the baud rates in Modes 1 and 3 are determined by the Timer 1 overflow rate. In the 8052, these baud rates can be determined by Timer 1, or by Timer 2, or by both (one for transmit and the other for receive).

### **Using Timer 1 to Generate Baud Rates**

When Timer 1 is used as the baud rate generator, the baud rates in Modes 1 and 3 are determined by the Timer 1 overflow rate and the value of SMOD as follows:

Modes 1, 3 Baud Rate =  $\frac{2^{\text{SMOD}}}{32}$  x (Timer 1 Overflow Rate)

The Timer 1 interrupt should be disabled in this application. The Timer itself can be configured for either "timer" or "counter" operation, and in any of its 3 running modes. In the most typical applications, it is configured for "timer" operation, in the auto-reload mode (high nibble of TMOD = 0010B). In that case, the baud rate is given by the formula

Modes 1, 3 Baud Rate = 
$$\frac{2^{\text{SMOD}}}{32} \times \frac{\text{Oscillator Frequency}}{12x[256 - (\text{TH1})]}$$

One can achieve very low baud rates with Timer 1 by leaving the Timer 1 interrupt enabled, and configuring the Timer to run as a 16-bit timer (high nibble of TMOD

= 0001B), and using the Timer 1 interrupt to do a 16-bit software reload.

Figure 7-17 lists various commonly used baud rates and how they can be obtained from Timer 1.

|                  |            |      | TIMER 1 |      |        |  |
|------------------|------------|------|---------|------|--------|--|
| BAUD RATE        | fosc       | SMOD | C/T     | MODE | RELOAD |  |
| MODE 0 MAX: 1MHZ | 12 MHZ     | X    | X       | X    | X      |  |
| MODE 2 MAX: 375K | 12 MHZ     | 1    | X       | x    | x      |  |
| MODES 1,3: 62.5K | 12 MHZ     | 1    | 0       | 2    | FFH    |  |
| 19.2K            | 11.059 MHZ | 1    | 0       | 2    | FDH    |  |
| 9.6K             | 11.059 MHZ | 0    | 0       | 2    | FDH    |  |
| 4.8K             | 11.059 MHZ | 0    | 0       | 2    | FAH    |  |
| 2.4K             | 11.059 MHZ | 0    | 0       | 2    | F4H    |  |
| 1.2K             | 11.059 MHZ | 0    | 0       | 2    | E8H    |  |
| 137.5            | 11.986 MHZ | Ó    | Ó       | 2    | 1DH    |  |
| 110              | 6 MHZ      | Ó    | Ó       | 2    | 72H    |  |
| 110              | 12 MHZ     | 0    | 0       | 1    | FEEBH  |  |

### Figure 7-17. Timer 1 Generated Commonly Used Baud Rates

### **Using Timer 2 to Generate Baud Rates**

In the 8052, Timer 2 is selected as the baud rate generator by setting TCLK and/or RCLK in T2CON (Figure 7-13). Note then the baud rates for transmit and receive can be simultaneously different. Setting RCLK and/or TCLK puts Timer 2 into its baud rate generator mode, as shown in Figure 7-18.



#### Figure 7-18. Timer 2 in Baud Rate Generator Mode

The baud rate generator mode is similar to the auto-reload mode, in that a rollover in TH2 causes the Timer 2 registers to be reloaded with the 16-bit value in registers RCAP2H and RCAP2L, which are preset by software.

Now, the baud rates in Modes 1 and 3 are determined by Timer 2's overflow rate as follows:

Modes 1, 3 Baud Rate =  $\frac{\text{Timer 2 Overflow Rate}}{16}$ 

The Timer can be configured for either "timer" or "counter" operation. In the most typical applications, it is configured for "timer" operation (C/T2 = 0). "Timer" operation is a little different for Timer 2 when it's being used as a baud rate generator. Normally as a timer it would increment every machine cycle (thus at 1/12 the oscillator frequency). As a baud rate generator, however, it increments every state time (thus at 1/2 the oscillator frequency). In that case the baud rate is given by the formula

Modes 1, 3 Baud Rate =  $\frac{\text{Oscillator Frequency}}{32x[65536 - (\text{RCAP2H, RCAP2L})]}$ 

where (RCAP2H, RCAP2L) is the content of RCAP2H and RCAP2L taken as a 16-bit unsigned integer.

Timer 2 as a baud rate generator is shown in Figure 7-18. This Figure is valid only if RCLK + TCLK = 1 in T2CON. Note that a rollover in TH2 does not set TF2, and will not generate an interrupt. Therefore, the Timer 2 interrupt does not have to be disabled when Timer 2 is in the baud rate generator mode. Note too, that if EXEN2 is set, a 1-to-0 transition in T2EX will set EXF2 but will not cause a reload from (RCAP2H, RCAP2L) to (TH2, TL2). Thus when Timer 2 is in use as a baud rate generator, T2EX can be used as an extra external interrupt, if desired.

It should be noted that when Timer 2 is running (TR2 = 1) in "timer" function in the baud rate generator mode, one should not try to read or write TH2 or TL2. Under these conditions the Timer is being incremented every state time, and the results of a read or write may not be accurate. The RCAP registers may be read, but shouldn't be written to, because a write might overlap a reload and cause write and/or reload errors. Turn the Timer off (clear TR2) before accessing the Timer 2 or RCAP registers, in this case.

### 7.7.4 More About Mode 0

Serial data enters and exits through RXD. TXD outputs the shift clock. 8 bits are transmitted/received: 8 data bits (LSB first). The baud rate is fixed at 1/12 the oscillator frequency.

Figure 7-19 shows a simplified functional diagram of the serial port in mode 0, and associated timing.

Transmission is initiated by any instruction that uses SBUF as a destination register. The "write to SBUF" signal at S6P2 also loads a 1 into the 9th bit position of the transmit shift register and tells the TX Control block to commence a transmission. The internal timing is such that one full machine cycle will elapse between "write to SBUF," and activation of SEND.

SEND enables the output of the shift register to the alternate output function line of P3.0, and also enables SHIFT CLOCK to the alternate output function line of P3.1. SHIFT CLOCK is low during S3, S4, and S5 of every machine cycle, and high during S6, S1 and S2. At S6P2 of every machine cycle in which SEND is active, the contents of the transmit shift register are shifted to the right one position.

As data bits shift out to the right, zeros come in from the left. When the MSB of the data byte is at the output position of the shift register, then the 1 that was initially loaded into the 9th position, is just to the left of the MSB, and all positions to the left of that contain zeros. This condition flags the TX Control block to do one last shift and then deactivate SEND and set T1. Both of these actions occur at S1P1 of the 10th machine cycle after ''write to SBUF.''

Reception is initiated by the condition REN = 1 and RI = 0. At S6P2 of the next machine cycle, the RX Control unit writes the bits 11111110 to the receive shift register, and in the next clock phase activates RECEIVE.

RECEIVE enables SHIFT CLOCK to the alternate output function line of P3.1. SHIFT CLOCK makes transitions at S3P1 and S6P1 of every machine cycle. At S6P2 of every machine cycle in which RECEIVE is active, the contents of the receive shift register are shifted to the left one position. The value that comes in from the right is the value that was sampled at the P3.0 pin at S5P2 of the same machine cycle.

As data bits come in from the right, 1s shift out to the left. When the 0 that was initially loaded into the rightmost position arrives at the leftmost position in the shift register, it flags the RX Control block to do one last shift and load SBUF. At S1P1 of the 10th machine cycle after the write to SCON that cleared RI, RECEIVE is cleared and RI is set.

### 7.7.5 More About Mode 1

Ten bits are transmitted (through TXD), or received (through RXD): a start bit (0), 8 data bits (LSB first), and a stop bit (1). On receive, the stop bit goes into RB8 in SCON. In the 8051 the baud rate is determined by the Timer 1 overflow rate. In the 8052 it is determined either by the Timer 1 overflow rate, or the Timer 2 overflow rate, or both (one for transmit and the other for receive).

Figure 7-20 shows a simplified functional diagram of the serial port in Mode 1, and associated timings for transmit and receive.



Figure 7-19. Serial Port Mode 0



Figure 7-20. Serial Port Mode 1 TCLK, RCLK, and Timer 2 are present in the 8052/8032 only.

1

Transmission is initiated by any instruction that uses SBUF as a destination register. The "write to SBUF" signal also loads a 1 into the 9th bit position of the transmit shift register and flags the TX Control unit that a transmission is requested. Transmission actually commences at S1P1 of the machine cycle following the next rollover in the divide-by-16 counter. (Thus, the bit times are synchronized to the divide-by-16 counter, not to the "write to SBUF" signal).

The transmission begins with activation of  $\overline{\text{SEND}}$ , which puts the start bit at TXD. One bit time later, DATA is activated, which enables the output bit of the transmit shift register to TXD. The first shift pulse occurs one bit time after that.

As data bits shift out to the right, zeros are clocked in from the left. When the MSB of the data byte is at the output position of the shift register, then the 1 that was initially loaded into the 9th position is just to the left of the MSB, and all positions to the left of that contain zeroes. This condition flags the TX Control unit to do one last shift and then deactivate SEND and set TI. This occurs at the 10th divide-by-16 rollover after "write to SBUF."

Reception is initiated by a detected 1-to-0 transition at RXD. For this purpose RXD is sampled at a rate of 16 times whatever baud rate has been established. When a transition is detected, the divide-by-16 counter is immediately reset, and 1FFH is written into the input shift register. Resetting the divide-by-16 counter aligns its rollovers with the boundaries of the incoming bit times.

The 16 states of the counter divide each bit time into 16ths. At the 7th, 8th, and 9th counter states of each bit time, the bit detector samples the value of RXD. The value accepted is the value that was seen in at least 2 of the 3 samples. This is done for noise rejection. If the value accepted during the first bit time is not 0, the receive circuits are reset and the unit goes back to looking for another 1-to-0 transition. This is to provide rejection of false start bits. If the start bit proves valid, it is shifted into the input shift register, and reception of the rest of the frame will proceed.

As data bits come in from the right, 1s shift out to the left. When the start bit arrives at the leftmost position in the shift register, (which in mode 1 is a 9-bit register), it flags the RX Control block to do one last shift, load SBUF and RB8, and set RI. The signal to load SBUF and RB8, and to set RI, will be generated if, and only if, the following conditions are met at the time the final shift pulse is generated.

1) RI = 0, and

2) Either SM2 = 0, or the received stop bit = 1

If either of these two conditions is not met, the received frame is irretrievably lost. If both conditions are met, the stop bit goes into RB8, the 8 data bits go into SBUF, and RI is activated. At this time, whether the above conditions are met or not, the unit goes back to looking for a 1-to-0 transition in RXD.

### 7.7.6 More About Modes 2 and 3

Eleven bits are transmitted (through TXD), or received (through RXD): a start bit (0), 8 data bits (LSB first), a programmable 9th data bit, and a stop bit (1). On transmit, the 9th data bit (TB8) can be assigned the value of 0 or 1. On receive, the 9th data bit goes into RB8 in SCON. The baud rate is programmable to either 1/32 or 1/64 the oscillator frequency in mode 2. Mode 3 may have a variable baud rate generated from either 1 or 2 depending on the state of TCLK and RCLK.

Figures 7-21 A and B show a functional diagram of the serial port in modes 2 and 3. The receive portion is exactly the same as in mode 1. The transmit portion differs from mode 1 only in the 9th bit of the transmit shift register.

Transmission is initiated by any instruction that uses SBUF as a destination register. The "write to SBUF" signal also loads TB8 into the 9th bit position of the transmit shift register and flags the TX Control unit that a transmission is requested. Transmission commences at SIP1 of the machine cycle following the next rollover in the divideby-16 counter. (Thus, the bit times are synchronized to the divide-by-16 counter, not to the "write to SBUF" signal.)

The transmission begins with activation of SEND, which puts the start bit at TXD. One bit time later, DATA is activated, which enables the output bit of the transmit shift register to TXD. The first shift pulse occurs one bit time after that. The first shift clocks a 1 (the stop bit) into the 9th bit position of the shift register. Thereafter, only zeroes are clocked in. Thus, as data bits shift out to the right, zeroes are clocked in from the left. When TB8 is at the output position of the shift register, then the stop bit is just to the left of TB8, and all positions to the left of that contain zeroes. This condition flags the TX Control unit to do one last shift and then deactivate SEND and set TI. This occurs at the 11th divide-by-16 rollover after "write to SBUF."

Reception is initiated by a detected 1-to-0 transition at RXD. For this purpose RXD is sampled at a rate of 16 times whatever baud rate has been established. When a transition is detected, the divide-by-16 counter is immediately reset, and 1FFH is written to the input shift register.

At the 7th, 8th and 9th counter states of each bit time, the bit detector samples the value of RXD. The value accepted is the value that was seen in at least 2 of the 3 samples. If the value accepted during the first bit time is not 0, the receive circuits are reset and the unit goes back to looking for another 1-to-0 transition. If the start bit proves valid, it is shifted into the input shift register, and reception of the rest of the frame will proceed.



Figure 7-21A. Serial Port Mode 2



Figure 7-21B. Serial Port Mode 3 TCLK, RCLK, and Timer 2 are present in the 8052/8032 only. As data bits come in from the right, 1s shift out to the left. When the start bit arrives at the leftmost position in the shift register (which in modes 2 and 3 is a 9-bit register), it flags the RX Control block to do one last shift, load SBUF and RB8, and set RI. The signal to load SBUF and RB8, and to set RI, will be generated if, and only if, the following conditions are met at the time the final shift pulse is generated:

1) RI = 0, and

2) Either SM2 = 0 or the received 9th data bit = 1

If either of these conditions is not met, the received frame is irretrievably lost, and RI is not set. IF both conditions are met, the received 9th data bit goes into RB8, and the first 8 data bits go into SBUF. One bit time later, whether the above conditions were met or not, the unit goes back to looking for a 1-to-0 transition at the RXD input.

Note that the value of the received stop bit is irrelevant to SBUF, RB8, or RI.

### 7.8 INTERRUPTS

. .

The 8051 provides 5 interrupt sources. The 8052 provides 6. These are shown in Figure 7-22.

The External Interrupts INTO and INTI can each be either level-activated or transition-activated, depending on bits

5.950

TF0 TF1 TF1 TF1 TF2 (8052 ONLY) HE0 HITERRUPT SOURCES

Figure 7-22. MCS-51 Interrupt Sources Same and

ITO and IT1 in Register TCON. The flags that actually generate these interrupts are bits IEO and IE1 in TCON. When an external interrupt is generated, the flag that generated it is cleared by the hardware when the service routine is vectored to only if the interrupt was transitionactivated. If the interrupt was level-activated, then the external requesting source is what controls the request flag, rather than the on-chip hardware.

The Timer 0 and Timer 1 Interrupts are generated by TF0 and TF1, which are set by a rollover in their respective timer/counter registers (except see Section 7.6.1 for Timer 0 in mode 3): When a timer interrupt is generated, the flag that generated it is cleared by the on-chip hardware when the service routine is vectored to.

The Serial Port Interrupt is generated by the logical OR of RI and TI. Neither of these flags is cleared by hardware when the service routine is vectored to. In fact, the service routine will normally have to determine whether it was RI or TI that generated the interrupt, and the bit will have to be cleared in software.

In the 8052, the Timer 2 Interrupt is generated by the logical OR of TF2 and EXF2. Neither of these flags is cleared by hardware when the service routine is vectored to. In fact, the service routine may have to determine whether it was TF2 or EXF2 that generated the interrupt, and the bit will have to be cleared in software.

All of the bits that generate interrupts can be set or cleared by software, with the same result as though it had been set or cleared by hardware. That is, interrupts can be generated or pending interrupts can be canceled in software.

| فالمرافع الأخر |       |       |      |                                                                                                                                                                                                 |          |        |          |                                           |
|----------------|-------|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------|----------|-------------------------------------------|
| (MSB)          |       |       |      |                                                                                                                                                                                                 | ,        |        |          | (LSB)                                     |
|                | EÅ    | X     | ET2  | ËS                                                                                                                                                                                              | ET1      | EX1    | ETÖ      | EXO                                       |
| Symbol         | Po    | sitio | n F  | unctio                                                                                                                                                                                          | on       |        |          |                                           |
| EĂ             | , I   | IE.7  | w    | disables all interrupts. If EA = 0, no interrupt<br>will be acknowledged. If EA = 1, each inter-<br>rupt source is individually enabled or dis-<br>abled by setting or clearing its enable bit. |          |        |          |                                           |
|                | I     | E.6   | re   | serve                                                                                                                                                                                           | d        |        |          |                                           |
| ET2            | ļ     | E.5   | ō    | r capi                                                                                                                                                                                          |          | terrup | t. If ET | imer 2 overflow<br>2 = 0, the Timer 2     |
| ES             | I     | E.4   | r    | enables or disables the Serial Port inter-<br>rupt. If ES = 0, the Serial Port interrupt is<br>disabled.                                                                                        |          |        |          |                                           |
| ET1            | 1     | E.3   | . ir | enables or disables the Timer 1 Overflow<br>interrupt. If ET1 = 0, the Timer 1 interrupt<br>is disabled.                                                                                        |          |        |          |                                           |
| EX1            | · • I | E.2   |      |                                                                                                                                                                                                 |          |        |          | nal Interrupt 1.<br>upt 1 is disabled.    |
| ETO            |       | E.1   | ir   |                                                                                                                                                                                                 | pt. If E |        |          | imer 0 Overflow<br>Fimer 0 Interrupt      |
| EXO            | 1     | Ę.0   |      |                                                                                                                                                                                                 |          |        |          | nal Interrupt 0 . If<br>pt 0 is disabled. |

Figure 7-23, IE: Interrupt Enable Register

Each of these interrupt sources can be individually enabled or disabled by setting or clearing a bit in Special Function Register IE (Figure 7-23). Note that IE contains also a global disable bit, EA, which disables all interrupts at once.

### 7.8.1 Priority Level Structure

Each interrupt source can also be individually programmed to one of two priority levels by setting or clearing a bit in Special Function Register IP (Figure 7-24). A lowpriority interrupt can itself be interrupted by a high-priority interrupt, but not by another low-priority interrupt. A high-priority interrupt can't be interrupted by any other interrupt source.

|        | (MSB)    | (LSB)                                                                                                    |
|--------|----------|----------------------------------------------------------------------------------------------------------|
|        | XXF      | PT2 PS PT1 PX1 PT0 PX0                                                                                   |
| Symbol | Position | Function                                                                                                 |
| -      | IP.7     | reserved                                                                                                 |
| -      | IP.6     | reserved                                                                                                 |
| PT2    | IP.5     | defines the Timer 2 interrupt priority<br>level. PT2 = 1 programs it to the higher<br>priority level.    |
| PS     | IP.4     | defines the Serial Port Interrupt priority<br>level. PS = 1 programs it to the higher<br>priority level. |
| PT1    | IP.3     | defines the Timer 1 interrupt priority<br>level. PT1 = 1 programs it to the higher<br>priority level.    |
| PX1    | IP.2     | defines the External Interrupt 1 priority<br>level. PX1 = 1 programs it to the higher<br>priority level. |
| РТО    | IP.1     | defines the Timer 0 interrupt priority<br>level. PT0 = 1 programs it to the higher<br>priority level.    |
| PXO    | IP.0     | defines the External Interrupt 0 priority<br>level. PX0 = 1 programs it to the higher<br>priority level. |

Figure 7-24. IP: Interrupt Priority Register

If two requests of different priority levels are received simultaneously, the request of higher priority level is serviced. If requests of the same priority level are received simultaneously, an internal polling sequence determines which request is serviced. Thus within each priority level there is a second priority structure determined by the polling sequence, as follows:

|      | SOURCE     | PRIORITY WITHIN LEVEL |  |  |  |
|------|------------|-----------------------|--|--|--|
| 1.   | IEO        | (highest)             |  |  |  |
| 2.   | TF0        |                       |  |  |  |
| 3.   | IE1        |                       |  |  |  |
| 4.   | TF1        |                       |  |  |  |
| 5. È | ŘI + TI    |                       |  |  |  |
| 6.   | TF2 + EXF2 | (lowest)              |  |  |  |

Note that the "priority within level" structure is only used to resolve simultaneous requests of the same priority level.

### 7.8.2 How Interrupts Are Handled

The interrupt flags are sampled at S5P2 of every machine cycle. The samples are polled during the following machine cycle. If one of the flags was in a set condition at S5P2 of the preceding cycle, the polling cycle will find it and the interrupt system will generate an LCALL to the appropriate service routine, provided this hardware-generated LCALL is not blocked by any of the following conditions:

- 1. An interrupt of equal or higher priority level is already in progress.
- 2. The current (polling) cycle is not the final cycle in the execution of the instruction in progress.
- 3. The instruction in progress is RETI or any access to the IE or IP registers.

Any of these three conditions will block the generation of the LCALL to the interrupt service routine. Condition 2 ensures that the instruction in progress will be completed



Figure 7-25. Interrupt Response Timing Diagram

before vectoring to any service routine. Condition 3 ensures that if the instruction in progress is RETI or any access to IE or IP, then at least *one more* instruction will be executed before any interrupt is vectored to.

The polling cycle is repeated with each machine cycle, and the values polled are the values that were present at S5P2 of the previous machine cycle. Note then that if an interrupt flag is active but not being responded to for one of the above conditions, if the flag is not *still* active when the blocking condition is removed, the denied interrupt will not be serviced. In other words, the fact that the interrupt flag was once active but not serviced is not remembered. Every polling cycle is new.

The polling cycle/LCALL sequence is illustrated in Figure 7-25.

Note that if an interrupt of higher priority level goes active prior to S5P2 of the machine cycle labeled C3 in Figure 7-25, then in accordance with the above rules it will be vectored to during C5 and C6, without any instruction of the lower priority routine having been executed.

Thus the processor acknowledges an interrupt request by executing a hardware-generated LCALL to the appropriate servicing routine. In some cases it also clears the flag that generated the interrupt, and in other cases it doesn't. It never clears the Serial Port or Timer 2 flags. This has to be done in the user's software. It clears an external interrupt flag (IE0 or IE1) only if it was transition-activated. The hardware-generated LCALL pushes the contents of the Program Counter onto the stack (but it does not save the PSW) and reloads the PC with an address that depends on the source of the interrupt being vectored to, as shown below.

|            | VECTOR  |
|------------|---------|
| SOURCE     | ADDRESS |
| IE0        | 0003H   |
| TF0        | 000BH   |
| IE1        | 0013H   |
| TF1        | 001BH   |
| RI + TI    | 0023H   |
| TF2 + EXF2 | 002BH   |

x

Execution proceeds from that location until the RETI instruction is encountered. The RETI instruction informs the processor that this interrupt routine is no longer in progress, then pops the top two bytes from the stack and reloads the Program Counter. Execution of the interrupted program continues from where it left off.

Note that a simple RET instruction would also have returned execution to the interrupted program, but it would have left the interrupt control system thinking an interrupt was still in progress.

### 7.8.3 External Interrupts

The external sources can be programmed to be levelactivated or transition-activated by setting or clearing bit IT1 or IT0 in Register TCON. If ITx = 0, external interrupt x is triggered by a detected low at the INTx pin. If ITx = 1, external interrupt x is edge-triggered. In this mode if successive samples of the INTx pin show a high in one cycle and a low in the next cycle, interrupt request flag IEx in TCON is set. Flag bit IEx then requests the interrupt.

Since the external interrupt pins are sampled once each machine cycle, an input high or low should hold for at least 12 oscillator periods to ensure sampling. If the external interrupt is transition-activated, the external source has to hold the request pin high for at least one cycle, and then hold it low for at least one cycle to ensure that the transition is seen so that interrupt request flag IEx will be set. IEx will be automatically cleared by the CPU when the service routine is called.

If the external interrupt is level-activated, the external source has to hold the request active until the requested interrupt is actually generated. Then it has to deactivate the request before the interrupt service routine is completed, or else another interrupt will be generated.

### 7.8.4 Response Time

The INTO and INTI levels are inverted and latched into IEO and IE1 at S5P2 of every machine cycle. The values are not actually polled by the circuitry until the next machine cycle. If a request is active and conditions are right for it to be acknowledged, a hardware subroutine call to the requested service routine will be the next instruction to be executed. The call itself takes two cycles. Thus, a minimum of three complete machine cycles elapse between activation of an external interrupt request and the beginning of execution of the first instruction of the service routine. Figure 7-25 shows interrupt response timings.

A longer response time would result if the request is blocked by one of the 3 previously listed conditions. If an interrupt of equal or higher priority level is already in progress, the additional wait time obviously depends on the nature of the other interrupt's service routine. If the instruction in progress is not in its final cycle, the additional wait time cannot be more than 3 cycles, since the longest instructions (MUL and DIV) are only 4 cycles long, and if the instruction in progress is RETI or an access to IE or IP, the additional wait time cannot be more than 5 cycles (a maximum of one more cycle to complete the instruction in progress, plus 4 cycles to complete the next instruction if the instruction is MUL or DIV).

Thus, in a single-interrupt system, the response time is always more than 3 cycles and less than 8 cycles.

### 7.9 SINGLE-STEP OPERATION

The 8051 interrupt structure allows single-step execution with very little software overhead. As previously noted, an interrupt request will not be responded to while an interrupt of equal priority level is still in progress, nor will it be responded to after RETI until at least one other instruction has been executed. Thus, once an interrupt routine has been entered, it cannot be re-entered until at least once instruction of the interrupted program is executed. One way to use this feature for single-step operation is to program one of the external interrupts (say, INT0) to be level-activated. The service routine for the interrupt will terminate with the following code:

| JNB  | P3.2,\$ | WAIT HERE TILL INTO                       |
|------|---------|-------------------------------------------|
| JB   | P3.2,\$ | NOW WAIT HERE TILL                        |
| RETI |         | GO BACK AND<br>EXECUTE ONE<br>INSTRUCTION |
|      |         |                                           |

Now if the  $\overline{INT0}$  pin, which is also the P3.2 pin, is held normally low, the CPU will go right into the External Interrupt 0 routine and stay there until  $\overline{INT0}$  is pulsed (from low to high to low). Then it will execute RETI, go back to the task program, execute one instruction, and immediately re-enter the External Interrupt 0 routine to await the next pulsing of P3.2. One step of the task program is executed each time P3.2 is pulsed.

### 7.10 RESET

The reset input is the RST pin, which is the input to a Schmitt Trigger.

A reset is accomplished by holding the RST pin high for at least two machine cycles (24 oscillator periods), *while* the oscillator is running. The CPU responds by executing





an internal reset. It also configures the ALE and PSEN pins as inputs. (They are quasi-bidirectional). The internal reset is executed during the second cycle in which RST is high and is repeated every cycle until RST goes low. It leaves the internal registers as follows:

| REGISTER           | CONTENT       |
|--------------------|---------------|
| PC                 | 0000H         |
| ACC                | 00H           |
| В                  | 00H           |
| PSW                | 00H           |
| SP                 | 07H           |
| DPTR               | 0000H         |
| P0-P3              | 0FFH          |
| IP (8051)          | XXX00000B     |
| IP (8052)          | XX000000B     |
| IE (8051)          | 0XX00000B     |
| IE (8052)          | 0X00000B      |
| TMOD               | 00H           |
| TCON               | 00H           |
| T2CON (8052 only)  | 00H           |
| THO                | 00H           |
| TLO                | 00H           |
| TH1                | 00H           |
| TL1                | 00H           |
| TH2                | 00H           |
| TL2                | 00H           |
| RCAP2H (8052 only) | 00H           |
| RCAP2L (8052 only) | 00H           |
| SCON               | 00H           |
| SBUF               | Indeterminate |
| PCON (HMOS)        | 0XXXXXXXB     |
| PCON (CHMOS)       | 0XXX0000B     |
| · · · ·            |               |

The internal RAM is not affected by reset. When VCC is turned on, the RAM content is indeterminate unless the part is returning from a reduced power mode of operation.

### **POWER-ON RESET**

An automatic reset can be obtained when VCC is turned on by connecting the RST pin to VCC through a 10  $\mu$ f capacitor and to VSS through an 8.2K $\Omega$  resistor, providing the VCC risetime does not exceed a millisecond and the oscillator start-up time does not exceed 10 milliseconds. This power-on reset circuit is shown in Figure 7-26. When power comes on, the current drawn by RST commences to charge the capacitor. The voltage at RST is the difference between VCC and the capacitor voltage, and decreases from VCC as the cap charges. The larger the capacitor, the more slowly VRST decreases. VRST must remain above the lower threshold of the Schmitt Trigger long enough to effect a complete reset. The time required is the oscillator start-up time, plus 2 machine cycles.

### 7.11 POWER-SAVING MODES OF OPERATION

For applications where power consumption is a critical factor, both the HMOS and CHMOS versions provide reduced power modes of operation. For the CHMOS ver-

sion of the 8051 the reduced power modes, Idle and Power Down, are standard features. In the HMOS versions a reduced power mode is available, but not as a standard feature. The local sales office will provide ordering information for users requiring this feature.

### 7.11.1 HMOS Power Down Mode

The power down mode in the HMOS devices allows one to reduce VCC to zero while saving the on-chip RAM through a backup supply connected to the RST pin. To use the feature, the user's system, upon detecting that a power failure is imminent, would interrupt the processor in some manner to transfer relevant data to the on-chip RAM and enable the backup power supply to the RST pin before VCC falls below its operating limit. When power returns, the backup supply needs to stay on long enough to accomplish a reset, and then can be removed so that normal operation can be resumed.

### 7.11.2 CHMOS Power Reduction Modes

CHMOS versions have two power-reducing modes, Idle and Power Down. The input through which backup power is supplied during these operations is VCC. Figure 7-27 shows the internal circuitry which implements these features. In the Idle mode (IDL = 1), the oscillator continues to run and the Interrupt, Serial Port, and Timer blocks continue to be clocked, but the clock signal is gated off to the CPU. In Power Down (PD = 1), the oscillator is frozen. The Idle and Power Down modes are activated by setting bits in Special Function Register PCON. The address of this register is 87H. Figure 7-28 details its contents.

### **IDLE MODE**

An instruction that sets PCON.0 causes that to be the last instruction executed before going into the Idle mode. In

| (MSB)     |                                                                                                                                                     |                           | ,         |          |         | (LSB) |  |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|-----------|----------|---------|-------|--|
| SMOD      | -   -                                                                                                                                               | •   -                     | GF1       | GF0      | PD      | IDL   |  |
| Symbol    | Position                                                                                                                                            | Name and                  | d Functio | n        |         |       |  |
| SMOD      | PCON.7 Double Baud rate bit. When set to a<br>1, the baud rate is doubled when<br>the serial port is being used in<br>either modes 1, 2 or 3.       |                           |           |          |         |       |  |
|           | PCON.6                                                                                                                                              | (Reserved                 |           |          |         |       |  |
| -         | PCON.5                                                                                                                                              | Reserved                  |           |          |         |       |  |
|           | PCON.4                                                                                                                                              | (Reserved)                |           |          |         |       |  |
| GF1       | PCON.3                                                                                                                                              | General-purpose flag bit. |           |          |         |       |  |
| GF0       | PCON.2                                                                                                                                              | General-                  |           |          |         |       |  |
| PD        | PCON.1                                                                                                                                              | Power Do                  |           |          | nis bit |       |  |
|           |                                                                                                                                                     | activates                 |           |          |         |       |  |
| IDL       | PCON.0                                                                                                                                              | Idle mode                 | bit. Sett | ing this | bit ac- |       |  |
| takes pro | tivates idle mode operation.<br>If 1s are written to PD and IDL at the same time, PD<br>takes precedence. The reset value of PCON is<br>(0XXX0000). |                           |           |          |         |       |  |

Figure 7-28. PCON: Power Control Register

the Idle mode, the internal clock signal is gated off to the CPU, but not to the Interrupt, Timer, and Serial Port functions. The CPU status is preserved in its entirety: the Stack Pointer, Program Counter, Program Status Word, Accumulator, and all other registers maintain their data during Idle. The port pins hold the logical states they had at the time Idle was activated. ALE and PSEN hold at logic high levels.

There are two ways to terminate the Idle. Activation of any enabled interrupt will cause PCON.0 to be cleared by hardware, terminating the Idle mode. The interrupt will be serviced, and following RETI the next instruction to be executed will be the one following the instruction that put the device into Idle.

The flag bits GF0 and GF1 can be used to give an indication if an interrupt occurred during normal operation or



Figure 7-27. Idle and Power Down Hardware

during an Idle. For example, an instruction that activates Idle can also set one or both flag bits. When Idle is terminated by an interrupt, the interrupt service routine can examine the flag bits.

The other way of terminating the Idle mode is with a hardware reset. Since the clock oscillator is still running, the hardware reset needs to be held active for only two machine cycles (24 oscillator periods) to complete the reset.

### POWER DOWN MODE

An instruction that sets PCON.1 causes that to be the last instruction executed before going into the Power Down mode. In the Power Down mode, the on-chip oscillator is stopped. With the clock frozen, all functions are stopped, but the on-chip RAM and Special Function Registers are held. The port pins output the values held by their respective SFRs. ALE and  $\overrightarrow{PSEN}$  output lows.

The only exit from Power Down is a hardware reset. Reset redefines all the SFRs, but does not change the on-chip RAM.

In the Power down mode of operation, VCC can be reduced to minimize power consumption. Care must be taken, however, to ensure that VCC is not reduced before the Power Down mode is invoked, and that VCC is restored to its normal operating level, before the Power Down mode is terminated. The reset that terminates Power Down also frees the oscillator. The reset should not be activated before VCC is restored to its normal operating level, and must be held active long enough to allow the oscillator to restart and stabilize (normally less than 10 msec).

### 7.12 8751H

The 8751H is the EPROM member of the MCS-51 family. This means that the on-chip Program Memory can be electrically programmed, and can be erased by exposure to ultraviolet light. The 8751H also has a provision for denying external access to the on-chip Program Memory, in order to protect its contents against software piracy.

### 7.12.1 Programming the EPROM

To be programmed, the 8751H must be running with a 4 to 6 MHz oscillator. (The reason the oscillator needs to be running is that the internal bus is being used to transfer address and program data to appropriate internal registers.) The address of an EPROM location to be programmed is applied to Port 1 and pins P2.0–P2.3 of Port 2, while the data byte is applied to Port 0. Pins P2.4–P2.6 and PSEN should be held low, and P2.7 and RST high. (These are all TTL levels except RST, which requires 2.5V for a logic high.) EA/VPP is held normally high, and is pulsed to +21V. While EA/VPP is at 21V, the ALE/PROG pin, which is normally being held high, is pulsed low for 50 msec. Then EA/VPP is returned to high. This setup is shown in Figure 7.29. Detailed timing specifications are provided in the 8751H data sheet.

Note: The  $\overline{EA}$  pin must not be allowed to go above the maximum specified VPP level of 21.5V for any amount of time. Even a narrow glitch above that voltage level can cause permanent damage to the device. The VPP source should be well regulated and free of glitches.

### 7.12.2 Program Verification

If the program security bit has not been programmed, the on-chip Program Memory can be read out for verification



Figure 7-29. Programming the 8751H

purposes, if desired, either during or after the programming operation. The required setup, which is shown in Figure 7.30, is the same as for programming the EPROM except that pin P2.7 is held at TTL low (or used as an active-low read strobe). The address of the Program Memory location to be read is applied to Port 1 and pins P2.0-P2.3. The other Port 2 pins and  $\overrightarrow{PSEN}$  are held low. ALE,  $\overrightarrow{EA}$ , and RST are held high. The contents of the addressed location will come out on Port 0. External pullups are required on Port 0 for this operation.

### 7.12.3 Program Memory Security

The 8751H contains a security bit, which, once programmed, denies electrical access by any external means to the on-chip Program Memory. The setup and procedure for programming the security bit are the same as for normal programming, except that pin P2.6 is held at TTL high. The setup is shown in Figure 7.31. Port 0, Port 1, and pins P2.0–P2.3 of Port 2 may be in any state.

Once the security bit has been programmed, it can be deactivated only by full erasure of the Program Memory. While it is programmed, the internal Program Memory cannot be read out, the device cannot be further programmed, and it *cannot execute external program memory*. Erasing the EPROM, thus deactivating the security bit, restores the device's full functionality. It can then be re-programmed.

### 7.12.4 Erasure Characteristics

Erasure of the 8751H Program Memory begins to occur when the chip is exposed to light with wavelengths shorter



Figure 7-30. Program Verification in the 8751H and 8051





than approximately 4,000 Angstroms. Since sunlight and fluorescent lighting have wavelengths in this range, exposure to these light sources over an extended time (about 1 week in sunlight, or 3 years in room-level fluorescent lighting) could cause inadvertent erasure. If an application subjects the 8751H to this type of exposure, it is suggested that an opaque label be placed over the window.

The recommended erasure procedure is exposure to ultraviolet light (at 2537 Angstroms) to an integrated dose of at least 15 W/cm<sup>2</sup>. Exposing the 8751H to an ultraviolet lamp of 12,000  $\mu$ W/cm<sup>2</sup> rating for 20 to 30 minutes, at a distance of about 1 inch, should be sufficient.

Erasure leaves the array in an all 1s state.

### 7.13 MORE ABOUT THE ON-CHIP OSCILLATOR 7.13.1 HMOS Versions

The on-chip oscillator circuitry for the HMOS (HMOS-I and HMOS-II) members of the MCS-51 family is a single stage linear inverter (Figure 7-32), intended for use as a crystal-controlled, positive reactance oscillator (Figure 7-33). In this application the crystal is operated in its fundamental response mode as an inductive reactance in parallel resonance with capacitance external to the crystal.



Figure 7-32. On-Chip Oscillator Circuitry in the HMOS Versions of the MCS-51 Family



### Figure 7-33. Using the HMOS On-Chip Oscillator

The crystal specifications and capacitance values (C1 and C2 in Figure 7-33) are not critical. 30 pF can be used in these positions at any frequency with good quality crystals. A ceramic resonator can be used in place of the crystal in cost-sensitive applications. When a ceramic resonator is used, C1 and C2 are normally selected to be of somewhat higher values, typically, 47 pF. The manufacturer of the ceramic resonator should be consulted for recommendations on the values of these capacitors.

A more in-depth discussion of crystal specifications, ce-



Figure 7-34. Driving the HMOS MCS-51 Parts with an External Clock Source

ramic resonators, and the selection of values for C1 and C2 can be found in Application Note AP-155, "Oscillators for Microcontrollers," which is included in this manual.

To drive the HMOS parts with an external clock source, apply the external clock signal to XTAL2, and ground XTAL1, as shown in Figure 7-34. A pull-up resistor may be used (to increase noise margin), but is optional if VOH of the driving gate exceeds the VIHMIN specification of XTAL2.

### 7.13.2 CHMOS

The on-chip oscillator circuitry for the 80C51, shown in Figure 7-35, consists of a single stage linear inverter intended for use as a crystal-controlled, positive reactance oscillator in the same manner as the HMOS parts. However, there are some important differences.

One difference is that the 80C51 is able to turn off its oscillator under software control (by writing a 1 to the PD bit in PCON). Another difference is that in the 80C51 the internal clocking circuitry is driven by the signal at XTAL1, whereas in the HMOS versions it is by the signal at XTAL2.

The feedback resistor Rf in Figure 7-35 consists of paralleled n- and p-channel FETs controlled by the PD bit, such that Rf is opened when PD = 1. The diodes D1 and D2, which act as clamps to VCC and VSS, are parasitic to the Rf FETs.



Figure 7-35. On-Chip Oscillator Circuitry in the CHMOS Versions of the MCS-51 Family



Figure 7-36. Using the CHMOS On-Chip Oscillator

The oscillator can be used with the same external components as the HMOS versions, as shown in Figure 7-36. Typically, C1 = C2 = 30 pF when the feedback element is a quartz crystal, and C1 = C2 = 47 pF when a ceramic resonator is used.

To drive the CHMOS parts with an external clock source, apply the external clock signal to XTAL1, and leave XTAL2 float, as shown in Figure 7-37.

The reason for this change from the way the HMOS part is driven can be seen by comparing Figures 7-32 and 7-35. In the HMOS devices the internal timing circuits are driven by the signal at XTAL2. In the CHMOS devices the internal timing circuits are driven by the signal at XTAL1.



Figure 7-37. Driving the CHMOS MCS-51 Parts with an External Clock Source

### 7.14 INTERNAL TIMING

Figures 7-38 through 7-41 show when the various strobe and port signals are clocked internally. The figures do not show rise and fall times of the signals, nor do they show propagation delays between the XTAL2 signal and events at other pins.

Rise and fall times are dependent on the external loading that each pin must drive. They are often taken to be something in the neighborhood of 10 nsec, measured between 0.8V and 2.0V.

Propagation delays are different for different pins. For a given pin they vary with pin loading, temperature, VCC, and manufacturing lot. If the XTAL2 waveform is taken as the timing reference, prop delays may vary from 25 to 125 nsec.

The AC Timings section of the data sheets do not reference any timing to the XTAL2 waveform. Rather, they relate the critical edges of control and input signals to each other. The timings published in the data sheets include the effects of propagation delays under the specified test conditions.

### 7.15 MCS-51 PIN DESCRIPTIONS

VCC: Supply voltage.

VSS: Circuit ground potential.

**Port 0:** Port 0 is an 8-bit open drain bidirectional I/O port. As an open drain output port it can sink 8 LS TTL loads. Port 0 pins that have 1s written to them float, and in that state will function as high-impedance inputs. Port 0 is also the multiplexed low-order address and data bus during accesses to external memory. In this application it uses strong internal pullups when emitting 1s. Port 0 also emits code bytes during program verification. In that application, external pullups are required.

**Port 1:** Port 1 is an 8-bit bidirectional I/O port with internal pullups. The port 1 output buffers can sink/source 4 LS TTL loads. Port 1 pins that have 1s written to them are pulled high by the internal pullups, and in that state can be used as inputs. As inputs, Port 1 pins that are externally being pulled low will source current (IIL, on the data sheet) because of the internal pullups.

In the 8052, pins P1.0 and P1.1 also serve the alternate functions of T2 and T2EX. T2 is the Timer 2 external input. T2EX is the input through which a Timer 2 "capture" is triggered.

**Port 2:** Port 2 is an 8-bit bidirectional I/O port with internal pullups. The Port 2 output buffers can sink/source 4 LS TTL loads. Port 2 emits the high-order address byte during accesses to external memory that use 16-bit addresses. In this application it uses the strong internal pullups when emitting 1s. Port 2 also receives the high-order address and control bits during 8751H programming and verification, and during program verification in the 8051AH.

**Port 3:** Port 3 is an 8-bit bidirectional I/O port with internal pullups. It also serves the functions of various special features of the MCS-51 Family, as listed below:

| PORT PIN | ALTERNATE FUNCTION          |
|----------|-----------------------------|
| P3.0     | RXD (serial input port)     |
| P3.1     | TXD (serial output port)    |
| P3.2     | INTO (external interrupt 0) |
| P3.3     | INT1 (external interrupt 1) |
| P3.4     | T0 (Timer 0 external input) |
| P3.5     | T1 (Timer 1 external input) |
| P3.6     | WR (external data memory    |
|          | write strobe)               |
| P3.7     | RD (external data memory    |
|          | read strobe)                |

The Port 3 output buffers can source/sink 4 LS TTL loads.

**RST:** Reset input. A high on this pin for two machine cycles while the oscillator is running resets the device.

**ALE/PROG:** Address Latch Enable output pulse for latching the low byte of the address during accesses to external memory. ALE is emitted at a constant rate of 1/6 of the oscillator frequency, for external timing or clocking purposes, even when there are no accesses to external memory. (However, one ALE pulse is skipped during each acces to external **Data** Memory) This pin is also the program pulse input (PROG) during EPROM programming.

**PSEN:** Program Store Enable is the read strobe to external Program Memory. When the device is executing out of external Program Memory, <u>PSEN</u> is activated twice each machine cycle (except that two <u>PSEN</u> activations are skipped during accesses to external **Data** Memory). <u>PSEN</u> is not activated when the device is executing out of internal Program Memory.

**EA/VPP:** When  $\overline{\text{EA}}$  is held high the CPU executes out of internal Program Memory (unless the Program Counter exceeds 0FFFH in the 8051AH, or 1FFFH in the 8052). Holding  $\overline{\text{EA}}$  low forces the CPU to execute out of external memory regardless of the Program Counter value. In the 8031AH and 8032,  $\overline{\text{EA}}$  must be externally wired low. In the 8751H, this pin also receives the 21V programming supply voltage (VPP) during EPROM programming.

XTAL1: Input to the inverting oscillator amplifier.

XTAL2: Output from the inverting oscillator amplifier.

### **MCS®-51 ARCHITECTURE**



Figure 7-38. External Program Memory Fetches



Figure 7-39. External Data Memory Read Cycle



Figure 7-40. External Data Memory Write Cycle



Figure 7-41. Port Operation

# MCS<sup>®</sup>-51 Instruction Set

8

·

# CHAPTER 8 MCS®-51 INSTRUCTION SET

### **8.0 INTRODUCTION**

The MCS®-51 instruction set includes 111 instructions, 49 of which are single-byte, 45 two-byte and 17 three byte. The instruction op code format consists of a function mnemonic followed by a "destination, source" operand field. This field specifies the data type and addressing method(s) to be used.

### **8.1 FUNCTIONAL OVERVIEW**

The MCS-51 instruction set is divided into four functional groups:

- Data Transfer
- Arithmetic
- Logic
- Control Transfer

### 8.1.1 Data Transfer

Data transfer operations are divided into three classes:

- General Purpose
- Accumulator-Specific
- Address-Object

None of these operations affect the PSW flag settings except a POP or MOV directly to the PSW.

### **GENERAL-PURPOSE TRANSFERS**

- MOV performs a bit or a byte transfer from the source operand to the destination operand.
- PUSH increments the SP register and then transfers a byte from the source operand to the stack location currently addressed by SP.
- POP transfer a byte operand from the stack location addressed by SP to the destination operand and then decrements SP.

### ACCUMULATOR SPECIFIC TRANSFERS

- XCH exchanges the byte source operand with register A (accumulator).
- XCHD exchanges the low-order nibble of the byte source operand with the low-order nibble of A.

- MOVX performs a byte move between the External Data Memory and the accumulator. The external address can be specified by the DPTR register (16bit) or the R1 or R0 register (8-bit).
- MOVC moves a byte from Program memory to the accumulator. The operand in A is used as an index into a 256-byte table pointed to by the base register (DPTR or PC). The byte operand accessed is transferred to the accumulator.

### ADDRESS-OBJECT TRANSFER

• MOV DPTR, #data loads 16-bits of immediate data into a pair of destination registers, DPH and DPL.

### 8.1.2 Arithmetic

The 8051 has four basic mathematical operations. Only 8-bit operations using unsigned arithmetic are supported directly. The overflow flag, however, permits the addition and subtraction operation to serve for both unsigned and signed binary integers. Arithmetic can also be performed directly on packed decimal (BCD) representations.

### ADDITION

- INC (increment) adds one to the source operand and puts the result in the operand.
- ADD adds A to the source operand and returns the result to A.
- ADDC (add with Carry) adds A and the source operand, then adds one (1) if CY is set, and puts the result in A.
- DA (decimal-add-adjust for BCD addition) corrects the sum which results from the binary addition of two two-digit decimal operands. The packed decimal sum formed by DA is returned to A. CY is set if the BCD result is greater than 99; otherwise, it is cleared.

### SUBTRACTION

- SUBB (subtract with borrow) subtracts the second source operand from the first operand (the accumulator), subtracts one (1) if CY is set and returns the result to A.
- DEC (decrement) subtracts one (1) from the source operand and returns the result to the operand.

### MULTIPLICATION

• MUL performs an unsigned multiplication of the A register by the B register, returning a double-byte result. A receives the low-order byte, B receives the high-order byte. OV is cleared if the top half of the result is zero and is set if it is non-zero. CY is cleared. AC is unaffected.

### DIVISION

• DIV performs an unsigned division of the A register by the B register and returns the integer quotient to A and returns the fractional remainder to the B register. Division by zero leaves indeterminate data in registers A and B and sets OV; otherwise OV is cleared. CY is cleared. AC is unaffected.

Unless otherwise stated in the above descriptions, the flags of PSW are affected as follows:

- CY is set if the operation causes a carry to or from the resulting high-order bit. Otherwise CY is cleared.
- AC is set if the operation results in a carry from the low-order four bits of the result (during addition), or a borrow from the high-order bits to the low-order bits (during subtraction); otherwise AC is cleared.
- OV is set if the operation results in a carry to the high-order bit of the result but not a carry from the high-order bit, or vice versa; otherwise OV is cleared. OV is used in two's-complement arithmetic, because it is set when the signed result cannot be represented in 8 bits.
- P is set if the modulo 2 sum of the eight bits in the accumulator is 1 (odd parity); otherwise P is cleared (even parity). When a value is written to the PSW register, the P bit remains unchanged, as it always reflects the parity of A.

### 8.1.3 Logic

The 8051 performs basic logic operations on both bit and byte operands.

### SINGLE-OPERAND OPERATIONS

- CLR sets A or any directly addressable bit to zero (0).
- SETB sets any directly addressable bit to one (1).
- CPL is used to compliment the contents of the A register without affecting any flags, or any directly addressable bit location.

 RL, RLC, RR, RRC, SWAP are the five rotate operations that can be performed on A. RL, rotate left, RR, rotate right, RLC, rotate left through C, RRC, rotate right through C, and SWAP, rotate left four. For RLC and RRC the CY flag becomes equal to the last bit rotated out. SWAP rotates A left four places to exchange bits 3 through 0 with bits 7 through 4.

### **TWO-OPERAND OPERATIONS**

- ANL performs bitwise logical and of with two source operands (for both bit and byte operands) and returns the result to the location of the first operand.
- ORL performs bitwise logical or of two source operands (for both bit and byte operands) and returns the result of the location of the first operand.
- XRL performs bitwise logical or of two source operands (byte operands) and returns the result to the location of the first operand.

### 8.1.4 Control Transfer

There are three classes of control transfer operations: unconditional calls, returns and jumps; conditional jumps; and interrupts. All control transfer operations cause, some upon a specific condition, the program execution to continue at a non-sequential location in program memory.

### UNCONDITIONAL CALLS, RETURNS AND JUMPS

Unconditional calls, returns and jumps transfer control from the current value of the Program Counter to the target address. Both direct and indirect transfers are supported.

 ACALL and LCALL push the address of the next instruction onto the stack and then transfer control to the target address. ACALL is a 2-byte instruction used when the target address is in the current 2K page. LCALL is a 3-byte instruction that addresses the full 64K program space. In ACALL, immediate data (i.e. an 11 bit address field) is concatenated to the five most significant bits of the PC (which is pointing to the next instruction). If ACALL is in the last 2 bytes of a 2K page then the call will be made to the next page since the PC will have been incremented to the next instruction prior to execution.

- RET transfers control to the return address saved on the stack by a previous call operation and decrements the SP register by two (2) to adjust the SP for the popped address.
- AJMP, LJMP and SJMP transfer control to the target operand. The operation of AJMP and LJMP are analogous to ACALL and LCALL. The SJMP (short jump) instruction provides for transfers within a 256 byte range centered about the starting address of the next instruction (-128 to +127).
- JMP @A+DPTR performs a jump relative to the DPTR register. The operand in A is used as the offset (0-255) to the address in the DPTR register. Thus, the effective destination for a jump can be anywhere in the Program Memory space.

### **CONDITIONAL JUMPS**

Conditional jumps perform a jump contingent upon a specific condition. The destination will be within a 256byte range centered about the starting address of the next instruction (-128 to +127).

- JZ performs a jump if the accumulator is zero.
- JNZ performs a jump if the accumulator is not zero.
- JC performs a jump if the carry flag is set.
- JNC performs a jump if the carry flag is not set.
- JB performs a jump if the Direct Addressed bit is set.
- JNB performs a jump if the Direct Addressed bit is not set.
- JBC performs a jump if the Direct Addressed bit is set and then clears the Direct Addressed bit.
- CJNE compares the first operand to the second operand and performs a jump if they are not equal. CY is set if the first operand is less than the second operand; otherwise it is cleared. Comparisons can be

made between A directly addressable bytes in Internal Data Memory or between an immediate value and either A, a register in the selected Register Bank, or a Register-Indirect addressed byte of Internal RAM.

• DJNZ decrements the source operand and returns the result to the operand. A jump is performed if the result is not zero. The source operand of the DJNZ instruction may be any byte in the Internal Data Memory. Either Direct or Register Addressing may be used to address the source operand.

### **INTERRUPT RETURNS**

• RETI transfers control as does RET, but additionally enables interrupts of the current priority level.

### **8.2 INSTRUCTION DEFINITIONS**

Each of the 51 basic MCS-51 operations, ordered alphabetically according to the operation mnemonic are described beginning page 8-8.

A brief example of how the instruction might be used is given as well as its effect on the PSW flags. The number of bytes and machine cycles required, the binary machinelanguage encoding, and a symbolic description or restatement of the function is also provided.

Note: Only the carry, auxiliary-carry, and overflow flags are discussed. The parity bit is computed after every instruction cycle that alters the accumulator. Similarly, instructions which alter directly addressed registers could affect the other status flags if the instruction is applied to the PSW. Status flags can also be modified by bitmanipulation.

For details on the MCS-51 assembler, ASM51, refer to the MCS-51 Macro Assembler User's Guide, publication number 9800937.

Table 8-1 summarized the M 3-51 instruction set.

### Table 8-1. 8051 Instruction Set Summary

Interrupt Response Time: To finish execution of current instruction, respond to the interrupt request, push the PC and to vector to the first instruction of the interrupt service program requires 38 to 81 oscillator periods (3 to 7µs @ 12 MHz).

### INSTRUCTIONS THAT AFFECT FLAG SETTINGS<sup>1</sup>

| INSTRUCTION | FLAG    | INSTRUCTION  | FLAG    |
|-------------|---------|--------------|---------|
|             | C OV AC |              | C OV AC |
| ADD .       | ххх     | CLR C        | 0       |
| ADDC        | ххх     | CPL C        | х       |
| SUBB        | XXX     | ANL C, bit   | х       |
| MUL         | οх      | ANL C, / bit | X       |
| DIV         | οх      | ORL C, bit   | х       |
| DA          | х       | ORL C, bit   | х       |
| RRC         | х       | MOV C, bit   | Х       |
| RLC         | .X      | CJNE         | x       |
| SETB C      | 1       |              | · .     |

'Note that operations on SFR byte address 208 or bit addresses 209-215 (i.e., the PSW or bits in the PSW) will also affect flag settings.

| Notes  | Notes on instruction set and addressing modes:                     |  |  |  |  |  |  |
|--------|--------------------------------------------------------------------|--|--|--|--|--|--|
| Rn     | -Register R7-R0 of the currently selected Register                 |  |  |  |  |  |  |
|        | Bank.                                                              |  |  |  |  |  |  |
| direct |                                                                    |  |  |  |  |  |  |
|        | an Internal Data RAM location (0-127) or a SFR                     |  |  |  |  |  |  |
|        | [i.e., 1/O port, control register, status register, etc.           |  |  |  |  |  |  |
|        | (128–255)].                                                        |  |  |  |  |  |  |
| @Ri    |                                                                    |  |  |  |  |  |  |
|        | indirectly through register R I or R0.                             |  |  |  |  |  |  |
| #data  |                                                                    |  |  |  |  |  |  |
|        | 16-16-bit constant included in instruction                         |  |  |  |  |  |  |
| addr l | 6 -16-bit destination address. Used by LCALL &                     |  |  |  |  |  |  |
|        | LJMP. A branch can be anywhere within the 64K-                     |  |  |  |  |  |  |
|        | byte Program Memory address space.                                 |  |  |  |  |  |  |
| addr i | 11 -11-bit destination address. Used by ACALL &                    |  |  |  |  |  |  |
|        | AJMP. The branch will be within the same 2K-byte                   |  |  |  |  |  |  |
|        | page of program memory as the first byte of the                    |  |  |  |  |  |  |
| rel    | following instruction.                                             |  |  |  |  |  |  |
| rei    | -Signed (two's complement) 8-bit offset byte. Used                 |  |  |  |  |  |  |
|        | by SJMP and all conditional jumps. Range is -128                   |  |  |  |  |  |  |
|        | to +127 bytes relative to first byte of the following instruction. |  |  |  |  |  |  |
| bit    | —Direct Addressed bit in Internal Data RAM or                      |  |  |  |  |  |  |
| on     | -Direct Addressed on in Internal Data KAM OF                       |  |  |  |  |  |  |

Special Function Register. \*

-New operation not provided by 8048AH/8049AH.

| ARITHMETIC OPERATIONS |           |                                                     |      |                      |  |  |  |
|-----------------------|-----------|-----------------------------------------------------|------|----------------------|--|--|--|
| <br>Mr                | nemonic   | Description                                         | Byte | Oscillator<br>Period |  |  |  |
| ADD                   | A,Rn      | Add register to<br>Accumulator                      | 1    | 12                   |  |  |  |
| ADD                   | A, direct | Add direct byte to<br>Accumulator                   | 2    | 12                   |  |  |  |
| ADD                   | A,@Ri     | Add indirect RAM<br>to Accumulator                  | 1    | 12                   |  |  |  |
| ADD                   | A,#data   | Add immediate<br>data to<br>Accumulator             | 2    | 12                   |  |  |  |
| ADDC                  | A,Rn      | Add register to<br>Accumulator<br>with Carry        | 1    | 12                   |  |  |  |
| ADDC                  | A,direct  | Add direct byte to<br>Accumulator<br>with Carry     | 2    | 12                   |  |  |  |
| ADDC                  | A,@Ri     | Add indirect<br>RAM to<br>Accumulator<br>with Carry | 1    | 12                   |  |  |  |
| ADDC                  | A,#data   | Add immediate<br>data to Acc<br>with Carry          | 2    | 12                   |  |  |  |
| SUBB                  | A,Rn      | Subtract register<br>from Acc with<br>borrow        | 1    | 12                   |  |  |  |
| SUBB                  | A,direct  | Subtract direct<br>byte from Acc<br>with borrow     | 2    | 12                   |  |  |  |

### **ARITHMETIC OPERATIONS Cont.**

| Mi   | nemonic | Description                                           | Byte | Oscillator<br>Period |
|------|---------|-------------------------------------------------------|------|----------------------|
| SUBB | A,@Ri   | Subtract indirect<br>RAM from Acc<br>with borrow      | ľ    | 12                   |
| SUBB | A,#data | Subtract<br>immediate data<br>from Acc with<br>borrow | 2    | 12                   |
| INC  | Α       | Increment<br>Accumulator                              | 1    | 12                   |
| INC  | Rn      | Increment register                                    | 1    | 12                   |
| INC  | direct  | Increment direct byte                                 | 2    | 12                   |
| INC  | @Ri     | Increment indirect<br>RAM                             | ł    | 12                   |
| DEC  | Α       | Decrement<br>Accumulator                              | 1    | .12                  |
| DĘC  | Rn      | Decrement<br>Register                                 | 1    | 12                   |
| DEC  | direct  | Decrement direct byte                                 | 2    | 12                   |
| DEC  | @Ri     | Decrement<br>indirect RAM                             | 1    | 12                   |
| INC  | DPTR    | Increment Data<br>Pointer                             | 1    | 24                   |
| MUL  | AB      | Multiply A & B                                        | 1 .  | 48                   |
| DIV  | AB      | Divide A by B                                         | 1    | 48                   |
| DA   | A       | Decimal Adjust<br>Accumulator                         | 1    | 12                   |

All mnemonics copyrighted ©Intel Corporation 1980

| LOGIC | LOGICAL OPERATIONS |                                                              |      |                      |  |
|-------|--------------------|--------------------------------------------------------------|------|----------------------|--|
| м     | nemonic            | Description                                                  | Byte | Oscillator<br>Period |  |
| ANL   | A,Rn               | AND register to<br>Accumulator                               | 1    | 12                   |  |
| ANL   | A, direct          | AND direct byte<br>to Accumulator                            | 2    | 12                   |  |
| ANL   | A,@Ri              | AND indirect<br>RAM to                                       | 1    | 12                   |  |
| AŇL   | A,#data            | Accumulator<br>AND immediate<br>data to                      | 2    | 12                   |  |
| ANL   | direct,A           | Accumulator<br>AND Accumulator<br>to direct byte             | 2    | 12                   |  |
| ANL   | direct,#data       | AND immediate                                                | 3    | 24 .                 |  |
| ORL   | A,Rn               | data to direct byte<br>OR register to                        | I    | 12                   |  |
| ORL   | A, direct          | Accumulator<br>OR direct byte to<br>Accumulator              | 2    | 12                   |  |
| ORL   | A,@Ri              | OR indirect RAM<br>to Accumulator                            | 1    | 12                   |  |
| ORL   | A,#data            | OR immediate                                                 | 2    | 12                   |  |
| ORL   | direct,A           | Accumulator<br>OR Accumulator<br>to direct byte              | 2    | 12                   |  |
| ORL   | direct,#data       | OR immediate<br>data to direct byte                          | 3    | 24                   |  |
| XRL   | A,Rn               | Exclusive-OR<br>register to                                  | 1    | 12                   |  |
| XRL   | A,direct           | Accumulator<br>Exclusive-OR<br>direct byte to<br>Accumulator | 2    | 12                   |  |

| Table 8-1. | 8051 Inst | ruction Set | Summary | (Continued) |
|------------|-----------|-------------|---------|-------------|
|------------|-----------|-------------|---------|-------------|

| LOGIC | LOGICAL OPERATIONS Cont. |                                |      |                      |  |
|-------|--------------------------|--------------------------------|------|----------------------|--|
| Mi    | nemonic                  | Description                    | Byte | Oscillator<br>Period |  |
| XRL   | A,@Ri                    | Exclusive-OR                   | 1    | 12                   |  |
|       |                          | indirect RAM to                |      |                      |  |
|       |                          | Accumulator                    |      |                      |  |
| XRL   | A,#data                  | Exclusive-OR                   | 2    | 12                   |  |
|       |                          | immediate data to              |      |                      |  |
|       |                          | Accumulator                    |      |                      |  |
| XRL   | direct,A                 | Exclusive-OR                   | 2    | 12                   |  |
|       |                          | Accumulator to                 |      |                      |  |
|       |                          | direct byte                    | •    |                      |  |
| XRL   | direct,#data             | Exclusive-OR<br>immediate data | 3    | 24                   |  |
|       |                          | to direct byte                 |      |                      |  |
| CLR   | А                        | Clear                          | ı    | 12                   |  |
| CLK   | A                        | Accumulator                    | 1    | 12                   |  |
| CPL   | А                        | Complement                     | 1    | 12                   |  |
| CIL   |                          | Accumulator                    | •    | 12                   |  |
| RL    | А                        | Rotate                         | 1    | 12                   |  |
|       |                          | Accumulator Left               |      | ,                    |  |
| RLC   | Α                        | Rotate                         | 1    | 12                   |  |
|       |                          | Accumulator Left               |      |                      |  |
|       |                          | through the Carry              |      |                      |  |
| RR    | Α                        | Rotate                         | 1    | 12                   |  |
|       |                          | Accumulator                    |      |                      |  |
|       |                          | Right                          |      |                      |  |
| RRC   | Α                        | Rotate                         | 1    | 12                   |  |
|       |                          | Accumulator                    |      |                      |  |
|       |                          | Right through                  |      |                      |  |
|       |                          | the Carry                      |      |                      |  |
| SWAP  | Α                        | Swap nibbles                   | 1    | 12                   |  |
|       |                          | within the                     |      |                      |  |
| L     |                          | Accumulator                    |      |                      |  |

All mnemonics copyrighted ©Intel Corporation 1980

| DATA       | DATA TRANSFER              |                                                |      |                      | DATA TRANSFER Cont. |              |                                                          |              |                     |
|------------|----------------------------|------------------------------------------------|------|----------------------|---------------------|--------------|----------------------------------------------------------|--------------|---------------------|
| `          | Mnemonic                   | Description                                    | Byte | Oscillator<br>Period |                     | Anemonic     | Description                                              | Byte         | Oscillato<br>Period |
| MOV        | A,Rn                       | Move<br>register to<br>Accumulator             | · 1  | 12                   | ΜΟΥ                 | DPTR,#data16 | Load Data<br>Pointer with a<br>16-bit constant           | 3            | 24                  |
| ΜΟΥ        | A,direct                   | Move direct<br>byte to<br>Accumulator          | 2    | 12                   | MOVC                | A,@A+DPTR    | Move Code<br>byte relative to<br>DPTR to Acc             | I            | 24                  |
| MOV        | A,@Ri                      | Move indirect<br>RAM to<br>Accumulator         | 1    | 12                   | ΜΟΥϹ                | A,@A+PC      | Move Code<br>byte relative to<br>PC to Acc               | <b>I</b><br> | 24                  |
| MOV        | A,#data                    | Move<br>immediate<br>data to<br>Accumulator    | 2.   | 12                   | ΜΟΥΧ                | A,@Ri        | Move<br>External<br>RAM (8-bit<br>addr) to Acc           | 1            | 24                  |
| MOV        | Rn,A                       | Move<br>Accumulator<br>to register             | 1    | 12                   | MOVX                | A,@DPTR      | Move<br>External<br>RAM (16-bit                          | 1            | 24                  |
| MOV        | Rn,direct                  | Move direct<br>byte to<br>register             | 2    | 24                   | моух                | @Ri,A        | addr) to Acc<br>Move Acc to<br>External RAM              | 1            | 24                  |
| MOV        | Rn,#data                   | Move<br>İmmediate data<br>to register          | 2    | 12                   | ΜΟΥΧ                | @DPTR,A      | (8-bit addr)<br>Move Acc to<br>External RAM              | 1            | , 24                |
| MOV        | direct,A                   | Move<br>Accumulator<br>to direct byte          | 2    | 12                   | PUSH                | dırect       | (16-bit addr)<br>Push direct<br>byte onto                | 2            | 24                  |
| MOV<br>MOV | direct,Rn<br>direct,direct | Move register<br>to direct byte<br>Move direct | 2    | 24                   | рор                 | direct       | stack<br>Pop direct<br>byte from                         | 2            | 24                  |
| моч        | direct,@Ri                 | byte to direct<br>Move indirect                | 2    | 24                   | хсн                 | A.Rn         | stack<br>Exchange                                        | 1            | 12                  |
|            |                            | RAM to<br>direct byte                          |      |                      |                     | ,            | register with<br>Accumulator                             |              |                     |
| моу        | direct,#data               | Move<br>immediate data<br>to direct byte       | 3    | 24                   | ХСН                 | A, direct    | Exchange<br>direct byte<br>with                          | 2            | 12                  |
| MOV        | @Ri,A                      | Move<br>Accumulator to<br>indirect RAM         | 1    | 12                   | хсн                 | A,@Ri        | Accumulator<br>Exchange<br>indirect RAM                  | 1            | 12                  |
| ΜΟΥ        | @Ri,dırect                 | Move direct<br>byte to                         | 2    | 24                   | VOUD                |              | with<br>Accumulator                                      |              |                     |
| моу        | @Ri,#data                  | indirect RAM<br>Move<br>immediate<br>data to   | 2    | 12                   | ХСНД                | A,@Ri        | Exchange low-<br>order Digit<br>indirect RAM<br>with Acc | 1            | 12                  |

 Table 8-1.
 8051 Instruction Set Summary (Continued)

.

| BOOLE | BOOLEAN VARIABLE MANIPULATION |                                             |      |                      |  |
|-------|-------------------------------|---------------------------------------------|------|----------------------|--|
| м     | nemonic                       | Description                                 | Byte | Oscillator<br>Period |  |
| CLR   | С                             | Clear Carry                                 | 1    | 12                   |  |
| CLR   | bit                           | Clear direct bit                            | 2    | 12                   |  |
| SETB  | С                             | Set Carry                                   | 1    | 12                   |  |
| SETB  | bit                           | Set direct bit                              | 2    | 12                   |  |
| CPL   | С                             | Complement<br>Carry                         | 1    | 12                   |  |
| CPL   | bit                           | Complement<br>direct bit                    | 2    | 12                   |  |
| ANL   | C,bit                         | AND direct bit<br>to Carry                  | 2    | 24                   |  |
| ANL   | C,/bit                        | AND complement<br>of direct bit<br>to Carry | 2    | 24                   |  |
| ORL   | C,bit                         | OR direct bit<br>to Carry                   | 2    | 24                   |  |
| ORL   | C, / bit                      | OR complement<br>of direct bit<br>to Carry  | 2    | 24                   |  |
| ΜΟΥ   | C,bit                         | Move direct bit<br>to Carry                 | 2    | 12                   |  |
| ΜΟΥ   | bit,C                         | Move Carry to direct bit                    | 2    | 24                   |  |
| JC    | rel                           | Jump if Carry<br>is set                     | 2    | 24                   |  |
| JNC   | rel                           | Jump if Carry<br>not set                    | 2    | 24                   |  |
| JB    | bit,rel                       | Jump if direct<br>Bit is set                | 3    | 24                   |  |
| JNB   | bit,rel                       | Jump if direct<br>Bit is Not set            | 3    | 24                   |  |
| JBC   | bit,rel                       | Jump if direct<br>Bit is set &<br>clear bit | 3    | 24                   |  |

RETI

**PROGRAM BRANCHING Cont.** 

Description

Return from

Mnemonic

Oscillator

Period

24

Byte

1

| KEII  |                | Return from     | 1 | 24 |
|-------|----------------|-----------------|---|----|
|       |                | interrupt       |   |    |
| AJMP  | addrll         | Absolute        | 2 | 24 |
|       |                | Jump            |   |    |
| LJMP  | addr16         | Long Jump       | 3 | 24 |
| SJMP  | rel            | Short Jump      | 2 | 24 |
|       |                | (relative addr) |   |    |
| JMP   | @A+DPTR        | Jump indirect   | 1 | 24 |
|       |                | relative to the |   |    |
|       |                | DPTR            |   |    |
| JZ    | rel            | Jump if         | 2 | 24 |
|       |                | Accumulator     |   |    |
|       |                | is Zero         |   |    |
| JNZ   | rel            | Jump if         | 2 | 24 |
|       |                | Accumulator     |   |    |
|       |                | is Not Zero     |   |    |
| CJNE  | A, direct, rel | Compare         | 3 | 24 |
|       |                | direct byte to  | - | ,  |
|       |                | Acc and Jump    |   |    |
|       |                | if Not Equal    |   |    |
| CJNE  | A,#data,rel    | Compare         | 3 | 24 |
|       |                | immediate to    | 5 |    |
|       |                | Acc and Jump    |   |    |
|       |                | if Not Equal    |   |    |
| CJNE  | Rn,#data,rel   | Compare         | 3 | 24 |
| 00112 |                | immediate to    | 5 | 2. |
|       |                | register and    |   |    |
|       |                | Jump If Not     |   |    |
|       |                | Equal           |   |    |
| CJNE  | @Ri,#data,rel  | Compare         | 3 | 24 |
| CONL  | e minutation   | immediate to    | 5 | 27 |
|       |                | indirect and    |   |    |
|       |                | Jump if Not     |   |    |
|       |                | Equal           |   |    |
| DJNZ  | Rn,rel         | Decrement       | 3 | 24 |
| DJINZ | 11,101         | register and    | 3 | 24 |
|       |                | Jump if Not     |   |    |
|       |                | Zero            |   |    |
| DJNZ  | direct rol     |                 | 2 | 24 |
| DJNZ  | direct, rel    | Decrement       | 3 | 24 |
|       |                | direct byte     |   |    |
|       | <i>,</i>       | and Jump if     |   |    |
| NOP   |                | Not Zero        | , | 12 |
| NUP   |                | No Operation    | 1 | 12 |

| ACALL | addrll | Absolute |
|-------|--------|----------|
|-------|--------|----------|

**PROGRAM BRANCHING** 

Mnemonic

| Absolute<br>Subroutine    | 2                                                               | 24                                                                  |
|---------------------------|-----------------------------------------------------------------|---------------------------------------------------------------------|
| Call                      | 2                                                               | 24                                                                  |
| Subroutine                | 3                                                               | 24                                                                  |
| Call                      |                                                                 |                                                                     |
| Return from<br>Subroutine | 1                                                               | 24                                                                  |
|                           | Subroutine<br>Call<br>Long<br>Subroutine<br>Call<br>Return from | Subroutine<br>Call<br>Long 3<br>Subroutine<br>Call<br>Return from 1 |

Description

All mnemonics copyrighted ©Intel Corporation 1980

Oscillator

Period

Byte

. . ... . . . .

| Function:    | Absolute Call                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Description: | ACALL unconditionally calls a subroutine located at the indicated addr<br>The instruction increments the PC twice to obtain the address of the follow<br>instruction, then pushes the 16-bit result onto the stack (low-order byte fi<br>and increments the stack pointer twice. The destination address is obtained<br>successively concatenating the five high-order bits of the incremented PC,<br>code bits 7-5, and the second byte of the instruction. The subroutine called n<br>therefore start within the same 2K block of the program memory as the five<br>byte of the instruction following ACALL. No flags are affected. |  |  |  |  |  |
| Example:     | Initially SP equals 07H. The label "SUBRTN" is at program memory locat 0345H. After executing the instruction,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
|              | ACALL SUBRTN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
|              | at location 0123H, SP will contain 09H, internal RAM locations 08H and 0 will contain 25H and 01H, respectively, and the PC will contain 0345H.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| Bytes:       | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| Cycles:      | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| Encoding:    | a10 a9 a8 1 0 0 0 1 a7 a6 a5 a4 a3 a2 a1 a0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| Operation:   | ACALL<br>$(PC) \leftarrow (PC) + 2$<br>$(SP) \leftarrow (SP) + 1$<br>$((SP)) \leftarrow (PC7-0)$<br>$(SP) \leftarrow (SP) + 1$<br>$((SP)) \leftarrow (PC15-8)$<br>$(PC10-0) \leftarrow page address$                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |

### ADD A, <src-byte>

| Function:<br>Description:         | Add<br>ADD adds the byte variable indicated to the accumulator, leaving the result in<br>the accumulator. The carry and auxiliary-carry flags are set, respectively, if<br>there is a carry-out from bit 7 or bit 3, and cleared otherwise. When adding un-<br>signed integers, the carry flag indicates an overflow occurred. |  |  |  |
|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                                   | OV is set if there is a carry-out of bit 6 but not out of bit 7, or a carry-out of bit 7 but not bit 6; otherwise OV is cleared. When adding signed integers, OV indicates a negative number produced as the sum of two positive operands, or a positive sum from two negative operands.                                       |  |  |  |
| Example:                          | Four source operand addressing modes are allowed: register, direct, register-<br>indirect, or immediate.<br>The accumulator holds 0C3H (11000011B) and register 0 holds 0AAH<br>(10101010B). The instruction,                                                                                                                  |  |  |  |
|                                   | ADD A,R0<br>will leave 6DH (01101101B) in the accumulator with the AC flag cleared and<br>both the carry flag and OV set to 1.                                                                                                                                                                                                 |  |  |  |
| ADD A,Rn<br>Bytes:<br>Cycles:     | 1                                                                                                                                                                                                                                                                                                                              |  |  |  |
| Encoding:                         | 0 0 1 0 1 r r r                                                                                                                                                                                                                                                                                                                |  |  |  |
| Operation:                        | $\begin{array}{l} \text{ADD} \\ \text{(A)} \longleftarrow \text{(A)} + \text{(Rn)} \end{array}$                                                                                                                                                                                                                                |  |  |  |
| ADD A,direct<br>Bytes:<br>Cycles: | 2<br>1                                                                                                                                                                                                                                                                                                                         |  |  |  |
| Encoding:                         | 0 0 1 0 0 1 0 1 direct address                                                                                                                                                                                                                                                                                                 |  |  |  |
| Operation:                        | ADD<br>(A) $\leftarrow$ (A) + (direct)                                                                                                                                                                                                                                                                                         |  |  |  |



### ADDC A, <src-byte>

### **Function:** Add with Carry

**Description:** ADDC simultaneously adds the byte variable indicated, the carry flag and the accumulator contents, leaving the result in the accumulator. The carry and auxiliary-carry flags are set, respectively, if there is a carry-out from bit 7 or bit 3, and cleared otherwise. When adding unsigned integers, the carry flag indicates an overflow occurred.

OV is set if there is a carry-out of bit 6 but not out of bit 7, or a carryout of bit 7 but not out of bit 6; otherwise OV is cleared. When adding signed integers, OV indicates a negative number produced as the sum of two positive operands or a positive sum from two negative operands.

Four source operand addressing modes are allowed: register, direct, registerindirect, or immediate.

**Example:** The accumulator holds 0C3H (11000011B) and register 0 holds 0AAH (10101010B) with the carry flag set. The instruction,

ADDC A,R0

will leave 6EH (01101110B) in the accumulator with AC cleared and both the carry flag and OV set to 1.

| ADDC A,Rn         | ť                                     |
|-------------------|---------------------------------------|
| Bytes:            | 1                                     |
| Cycles:           | 1                                     |
| Encoding:         | 0 0 1 1 1 r r r                       |
| <b>Operation:</b> | ADDC                                  |
|                   | $(A) - (A) + (C) + (R_n)$             |
| ADDC A,dired      | ct                                    |
| Bytes:            | 2                                     |
| Cycles:           | 1                                     |
| Encoding:         | 0 0 1 1 0 1 0 1 direct address        |
| Operation:        | ADDC                                  |
| -                 | $(A) \leftarrow (A) + (C) + (direct)$ |

| ADDC A,@Ri<br>Bytes:<br>Cycles:   | 1                                               |
|-----------------------------------|-------------------------------------------------|
| Encoding:                         | 0 0 1 1 0 1 1 i                                 |
| Operation:                        | ADDC<br>(A) $-$ (A) + (C) + ((R <sub>i</sub> )) |
| ADDC A,#data<br>Bytes:<br>Cycles: | 2 1                                             |
| Encoding:                         | 0 0 1 1 0 1 0 0 immediate data                  |
| Operation:                        | ADDC<br>(A) $\leftarrow$ (A) + (C) + #data      |

# AJMP addr11

| Function:<br>Description: | Absolute Jump<br>AJMP transfers program execution to the indicated address, which is formed at<br>run-time by concatenating the high-order five bits of the PC ( <i>after</i> incrementing<br>the PC twice), opcode bits 7-5, and the second byte of the instruction. The<br>destination must therefore be within the same 2K block of program memory as<br>the first byte of the instruction following AJMP. |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Example:                  | The label "JMPADR" is at program memory location 0123H. The instruction,                                                                                                                                                                                                                                                                                                                                      |
|                           | AJMP JMPADR                                                                                                                                                                                                                                                                                                                                                                                                   |
|                           | is at location 0345H and will load the PC with 0123H.                                                                                                                                                                                                                                                                                                                                                         |
| Bytes:                    | 2                                                                                                                                                                                                                                                                                                                                                                                                             |
| Cycles:                   | 2                                                                                                                                                                                                                                                                                                                                                                                                             |
| Encoding:                 | a10 a9 a8 0 0 0 0 1 a7 a6 a5 a4 a3 a2 a1 a0                                                                                                                                                                                                                                                                                                                                                                   |
| <b>Operation:</b>         | AJMP                                                                                                                                                                                                                                                                                                                                                                                                          |
|                           | $(PC) \leftarrow (PC) + 2$                                                                                                                                                                                                                                                                                                                                                                                    |
|                           | (PC10-0) – page address                                                                                                                                                                                                                                                                                                                                                                                       |
|                           |                                                                                                                                                                                                                                                                                                                                                                                                               |

# ANL <dest-byte> , <src-byte>

| Function:<br>Description:     | Logical-AND for byte variables<br>ANL performs the bitwise logical-AND operation between the variables in-<br>dicated and stores the results in the destination variable. No flags are affected                                                                                                                                                      |
|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                               | The two operands allow six addressing mode combinations. When the destina-<br>tion is the accumulator, the source can use register, direct, register-indirect, or<br>immediate addressing; when the destination is a direct address, the source can<br>be the accumulator or immediate data.                                                         |
|                               | <i>Note:</i> When this instruction is used to modify an output port, the value used as the original port data will be read from the output data latch, <i>not</i> the input pins.                                                                                                                                                                    |
| Example:                      | If the accumulator holds 0C3H (11000011B) and register 0 holds 0AAH (10101010B) then the instruction,                                                                                                                                                                                                                                                |
|                               | ANL A,RO                                                                                                                                                                                                                                                                                                                                             |
|                               | will leave 41H (01000001B) in the accumulator.                                                                                                                                                                                                                                                                                                       |
|                               | When the destination is a directly addressed byte, this instruction will clear<br>combinations of bits in any RAM location or hardware register. The mask byte<br>determining the pattern of bits to be cleared would either be a constant con-<br>tained in the instruction or a value computed in the accumulator at run-time.<br>The instruction, |
|                               | ANL P1,#01110011B                                                                                                                                                                                                                                                                                                                                    |
|                               | will clear bits 7, 3, and 2 of output port 1.                                                                                                                                                                                                                                                                                                        |
| ANL A,Rn<br>Bytes:<br>Cycles: | 1<br>1                                                                                                                                                                                                                                                                                                                                               |
| Encoding:                     | 0 1 0 1 1 r r r                                                                                                                                                                                                                                                                                                                                      |
|                               |                                                                                                                                                                                                                                                                                                                                                      |

| ANL A, direct                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bytes:                         | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Cycles:                        | $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $1$ , $\mathbf$ |
| Encoding:                      | 0 1 0 1 0 1 0 1 direct address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Operation:                     | ANL<br>(A) $\leftarrow$ (A) $\land$ (direct)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| ANL A,@Ri<br>Bytes:<br>Cycles: |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Encoding:                      | 0 1 0 1 0 1 1 i                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Operation:                     | ANL<br>(A) $\leftarrow$ (A) $\land$ ((Ri))                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ANL A,#data                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bytes:                         | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Cycles:                        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Encoding:                      | 0 1 0 1 0 1 0 0 immediate data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Operation:                     | ANL (A) $\leftarrow$ (A) $\land$ #data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| ANL direct,A                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bytes:                         | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Cycles:                        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Encoding:                      | 0 1 0 1 0 0 1 0 direct address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Operation:                     | ANL (direct) $\leftarrow$ (direct) $\land$ (A)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| ANL 'direct,#d                 | ata                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bytes:                         | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Cycles:                        | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Encoding:                      | 0 1 0 1 0 0 1 1 direct address immediate data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Operation:                     | ANL<br>(direct) < (direct) ^ #data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |



#### ANL C, <src-bit>

| Function:<br>Description:                                  | Logical-AND for bit variables<br>If the Boolean value of the source bit is a logical 0 then clear the carry flag;<br>otherwise leave the carry flag in its current state. A slash ("/") preceding the<br>operand in the assembly language indicates that the logical complement of the<br>addressed bit is used as the source value, <i>but the source bit itself is not affected</i> .<br>No other flags are affected.<br>Only direct bit addressing is allowed for the source operand. |  |  |
|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Example:                                                   | Set the carry flag if, and only if, P1.0=1, ACC. 7=1, and OV=0:MOVC,P1.0ANLC,ACC.7ANLC,ACC.7ANLC,OV;AND WITH INVERSE OF OVERFLOWFLAG                                                                                                                                                                                                                                                                                                                                                     |  |  |
| ANL C,bit<br>Bytes:<br>Cycles:                             | 2<br>2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| Encoding:                                                  | 1 0 0 0 0 1 0 bit address                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| Operation:<br>ANL C,/bit<br>Bytes:<br>Cycles:<br>Encoding: | ANL<br>(C) $\leftarrow$ (C) $\land$ (bit)<br>2<br>2<br>1 0 1 1 0 0 0 0<br>bit address                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| Operation:                                                 | ANL<br>(C) $\leftarrow$ (C) $\land \neg$ (bit)                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |

#### CJNE <dest-byte>,<src-byte>, rel

Function:Compare and Jump if Not Equal.Description:CJNE compares the magnitudes of the first two operands, and branches if their<br/>values are not equal. The branch destination is computed by adding the signed<br/>relative-displacement in the last instruction byte to the PC, after incrementing<br/>the PC to the start of the next instruction. The carry flag is set if the unsigned<br/>integer value of <dest-byte> is less than the unsigned integer value of <src-byte>;<br/>otherwise, the carry is cleared. Neither operand is affected.

The first two operands allow four addressing mode combinations: the accumulator may be compared with any directly addressed byte or immediate data, and any indirect RAM location or working register can be compared with an immediate constant.

Example:

The accumulator contains 34H. Register 7 contains 56H. The first instruction in the sequence,

|         | CJNE  | R7,#60H, NOTEQ |   |              |
|---------|-------|----------------|---|--------------|
| ,       | • • • |                | ; | R7 = 60H.    |
| NOT_EQ: | JC    | REQLOW         | ; | IF R7 < 60H. |
| ;       | • • • | • • • • •      | ; | R7 > 60H.    |

sets the carry flag and branches to the instruction at label NOT\_EQ. By testing the carry flag, this instruction determines whether R7 is greater or less than 60H.

If the data being presented to port 1 is also 34H, then the instruction,

WAIT: CJNE A, P1, WAIT

clears the carry flag and continues with the next instruction in sequence, since the accumulator does equal the data read from P1. (If some other value was being input on P1, the program will loop at this point until the P1 data changes to 34H.)

## CJNE A.direct.rel **Bvtes:** 3 **Cycles:** 2 **Encodina:** 1 0 1 1 0 1 0 1 direct address rel. address **Operation:** $(PC) \leftarrow (PC) + 3$ IF (A) $\leq >$ (direct) THEN $(PC) \leftarrow (PC) + relative offset$ IF (A) < (*direct*) THEN $(C) \leftarrow 1$ ELSE $(C) \leftarrow 0$

| CJNE A,#dat       |                                             |
|-------------------|---------------------------------------------|
| Bytes:            | 3                                           |
| Cycles:           | 2                                           |
| Encoding:         | 1 0 1 1 0 1 0 0 immediate data rel. address |
| <b>Operation:</b> | $(PC) \leftarrow (PC) + 3$                  |
| operation.        | IF(A) <> data                               |
|                   |                                             |
|                   | THEN                                        |
|                   | $(PC) \leftarrow (PC) + relative offset$    |
|                   | IF (A) $< data$                             |
|                   | THEN                                        |
|                   | $(C) \leftarrow 1$                          |
|                   | ELSE                                        |
|                   | $(C) \leftarrow 0$                          |
| CJNE Rn,#da       | ta.rel                                      |
| Bytes:            | 3                                           |
| Cycles:           | 2                                           |
|                   | · · · · · · · · · · · · · · · · · · ·       |
| Encoding:         | 1 0 1 1 1 r r r immediate data rel. address |
| Enovanig.         |                                             |
| <b>Operation:</b> | $(PC) \leftarrow (PC) + 3$                  |
| Operation.        |                                             |
|                   | IF (Rn) <> data                             |
|                   | THEN                                        |
|                   | $(PC) \leftarrow (PC) + relative offset$    |
|                   | IF $(\mathbf{Rn}) < data$                   |
|                   | THEN                                        |
|                   | $(C) \leftarrow 1$                          |
|                   | ELSE                                        |
|                   | (C) ← 0                                     |
| CJNE @Ri,#c       |                                             |
| Bytes:            | 3                                           |
| Cycles:           | 2                                           |
| Cycles.           | 2                                           |
| Éneedines         |                                             |
| Encoding:         | 1 0 1 1 0 1 1 i immediate data rel. address |
| 0                 |                                             |
| Operation:        | $(PC) \leftarrow (PC) + 3$                  |
|                   | IF ((Ri)) $\leq data$                       |
|                   | THEN                                        |
|                   | $(PC) \leftarrow (PC) + relative offset$    |
|                   | IF $((Ri)) < data$                          |
|                   | THEN                                        |
|                   | (C) ← 1                                     |
|                   | ELSE                                        |
|                   |                                             |
|                   | $(C) \leftarrow 0$ 8-17                     |

.

# CLR A

| Function:<br>Description:<br>Example: | Clear Accumulator<br>The accumulator is cleared (all bits set to zero). No flags are affected.<br>The accumulator contains 5CH (01011100B). The instruction, |  |  |
|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                                       | CLR A                                                                                                                                                        |  |  |
| Bytes:<br>Cycles:                     | will leave the accumulator set to 00H (0000000B).<br>1<br>1                                                                                                  |  |  |
| Encoding:                             | 1 1 1 0 0 1 0 0                                                                                                                                              |  |  |
| Operation:                            | CLR<br>(A) ← 0                                                                                                                                               |  |  |

# CLR bit

| Function:<br>Description:    | Clear bit<br>The indicated bit is cleared (reset to zero). No other flags are affected. CLR can<br>operate on the carry flag or any directly addressable bit. |  |  |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Example:                     | Port 1 has previously been written with 5DH (01011101B). The instruction,                                                                                     |  |  |
|                              | CLR P1.2                                                                                                                                                      |  |  |
|                              | will leave the port set to 59H (01011001B).                                                                                                                   |  |  |
| CLR C<br>Bytes:<br>Cycles:   | 1<br>1                                                                                                                                                        |  |  |
| Encoding:                    | 1 1 0 0 0 1 1                                                                                                                                                 |  |  |
| Operation:                   | CLR<br>(C) <b></b> ←0                                                                                                                                         |  |  |
| CLR bit<br>Bytes:<br>Cycles: | 2 ×<br>1 ,                                                                                                                                                    |  |  |
| Encoding:                    | 1 1 0 0 0 1 0 bit address                                                                                                                                     |  |  |
| Operation:                   | CLR<br>(bit) <del>        0</del>                                                                                                                             |  |  |

.

Surger State

| CPL | A |
|-----|---|
|-----|---|

| Function:<br>Description:<br>Example: | Complement Accumulator<br>Each bit of the accumulator is logically complemented (one's complement). Bits<br>which previously contained a one are changed to zero and vice-versa. No flags<br>are affected.<br>The accumulator contains 5CH (01011100B). The instruction, |  |  |
|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                                       | CPL A                                                                                                                                                                                                                                                                    |  |  |
|                                       | will leave the accumulator set to 0A3H (10100011B).                                                                                                                                                                                                                      |  |  |
| Bytes:                                | 1                                                                                                                                                                                                                                                                        |  |  |
| Cycles:                               | 1                                                                                                                                                                                                                                                                        |  |  |
| Encoding:                             | 1 1 1 1 0 1 0 0                                                                                                                                                                                                                                                          |  |  |
| Operation:                            | CPL<br>(A) ← ¬ (A)                                                                                                                                                                                                                                                       |  |  |

# CPL bit

| Function:<br>Description:  | Complement bit<br>The bit variable specified is complemented. A bit which had been a one is<br>changed to zero and vice-versa. No other flags are affected. CLR can operate<br>on the carry or any directly addressable bit.                                  |  |  |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Example:                   | <i>Note:</i> When this instruction is used to modify an output pin, the value used as the original data will be read from the output data latch, <i>not</i> the input pin. Port 1 has previously been written with 5BH (01011101B). The instruction sequence, |  |  |
| ,                          | CPLP1.1CPLP1.2                                                                                                                                                                                                                                                |  |  |
|                            | will leave the port set to 5BH (01011011B).                                                                                                                                                                                                                   |  |  |
| CPL C<br>Bytes:<br>Cycles: | 1 1                                                                                                                                                                                                                                                           |  |  |
| Encoding:                  | 1 0 1 1 0 0 1 1                                                                                                                                                                                                                                               |  |  |
| Operation:                 | CPL<br>(C) ← ¬(C)                                                                                                                                                                                                                                             |  |  |

| CPL bit<br>Bytes:<br>Cycles:<br>Encoding:<br>Operation: | 2<br>1<br>$1 \ 0 \ 1 \ 1 \ 0 \ 0 \ 1 \ 0$ bit address<br>CPL<br>(bit) $\neg$ (bit)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DA A                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Function:<br>Description:                               | <ul> <li>Decimal-adjust Accumulator for Addition</li> <li>DA A adjusts the eight-bit value in the accumulator resulting from the earlier addition of two variables (each in packed-BCD format), producing two four-bit digits. Any ADD or ADDC instruction may have been used to perform the addition.</li> <li>If accumulator bits 3-0 are greater than nine (xxxx1010-xxxx1111), or if the AC flag is one, six is added to the accumulator producing the proper BCD digit in the low-order nibble. This internal addition would set the carry flag if a carry-out of the low-order four-bit field propagated through all high-order bits, but it would not clear the carry flag otherwise.</li> <li>If the carry flag is now set, or if the four high-order bits now exceed nine (1010xxxx-1111xxx), these high-order bits are incremented by six, producing the proper BCD digit in the high-order bits, but wouldn't clear the carry flag if there was a carry-out of the high-order bits, but wouldn't clear the carry. The carry flag thus indicates if the sum of the original two BCD variables is greater than 100, allowing multiple precision decimal addition. OV is not affected.</li> <li>All of this occurs during the one instruction cycle. Essentially, this instruction performs the decimal conversion by adding 00H, 06H, 60H, or 66H to the accumulator, depending on initial accumulator and PSW conditions.</li> <li><i>Note:</i> DA A <i>cannot</i> simply convert a hexadecimal number in the accumulator to BCD notation, nor does DA A apply to decimal subtraction.</li> </ul> |

÷

Example:

The accumulator holds the value 56H (01010110B) representing the packed BCD digits of the decimal number 56. Register 3 contains the value 67H (01100111B) representing the packed BCD digits of the decimal number 67. The carry flag is set. The instruction sequence,

ADDC A,R3 DA A

will first perform a standard twos-complement binary addition, resulting in the value 0BEH (10111110) in the accumulator. The carry and auxiliary carry flags will be cleared.

The Decimal Adjust instruction will then alter the accumulator to the value 24H (00100100B), indicating the packed BCD digits of the decimal number 24, the low-order two digits of the decimal sum of 56, 67, and the carry-in. The carry flag will be set by the Decimal Adjust instruction, indicating that a decimal overflow occurred. The true sum 56, 67, and 1 is 124.

BCD variables can be incremented or decremented by adding 01H or 99H. If the accumulator initially holds 30H (representing the digits of 30 decimal), then the instruction sequence,

ADD A,#99H DA A

will leave the carry set and 29H in the accumulator, since 30 + 99 = 129. The low-order byte of the sum can be interpreted to mean 30 - 1 = 29.

Bytes:

1

1

1 1 0 1

Cycles:

Encoding:

Operation:

DA -contents of Accumulator are BCD IF  $[[(A_{3-0}) > 9] \lor [(AC) = 1]]$ THEN  $(A_{3-0}) \leftarrow (A_{3-0}) + 6$ AND IF  $[[(A_{7-4}) > 9] \lor [(C) = 1]]$ THEN  $(A_{7-4}) \leftarrow (A_{7-4}) + 6$ 

0 1

0 0

## **MCS®-51 INSTRUCTION SET**

| DEC           | byte                   | and the second | and the second second second second                                                                                                                                                                    |
|---------------|------------------------|------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Fun<br>Descri | ction:<br>ption:       | underflow to 0FFH. No flag                                                                                       | lecremented by 1. An original value of 00H will<br>as are affected. Four operand addressing modes are<br>ter, direct, or register-indirect.                                                            |
| Exa           | mple:                  | the original port data will b<br>pins.<br>Register 0 contains 7FH (01                                            | is used to modify an output port, the value used as<br>be read from the output data latch, <i>not</i> the input<br>111111B). Internal RAM locations 7EH and 7FH<br>ectively. The instruction sequence, |
|               | x                      | DEC @R0<br>DEC R0<br>DEC @R0                                                                                     |                                                                                                                                                                                                        |
|               |                        | will leave register 0 set to 7E<br>0FFH and 3FH.                                                                 | H and internal RAM locations 7EH and 7FH set to                                                                                                                                                        |
| E             | A<br>Bytes:<br>ycles:  | 1<br>1                                                                                                           |                                                                                                                                                                                                        |
| Enco          | oding:                 | 0 0 0 1 0 1 0 0                                                                                                  |                                                                                                                                                                                                        |
| Opera         | ation:                 | DEC $(A) \leftarrow (A) - 1$                                                                                     |                                                                                                                                                                                                        |
| E             | Rn<br>Bytes:<br>ycles: | 1                                                                                                                |                                                                                                                                                                                                        |
| Enco          | oding:                 | 0 0 0 1 1 r r r                                                                                                  |                                                                                                                                                                                                        |
| Opera         | ation:                 | DEC $(Rn) \leftarrow (Rn) - 1$                                                                                   |                                                                                                                                                                                                        |
|               |                        |                                                                                                                  |                                                                                                                                                                                                        |

| DEC direct<br>Bytes:<br>Cycles: | 2<br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Encoding:                       | 0 0 0 1 0 1 0 1 direct address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| Operation:                      | DEC $(direct) \leftarrow (direct) - 1$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| DEC @Ri<br>Bytes:<br>Cycles:    | 1<br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| Encoding:                       | 0 0 0 1 0 1 1 i                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| Operation:                      | DEC $((Ri)) - 1$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| DIV AB                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| Function:<br>Description:       | Divide<br>DIV AB divides the unsigned eight-bit integer in the accumulator by the un-<br>signed eight-bit integer in register B. The accumulator receives the integer part<br>of the quotient; register B receives the integer remainder. The carry and OV<br>flags will be cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| Example:                        | <ul> <li>Exception: if B had originally contained 00H, the values returned in the accumulator and B-register will be undefined and the overflow flag will be set. The carry flag is cleared in any case.</li> <li>The accumulator contains 251 (0FBH or 11111011B) and B contains 18 (12H or 00010010B). The instruction,</li> <li>DIV AB</li> <li>will leave 13 in the accumulator (0DH or 00001101B) and the value 17 (11H or 000010010D) in B and the value 17 (11H or 000010010D) in B and the value 17 (11H or 000010010D) in B and the value 17 (11H or 00001101B) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and the value 17 (11H or 00001101D) in B and 00001101D) in B an</li></ul> |  |  |
| Bytes:<br>Cycles:               | 00010001B) in B, since $251 = (13 \times 18) + 17$ . Carry and OV will both be cleared.<br>1<br>4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| Encoding:                       | 1 0 0 0 0 1 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| Operation:                      | DIV<br>$(A)_{15-8} (A) / (B)$<br>$(B)_{7-0} (A) / (B)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |

#### DJNZ <byte>,<rel-addr>

**Function:** Decrement and Jump if Not Zero

**Description:** DJNZ decrements the location indicated by 1, and branches to the address indicated by the second operand if the resulting value is not zero. An original value of 00H will underflow to 0FFH. No flags are affected. The branch destination would be computed by adding the signed relative-displacement value in the last instruction byte to the PC, after incrementing the PC to the first byte of the following instruction.

The location decremented may be a register or directly addressed byte.

*Note:* When this instruction is used to modify an output port, the value used as the original port data will be read from the output data latch, *not* the input pins.

**Example:** Internal RAM locations 40H, 50H, and 60H contain the values 01H, 70H, and 15H, respectively. The instruction sequence,

| DJNZ | 40H,LABEL_1 |
|------|-------------|
| DJNZ | 50H,LABEL_2 |
| DJNZ | 60H,LABEL3  |

will cause a jump to the instruction at label LABEL\_2 with the values 00H, 6FH, and 15H in the three RAM locations. The first jump was *not* taken because the result was zero.

This instruction provides a simple way of executing a program loop a given number of times, or for adding a moderate time delay (from 2 to 512 machine cycles) with a single instruction. The instruction sequence,

|         | MOV  | R2,#8     |
|---------|------|-----------|
| TOGGLE: | CPL  | P1.7      |
|         | DJNZ | R2,TOGGLE |

will toggle P1.7 eight times, causing four output pulses to appear at bit 7 of output port 1. Each pulse will last three machine cycles; two for DJNZ and one to alter the pin.



#### INC <byte>

Function:IncrementDescription:INC increments the indicated variable by 1. An original value of 0FFH will<br/>overflow to 00H. No flags are affected. Three addressing modes are allowed:<br/>register, direct, or register-indirect.

*Note:* When this instruction is used to modify an output port, the value used as the original port data will be read from the output data latch, *not* the input pins.

| Example:                        | Register 0 contains 7EH (011111110B). Internal RAM locations 7EH and 7FH contain 0FFH and 40H, respectively. The instruction sequence, |  |  |
|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                                 | INC @R0<br>INC R0<br>INC @R0                                                                                                           |  |  |
|                                 | will leave register 0 set to 7FH and internal RAM locations 7EH and 7FH holding (respectively) 00H and 41H.                            |  |  |
| INC A<br>Bytes:<br>Cycles:      | 1                                                                                                                                      |  |  |
| Encoding:                       | 0 0 0 0 0 1 0 0                                                                                                                        |  |  |
| Operation:                      | INC<br>(A) $\leftarrow$ (A) + 1                                                                                                        |  |  |
| INC Rn<br>Bytes:<br>Cycles:     | 1<br>1                                                                                                                                 |  |  |
| Encoding:                       | 0 0 0 0 1 r r r                                                                                                                        |  |  |
| Operation:                      | INC $(Rn) \leftarrow (Rn) + 1$                                                                                                         |  |  |
| INC direct<br>Bytes:<br>Cycles: | 2 1                                                                                                                                    |  |  |
| Encoding:                       | 0 0 0 0 0 1 0 1 direct address                                                                                                         |  |  |
| Operation:                      | INC $(direct) \leftarrow (direct) + 1$                                                                                                 |  |  |

| INC @Ri<br>Bytes:<br>Cycles: | 1<br>1                                                                                                                                                                                                                                                                |  |
|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Encoding:                    | 0 0 0 0 0 1 1 i                                                                                                                                                                                                                                                       |  |
| Operation:                   | INC $((\text{Ri})) \leftarrow ((\text{Ri})) + 1$                                                                                                                                                                                                                      |  |
| INC DPTR                     | · · · ·                                                                                                                                                                                                                                                               |  |
| Function:<br>Description:    | Increment Data Pointer<br>Increment the 16-bit data pointer by 1. A 16-bit increment (modulo 216) is per-<br>formed; an overflow of the low-order byte of the data pointer (DPL) from<br>0FFH to 00H will increment the high-order byte (DPH). No flags are affected. |  |
| Example:                     | This is the only 16-bit register which can be incremented.<br>Registers DPH and DPL contain 12H and 0FEH, respectively. The instruction<br>sequence,<br>INC DPTR<br>INC DPTR<br>INC DPTR<br>will change DPH and DPL to 13H and 01H.                                   |  |
| Bytes:<br>Cycles:            | 1<br>2                                                                                                                                                                                                                                                                |  |
| Encoding:                    | 1 0 1 0 0 0 1 1                                                                                                                                                                                                                                                       |  |
| Operation:                   | INC $(DPTR) \leftarrow (DPTR) + 1$                                                                                                                                                                                                                                    |  |

х. х. х. х.

| JB                                    | bit,rel           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|---------------------------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Function:<br>Description:<br>Example: |                   | Jump if Bit set<br>If the indicated bit is a one, jump to the address indicated; otherwise proceed<br>with the next instruction. The branch destination is computed by adding the<br>signed relative-displacement in the third instruction byte to the PC, after in-<br>crementing the PC to the first byte of the next instruction. <i>The bit tested is not</i><br><i>modified</i> . No flags are affected.<br>The data present at input port 1 is 11001010B. The accumulator holds 56<br>(01010110B). The instruction sequence, |  |  |
|                                       |                   | JB P1.2,LABEL1<br>JB ACC.2,LABEL2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|                                       | Bytes:<br>Cycles: | will cause program execution to branch to the instruction at label LABEL2.<br>3<br>2                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| En                                    | coding:           | 0 0 1 0 0 0 0 0 bit address rel. address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| Ор                                    | eration:          | JB<br>$(PC) \leftarrow (PC) + 3$<br>IF (bit) = 1<br>THEN<br>$(PC) \leftarrow (PC) + rel$                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|                                       | hit rol           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |

| JBC | bit,rel |  |
|-----|---------|--|
|-----|---------|--|

| Function:    | Jump if Bit is set and Clear bit                                                 |  |  |  |  |
|--------------|----------------------------------------------------------------------------------|--|--|--|--|
| Description: | If the indicated bit is one, branch to the address indicated; otherwise proceed  |  |  |  |  |
|              | with the next instruction. In either case, clear the designated bit. The branch  |  |  |  |  |
|              | destination is computed by adding the signed relative-displacement in the third  |  |  |  |  |
|              | instruction byte to the PC, after incrementing the PC to the first byte of the   |  |  |  |  |
|              | next instruction. No flags are affected.                                         |  |  |  |  |
|              | Note: When this instruction is used to test an output pin, the value used as the |  |  |  |  |
| 1            | original data will be read from the output data latch, not the input pin.        |  |  |  |  |
| Example:     | The accumulator holds 56H (01010110B). The instruction sequence,                 |  |  |  |  |
|              | JBC ACC.3,LABEL1                                                                 |  |  |  |  |
|              | JBC ACC.2,LABEL2                                                                 |  |  |  |  |
|              | will cause program execution to continue at the instruction identified by the    |  |  |  |  |
|              | label LABEL2, with the accumulator modified to 52H (01010010B).                  |  |  |  |  |

.

| Bytes:<br>Cycles:                     | 3 2                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Encoding:                             | 0 0 0 1 0 0 0 0 bit address rel. address                                                                                                                                                                                                                                                                                                                                           |
| Operation:                            | JBC<br>(PC) $\leftarrow$ (PC) + 3<br>IF (bit) = 1<br>THEN<br>(bit) $\leftarrow$ 0<br>(PC) $\leftarrow$ (PC) + rel                                                                                                                                                                                                                                                                  |
|                                       |                                                                                                                                                                                                                                                                                                                                                                                    |
| JC rel                                | · .                                                                                                                                                                                                                                                                                                                                                                                |
| Function:<br>Description:<br>Example: | Jump if Carry is set<br>If the carry flag is set, branch to the address indicated; otherwise proceed with<br>the next instruction. The branch destination is computed by adding the signed<br>relative-displacement in the second instruction byte to the PC, after incremen-<br>ting the PC twice. No flags are affected.<br>The carry flag is cleared. The instruction sequence, |
|                                       | JC LABEL1<br>CPL C<br>JC LABEL2                                                                                                                                                                                                                                                                                                                                                    |
| Bytes:<br>Cycles:                     | will set the carry and cause program execution to continue at the instruction identified by the label LABEL2.<br>2<br>2                                                                                                                                                                                                                                                            |
| Encoding:                             | 0 1 0 0 0 0 0 0 rel. address                                                                                                                                                                                                                                                                                                                                                       |
| Operation:                            | JC<br>$(PC) \leftarrow (PC) + 2$<br>IF $(C) = 1$<br>THEN<br>$(PC) \leftarrow (PC) + rel$                                                                                                                                                                                                                                                                                           |

i.

## JMP @A+DPTR

| Function:<br>Description: | pointer, and l<br>dress for sub<br>(modulo 216) | -bit unsigned<br>oad the resul<br>osequent inst<br>: a carry-out<br>bits. Neither | contents of the accumulator with the sixteen-bit data<br>ting sum to the program counter. This will be the ad-<br>ruction fetches. Sixteen-bit addition is performed<br>from the low-order eight bits propagates through the<br>the accumulator nor the data pointer is altered. No |
|---------------------------|-------------------------------------------------|-----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Example:                  |                                                 | ill branch to                                                                     | o 6 is in the accumulator. The following sequence of<br>one of four AJMP instructions in a jump table start-                                                                                                                                                                        |
|                           |                                                 | MOV                                                                               | DPTR,#JMPTBL                                                                                                                                                                                                                                                                        |
|                           |                                                 | JMP                                                                               | @A+DPTR                                                                                                                                                                                                                                                                             |
|                           | JMPTBL:                                         | AJMP                                                                              | LABEL0                                                                                                                                                                                                                                                                              |
| ,                         |                                                 | AJMP                                                                              | LABEL1                                                                                                                                                                                                                                                                              |
|                           |                                                 | AJMP                                                                              | LABEL2                                                                                                                                                                                                                                                                              |
|                           |                                                 | AJMP                                                                              | LABEL3                                                                                                                                                                                                                                                                              |
|                           | to label LAB                                    | EL2. Remem                                                                        | 04H when starting this sequence, execution will jump<br>ber that AJMP is a two-byte instruction, so the jump<br>other address.                                                                                                                                                      |
| Bytes:                    | 1                                               |                                                                                   |                                                                                                                                                                                                                                                                                     |
| Cycles:                   | 2                                               |                                                                                   |                                                                                                                                                                                                                                                                                     |
| -                         | <b>-</b>                                        | •                                                                                 | <b></b>                                                                                                                                                                                                                                                                             |
| Encoding:                 | 0 1 1 1                                         | 0 0 1 1                                                                           |                                                                                                                                                                                                                                                                                     |
| Operation:                | JMP                                             |                                                                                   |                                                                                                                                                                                                                                                                                     |
|                           | (PC) <b>∢</b> —(A)                              | + (DPTR)                                                                          |                                                                                                                                                                                                                                                                                     |

| JNB                                   | bit,rel                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------------------------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Function:<br>Description:<br>Example: |                           | Jump if Bit Not set<br>If the indicated bit is a zero, branch to the indicated address; otherwise proceed<br>with the next instruction. The branch destination is computed by adding the<br>signed relative-displacement in the third instruction byte to the PC, after in-<br>crementing the PC to the first byte of the next instruction. <i>The bit tested is not</i><br><i>modified</i> . No flags are affected.<br>The data present at input port 1 is 11001010B. The accumulator holds 56H<br>(01010110B). The instruction sequence, |
|                                       |                           | JNB P1.3,LABEL1<br>JNB ACC.3,LABEL2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                       | Bytes:<br>ycles:          | will cause program execution to continue at the instruction at label LABEL2.<br>3<br>2                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Enco                                  | oding:                    | 0 0 1 1 0 0 0 0 bit address rel. address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Oper                                  | ation:                    | JNB<br>$(PC) \leftarrow (PC) + 3$<br>IF (bit) = 0<br>THEN (PC) \leftarrow (PC) + rel.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| JNC                                   | rel                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Descri                                | ction:<br>ption:<br>mple: | Jump if Carry not set<br>If the carry flag is a zero, branch to the address indicated; otherwise proceed<br>with the next instruction. The branch destination is computed by adding the<br>signed relative-displacement in the second instruction byte to the PC, after in-<br>crementing the PC twice to point to the next instruction. The carry flag is not<br>modified.<br>The carry flag is set. The instruction sequence,                                                                                                            |
|                                       | •                         | JNC LABEL1<br>CPL C<br>JNC LABEL2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                       |                           | will clear the carry and cause program execution to continue at the instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

will clear the carry and cause program execution to continue at the instruction identified by the label LABEL2.

| Bytes:<br>Cycles: | 2<br>2                                                                                 |
|-------------------|----------------------------------------------------------------------------------------|
| Encoding:         | 0 1 0 1 0 0 0 0 rel. address                                                           |
| Operation:        | JNC<br>$(PC) \leftarrow (PC) + 2$<br>IF $(C) = 0$<br>THEN $(PC) \leftarrow (PC) + rel$ |

| JNZ                                   | rei               |                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------------------------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Function:<br>Description:<br>Example: |                   | Jump if accumulator Not Zero<br>If any bit of the accumulator is a one, branch to the indicated address; other-<br>wise proceed with the next instruction. The branch destination is computed by<br>adding the signed relative-displacement in the second instruction byte to the<br>PC, after incrementing the PC twice. The accumulator is not modified. No<br>flags are affected.<br>The accumulator originally holds 00H. The instruction sequence, |
|                                       |                   | JNZ LABEL1<br>INC A<br>JNZ LABEL2                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                       | Bytes:<br>Sycles: | will set the accumulator to 01H and continue at label LABEL2.<br>2<br>2                                                                                                                                                                                                                                                                                                                                                                                 |
| Enc                                   | oding:            | 0 1 1 1 0 0 0 0 rel. address                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Oper                                  | ration:           | JNZ<br>(PC) $\leftarrow$ (PC) + 2<br>IF (A) $\neq 0$<br>THEN (PC) $\leftarrow$ (PC) + rel                                                                                                                                                                                                                                                                                                                                                               |

| JZ rel                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Function:<br>Description:<br>Example: | Jump if Accumulator Zero<br>If all bits of the accumulator are zero, branch to the address indicated; other-<br>wise proceed with the next instruction. The branch destination is computed by<br>adding the signed relative-displacement in the second instruction byte to the<br>PC, after incrementing the PC twice. The accumulator is not modified. No<br>flags are affected.<br>The accumulator originally contains 01H. The instruction sequence, |
| •                                     | JZ LABEL1<br>DEC A<br>JZ LABEL2                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                       | will change the accumulator to 00H and cause program execution to continue at the instruction identified by the label LABEL2.                                                                                                                                                                                                                                                                                                                           |
| Bytes:<br>Cycles:                     | 2 2                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Encoding:                             | 0 1 1 0 0 0 0 0 rel. address                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Operation:                            | JZ<br>$(PC) \leftarrow (PC) + 2$<br>IF (A) = 0<br>THEN $(PC) \leftarrow (PC) + rel$                                                                                                                                                                                                                                                                                                                                                                     |
|                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

#### LCALL addr16

## Function: Description:

Long Call

LCALL calls a subroutine located at the indicated address. The instruction adds three to the program counter to generate the address of the next instruction and then pushes the 16-bit result onto the stack (low byte first), incrementing the stack pointer by two. The high-order and low-order bytes of the PC are then loaded, respectively, with the second and third bytes of the LCALL instruction. Program execution continues with the instruction at this address. The subroutine may therefore begin anywhere in the full 64K-byte program memory address space. No flags are affected.

| Example:   | initially the stack pointer equals 07H. The label "SUBRTN" is assigned to program memory location 1234H. After executing the instruction,                                                                            |  |  |  |  |  |  |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 1          | LCALL SUBRTN                                                                                                                                                                                                         |  |  |  |  |  |  |
|            | at location 0123H, the stack pointer will contain 09H, internal RAM locations 08H and 09H will contain 26H and 01H, and the PC will contain 1235H.                                                                   |  |  |  |  |  |  |
| Bytes:     | 3                                                                                                                                                                                                                    |  |  |  |  |  |  |
| Cycles:    | 2                                                                                                                                                                                                                    |  |  |  |  |  |  |
| Encoding:  | 0 0 0 1 0 0 1 0 addr15 - addr8 addr7 - addr0                                                                                                                                                                         |  |  |  |  |  |  |
| Operation: | LCALL<br>$(PC) \longleftarrow (PC) + 3$<br>$(SP) \longleftarrow (SP) + 1$<br>$((SP)) \longleftarrow (PC7-0)$<br>$(SP) \longleftarrow (SP) + 1$<br>$((SP)) \longleftarrow (PC15-8)$<br>$(PC) \longleftarrow addr15-0$ |  |  |  |  |  |  |

## LJMP addr16

| Function:<br>Description:<br>Example:        | Long Jump<br>LJMP causes an unconditional branch to the indicated address, by loading the<br>high-order and low-order bytes of the PC (respectively) with the second and<br>third instruction bytes. The destination may therefore be anywhere in the full<br>64K program memory address space. No flags are affected.<br>The label "JMPADR" is assigned to the instruction at program memory loca-<br>tion 1234H. The instruction,<br>LIMP JMPADR |  |  |  |  |  |  |
|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Bytes:<br>Cycles:<br>Encoding:<br>Operation: | at location 0123H will load the program counter with 1234H.<br>3<br>2<br>$0 \ 0 \ 0 \ 0 \ 0 \ 1 \ 0$ addr15 - addr8 addr7 - addr0<br>LJMP<br>(PC) $-addr_{15-0}$                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |

.

# MOV <dest-byte>,<src-byte>

| Function:<br>Description:          | Move byte variable<br>The byte variable indicated by the second operand is copied into the location<br>specified by the first operand. The source byte is not affected. No other register<br>or flag is affected.                                            |  |  |  |  |  |  |  |
|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Example:                           | This is by far the most flexible operation. Fifteen combinations of source and destination addressing modes are allowed.<br>Internal RAM location 30H holds 40H. The value of RAM location 40H is 10H. The data present at input port 1 is 11001010B (0CAH). |  |  |  |  |  |  |  |
|                                    | MOV $R0,#30H$ ; $R0 <= 30H$ MOV $A,@R0$ ; $A <= 40H$ MOV $R1,A$ ; $R1 <= 40H$ MOV $R,@R1$ ; $B <= 10H$ MOV $@R1,P1$ ; $RAM (40H) <= 0CAH$ MOVP2, P1; $P2 #0CAH$                                                                                              |  |  |  |  |  |  |  |
|                                    | leaves the value 30H in register 0, 40H in both the accumulator and register 1, 10H in register B, and 0CAH (11001010B) both in RAM location 40H and output on port 2.                                                                                       |  |  |  |  |  |  |  |
| MOV A,Rn<br>Bytes:<br>Cycles:      | 1<br>1<br>1                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |
| Encoding:                          | 1 1 1 0 1 r r r                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |
| Operation:                         | $\begin{array}{l} \text{MOV} \\ \text{(A)} \\ \hline \end{array} \\ \begin{array}{l} \textbf{(Rn)} \end{array}$                                                                                                                                              |  |  |  |  |  |  |  |
| *MOV A,direct<br>Bytes:<br>Cycles: | 2 1                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
| Encoding:                          | 1 1 1 0 0 1 0 1 direct address                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
| Operation:                         | $MOV (A) \leftarrow (direct)$                                                                                                                                                                                                                                |  |  |  |  |  |  |  |

\*MOV A, ACC is not a valid instruction.

1

## **MCS®-51 INSTRUCTION SET**

| MOV A,@Ri<br>Bytes:               | 1                              |                  |
|-----------------------------------|--------------------------------|------------------|
| Cycles:                           | 1                              | , <b>,</b> , , , |
| Encoding:                         | 1 1 1 0 0 1 1 i                | , · · . ,        |
| Operation:                        | MOV<br>(A) <b>←</b> ((Ri))     |                  |
| MOV A,#data<br>Bytes:<br>Cycles:  | 2<br>1                         |                  |
| Encoding:                         | 0 1 1 1 0 1 0 0 immediate data |                  |
| Operation:                        | MOV<br>(A) ← #data             |                  |
| MOV Rn,A<br>Bytes:<br>Cycles:     | 1                              |                  |
| Encoding:                         | 1 1 1 1 1 r r r                | ,<br>,           |
| Operation:                        | MOV<br>(Rn) ← (A)              |                  |
| MOV Rn,direc<br>Bytes:<br>Cycles: |                                | :                |
| Encoding:                         | 1 0 1 0 1 r r r direct addr.   | * ,              |
| Operation:                        | MOV<br>(Rn)←(direct)           |                  |
| MOV Rn,#data<br>Bytes:<br>Cycles: | 2<br>1                         |                  |
| Encoding:                         | 0 1 1 1 1 r r r immediate data |                  |
| Operation:                        | MOV<br>(Rn) ← #data            |                  |

.

ł

| MOV direct,A<br>Bytes:             | 2                          | ·                                        |
|------------------------------------|----------------------------|------------------------------------------|
| Cycles:                            | 1                          | ·                                        |
| Encoding:                          | 1 1 1 1 0 1 0 1 d          | irect address                            |
| Operation:                         | MOV<br>(direct) ← (A)      |                                          |
| MOV direct,Rr<br>Bytes:<br>Cycles: | n<br>2<br>2                |                                          |
| Encoding:                          | 1 0 0 0 1 r r r di         | rect address                             |
| Operation:                         | MOV<br>(direct) ← (Rn)     |                                          |
| MOV direct,di<br>Bytes:<br>Cycles: | rect<br>3<br>2             |                                          |
| Encoding:                          | 1 0 0 0 0 1 0 1 di         | r. addr. (src) dir. addr. (dest)         |
| Operation:                         | MOV<br>(direct) ← (direct) | na na an a |
| MOV direct,@<br>Bytes:<br>Cycles:  | Ri<br>2<br>2               |                                          |
| Encoding:                          | 1 0 0 0 0 1 1 i            | irect addr.                              |
| Operation:                         | MOV<br>(direct) ← ((Ri))   |                                          |
| MOV direct,#d                      | lata                       |                                          |
| Bytes:<br>Cycles:                  | 3 2                        |                                          |
| Encoding:                          | 0 1 1 1 0 1 0 1 di         | rect address immediate data              |
| Operation:                         | MOV<br>(direct) ← #data    |                                          |

٠

# **MCS®-51 INSTRUCTION SET**

<u>n</u> 1997

а 2 2 хар 2 хар

ί.

| MOV @Ri,A   |                     |                |
|-------------|---------------------|----------------|
| Bytes:      | 1                   |                |
| Cycles:     | 1                   |                |
| Encoding:   | 1 1 1 1 0 1 1 i     |                |
| Operation:  | MOV                 |                |
|             | ((Ri)) <b>←</b> (A) | •              |
| MOV @Ri,dir |                     |                |
| Bytes:      | 2                   |                |
| Cycles:     | 2                   | ,              |
|             |                     | []             |
| Encoding:   | 1 0 1 0 0 1 1 i     | direct addr.   |
|             |                     |                |
| Operation:  | MOV                 |                |
|             | ((Ri)) - (direct)   |                |
| MOV @Ri,#da | ata                 |                |
| Bytes:      | 2                   | •              |
| Cycles:     | -                   |                |
| -,          | -                   |                |
| Encoding:   | 0 1 1 1 0 1 1 i     | immediate data |
| Operation:  | MOV                 |                |
|             | ((RI)) 🖛 #data      |                |

# MOV <dest-bit>,<src-bit>

| Function:<br>Description: | Move bit data<br>The Boolean variable indicated by the second operand is copied into the loca-<br>tion specified by the first operand. One of the operands must be the carry flag;<br>the other may be any directly addressable bit. No other register or flag is af-<br>fected. |  |  |  |  |  |  |
|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Example:                  | The carry flag is originally set. The data present at input port 3 is 11000101B.<br>The data previously written to output port 1 is 35H (00110101B).                                                                                                                             |  |  |  |  |  |  |
|                           | MOV P1.3,C                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|                           | MOV C,P3.3                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|                           | MOV P1.2,C                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|                           | will leave the carry cleared and change port 1 to 39H (00111001B).                                                                                                                                                                                                               |  |  |  |  |  |  |



## MOV DPTR,#data16

| Function:<br>Description: | Load Data Pointer with a 16-bit constant<br>The data pointer is loaded with the 16-bit constant indicated. The 16-bit con-<br>stant is loaded into the second and third bytes of the instruction. The second<br>byte (DPH) is the high-order byte, while the third byte (DPL) holds the low-<br>order byte. No flags are affected. |   |  |  |  |  |  |  |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--|--|--|--|--|--|
| Example:                  | This is the only instruction which moves 16 bits of data at once.<br>The instruction,                                                                                                                                                                                                                                              |   |  |  |  |  |  |  |
|                           | MOV DPTR,#1234H                                                                                                                                                                                                                                                                                                                    |   |  |  |  |  |  |  |
| ,                         | will load the value 1234H into the data pointer: DPH will hold 12H and DPL will hold 34H.                                                                                                                                                                                                                                          |   |  |  |  |  |  |  |
| Bytes:                    | 3                                                                                                                                                                                                                                                                                                                                  |   |  |  |  |  |  |  |
| Cycles:                   | 2                                                                                                                                                                                                                                                                                                                                  | 1 |  |  |  |  |  |  |
| Encoding:                 | 1 0 0 1 0 0 0 0 immed. data15 - 8 immed. data7 - 0                                                                                                                                                                                                                                                                                 |   |  |  |  |  |  |  |
| <b>Operation:</b>         | MOV                                                                                                                                                                                                                                                                                                                                |   |  |  |  |  |  |  |
| •                         | (DPTR) - #data15-0                                                                                                                                                                                                                                                                                                                 |   |  |  |  |  |  |  |
|                           | DPH $\Box$ DPL#data <sub>15-8</sub> $\Box$ #data <sub>7-0</sub>                                                                                                                                                                                                                                                                    |   |  |  |  |  |  |  |

#### MOVC A,@A + <base-reg>

#### Function: Move Code byte

**Description:** The MOVC instructions load the accumulator with a code byte, or constant from program memory. The address of the byte fetched is the sum of the original unsigned eight-bit accumulator contents and the contents of a sixteenbit base register, which may be either the data pointer or the PC. In the latter case, the PC is incremented to the address of the following instruction before being added with the accumulator: otherwise the base register is not altered. Sixteen-bit addition is performed so a carry-out from the low-order eight bits may propagate through higher-order bits. No flags are affected.

**Example:** A value between 0 and 3 is in the accumulator. The following instructions will translate the value in the accumulator to one of four values defined by the DB (define byte) directive.

| REL_PC: | INC  | Α         |
|---------|------|-----------|
|         | MOVC | A,@A + PC |
|         | RET  |           |
|         | DB   | 66H       |
|         | DB   | 77H       |
|         | DB   | 88H       |
|         | DB   | 99H       |

If the subroutine is called with the accumulator equal to 01H, it will return with 77H in the accumulator. The INC A before the MOVC instruction is needed to "get around" the RET instruction above the table. If several bytes of code separated the MOVC from the table, the corresponding number would be added to the accumulator instead.

| OVC A,@A  | + DP | TR |   |   |   |   |   |   |  |
|-----------|------|----|---|---|---|---|---|---|--|
| Bytes:    | 1    |    |   |   |   |   |   |   |  |
| Cycles:   | 2    |    |   |   |   |   |   |   |  |
| Encoding: | 1    | 0  | Ņ | 1 | 0 | 0 | 1 | 1 |  |
| •         |      |    |   |   |   |   |   |   |  |

MOVC

**Operation:** 

M

 $(A) \leftarrow ((A) + (DPTR))$ 

| MOVC A,@A                                                | + PC |   |   |   | ; |   |   | , |  |
|----------------------------------------------------------|------|---|---|---|---|---|---|---|--|
| Bytes:                                                   | 1    |   |   |   |   |   |   |   |  |
| Cycles:                                                  | . 2  |   |   |   |   |   |   |   |  |
| Encoding:                                                | 1    | 0 | 0 | 0 | 0 | 0 | 1 | 1 |  |
| Operation: MOVC<br>(PC) ← (PC) + 1<br>(A) ← ((A) + (PC)) |      |   |   |   |   |   |   |   |  |

#### MOVX <dest-byte>,<src-byte>

#### **Function:** Move External

**Description:** 

The MOVX instructions transfer data between the accumulator and a byte of external data memory, hence the "X" appended to MOV. There are two types of instructions, differing in whether they provide an eight-bit or sixteen-bit indirect address to the external data RAM.

In the first type, the contents of R0 or R1 in the current register bank provide an eight-bit address multiplexed with data on P0. Eight bits are sufficient for external I/O expansion decoding or a relatively small RAM array. For somewhat larger arrays, any output port pins can be used to output higher-order address bits. These pins would be controlled by an output instruction preceding the MOVX.

In the second type of MOVX instruction, the data pointer generates a sixteenbit address. P2 outputs the high-order eight address bits (the contents of DPH) while P0 multiplexes the low-order eight bits (DPL) with data. The P2 Special Function Register retains its previous contents while the P2 output buffers are emitting the contents of DPH. This form is faster and more efficient when accessing very large data arrays (up to 64K bytes), since no additional instructions are needed to set up the output ports.

It is possible in some situations to mix the two MOVX types. A large RAM array with its high-order address lines driven by P2 can be addressed via the data pointer, or with code to output high-order address bits to P2 followed by a MOVX instruction using R0 or R1.

**Example:** An external 256 byte RAM using multiplexed address/data lines (e.g., an Intel<sup>®</sup> 8155 RAM/I/O/Timer) is connected to the 8051 Port 0. Port 3 provides control lines for the external RAM. Ports 1 and 2 are used for normal I/O. Registers 0 and 1 contain 12H and 34H. Location 34H of the external RAM holds the value 56H. The instruction sequence,

MOVX A,@R1 MOVX @R0,A

. ...

copies the value 56H into both the accumulator and external RAM location 12H.

| MOVX A,@Ri          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |              |          |              |    |          |   |   |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----------|--------------|----|----------|---|---|
| Bytes:              | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |              |          |              |    |          |   |   |
| Cycles:             | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |              |          |              |    |          |   |   |
| • , • . • • •       | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |              |          |              |    |          |   |   |
| Encoding:           | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1            | 1        | 0            | 0  | 0        | 1 | i |
| Enooding.           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |              |          |              |    | <u> </u> |   | 1 |
| <b>Operation:</b>   | мс                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | )VX          | 2        |              |    |          |   |   |
| operation.          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | -            |          | <b>;</b> ,,  |    |          |   |   |
|                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |              | -(()     | XI <i>))</i> |    |          |   |   |
| MOVX A,@DP          | TR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |          |              | •  | ,        |   |   |
| Bytes:              | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |              |          |              |    |          |   | , |
| Cycles:             | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |              |          |              |    |          |   |   |
|                     | ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |              |          |              |    |          |   |   |
| Encoding:           | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1            | 1        | 0            | 0  | 0        | 0 | 0 |
| . –                 | L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |              |          |              | L  |          |   |   |
| Operation:          | MC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | )VX          | ζ        |              |    |          |   |   |
| · · · · · · · · · · |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | -            |          | эрт          | R  | •        |   |   |
|                     | ()                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              | ((-      |              | ,, |          |   |   |
| MOVX @RI,A          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |              |          |              |    |          |   | , |
| Bytes:              | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |              |          |              |    |          |   |   |
| Cycles:             | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |              |          |              |    | ,        |   |   |
|                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |              |          |              |    |          |   |   |
| Encoding:           | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1            | 1        | 1            | 0  | 0        | 1 | i |
| 2                   | L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |              |          | l            |    |          |   |   |
| <b>Operation:</b>   | MC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | )VX          | ζ.,      |              |    |          |   |   |
|                     | ((R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | i)) <b>∢</b> | <b>[</b> | (A)          |    |          |   |   |
| MOVX @DPTF          | ••                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | .,           |          |              |    |          |   |   |
| -                   | <b>ъ,</b> А<br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |              |          |              |    |          |   | , |
| Bytes:              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | •            |          |              |    | ,        |   |   |
| Cycles:             | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |              |          |              |    |          |   |   |
|                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | •            |          |              |    |          |   |   |
| Encoding:           | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1            | 1        | 1            | 0  | 0        | 0 | 0 |
|                     | <b>K</b> ong and the second sec |              |          |              |    |          |   |   |
| Operation:          | MC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | )VX          | ζ.       |              |    |          |   |   |
|                     | (DI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | PTR          | k)∢      | (,           | A) |          |   |   |
|                     | (24                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |              |          | V            |    |          |   |   |

# MUL AB

Ń

| Function:<br>Description:<br>Example: | Multiply<br>MUL AB multiplies the unsigned eight-bit integers in the accumulator and<br>register B. The low-order byte of the sixteen-bit product is left in the ac-<br>cumulator, and the high-order byte in B. If the product is greater than 255<br>(0FFH) the overflow flag is set; otherwise it is cleared. The carry flag is always<br>cleared.<br>Originally the accumulator holds the value 80 (50H). Register B holds the value |
|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Example.                              | 160 (0A0H). The instruction,                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                       | MUL AB                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                       | will give the product 12,800 (3200H), so B is changed to 32H (00110010B) and the accumulator is cleared. The overflow flag is set, carry is cleared.                                                                                                                                                                                                                                                                                     |
| Bytes:                                | 1                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Cycles:                               | 4                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Encoding:                             | 1 0 1 0 0 1 0 0                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <b>Operation:</b>                     | MUL                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| -                                     | (A)7-0 $\leftarrow$ (A) X (B)<br>(B)15-8                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                       | -                                                                                                                                                                                                                                                                                                                                                                                                                                        |

1

## MCS®-51 INSTRUCTION SET

| Function:<br>Description: | No Operation<br>Execution continues at the following instruction. Other than the PC, no<br>registers or flags are affected.                                                                                                                                                                             |  |  |  |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Example:                  | It is desired to produce a low-going output pulse on bit 7 of port 2 lasting exact<br>ly 5 cycles. A simple SETB/CLR sequence would generate a one-cycle pulse, so<br>four additional cycles must be inserted. This may be done (assuming no inter<br>rupts are enabled) with the instruction sequence, |  |  |  |
| -                         | CLR P2.7<br>NOP<br>NOP<br>NOP<br>SETB P2.7                                                                                                                                                                                                                                                              |  |  |  |
| Bytes:<br>Cycles:         | 1 1 .                                                                                                                                                                                                                                                                                                   |  |  |  |
| Encoding:                 | 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                         |  |  |  |
| Operation:                | NOP $(PC) \leftarrow (PC) + 1$                                                                                                                                                                                                                                                                          |  |  |  |

8-44

#### ORL <dest-byte> <src-byte>

#### Function: Logical-OR for byte variables **Description:** ORL performs the bitwise logical-OR operation between the indicated variables, storing the results in the destination byte. No flags are affected. The two operands allow six addressing mode combinations. When the destination is the accumulator, the source can use register, direct, register-indirect, or immediate addressing; when the destination is a direct address, the source can be the accumulator or immediate data. Note: When this instruction is used to modify an output port, the value used as the original port data will be read from the output data latch, not the input pins. Example: If the accumulator holds 0C3H (11000011B) and R0 holds 55H (01010101B) then the instruction, ORL A,R0 will leave the accumulator holding the value 0D7H (11010111B). When the destination is a directly addressed byte, the instruction can set combinations of bits in any RAM location or hardware register. The pattern of bits to be set is determined by a mask byte, which may be either a constant data value in the instruction or a variable computed in the accumulator at run-time. The instruction, ORL P1,#00110010B will set bits 5, 4, and 1 of output port 1. ORL A.Rn Bytes: 1 Cycles: 1 Encoding: 0 1 0 0 1 r r r **Operation:** ORL $(A) \leftarrow (A) \lor (Rn)$

# intel

| ORL A, direct<br>Bytes:<br>Cycles: | 2 1                                         | •<br>•<br>•                 |
|------------------------------------|---------------------------------------------|-----------------------------|
| Encoding:                          | 0 1: 0 0 0 1 0 1 di                         | irect address               |
| Operation:                         | ORL<br>(A) $\leftarrow$ (A) $\lor$ (direct) |                             |
| ORL A,@Ri<br>Bytes:<br>Cycles:     | 1<br>1                                      |                             |
| Encoding:                          | 0 1 0 0 0 1 1 i                             | ,                           |
| Operation:                         | ORL<br>(A) ← (A) ∨ ((Ri))                   |                             |
| ORL A,#data<br>Bytes:<br>Cycles:   | <b>2</b>                                    |                             |
| Encoding:                          | 0 1 0 0 0 1 0 0 i                           | mmediate data               |
| Operation:                         | ORL<br>(A) ← (A) ∨ #data                    |                             |
| ORL direct,A<br>Bytes:<br>Cycles:  | 2                                           | • •                         |
| Encoding:                          | 0 1 0 0 0 0 1 0                             | direct address              |
| Operation:                         | ORL $(direct) \checkmark (A)$               | ·                           |
| ORL direct,#d<br>Bytes:<br>Cycles: | ata<br>3<br>2                               |                             |
| Enculing:                          | 0 1 0 0 0 0 1 1                             | direct addr. immediate data |
| Operation:                         | ORL<br>(direct) ← (direct) ∨ #data          |                             |

## ORL C, <src-bit>

| Function:<br>Description<br>Example: | Logical-OR for bit variables<br>Set the carry flag if the Boolean value is a logical l; leave the carry in its current<br>state otherwise. A slash ("/") preceding the operand in the assembly language<br>indicates that the logical complement of the addressed bit is used as the source<br>value, but the source bit itself is not affected. No other flags are affected.<br>Set the carry flag if and only if $P1.0 = 1$ , ACC.7 = 1, or OV = 0:<br>MOV C,P1.0 ;LOAD CARRY WITH INPUT PIN P10<br>ORL C,ACC.7 ;OR CARRY WITH THE ACC. BIT 7 |
|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                      | ORL C,/OV :OR CARRY WITH THE INVERSE OF OV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| ORL C,bit<br>Bytes:<br>Cycles:       | 2 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Encoding:                            | 0 1 1 1 0 0 1 0 bit address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Operation:                           | ORL<br>(C) $\leftarrow$ (C) $\vee$ (bit)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| ORL C,/bit<br>Bytes:<br>Cycles:      | 2 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Encoding:                            | 1 0 1 0 0 0 0 0 bit address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Operation:                           | ORL<br>(C) $\leftarrow$ (C) $\vee$ (bit)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

#### POP direct

Function:Pop from stack.Description:The contents of the internal RAM location addressed by the stack pointer is<br/>read, and the stack pointer is decremented by one. The value read is the transfer<br/>to the directly addressed byte indicated. No flags are affected.

.

.

| Example:   | The stack pointer originally contains the value 32H, and internal RAM loca-<br>tions 30H through 32H contain the values 20H, 23H, and 01H, respectively.<br>The instruction sequence, |  |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| · · ·      | POP DPH<br>POP DPL                                                                                                                                                                    |  |
|            | will leave the stack pointer equal to the value 30H and the data pointer set to 0123H. At this point the instruction,                                                                 |  |
|            | POP SP                                                                                                                                                                                |  |
|            | will leave the stack pointer set to 20H. Note that in this special case the stack pointer was decremented to 2FH before being loaded with the value popped (20H).                     |  |
| Bytes:     | 2                                                                                                                                                                                     |  |
| Cycles:    | 2                                                                                                                                                                                     |  |
| Encoding:  | 1 1 0 1 0 0 0 0 direct address                                                                                                                                                        |  |
| Operation: | POP<br>(direct) $\leftarrow ((SP))$<br>(SP) $\leftarrow (SP) - 1$                                                                                                                     |  |

# PUSH direct

| Function:<br>Description: | Push onto stack<br>The stack pointer is incremented by one. The contents of the indicated variable<br>is then copied into the internal RAM location addressed by the stack pointer.<br>Otherwise no flags are affected. |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Example:                  | On entering an interrupt routine the stack pointer contains 09H. The data pointer holds the value 0123H. The instruction sequence,                                                                                      |
|                           | PUSH DPL<br>PUSH DPH                                                                                                                                                                                                    |
|                           | will leave the stack pointer set to 0BH and store 23H and 01H in internal RAM locations 0AH and 0BH, respectively.                                                                                                      |
| Bytes:                    | 2                                                                                                                                                                                                                       |
| Cycles:                   | 2                                                                                                                                                                                                                       |
| Encoding:                 | 1 1 0 0 0 0 0 0 direct address                                                                                                                                                                                          |
| Operation:                | PUSH<br>$(SP) \rightarrow (SP) + 1$<br>$((SP)) \rightarrow (direct)$                                                                                                                                                    |

| Function:<br>Description: | Return from subroutine<br>RET pops the high- and low-order bytes of the PC successively from the stack,<br>decrementing the stack pointer by two. Program execution continues at the<br>resulting address, generally the instruction immediately following an ACALL<br>or LCALL. No flags are affected. |  |  |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Example:                  | The stack pointer originally contains the value 0BH. Internal RAM locations 0AH and 0BH contain the values 23H and 01H, respectively. The instruction,                                                                                                                                                  |  |  |
|                           | RET                                                                                                                                                                                                                                                                                                     |  |  |
|                           | will leave the stack pointer equal to the value 09H. Program execution will con-<br>tinue at location 0123H.                                                                                                                                                                                            |  |  |
| Bytes:                    | 1                                                                                                                                                                                                                                                                                                       |  |  |
| Cycles:                   | 2                                                                                                                                                                                                                                                                                                       |  |  |
| Encoding:                 |                                                                                                                                                                                                                                                                                                         |  |  |
| Operation:                | RET<br>(PC15-8) ← ((SP))                                                                                                                                                                                                                                                                                |  |  |
|                           | (SP) - (SP) - 1<br>(PC7-0) - ((SP))<br>(SP) - (SP) - 1                                                                                                                                                                                                                                                  |  |  |

#### RETI

RET

**Function:** Return from interrupt

**Description:** RETI pops the high- and low-order bytes of the PC successively from the stack, and restores the interrupt logic to accept additional interrupts at the same priority level as the one just processed. The stack pointer is left decremented by two. No other registers are affected; the PSW is *not* automatically restored to its pre-interrupt status. Program execution continues at the resulting address, which is generally the instruction immediately after the point at which the interrupt request was detected. If a lower- or same-level interrupt had been pending when the RETI instruction is executed, that one instruction will be executed before the pending interrupt is processed.

**Example:** The stack pointer originally contains the value 0BH. An interrupt was detected during the instruction ending at location 0122H. Internal RAM locations 0AH and 0BH contain the values 23H and 01H, respectively. The instruction, RETI

will leave the stack pointer equal to 09H and return program execution to location 0123H.

Bytes: Cycles: 1

2

Encoding:

0 0 1 1 0 0 1 0

Operation:

RETI  $(PC_{15-8}) \leftarrow ((SP))$   $(SP) \leftarrow (SP) - 1$   $(PC_{7-0}) \leftarrow ((SP))$  $(SP) \leftarrow (SP) - 1$ 

## RL A

| Function:<br>Description: | Rotate accumulator Left<br>The eight bits in the accumulator are rotated one bit to the left. Bit 7 is rotated |  |  |  |  |
|---------------------------|----------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                           | into the bit 0 position. No flags are affected.                                                                |  |  |  |  |
| Example:                  | The accumulator holds the value 0C5H (11000101B). The instruction,                                             |  |  |  |  |
|                           | RL A                                                                                                           |  |  |  |  |
|                           | leaves the accumulator holding the value 8BH (10001011B) with the carry unaffected.                            |  |  |  |  |
| Bytes:                    | 1                                                                                                              |  |  |  |  |
| Cycles:                   | 1                                                                                                              |  |  |  |  |
| Encoding:                 | 0 0 1 0 0 0 1 1                                                                                                |  |  |  |  |
| Operation:                | RL<br>$(A_{n+1}) \leftarrow (A_n)$ $n=0-6$<br>$(A_0) \leftarrow (A_7)$                                         |  |  |  |  |

### RLC A

| Function:<br>Description:<br>Example: | Rotate accumulator Left through the Carry flag<br>The eight bits in the accumulator and the carry flag are together rotated one bit<br>to the left. Bit 7 moves into the carry flag; the original state of the carry flag<br>moves into the bit 0 position. No other flags are affected.<br>The accumulator holds the value 0C5H (11000101B), and the carry is zero. The |
|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                       | instruction,                                                                                                                                                                                                                                                                                                                                                             |
|                                       | RLC A                                                                                                                                                                                                                                                                                                                                                                    |
|                                       | leaves the accumulator holding the value 8BH (10001010B) with the carry set.                                                                                                                                                                                                                                                                                             |
| Bytes:<br>Cycles:                     | 1 1                                                                                                                                                                                                                                                                                                                                                                      |
| Encoding:                             | 0 0 1 1 0 0 1 1                                                                                                                                                                                                                                                                                                                                                          |
| <b>Operation:</b>                     | RLC                                                                                                                                                                                                                                                                                                                                                                      |
| N.                                    | $(An+1) \leftarrow (An)$ $n=0-6$                                                                                                                                                                                                                                                                                                                                         |
|                                       | $(A0) \leftarrow (C)$                                                                                                                                                                                                                                                                                                                                                    |
|                                       | (C) <b>←</b> −(A7)                                                                                                                                                                                                                                                                                                                                                       |

r

## RR A

| Function:<br>Description:               | Rotate accumulator Right<br>The eight bits in the accumulator are rotated one bit to the right. Bit 0 is rotated<br>into the bit 7 position. No flags are affected. |  |  |  |  |  |  |
|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Example:                                | The accumulator holds the value 0C5H (11000101B). The instruction,                                                                                                  |  |  |  |  |  |  |
|                                         | RR A                                                                                                                                                                |  |  |  |  |  |  |
| х., , , , , , , , , , , , , , , , , , , | leaves the accumulator holding the value 0E2H (11100010B) with the carry unaffected.                                                                                |  |  |  |  |  |  |
| Bytes:                                  | 1                                                                                                                                                                   |  |  |  |  |  |  |
| Cycles:                                 | 1 ·                                                                                                                                                                 |  |  |  |  |  |  |
| Encoding:                               | 0 0 0 0 0 1 1                                                                                                                                                       |  |  |  |  |  |  |
| Operation:                              | RR<br>(An) $\leftarrow$ (A <sub>n+1</sub> ) $n=0-6$<br>(A7) $\leftarrow$ (A0)                                                                                       |  |  |  |  |  |  |

#### RRC A

,

| Function:    | Rotate accumulator Right through Carry flag<br>The eight bits in the accumulator and the carry flag are together rotated one bit<br>to the right. Bit 0 moves into the carry flag; the original value of the carry flag<br>moves into the bit 7 position. No other flags are affected. |  |  |  |  |  |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Description: |                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| Example:     | The accumulator holds the value 0C5H (11000101B), the carry is zero. The in-<br>struction,                                                                                                                                                                                             |  |  |  |  |  |
|              | RRC A                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| e -          | leaves the accumulator holding the value 62 (01100010B) with the carry set.                                                                                                                                                                                                            |  |  |  |  |  |
| Bytes:       | 1                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| Cycles:      | 1                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| Encoding:    | 0 0 0 1 0 0 1 1                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| Operation:   | RRC<br>(An) $- (A_{n+1})$ $n=0-6$<br>(A7) $- (C)$<br>(C) $- (A0)$                                                                                                                                                                                                                      |  |  |  |  |  |

| SETB            | <bit></bit>           |                                                                                                                                                    |
|-----------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Func<br>Descrip |                       | Set Bit<br>SETB sets the indicated bit to one. SETB can operate on the carry flag or any<br>directly addressable bit. No other flags are affected. |
| Exan            | nple:                 | The carry flag is cleared. Output port 1 has been written with the value 34H (00110100B). The instructions,                                        |
|                 | · · · ,               | SETB C<br>SETB P1.0                                                                                                                                |
|                 |                       | will leave the carry flag set to 1 and change the data output on port 1 to 35H (00110101B).                                                        |
| B               | C<br>ytes:            | 1                                                                                                                                                  |
| Cy              | cles:                 | 1                                                                                                                                                  |
| Encod           | ding:                 | 1 1 0 1 0 0 1 1                                                                                                                                    |
| Opera           | tion:                 | SETB<br>(C) ← 1                                                                                                                                    |
| By              | bit<br>ytes:<br>cles: | 2 1                                                                                                                                                |
| Encod           | ding:                 | 1 1 0 1 0 0 1 0 bit address                                                                                                                        |
| Operat          | tion:                 | SETB<br>(bit) ← 1                                                                                                                                  |
| *               |                       |                                                                                                                                                    |
| SJMP            | rel                   |                                                                                                                                                    |
| Funct           | ion:                  | Short Jump                                                                                                                                         |

**Description:** Program control branches unconditionally to the address indicated. The branch destination is computed by adding the signed displacement in the second instruction byte to the PC, after incrementing the PC twice. Therefore, the range of destinations allowed is from 128 bytes preceding this instruction to 127 bytes following it.

**Example:** The label "RELADR" is assigned to an instruction at program memory location 0123H. The instruction,

#### SJMP RELADR

will assemble into location 0100H. After the instruction is executed, the PC will contain the value 0123H.

(Note: Under the above conditions the instruction following SJMP will be at 102H. Therefore, the displacement byte of the instruction will be the relative offset (0123H-0102H) = 21H. Put another way, an SJMP with a displacement of 0FEH would be a one-instruction infinite loop.)

#### Bytes: Cycles:

2

2

| Encoding: | 1                 | 0   | 0  | 0 | 0 | 0 | 0 | 0 | rel. address |
|-----------|-------------------|-----|----|---|---|---|---|---|--------------|
|           | SJN<br>(PC<br>(PC | C)∢ | `` |   |   |   |   |   |              |

\_\_\_\_\_

### SUBB A, <src-byte>

| Function:<br>Description: | Subtract with borrow<br>SUBB subtracts the indicated variable and the carry flag together from the ac-<br>cumulator, leaving the result in the accumulator. SUBB sets the carry (borrow)<br>flag if a borrow is needed for bit 7, and clears C otherwise. (If C was set <i>before</i><br>executing a SUBB instruction, this indicates that a borrow was needed for the<br>previous step in a multiple precision subtraction, so the carry is subtracted from<br>the accumulator along with the source operand.) AC is set if a borrow is needed<br>for bit 3, and cleared otherwise. OV is set if a borrow is needed into bit 6, but<br>not into bit 7, or into bit 7, but not bit 6. |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                           | When subtracting signed integers OV indicates a negative number produced<br>when a negative value is subtracted from a positive value, or a positive result<br>when a positive number is subtracted from a negative number.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                           | The source operand allows four addressing modes: register, direct, register-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Example:                  | indirect, or immediate.<br>The accumulator holds 0C9H (11001001B), register 2 holds 54H (01010100B),<br>and the carry flag is set. The instruction,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                           | SUBB A,R2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                           | will leave the value 74H (01110100B) in the accumulator, with the carry flag and AC cleared but OV set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                           | Notice that 0C9H minus 54H is 75H. The difference between this and the above result is due to the carry (borrow) flag being set before the operation. If the state of the carry is not known before starting a single or multiple-precision sub-traction, it should be explicitly cleared by a CLR C instruction.                                                                                                                                                                                                                                                                                                                                                                     |
| SUBB A,Rn                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bytes:<br>Cycles:         | 1 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Encoding:                 | 1 0 0 1 1 r r r                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Operation:                | SUBB<br>(A) $\leftarrow$ (A) $-$ (C) $-$ (Rn)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| SUBB A,direct<br>Bytes:<br>Cycles: | <b>1</b>                                                                                                                                                                                                                                                     |
|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Encoding:                          | 1 0 0 1 0 1 0 1 direct address                                                                                                                                                                                                                               |
| Operation:                         | SUBB<br>(A) $\leftarrow$ (A) $-$ (C) $-$ (direct)                                                                                                                                                                                                            |
| SUBB A,@Ri<br>Bytes:<br>Cycles:    | 1<br>1                                                                                                                                                                                                                                                       |
| Encoding:                          | 1 0 0 1 0 1 1 i                                                                                                                                                                                                                                              |
| Operation:                         | SUBB<br>$(A) \leftarrow (A) - (C) - ((Ri))$                                                                                                                                                                                                                  |
| SUBB A,#data<br>Bytes:<br>Cycles:  |                                                                                                                                                                                                                                                              |
| Encoding:                          | 1 0 0 1 0 1 0 0 immediate data                                                                                                                                                                                                                               |
| Operation:                         | SUBB<br>(A) $(A) - (C) - #data$                                                                                                                                                                                                                              |
| SWAP A                             |                                                                                                                                                                                                                                                              |
| Function:<br>Description:          | Swap nibbles within the Accumulator<br>SWAP A interchanges the low- and high-order nibbles (four-bit fields) of the<br>accumulator (bits 3-0 and bits 7-4). The operation can also be thought of as a<br>four-bit rotate instruction. No flags are affected. |
| Example:                           | The accumulator holds the value 0C5H (11000101B). The instruction,<br>SWAP A                                                                                                                                                                                 |
| Bytes:                             | SwAP A<br>leaves the accumulator holding the value 5CH (01011100B).                                                                                                                                                                                          |

Cycles:

1.

Encoding: 1 1 0 0 0 1 0 0

Operation:

SWAP (A3-0) (A7-4), (A7-4) (A3-0)

8-56

| Function:<br>Description:         | Exchange Accumulator with byte variable<br>XCH loads the accumulator with the contents of the indicated variable, at the<br>same time writing the original accumulator contents to the indicated variable.<br>The source/destination operand can use register, direct, or register-indirect ad- |  |  |  |  |  |  |
|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Example:                          | dressing.<br>R0 contains the address 20H. The accumulator holds the value 3FH (00111111B). Internal RAM location 20H holds the value 75H (01110101B). The instruction,                                                                                                                          |  |  |  |  |  |  |
|                                   | XCH A,@R0                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| ,                                 | will leave RAM location 20H holding the values 3FH (00111111B) and 75H (01110101B) in the accumulator.                                                                                                                                                                                          |  |  |  |  |  |  |
| XCH A,Rn<br>Bytes:<br>Cycles:     | 1                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
| Encoding:                         | 1 1 0 0 1 r r r                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| Operation:                        | XCH<br>(A) (Rn)                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| XCH A,direct<br>Bytes:<br>Cycles: | 2 1                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| Encoding:                         | 1 1 0 0 0 1 0 1 direct address                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| Operation:                        | $\begin{array}{c} XCH \\ (A) \xrightarrow{} (direct) \end{array}$                                                                                                                                                                                                                               |  |  |  |  |  |  |
| XCH A,@Ri<br>Bytes:<br>Cycles:    | 1 1                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| Encoding:                         | 1 1 0 0 0 1 1 i                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| Operation:                        | $\begin{array}{c} \text{XCH} \\ \text{(A)} \xrightarrow{} ((\text{Ri})) \end{array}$                                                                                                                                                                                                            |  |  |  |  |  |  |

| XCHD |       |
|------|-------|
| хопи | A,@Ri |

| Function:    | Exchange Digit                                                                                                                                                                                                                                                                                            |  |  |  |  |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Description: | XCHD exchanges the low-order nibble of the accumulator (bits 3-0), generally representing a hexadecimal or BCD digit), with that of the internal RAM location indirectly addressed by the specified register. The high-order nibbles (bits 7-4) of each register are not affected. No flags are affected. |  |  |  |  |
| Example:     | R0 contains the address 20H. The accumulator holds the value 36H (00110110B). Internal RAM location 20H holds the value 75H (01110101B). The instruction,                                                                                                                                                 |  |  |  |  |
|              | XCHD A,@R0                                                                                                                                                                                                                                                                                                |  |  |  |  |
|              | will leave RAM location 20H holding the value 76H (01110110B) and 35H (00110101B) in the accumulator.                                                                                                                                                                                                     |  |  |  |  |
| Bytes:       | 1                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| Cycles:      | 1                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| Encoding:    | 1 1 0 1 0 1 1 i                                                                                                                                                                                                                                                                                           |  |  |  |  |
| Operation:   | XCHD                                                                                                                                                                                                                                                                                                      |  |  |  |  |
|              | $(A_{3-0})  ((Ri_{3-0}))$                                                                                                                                                                                                                                                                                 |  |  |  |  |

/

### XRL <dest-byte>, <src-byte>

| Function:<br>Description:         | Logical Exclusive-OR for byte variables<br>XRL performs the bitwise logical Exclusive-OR operation between the in-<br>dicated variables, storing the results in the destination. No flags are affected.                                                                                                                                                              |  |  |  |  |
|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                                   | The two operands allow six addressing mode combinations. When the destina-<br>tion is the accumulator, the source can use register, direct, register-indirect, or<br>immediate addressing; when the destination is a direct address, the source can<br>be the accumulator or immediate data.                                                                         |  |  |  |  |
| Example:                          | (Note: When this instruction is used to modify an output port, the value used as the original port data will be read from the output data latch, <i>not</i> the input pins.)<br>If the accumulator holds 0C3H (11000011B) and register 0 holds 0AAH (10101010B) then the instruction,                                                                                |  |  |  |  |
| ÷                                 | XRL A,RO                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|                                   | will leave the accumulator holding the value 69H (01101001B).                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|                                   |                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| • •                               | When the destination is a directly addressed byte, this instruction can comple-<br>ment combinations of bits in any RAM location or hardware register. The pat-<br>tern of bits to be complemented is then determined by a mask byte, either a con-<br>stant contained in the instruction or a variable computed in the accumulator at<br>run-time. The instruction, |  |  |  |  |
| `                                 | XRL P1,#00110001B                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
| 1                                 | will complement bits 5, 4, and 0 of output port 1.                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| XRL A,Rn<br>Bytes:<br>Cycles:     | 1<br>1                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| Encoding:                         | 0 1 1 0 1 r r r                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| Operation:                        | $\begin{array}{l} XRL \\ (A) \longleftarrow (A) \ \forall \ (Rn) \end{array}$                                                                                                                                                                                                                                                                                        |  |  |  |  |
| XRL A,direct<br>Bytes:<br>Cycles: | 2<br>1 -                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| Encoding:                         | 0 1 1 0 0 1 0 1 direct address                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| Operation:                        | XRL                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |

1

#### MCS®-51 INSTRUCTION SET

| XRL A,@Ri                          | 1                                                                       |                                        |
|------------------------------------|-------------------------------------------------------------------------|----------------------------------------|
| Bytes:<br>Cycles:                  |                                                                         |                                        |
| Encoding:                          | 0 1 1 0 0 1 1 i to the set of the set                                   |                                        |
| Operation:                         | XRL<br>(A) ← ((Ŕi))                                                     | () ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) |
| XRL A,#data<br>Bytes:<br>Cycles:   | 2<br>1                                                                  | · .<br>·                               |
| Encoding:                          | 0 1 1 0 0 1 0 0 immediate data                                          |                                        |
| Operation:                         | XRL<br>(A) ← (A) ∀ #data                                                | · · ·                                  |
| XRL direct,A<br>Bytes:<br>Cycles:  | 2<br>1                                                                  |                                        |
| Encoding:                          | 0 1 1 0 0 0 1 0 direct address                                          | ( *                                    |
| Operation:                         | $\begin{array}{l} XRL \\ (direct) \blacktriangleleft & (A) \end{array}$ | i i                                    |
| XRL direct,#d<br>Bytes:<br>Cycles: | data<br>3<br>2                                                          |                                        |
| Encoding:                          | 0 1 1 0 0 0 1 1 direct address imm                                      | nediate data                           |
| Operation:                         | XRL<br>(direct) ← (direct) → #data                                      |                                        |

١

الم المراجع الم المراجع 
. . .

•

# MCS<sup>®</sup>-51 Data Sheets

. •

# intel

# MCS®-51 8-BIT CONTROL-ORIENTED MICROCOMPUTERS

8031/8051 8031AH/8051AH 8032AH/8052AH 8751H/8751H-12

- High Performance HMOS Process
- Internal Timers/Event Counters
- 2-Level Interrupt Priority Structure
- 32 I/O Lines (Four 8-Bit Ports)
- 64K Program Memory Space

- Boolean Processor
- Bit-Addressable RAM
- Programmable Full Duplex Serial Channel
- 111 Instructions (64 Single-Cycle)
- 64K Data Memory Space

#### Security Feature Protects EPROM Parts Against Software Piracy

The MCS<sup>®</sup>-51 products are optimized for control applications. Byte-processing and numerical operations on small data structures are facilitated by a variety of fast addressing modes for accessing the internal RAM. The instruction set provides a convenient menu of 8-bit arithmetic instructions, including multiply and divide in structions. Extensive on-chip support is provided for one-bit variables as a separate data type, allowing direct bit manipulation and testing in control and logic systems that require Boolean processing.

|          | Internal            | Memory                     | 1                         |            |
|----------|---------------------|----------------------------|---------------------------|------------|
| Device   | Program             | Data                       | Timers/<br>Event Counters | Interrupts |
| 8052AH   | 8K × 8 ROM          | 256 × 8 RAM                | 3 × 16-Bit                | 6          |
| 8051AH   | $4K \times 8 ROM$   | 128 $	imes$ 8 RAM          | 2 × 16-Bit                | 5          |
| 8051     | $4K \times 8 ROM$   | 128 $	imes$ 8 RAM          | 2 × 16-Bit                | 5          |
| 8032AH   | none                | $256 \times 8 \text{ RAM}$ | 3 × 16-Bit                | 6          |
| 8031AH   | none                | $128 \times 8$ RAM         | 2 × 16-Bit                | 5          |
| 8031     | none                | $128 \times 8 \text{ RAM}$ | 2 × 16-Bit                | 5          |
| 8751H    | $4K \times 8 EPROM$ | 128 × 8 RAM                | 2 × 16-Bit                | 5 ′        |
| 8751H-12 | $4K \times 8 EPROM$ | 128 × 8 RAM                | 2 × 16-Bit                | 5          |

The 8751H is an EPROM version of the 8051AH; that is, the on-chip Program Memory can be electrically programmed, and can be erased by exposure to ultraviolet light. It is fully compatible with its predecessor, the 8751-8, but incorporates two new features: a Program Memory Security bit that can be used to protect the EPROM against unauthorized read-out, and a programmable baud rate modification bit (SMOD). SMOD is not present in the 8751H-12.



Figure 1. MCS®-51 Block Diagram

#### **PIN DESCRIPTIONS**

#### VCC

Supply voltage.

#### VSS

Circuit ground.

#### Port 0

Port 0 is an 8-bit open drain bidirectional I/O port. As an output port each pin can sink 8 LS TTL inputs. Port 0 pins that have 1s written to them float, and in that state can be used as high-impedance inputs.

Port 0 is also the multiplexed low-order address and data bus during accesses to external Program and Data Memory. In this application it uses strong internal pullups when emitting 1s, and can source and sink 8 LS TTL inputs.

Port 0 also receives the code bytes during programming of the EPROM parts, and outputs the code bytes during program verification of the ROM and EPROM parts. External pullups are required during program verification.

#### Port 1

Port 1 is an 8-bit bidirectional I/O port with internal pullups. The Port 1 output buffers can sink/source 4 LS TTL inputs. Port 1 pins that have 1s written to them are pulled high by the internal pullups, and in that state can be used as inputs. As inputs, Port 1 pins that are externally being pulled low will source current (IIL, on the data sheet) because of the internal pullups.

Port 1 also receives the low-order address bytes during programming of the EPROM parts and during program verification of the ROM and EPROM parts.



Figure 2. MCS®-51 Pin Connections

In the 8032AH and 8052AH, Port 1 pins P1.0 and P1.1 also serve the T2 and T2EX functions, respectively.

#### Port 2

Port 2 is an 8-bit bidirectional I/O port with internal pullups. The Port 2 output buffers can sink/source 4 LS TTL inputs. Port 2 pins that have 1s written to them are pulled high by the internal pullups, and in that state can be used as inputs. As inputs, Port 2 pins that are externally being pulled low will source current (IIL, on the data sheet) because of the internal pullups.

Port 2 emits the high-order address byte during fetches from external Program Memory and during accesses to external Data Memory that use 16-bit addresses (MOVX @DPTR). In this application it uses strong internal pullups when emitting 1s. During accesses to external Data Memory that use 8-bit addresses (MOVX @Ri), Port 2 emits the contents of the P2 Special Function Register.

Port 2 also receives the high-order address bits during programming of the EPROM parts and during program verification of the ROM and EPROM parts.

#### Port 3

Port 3 is an 8-bit bidirectional I/O port with internal pullups. The Port 3 output buffers can sink/source 4 LS TTL inputs. Port 3 pins that have 1s written to them are pulled high by the internal pullups, and in that state can be used as inputs. As inputs, Port 3 pins that are externally being pulled low will source current (IIL, on the data sheet) because of the pullups.

Port 3 also serves the functions of various special features of the MCS-51 Family, as listed below:

| Port Pin | Alternative Function                   |
|----------|----------------------------------------|
| P3.0     | RXD (serial input port)                |
| P3.1     | TXD (serial output port)               |
| P3.2     | INTO (external interrupt 0)            |
| P3.3     | INT1 (external interrupt 1)            |
| P3.4     | T0 (Timer 0 external input)            |
| P3.5     | T1 (Timer 1 external input)            |
| P3.6     | WR (external data memory write strobe) |
| P3.7     | RD (external data memory read strobe)  |

#### RST

Reset input. A high on this pin for two machine cycles while the oscillator is running resets the device.

#### ALE/PROG

Address Latch Enable output pulse for latching the low byte of the address during accesses to external memory. ALE can drive 8 LS TTL inputs. This pin is also the program pulse input (PROG) during programming of the EPROM parts.

In normal operation ALE is emitted at a constant rate of 1/6 the oscillator frequency, and may be used for external timing or clocking purposes. Note, however, that one ALE pulse is skipped during each access to external Data Memory.

#### PSEN

Program Store Enable is the read strobe to external Program Memory. PSEN can drive 8 LS TTL inputs.

When the device is executing code from external Program Memory, PSEN is activated twice each machine cycle, except that two PSEN activations are skipped during each access to external Data Memory.

#### EA/VPP

External Access enable EA must be externally held low in order to enable any MCS-51 device to fetch code from external Program Memory locations 0 to 0FFFH (0 to 1FFFH, in the 8032AH and 8052AH). Note, however, that if the Security Bit in the EPROM devices is programmed, the device will not fetch code from any location in external Program Memory.

This pin also receives the 21V programming supply voltage (VPP) during programming of the EPROM parts.

#### XTAL1

Input to the inverting oscillator amplifier.

#### XTAL2

Output from the inverting oscillator amplifier.

#### **OSCILLATOR CHARACTERISTICS**

XTAL1 and XTAL2 are the input and output, respectively, of an inverting amplifier which can be configured for use as an on-chip oscillator, as shown in Figure 3. Either a quartz crystal or ceramic resonator may be used. More detailed information concerning the use of the on-chip oscillator is available in Application Note AP-155, "Oscillators for Microcontrollers."

To drive the device from an external clock source, XTAL1 should be grounded, while XTAL2 is driven, as shown in Figure 4. There are no requirements on the duty cycle of the external clock signal, since the input to the internal clocking circuitry is through a divide-by-two flip-flop, but minimum and maximum high and low times specified on the Data Sheet must be observed.



Figure 3. Oscillator Connections



#### Figure 4. External Drive Configuration

#### ABSOLUTE MAXIMUM RATINGS\*

 \*NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

| <b>D.C. CHARACTERISTICS:</b> $(1A = 0 \ C \ 0 \ 70 \ C, \ VCC = 5V \pm 10\%, \ VSS = 0V)$ | D.C. CHARACTERISTICS: (TA | = 0 °C to 70 °C; VCC = 5V $\pm$ 10%; VSS = 0V) |
|-------------------------------------------------------------------------------------------|---------------------------|------------------------------------------------|
|-------------------------------------------------------------------------------------------|---------------------------|------------------------------------------------|

| Symbol | Para                                                                                | meter               | Min  | Max                      | Unit                 | <b>Test Conditions</b>                  |
|--------|-------------------------------------------------------------------------------------|---------------------|------|--------------------------|----------------------|-----------------------------------------|
| VIL    | Input Low Voltage (Except EA Pin of<br>8751H, 8751H-12)                             |                     | -0.5 | 0.8                      | v                    |                                         |
| VIL1   | Input Low Voltage<br>8751H, 8751H-1                                                 | 0                   | 0.7  | V                        |                      |                                         |
| VIH    | Input High Voltage<br>RST)                                                          | e (Except XTAL2,    | 2.0  | VCC+0.5                  | v                    |                                         |
| VIH1   | Input High Voltage                                                                  | e to XTAL2, RST     | 2.5  | VCC+0.5                  | V                    | XTAL1 = VSS                             |
| VOL    | Output Low Voltag                                                                   | ge (Ports 1, 2, 3)* |      | 0.45                     | v                    | IOL = 1.6  mA                           |
| VOL1   | Output Low Voltage<br>PSEN)*                                                        | ge (Port 0, ALE,    |      |                          |                      |                                         |
|        | 8751H, 8751H-12                                                                     |                     |      | 0.60<br>0.45             | V<br>V               | IOL = 3.2  mA<br>IOL = 2.4  mA          |
|        | All Others                                                                          |                     |      | 0.45                     | V                    | IOL = 3.2  mA                           |
| VOH    | Output High Volta                                                                   | 2.4                 |      | V                        | $IOH = -80 \ \mu A$  |                                         |
| VOH1   | Output High Volta<br>External Bus M                                                 | 2.4                 |      | V                        | $IOH = -400 \ \mu A$ |                                         |
| IIL    | Logical 0 Input Current (Ports 1, 2, 3)<br>8032AH, 8052AH<br>All Others             |                     |      | - 800<br>- 500           | μΑ<br>μΑ             | Vin = 0.45 V<br>Vin = 0.45 V            |
| HL1    | Logical 0 Input Current to EA Pin of<br>8751H, 8751H-12 Only                        |                     | ¢    | - 15                     | mA                   |                                         |
| IIL2   | Logical 0 Input Cu                                                                  | urrent (XTAL2)      |      | - 3.2                    | mA                   | Vin = 0.45 V                            |
| ILI    | Input Leakage Current (Port 0)<br>8751H, 8751H-12<br>All Others                     |                     |      | ± 100                    | μΑ<br>μΑ             | 0.45 < Vin < VCC<br>0.45 < Vin < VCC    |
| IIH    | Logical 1 Input Current to EA Pin of<br>8751H, 8751H-12                             |                     |      | 500                      | μA                   |                                         |
| IIH1   | Input Current to RST to Activate Reset                                              |                     |      | 500                      | μA                   | Vin < (VCC - 1.5V)                      |
| ICC    | Power Supply Current: 8031/8051<br>8031AH/8051AH<br>8032AH/8052AH<br>8751H/8751H-12 |                     |      | 160<br>125<br>175<br>250 | mA<br>mA<br>mA<br>mA | All Outputs Discon-<br>nected; EA = VCC |
| CIO    | Pin Capacitance                                                                     |                     |      | 10                       | pF                   | test freq = 1MHz                        |

\*Note: Capacitive loading on Ports 0 and 2 may cause spurious noise pulses to be superimposed on the VOLs of ALE and Ports 1 and 3. The noise is due to external bus capacitance discharging into the Port 0 and Port 2 pins when these pins make 1-to-0 transitions during bus operations. In the worst cases (capacitive loading > 100 pF), the noise pulse on the ALE line may exceed 0.8V. In such cases it may be desirable to qualify ALE with a Schmitt Trigger, or use an address latch with a Schmitt Trigger STROBE input.

# A.C. CHARACTERISTICS: $(T_A = 0 \degree C \text{ to } +70 \degree C, \text{ VCC} = 5\text{V} \pm 10\%, \text{ VSS} = 0\text{V}, \text{Load Capacitance for Port 0, ALE, and PSEN} = 100 \text{ pF}, \text{Load Capacitance for All Other Outputs} = 80 \text{ pF})$

|         | · · · ·                                                      | 12MH       | z Osc      | Variable               | Oscillator                              | `          |
|---------|--------------------------------------------------------------|------------|------------|------------------------|-----------------------------------------|------------|
| Symbol  | Parameter                                                    | Min        | Max        | Min                    | Max                                     | Units      |
| 1/TCLCL | Oscillator Frequency                                         |            | -          | 3.5                    | 12.                                     | MHz        |
| TLHLL   | ALE Pulse Width                                              | 127        |            | 2TCLCL-40              |                                         | 'ns        |
| TAVLL   | Address Valid to ALE Low                                     | 43         |            | TCLCL-40               | · · · · · · · · · · · · · · · · · · ·   | ns         |
| TLLAX   | Address Hold After ALE Low                                   | 48         |            | TCLCL-35               |                                         | ns         |
| TLLIV   | ALE Low to Valid Instr In<br>8751H, 8751H-12<br>All Others   | ,          | 183<br>233 | A<br>1                 | 4TCLCL-150<br>4TCLCL-100                | 'ns        |
| TLLPL   | ALE Low to PSEN Low                                          | 58         |            | TCLCL-25               |                                         | ns         |
| TPLPH   | PSEN Pulse Width<br>8751H, 8751H-12<br>All Others            | 190<br>215 |            | 3TCLCL-60<br>3TCLCL-35 | e de la                                 | ns<br>ns   |
| TPLIV   | PSEN Low to Valid Instr In<br>8751H, 8751H-12<br>All Others  |            | 100<br>125 | •                      | 3TCLCL-150<br>3TCLCL-125                | ns<br>. ns |
| ΤΡΧΙΧ   | Input Instr Hold After PSEN                                  | 0          |            | 0                      | . <sup>1</sup>                          | ns         |
| TPXIZ   | Input Instr Float After PSEN                                 | ,          | 63         |                        | TCLCL-20                                | ns         |
| TPXAV   | PSEN to Address Valid                                        | 75         |            | TCLCL-8                |                                         | ns         |
| TAVIV   | Address to Valid Instr In<br>8751H, 8751H-12<br>All Others   | ×          | 267<br>302 |                        | 5TCLCL-150<br>5TCLCL-115                | ns<br>ns   |
| TPLAZ   | PSEN Low to Address Float                                    |            | TBD        |                        | TBD                                     | ns         |
| TRLRH   | RD Pulse Width                                               | 400        |            | 6TCLCL-100             |                                         | ns         |
| TWLWH   | WR Pulse Width                                               | 400        | 1          | 6TCLCL-100             | ı.                                      | ns         |
| TRLDV   | RD Low to Valid Data In                                      |            | 252        |                        | 5TCLCL-165                              | ns         |
| TRHDX   | Data Hold After RD                                           | 0          |            | 0                      | , · · · · · · · · · · · · · · · · · · · | ns         |
| TRHDZ   | Data Float After RD                                          |            | 97         |                        | 2TCLCL-70                               | ns         |
| TLLDV   | ALE Low to Valid Data In                                     |            | 517        |                        | 8TCLCL-150                              | ns         |
| TAVDV   | Address to Valid Data In                                     |            | 585        |                        | 9TCLCL-165                              | ns         |
| TLLWL   | ALE Low to RD or WR Low                                      | 200        | 300        | 3TCLCL-50              | 3TCLCL+50                               | ns         |
| TAVWL   | Address to RD or WR Low                                      | 203        |            | 4TCLCL-130             |                                         | ns         |
| TQVWX   | Data Valid to WR Transition<br>8751H, 8751H-12<br>All Others | 13<br>23   | , e .,     | TCLCL-70<br>TCLCL-60   | 1                                       | ns<br>ns   |
| TQVWH   | Data Valid to WR High                                        | 433        | ۰,         | 7TCLCL-150             |                                         | ns         |
| TWHQX   | Data Held After WR                                           | 33         | · ·        | TCLCL-50               |                                         | ns         |
| TRLAZ   | RD Low to Address Float                                      |            | TBD        | τ.                     | TBD                                     | ns         |
| TWHLH   | RD or WR High to ALE High<br>8751H, 8751H-12<br>All Others   | 33<br>43   | 133<br>123 | TCLCL-50<br>TCLCL-40   | TCLCL+50<br>TCLCL+40                    | ns<br>ns   |

#### EXTERNAL PROGRAM MEMORY READ CYCLE



#### EXTERNAL DATA MEMORY READ CYCLE

and the second 


#### EXTERNAL DATA MEMORY WRITE CYCLE



#### SERIAL PORT TIMING - SHIFT REGISTER MODE

Test Conditions:  $T_A = 0$  °C to 70 °C; VCC = 5V ±10%; VSS = 0V; Load Capacitance = 80 pF

| 4      |                                             | 12MHz Osc |     | Variable    | Oscillator  |       |
|--------|---------------------------------------------|-----------|-----|-------------|-------------|-------|
| Symbol | Parameter                                   | Min       | Max | Min         | Max         | Units |
| TXLXL  | Serial Port Clock Cycle Time                | 1.0       |     | 12TCLCL     | 1.          | μs    |
| TQVXH  | Output Data Setup to Clock Rising Edge      | 700       |     | 10TCLCL-133 |             | ns    |
| TXHQX  | Output Data Hold After Clock<br>Rising Edge | 50        |     | 2TCLCL-117  |             | ns    |
| TXHDX  | Input Data Hold After Clock Rising Edge     | 0         |     | 0           |             | ns    |
| TXHDV  | Clock Rising Edge to Input Data Valid       |           | 700 |             | 10TCLCL-133 | ns    |

#### SHIFT REGISTER TIMING WAVEFORMS



#### **EXTERNAL CLOCK DRIVE**

| Symbol  | Parameter            | Min | Max | Units |
|---------|----------------------|-----|-----|-------|
| 1/TCLCL | Oscillator Frequency | 3.5 | 12  | MHz   |
| TCHCX   | High Time            | 20  |     | ns    |
| TCLCX   | Low Time             | 20  |     | ns    |
| TCLCH   | Rise Time            |     | 20  | ns    |
| TCHCL   | Fall Time            |     | 20  | ns    |

#### EXTERNAL CLOCK DRIVE WAVEFORMS



1

#### A.C. TESTING INPUT, OUTPUT WAVEFORM



#### **EPROM CHARACTERISTICS:**

**Table 3. EPROM Programming Modes** 

|              |     |      | •   | •   |      |      |      |      |
|--------------|-----|------|-----|-----|------|------|------|------|
| Mode         | RST | PSEN | ALE | EA  | P2.7 | P2.6 | P2.5 | P2.4 |
| Program      | 1   | 0    | 0*  | VPP | 1    | 0    | X    | X    |
| Inhibit      | 1   | 0    | 1   | X   | 1    | 0    | X    | X    |
| Verify       | 1   | 0    | 1   | 1   | 0    | · 0  | х    | X    |
| Security Set | 1   | 0    | 0*  | VPP | 1    | , 1  | Х    | X    |

**Note:** "1" = logic high for that pin "0" = logic low for that pin

"X" = "don't care"

"VPP" =  $+21V \pm 0.5V$ 

#### Programming the EPROM

To be programmed, the part must be running with a 4 to 6 MHz oscillator. (The reason the oscillator needs to be running is that the internal bus is being used to transfer address and program data to appropriate internal registers.) The address of an EPROM location to be programmed is applied to Port 1 and pins P2.0–P2.3 of Port 2, while the code byte to be programmed into that location is applied to Port 0. The other Port 2 pins, and RST, PSEN, and EA should be held at the "Program" levels indicated in Table 3. ALE is **pulsed** low for 50 msec to program the code byte into the addressed EPROM location. The setup is shown in Figure 5.

Normally  $\overline{EA}$  is held at a logic high until just before ALE is to be pulsed. Then  $\overline{EA}$  is raised to +21V, ALE is pulsed, and then  $\overline{EA}$  is returned to a logic high. Waveforms and detailed timing specifications are shown in later sections of this data sheet.



Figure 5. Programming Configuration

\*ALE is pulsed low for 50 msec.

Note that the EA/VPP pin must not be allowed to go above the maximum specified VPP level of 21.5V for any amount of time. Even a narrow glitch above that voltage level can cause permanent damage to the device. The VPP source should be well regulated and free of glitches.

#### Program Verification

If the Security Bit has not been programmed, the onchip Program Memory can be read out for verification purposes, if desired, either during or after the programming operation. The address of the Program Memory location to be read is applied to Port 1 and pins P2.0–P2.3. The other pins should be held at the "Verify" levels indicated in Table 3. The contents of the addressed location will come out on Port 0. External pullups are required on Port 0 for this operation.

The setup, which is shown in Figure 6, is the same as for programming the EPROM except that pin P2.7 is held at a logic low, or may be used as an active-low read strobe.



Figure 6. Program Verification

#### **EPROM Security**

The security feature consists of a "locking" bit which when programmed denies electrical access by any external means to the on-chip Program Memory. The bit is programmed as shown in Figure 7. The setup and procedure are the same as for normal EPROM programming, except that P2.6 is held at a logic high. Port 0, Port 1, and pins P2.0–P2.3 may be in any state. The other pins should be held at the "Security" levels indicated in Table 3.

Once the Security Bit has been programmed, it can be cleared only by full erasure of the Program Memory. While it is programmed, the internal Program Memory can not be read out, the device can not be further programmed, and it can not execute out of external program memory. Erasing the EPROM, thus clearing the Security Bit, restores the device's full functionality. It can then be reprogrammed.

#### **Erasure Characteristics**

Erasure of the EPROM begins to occur when the chip is exposed to light with wavelengths shorter than approximately 4,000 Angstroms. Since sunlight and flourescent lighting have wavelengths in this range, exposure to these light sources over an extended time (about 1 week in sunlight, or 3 years in roomlevel flourescent lighting) could cause inadvertent erasure. If an application subjects the device to this type of exposure, it is suggested that an opaque label be placed over the window.



Figure 7. Programming the Security Bit

The recommended erasure procedure is exposure to ultraviolet light (at 2537 Angstroms) to an integrated dose of at least 15 W-sec/cm<sup>2</sup>. Exposing the EPROM to an ultraviolet lamp of 12,000  $\mu$ W/cm<sup>2</sup> rating for 20 to 30 minutes, at a distance of about 1 inch, should be sufficient.

Erasure leaves the array in an all 1s state.

#### **EPROM PROGRAMMING AND VERIFICATION CHARACTERISTICS:**

 $(T_A = 21 \degree C \text{ to } 27 \degree C, VCC = 5V \pm 10\%, VSS = 0V)$ 

| Symbol  | Parameter                  | Min     | Max     | Units                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|----------------------------|---------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VPP     | Programming Supply Voltage | 20.5    | 21.5    | V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| IPP     | Programming Supply Current |         | 30      | mA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1/TCLCL | Oscillator Frequency       | 4       | 6       | MHz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| TAVGL   | Address Setup to PROG Low  | 48TCLCL |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| TGHAX   | Address Hold After PROG    | 48TCLCL |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| TDVGL   | Data Setup to PROG Low     | 48TCLCL |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| TGHDX   | Data Hold After PROG       | 48TCLCL |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| TEHSH   | P2.7 (ENABLE) High to VPP  | 48TCLCL |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| TSHGL   | VPP Setup to PROG Low      | 10      |         | μsec                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| TGHSL   | VPP Hold After PROG        | 10      |         | μsec                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| TGLGH   | PROG Width                 | 45      | 55      | msec                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| TAVQV   | Address to Data Valid      |         | 48TCLCL | , <b>1997 - 1997 - 1997 - 1997 - 1997</b> - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 1997 - 199 |
| TELQV   | ENABLE Low to Data Valid   |         | 48TCLCL |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| TEHQZ   | Data Float After ENABLE    | 0       | 48TCLCL |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

PRELIMINARY

#### EPROM PROGRAMMING AND VERIFICATION WAVEFORMS





8052AH-BASIC

# intel

- Full BASIC Interpreter in ROM on a Single Chip
- BCD Floating Point Math
- Generates All Timing Necessary to Program EPROMS and E<sup>2</sup>PROMS
- Fast Tokenized Interpreter
- "Stand Alone" Software Development
- All Arithmetic and Utility Routines Can Be Called From Assembly Language
- Interrupts Can Be Handled By BASIC or Assembly Language
- Built-In Accurate REAL TIME CLOCK
- Multiple User Programs
- Programs May Reside in RAM, EPROM or E<sup>2</sup>PROM
- Built in Radix Conversion Hex to Decimal and Decimal to Hex

8052AH-BASIC is an 8052AH microcontroller with a complete full-featured BASIC interpreter, MCS® BASIC-52, resident in the 8K of available ROM. This Software-On-Silicon product is specifically designed to address the needs of process control, measurement, and instrumentation applications. MCS BASIC-52 allows 8052AH users to write programs in the popular BASIC language, which is much simpler to write and easier to understand than assembly language.

In addition to the standard BASIC commands and functions, such as floating point arithmetic and transcendental operations, MCS BASIC-52 contains many unique features that allow the user to perform tasks that usually require assembly language. Bit-wise logical operators, such as AND, OR, and EXCLUSIVE-OR are supported as well as hexadecimal arithmetic.

A minimum amount of hardware is required to support MCS BASIC-52. Small systems can be constructed with only a latch, 1K bytes of external memory, and the appropriate serial port drivers. With the addition of a transistor, a gate, and a couple of passive components, MCS BASIC-52 can program EPROM or E<sup>2</sup>PROM devices with the users application program. Both the standard and the int<sub>e</sub>ligent Programming<sup>™</sup> algorithms are supported.

MCS BASIC-52 is an interpreted language. This allows the user to develop a program interactively without the cumbersome and repetitive process of editing, assembling, loading, and running which is required by assemblers and compilers. MCS BASIC-52 was designed to permit the programmer to develop resident high level language software using the high performance 8052AH device.



#### FEATURES

#### COMMAND SET

MCS BASIC-52 contains all standard BASIC commands, statements, and operators. Figure 1 list the software feature set of MCS BASIC-52.

#### DATA FORMAT

The range of numbers that can be represented in MCS BASIC-52 is:

±1E-127 to ±.99999998 + 127

#### CONTROL ORIENTED FEATURES

MCS BASIC-52 contains many unique features to perform task that usually require assembly language programming. The XBY and DBY operators can read and/or write external and internal memory respectively. The CBY operator is used to read program memory. Additionally, virtually all of the special function registers on the 8052AH can be accessed with MCS BASIC-52. This allows the user to set the timer or interrupt modes within the constructs of a BASIC program. An accurate interrupt driven REAL TIME CLOCK that has a 5 millisecond resolution is also implemented in MCS BASIC-52. This clock can be enabled, disabled, and used to generate interrupts. Finally, a CALL statement that allows the programmer to CALL assembly language routines is available in MCS BASIC-52. Parameters can be passed in a number of different ways.

#### EPROM/E<sup>2</sup>PROM FILE

Most Basic interpreters allow only one program to be resident in memory, and many require that the program reside in RAM. MCS BASIC-52 allows programs to reside in both RAM and EPROM/ E<sup>2</sup>PROM. Additionally, up to 255 programs may reside in EPROM/E<sup>2</sup>PROM. Programs may also be transfered (XFER) from EPROM/E<sup>2</sup>PROM to RAM for editing purposes.

#### EPROM/E<sup>2</sup>PROM PROGRAMMING

A powerful feature of MCS BASIC-52 is that it generates all of the timing necessary to program any standard EPROM or E<sup>2</sup>PROM device with the users' program (PROG/FPROG). Additionally, very little external hardware is required to implement this feature. Saving programs in EPROM/E<sup>2</sup>PROM is much more attractive and reliable than other alternatives, such as cassette tape, especially in control and/or other noisy environments.

#### AUTOSTART

After the user programs an EPROM or E<sup>2</sup>PROM with the desired BASIC program. The PROG2 or FPROG2 commands may be used to enable the unique AUTOSTART feature of MCS BASIC-52. When AUTOSTART is enabled, MCS BASIC-52 will execute the user program after RESET or a power-up condition. This permits the user to RUN a program without connecting the MCS BASIC-52 device to a console — a powerful feature for control environments.

#### USER ACCESSABLE FUNCTION LIBRARY

Another unique feature of MCS BASIC-52 is that it contains a complete library of functions that can be accessed with assembly language. All floating point, radix conversion, and I/O routines contained in MCS BASIC-52 can be accessed with assembly language CALL instructions. These complex arithmetic routines can be used by the programmer in applications requiring the speed of assembly language, but also the complex arithmetics offered by BASIC.

#### 8052AH-BASIC PIN DESCRIPTION (FIGURE 2)

8052AH-BASIC is an 8052AH device, however, MCS BASIC-52 assumes a particular hardware configuration. The following pin description outlines the pin functions defined by MCS BASIC-52.

#### VSS

Circuit ground potential.

#### VCC

Circuit supply voltage. 5 volts  $\pm$  10% relative to VSS.

#### AD0-AD7

The multiplexed low-order address and data bus used during accesses to external memory. External pullup devices ( $\sim$  10K  $\Omega$ ) are required on these pins if the MCS BASIC-52 EPROM/E<sup>2</sup>PROM programming feature is used.

#### A8-A15

The high order address bus used during accesses to external memory.

| $\begin{array}{c c} \textbf{Commands} & \textbf{Statements} & \textbf{Operators} \\ \hline \textbf{RUN} & \textbf{BAUD} & \textbf{ADD} (+) \\ LIST & \textbf{CALL} & DIVIDE (/) \\ LIST \# & \textbf{CLEAR} & \textbf{EXPONENTIATION (**)} \\ \textbf{NEW} & \textbf{CLEARS} & \textbf{MULTIPLY (*)} \\ \hline \textbf{NULL} & \textbf{CLEARI} & \textbf{SUBTRACT} (-) \\ \hline \textbf{RAM} & \textbf{CLOCK0} & \textbf{LOGICAL AND (.AND.)} \\ \hline \textbf{ROM} & \textbf{CLOCK1} & \textbf{LOGICAL OR (.OR.)} \\ \hline \textbf{ROM} & \textbf{CLOCK1} & \textbf{LOGICAL NOT (.XOR.)} \\ \hline \textbf{PROG} & \textbf{READ} & \textbf{LOGICAL NOT} \\ \hline \textbf{PROG1} & \textbf{RESTORE} & \textbf{ABS} ( ) \\ \hline \textbf{PROG2} & \textbf{DIM} & \textbf{INT} ( ) \\ \hline \textbf{FPROG1} & \textbf{DO-UNTIL} & \textbf{SQR} ( ) \\ \hline \textbf{FPROG1} & \textbf{DO-UNTIL} & \textbf{SQR} ( ) \\ \hline \textbf{FPROG2} & \textbf{END} & \textbf{RND} \\ \hline \textbf{FOR-TO-STEP} & \textbf{LOG} ( ) \\ \hline \textbf{RETURN} & \textbf{COS} ( ) \\ \hline \textbf{GOSUB} & \textbf{SIN} ( ) \\ \hline \textbf{RETURN} & \textbf{COS} ( ) \\ \hline \textbf{GOTO} & \textbf{TAN} ( ) \\ \hline \textbf{ON-GOSUB} & =, > =, < \\ <, < =, <> \\ \hline \textbf{IF-THEN-ELSE} & \textbf{ASC} ( ) \\ \hline \textbf{INPUT} & \textbf{CHR} ( ) \\ \hline \textbf{LET} & \textbf{CBY} ( ) \\ \hline \textbf{ONERR} & \textbf{DBY} ( ) \\ \hline \textbf{ONERR} & \textbf{DBY} ( ) \\ \hline \textbf{ONTIME} & \textbf{GET} \\ \hline \textbf{PRINT} & \textbf{IE} \\ \hline \textbf{PRINT} & \textbf{IE} \\ \hline \textbf{PRINT} & \textbf{IE} \\ \hline \textbf{PRINT} & \textbf{PHO.} \\ \hline \textbf{PHO.} & \textbf{PORT1} \\ \hline \textbf{PHO.} & \textbf{PORT1} \\ \hline \textbf{PH0.} & \textbf{PCN} \\ \hline \textbf{PH0.} & \textbf{PCN} \\ \hline \textbf{PH1.} & \textbf{T2CON} \\ \end{array}$                                                                                                                                                                                                                                                                |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LIST CALL DIVIDE ( $i$ )<br>LIST CALL DIVIDE ( $i$ )<br>LIST CLEAR EXPONENTIATION (**)<br>NEW CLEARS MULTIPLY (*)<br>NULL CLEARI SUBTRACT (-)<br>RAM CLOCK0 LOGICAL AND (AND.)<br>ROM CLOCK1 LOGICAL OR (.OR.)<br>XFER DATA LOGICAL OR (.OR.)<br>XFER DATA LOGICAL NOT<br>PROG READ LOGICAL NOT<br>PROG1 RESTORE ABS ()<br>PROG2 DIM INT ()<br>FPROG1 DO-UNTIL SGR ()<br>FPROG1 DO-UNTIL SGR ()<br>FPROG2 END RND<br>FOR-TO-STEP LOG ()<br>NEXT EXP ()<br>GOSUB SIN ()<br>RETURN COS ()<br>GOTO TAN ()<br>ON-GOSUB =, >, >=,<br><, <=, <><br>IF-THEN-ELSE ASC ()<br>INPUT CHR ()<br>LET CBY ()<br>ONERT DEY ()<br>ONERT DEY ()<br>ONERT DEY ()<br>ONTIME GET<br>PRINT IE<br>PRINT IE<br>PRINT IE<br>PRINT IE<br>PRINT IP<br>PH0. PORT1<br>PH0. PORT1<br>PH0. PORT1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| $ \begin{array}{llllllllllllllllllllllllllllllllllll$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| $\begin{array}{cccc} NEW & CLEARS & MULTIPLY(*) \\ NULL & CLEARI & SUBTRACT(-) \\ RAM & CLOCK0 & LOGICAL AND(AND.) \\ ROM & CLOCK1 & LOGICAL OR(OR) \\ ROM & CLOCK1 & LOGICAL OR(OR) \\ XFER & DATA & LOGICAL OR(OR) \\ PROG & READ & LOGICAL OR(OR) \\ PROG1 & RESTORE & ABS(\;) \\ PROG2 & DIM & INT(\;) \\ FPROG & DO-WHILE & SGN(\;) \\ FPROG1 & DO-UNTIL & SQR(\;) \\ FPROG1 & DO-UNTIL & SQR(\;) \\ FOR-TO-STEP & LOG(\;) \\ FOR-TO-STEP & LOG(\;) \\ GOSUB & SIN(\;) \\ RETURN & COS(\;) \\ GOTO & ATN(\;) \\ ON-GOTO & ATN(\;) \\ ON-GOTO & ATN(\;) \\ ON-GOSUB & =, >, >=, \\ <, <=, <> \\ IF-THEN-ELSE & ASC(\;) \\ INPUT & CHR(\;) \\ LET & CBY(\;) \\ ONERR & DBY(\;) \\ ONERT1 & XBY(\;) \\ ONEXT1 & XBY(\;) \\ ONEXT1 & XBY(\;) \\ ONEXT1 & XBY(\;) \\ ONEXT1 & PRINT & IP \\ PRINT & IP \\ PH0 & PCON \\ PH1 & RCAP2 \\ \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| $\begin{array}{c c} NULL & CLEARI & SUBTRACT(-) \\ RAM & CLOCK0 & LOGICAL AND(AND.) \\ ROM & CLOCK1 & LOGICAL AND(AND.) \\ ROM & CLOCK1 & LOGICAL AND(AND.) \\ ROM & CLOCK1 & LOGICAL ANO(AND.) \\ PROG & READ & LOGICAL AOR(XOR.) \\ PROG1 & RESTORE & ABS(\ ) \\ PROG2 & DIM & INT(\ ) \\ FPROG1 & DO-WHILE & SGN(\ ) \\ FPROG1 & DO-WHILE & SGN(\ ) \\ FPROG2 & END & RND \\ FOR-TO-STEP & LOG(\ ) \\ NEXT & EXP(\ ) \\ GOSUB & SIN(\ ) \\ RETURN & COS(\ ) \\ GOTO & TAN(\ ) \\ ON-GOSUB & sin(\ ) \\ ON-GOSUB & sin(\ ) \\ ON-GOSUB & sin(\ ) \\ ON-GOSUB & SSC(\ ) \\ IF-THEN-ELSE & ASC(\ ) \\ INPUT & CHR(\ ) \\ LET & CBY(\ ) \\ ONERR & DBY(\ ) \\ ONERR & DBY(\ ) \\ ONERT1 & XBY(\ ) \\ ONTIME & GET \\ PRINT & IE \\ PRINT & IP \\ PH0 & PORT1 \\ PH0 & PORT1 \\ PH0 & PCON \\ PH1 & RCAP2 \\ \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| $\begin{array}{c c} NULL & CLEARI & SUBTRACT(-) \\ RAM & CLOCK0 & LOGICAL AND(AND.) \\ ROM & CLOCK1 & LOGICAL AND(AND.) \\ ROM & CLOCK1 & LOGICAL AND(AND.) \\ ROM & CLOCK1 & LOGICAL ANO(AND.) \\ PROG & READ & LOGICAL AOR(XOR.) \\ PROG1 & RESTORE & ABS(\ ) \\ PROG2 & DIM & INT(\ ) \\ FPROG1 & DO-WHILE & SGN(\ ) \\ FPROG1 & DO-WHILE & SGN(\ ) \\ FPROG2 & END & RND \\ FOR-TO-STEP & LOG(\ ) \\ NEXT & EXP(\ ) \\ GOSUB & SIN(\ ) \\ RETURN & COS(\ ) \\ GOTO & TAN(\ ) \\ ON-GOSUB & sin(\ ) \\ ON-GOSUB & sin(\ ) \\ ON-GOSUB & sin(\ ) \\ ON-GOSUB & SSC(\ ) \\ IF-THEN-ELSE & ASC(\ ) \\ INPUT & CHR(\ ) \\ LET & CBY(\ ) \\ ONERR & DBY(\ ) \\ ONERR & DBY(\ ) \\ ONERT1 & XBY(\ ) \\ ONTIME & GET \\ PRINT & IE \\ PRINT & IP \\ PH0 & PORT1 \\ PH0 & PORT1 \\ PH0 & PCON \\ PH1 & RCAP2 \\ \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| $\begin{array}{cccc} XFER & DATA & LOGICAL X-OR (.XOR.) \\ PROG & READ & LOGICAL NOT \\ PROG1 & RESTORE & ABS ( ) \\ PROG2 & DIM & INT ( ) \\ FPROG & DO-WHILE & SGN ( ) \\ FPROG1 & DO-UNTIL & SQR ( ) \\ FPROG1 & DO-UNTIL & SQR ( ) \\ FOR-TO-STEP & LOG ( ) \\ NEXT & EXP ( ) \\ GOSUB & SIN ( ) \\ RETURN & COS ( ) \\ GOTO & TAN ( ) \\ ON-GOTO & ATN ( ) \\ ON-GOTO & ATN ( ) \\ ON-GOSUB & =, >, >=, \\ <, <=, <> \\ IF-THEN-ELSE & ASC ( ) \\ INPUT & CHR ( ) \\ LET & CBY ( ) \\ ONERR & DBY ( ) \\ ONERR & DBY ( ) \\ ONTIME & GET \\ PRINT & IE \\ PRINT & IE \\ PRINT & IP \\ PH0. & PORT1 \\ PH0. & PORT1 \\ PH0. & PCON \\ PH1. & RCAP2 \\ \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| $\begin{array}{c c} PROG & READ & LOGICAL NOT \\ PROG1 & RESTORE & ABS ( \ ) \\ PROG2 & DIM & INT ( \ ) \\ FPROG & DO-WHILE & SGN ( \ ) \\ FPROG1 & DO-UNTIL & SQR ( \ ) \\ FPROG2 & END & RND \\ FOR-TO-STEP & LOG ( \ ) \\ NEXT & EXP ( \ ) \\ GOSUB & SIN ( \ ) \\ RETURN & COS ( \ ) \\ GOTO & ATN ( \ ) \\ ON-GOTO & ATN ( \ ) \\ ON-GOTO & ATN ( \ ) \\ ON-GOSUB & =, >, >=, \\ <, <=, <> \\ IF-THEN-ELSE & ASC ( \ ) \\ INPUT & CHR ( \ ) \\ LET & CBY ( \ ) \\ ONERR & DBY ( \ ) \\ ONERR & DBY ( \ ) \\ ONEXT1 & XBY ( \ ) \\ ONEXT1 & XBY ( \ ) \\ ONEXT1 & XBY ( \ ) \\ ONTIME & GET \\ PRINT & IP \\ PH0 & PORT1 \\ PH0 & PORT1 \\ PH0 & PCON \\ PH1 & RCAP2 \\ \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| $\begin{array}{c c} PROG & READ & LOGICAL NOT \\ PROG1 & RESTORE & ABS ( \ ) \\ PROG2 & DIM & INT ( \ ) \\ FPROG & DO-WHILE & SGN ( \ ) \\ FPROG1 & DO-UNTIL & SQR ( \ ) \\ FPROG2 & END & RND \\ FOR-TO-STEP & LOG ( \ ) \\ NEXT & EXP ( \ ) \\ GOSUB & SIN ( \ ) \\ RETURN & COS ( \ ) \\ GOTO & ATN ( \ ) \\ ON-GOTO & ATN ( \ ) \\ ON-GOTO & ATN ( \ ) \\ ON-GOSUB & =, >, >=, \\ <, <=, <> \\ IF-THEN-ELSE & ASC ( \ ) \\ INPUT & CHR ( \ ) \\ LET & CBY ( \ ) \\ ONERR & DBY ( \ ) \\ ONERR & DBY ( \ ) \\ ONEXT1 & XBY ( \ ) \\ ONEXT1 & XBY ( \ ) \\ ONEXT1 & XBY ( \ ) \\ ONTIME & GET \\ PRINT & IP \\ PH0 & PORT1 \\ PH0 & PORT1 \\ PH0 & PCON \\ PH1 & RCAP2 \\ \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| $\begin{array}{cccc} PROG2 & DIM & INT( \ ) \\ FPROG & DO-WHILE & SGN( \ ) \\ FPROG1 & DO-UNTIL & SQR( \ ) \\ FPROG2 & END & RND \\ & FOR-TO-STEP & LOG( \ ) \\ & NEXT & EXP( \ ) \\ & GOSUB & SIN( \ ) \\ & RETURN & COS( \ ) \\ & GOTO & TAN( \ ) \\ & ON-GOTO & ATN( \ ) \\ & ON-GOTO & ATN( \ ) \\ & ON-GOTO & ATN( \ ) \\ & ON-GOSUB & =, >, >=, \\ & <, <=, <> \\ & IF-THEN-ELSE & ASC( \ ) \\ & IIPUT & CHR( \ ) \\ & LET & CBY( \ ) \\ & ONERR & DBY( \ ) \\ & ONERR & DBY( \ ) \\ & ONTIME & GET \\ & PRINT & IE \\ & PRINT & IP \\ & PHO. & PORT1 \\ & PHO. & PORT1 \\ & PH0. & PCON \\ & PH1. & RCAP2 \\ \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| $\begin{array}{cccc} PROG2 & DIM & INT( \ ) \\ FPROG & DO-WHILE & SGN( \ ) \\ FPROG1 & DO-UNTIL & SQR( \ ) \\ FPROG2 & END & RND \\ & FOR-TO-STEP & LOG( \ ) \\ & NEXT & EXP( \ ) \\ & GOSUB & SIN( \ ) \\ & RETURN & COS( \ ) \\ & GOTO & TAN( \ ) \\ & ON-GOTO & ATN( \ ) \\ & ON-GOTO & ATN( \ ) \\ & ON-GOTO & ATN( \ ) \\ & ON-GOSUB & =, >, >=, \\ & <, <=, <> \\ & IF-THEN-ELSE & ASC( \ ) \\ & IIPUT & CHR( \ ) \\ & LET & CBY( \ ) \\ & ONERR & DBY( \ ) \\ & ONERR & DBY( \ ) \\ & ONTIME & GET \\ & PRINT & IE \\ & PRINT & IP \\ & PHO. & PORT1 \\ & PHO. & PORT1 \\ & PH0. & PCON \\ & PH1. & RCAP2 \\ \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| FPROG1         DO-UNTIL         SQR ( )           FPROG2         END         RND           FOR-TO-STEP         LOG ( )         NEXT           GOSUB         SIN ( )           RETURN         COS ( )           GOTO         TAN ( )           ON-GOSUB         =, >, >=,           <, <=, <>         IF-THEN-ELSE           IF-THEN-ELSE         ASC ( )           INPUT         CHR ( )           LET         CBY ( )           ONERR         DBY ( )           ONTIME         GET           PRINT         IE           PRINT         IE           PRINT         IP           PH0.         PORT1           PH0.#         PCON           PH1.         RCAP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| $\begin{array}{cccc} \mbox{FPROG2} & \mbox{END} & \mbox{RND} \\ \mbox{FOR-TO-STEP} & \mbox{LOG}(\ ) \\ \mbox{NEXT} & \mbox{EXP}(\ ) \\ \mbox{GOSUB} & \mbox{SIN}(\ ) \\ \mbox{RETURN} & \mbox{COS}(\ ) \\ \mbox{GOTO} & \mbox{TAN}(\ ) \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{COS}(\ ) \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{COS}(\ ) \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{COS}(\ ) \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{COS}(\ ) \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{COS}(\ ) \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{COS}(\ ) \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{COS}(\ ) \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{COS}(\ ) \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{COS}(\ ) \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{COS}(\ ) \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{COS}(\ ) \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{COS}(\ ) \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{COS}(\ ) \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{COS}(\ ) \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{COS}(\ ) \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{COS}(\ ) \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{COS}(\ ) \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{COS}(\ ) \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{ON-GOSUB} & \mbox{=}, >, > =, \\ \mbox{ON-GOSUB} & \mbox{ON-GOSUB} & \mbox{ON-GOSUB} \\ \mbox{ON-GOSUB} & \mbox{ON-GOSUB} & \mbox{ON-GOSUB} & \mbox{ON-GOSUB} \\ \mbox$ |
| FOR-TO-STEP       LOG ( )         NEXT       EXP ( )         GOSUB       SIN ( )         RETURN       COS ( )         GOTO       TAN ( )         ON-GOTO       ATN ( )         ON-GOTO       ATN ( )         ON-GOSUB       =, >, > =,         <, <=, <>          IF-THEN-ELSE       ASC ( )         INPUT       CHR ( )         LET       CBY ( )         ONERR       DBY ( )         ONTIME       GET         PRINT       IE         PRINT       IE         PRINT       IP         PH0.       PORT1         PH0.#       PCON         PH1.       RCAP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| NEXT         EXP ( )           GOSUB         SIN ( )           RETURN         COS ( )           GOTO         TAN ( )           ON-GOTO         ATN ( )           ON-GOSUB         =, >, >=,           <, <=, <>            IF-THEN-ELSE         ASC ( )           IF-THEN-ELSE         ASC ( )           ONERR         DBY ( )           ONERR         DBY ( )           ONTIME         GET           PRINT         IE           PRINT         IE           PRINT#         IP           PH0.         PORT1           PH0.#         PCON           PH1.         RCAP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| GOSUB       SIN ( )         RETURN       COS ( )         GOTO       TAN ( )         ON-GOTO       ATN ( )         ON-GOTO       ATN ( )         ON-GOTO       ATN ( )         ON-GOSUB       =, >, >=,         <, <=, <>          IF-THEN-ELSE       ASC ( )         INPUT       CHR ( )         LET       CBY ( )         ONERR       DBY ( )         ONERR       DBY ( )         ONTIME       GET         PRINT       IE         PRINT       IP         PH0.       PORT1         PH0.#       PCON         PH1.       RCAP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| RETURN       COS ( )         GOTO       TAN ( )         ON-GOTO       ATN ( )         ON-GOSUB       =, >, >=,         <, <=, <>          IF-THEN-ELSE       ASC ( )         INPUT       CHR ( )         LET       CBY ( )         ONERR       DBY ( )         ONERT       DBY ( )         ONTIME       GET         PRINT       IE         PRINT       IP         PH0.       POCN1         PH0.#       PCON         PH1.       RCAP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| GOTO       TAN ( )         ON-GOTO       ATN ( )         ON-GOSUB       =, >, >=,         <, <=, <>         IF-THEN-ELSE       ASC ( )         INPUT       CHR ( )         LET       CBY ( )         ONERR       DBY ( )         ONERR       DBY ( )         ONTIME       GET         PRINT       IE         PRINT       IP         PH0.       PORT1         PH0.#       PCON         PH1.       RCAP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| ON-GOTO ATN ( )<br>ON-GOSUB =, >, >=,<br><, <=, <><br>IF-THEN-ELSE ASC ( )<br>INPUT CHR ( )<br>LET CBY ( )<br>ONERR DBY ( )<br>ONERT DBY ( )<br>ONTIME GET<br>PRINT IE<br>PRINT IE<br>PRINT IE<br>PRINT # IP<br>PH0. PORT1<br>PH0. PCON<br>PH1. RCAP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ON-GOSUB =, >, >=,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <, <=, <><br>IF-THEN-ELSE ASC ( )<br>INPUT CHR ( )<br>LET CBY ( )<br>ONERR DBY ( )<br>ONEXT1 XBY ( )<br>ONTIME GET<br>PRINT IE<br>PRINT IE<br>PRINT# IP<br>PH0. PORT1<br>PH0.# PCON<br>PH1. RCAP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| <, <=, <><br>IF-THEN-ELSE ASC ( )<br>INPUT CHR ( )<br>LET CBY ( )<br>ONERR DBY ( )<br>ONEXT1 XBY ( )<br>ONTIME GET<br>PRINT IE<br>PRINT IE<br>PRINT# IP<br>PH0. PORT1<br>PH0.# PCON<br>PH1. RCAP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| INPUT CHR ( )<br>LET CBY ( )<br>ONERR DBY ( )<br>ONEXT1 XBY ( )<br>ONTIME GET<br>PRINT IE<br>PRINT# IP<br>PH0. PORT1<br>PH0.# PCON<br>PH1. RCAP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| LET CBY()<br>ONERR DBY()<br>ONEXT1 XBY()<br>ONTIME GET<br>PRINT IE<br>PRINT# IP<br>PH0. PORT1<br>PH0.# PCON<br>PH1. RCAP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| ONERR DBY()<br>ONEXT1 XBY()<br>ONTIME GET<br>PRINT IE<br>PRINT# IP<br>PH0. PORT1<br>PH0.# PCON<br>PH1. RCAP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| ONEXT1 XBY()<br>ONTIME GET<br>PRINT IE<br>PRINT# IP<br>PH0. PORT1<br>PH0.# PCON<br>PH1. RCAP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| ONTIME GET<br>PRINT IE<br>PRINT# IP<br>PH0. PORT1<br>PH0.# PCON<br>PH1. RCAP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| PRINT IE<br>PRINT# IP<br>PH0. PORT1<br>PH0.# PCON<br>PH1. RCAP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| PRINT# IP<br>PH0. PORT1<br>PH0.# PCON<br>PH1. RCAP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| PH0. PORT1<br>PH0.# PCON<br>PH1. RCAP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| PH0.# PCON<br>PH1. RCAP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| PH1. RCAP2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| PH1.# T2CON                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| PUSH TCON                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| POP TMOD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| PWM TIME                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| REM TIMERO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| RET1 TIMER1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| STOP TIMER2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| STRING TIME                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| UIO XTAL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| UI1 MTOP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| UO0 LEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| UO1 FREE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Pl                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

#### Figure 1. MCS® BASIC-52 Software Feature Set

#### PORT 1

A general purpose quasi-bidirectional 8-bit input/ output port. The individual pins on PORT 1 all have alternate functions which may or may not be implemented by the user. The alternate functions are as follows:

#### PORT 1.0 (T2)

Can be used as the trigger input to TIMER/COUNTER 2. A one (1) must be written to this port pin output latch in order for this function to operate. Details of





the T2 trigger function are covered in the Microcontrollers Handbook. Order Number 210918-002.

#### **PORT 1.1 (T2EX)**

Can be used as the external input to TIMER/ COUNTER 2. A one (1) must be written to this port pin output latch in order for this function to operate. Details of the T2 trigger function are covered in the Microcontroller Users Manual.

#### PORT 1.2 (PWM OUTPUT)

This pin is used as the PWM output port when the PWM statement is executed. PWM stands for Pulse Width Modulation and is used to generate pulses of varying duty cycle and frequency.

#### PORT 1.3 (ALE DISABLE)

This pin is used to disable the ALE signal to the external address latch when the EPROM/E<sup>2</sup>PROM programming feature is used. In a system, this pin is logically anded with ALE.

#### PORT 1.4 (PROGRAMMING PULSE)

When the EPROM/E<sup>2</sup>PROM programming feature is used, this pin provides the proper programming pulse width to program EPROM and INTELligent EPROM<sup>®</sup> devices. MCS BASIC-52 actually calculates the proper programming pulse width from the system crystal value (XTAL) to assure the proper timing of this pulse. When used to program E<sup>2</sup>PROM devices, the length of this pulse is not critical. This pin is active in the logical zero (0) state.

#### PORT 1.5 (PROGRAMMING ENABLE)

When the EPROM/E<sup>2</sup>PROM programming feature is implemented, this pin is used to enable the EPROM programming voltage. This pin remains active (logically low (0)) during the entire EPROM programming process. On E<sup>2</sup>PROM devices that do not require any special programming voltage, this pin is not used.

#### PORT 1.6 (DMA ACKNOWLEDGE)

When the DMA feature is implemented as described in the MCS® BASIC-52 users manual, this pin functions as an active low DMA ACKNOWLEDGE output.

#### PORT 1.7 (LINE PRINTER OUTPUT)

This pin functions as a serial output port when the LIST# or PRINT# command and/or statement is used. This enables the user to make a "hard copy" of a program or to print out results of a calculation.

#### RESET

A high (2.5 volts) on this pin for two machine cycles while the oscillator is running resets the device. An external pulldown resistor ( $\sim$ 8.2K) from RESET to VSS permits power-on reset when a capacitor ( $\sim$ 10 uf) is connected from this pin to VCC.

#### ALE

ALE (address latch enable) is an output pin that is used to latch the low order address byte during Read, Write, or program fetch operations to external memory.

#### PSEN

This pin (Program Store ENable) is a control signal that is used to enable external program memory. In MCS® BASIC-52, this pin will always remain inactive (logically high (1)) unless the user is running an assembly language program in external memory.

#### XTAL1

Input to the inverting amplifier that forms the oscillator.

#### XTAL2

Output of the inverting amplifier that forms the oscillator, and input to the internal clock generator. Receives the external oscillator signal when an external oscillator is used.

#### RD

A control signal that is used to enable READ operations to external data memory. This pin is active low (0).

#### WR

A control signal that is used to enable WRITE operations to external data memory. This pin is active low (0).

#### T1

This pin can be programmed to be an external input to TIMER/COUNTER 1.

#### TO

This pin can be programmed to be an external input to TIMER/COUNTER 0.

#### INT1

This pin is the external interrupt 1 pin. It is active low and interrupts on this pin may be handled in either BASIC or in assembly language.

#### INTO/DMA REQUEST

This is the external interrupt 0 pin. It is active low and may be optionally programmed to function as a DMA request input pin. The DMA REQUEST pin is used by E<sup>2</sup>PROM devices during programming.

#### CONSOLE SERIAL OUTPUT

This is the serial output pin to the console device. Standard ASCII codes are used as well as a standard asynchronous frame.

#### CONSOLE SERIAL INPUT

This is the serial input pin that receives data from the console device. Standard ASCII codes are assumed to be the input and the data is assumed to be transmitted using a standard asynchronous frame.

#### NOTES

If pin 31 is grounded the 8052AH-BASIC will operate as a standard 8032AH. The tolerances on this pin are described under DC characteristics.

For detailed information concerning this product please refer to the MCS BASIC-52 Users Manual (Order Number 210918-002).

#### ABSOLUTE MAXIMUM RATINGS\*

| Ambient Temperature Under Bias 0°C to 70°C                            |
|-----------------------------------------------------------------------|
| Storage Temperature $\ldots \ldots -65^{\circ}C$ to $+150^{\circ}C$   |
| Voltage on Any Pin With Respect to Ground (VSS) $\ldots$ -0.5V to +7V |
| Power Dissipation                                                     |

\*NOTICE: Stresses above those listed under ''Absolute Maximum Ratings'' may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

| Symbol | Parameter                                                  | Min  | Max                   | Unit       | Test Conditions                                 |
|--------|------------------------------------------------------------|------|-----------------------|------------|-------------------------------------------------|
| VIL    | Input Low Voltage                                          | -0.5 | 0.8                   | V          |                                                 |
| VIH    | Input High Voltage<br>(Except RST and XTAL2)               | 2.0  | V <sub>CC</sub> + 0.5 | V          |                                                 |
| VIH1   | Input High Voltage to<br>RST for Reset, XTAL2              | 2.5  | V <sub>CC</sub> + 0.5 | V          | XTAL1 to VSS                                    |
| VOL    | Output Low Voltage Port 1, A8-15,<br>Control Functions     |      | 0.45                  | . <b>V</b> | IOL = 1.6mA                                     |
| VOL1   | Output Low Voltage ALE, PSEN<br>(Note 1)                   |      | 0.45                  | V          | IOL = 3.2mA                                     |
| VOH    | Output High Voltage Port 1, A8–15,<br>Control Functions    | 2.4  |                       | V          | $IOH = -80\mu A$                                |
| VOH1   | Output High Voltage AD0-7, ALE, PSEN                       | 2.4  |                       | V          | $IOH = -400 \mu A$                              |
| IIL    | Logical 0 Input Current Port 1, A8–15<br>Control Functions |      | - 800                 | μA         | Vin = 0.45V                                     |
| IIL2   | Logical 0 Input Current XTAL2                              |      | -2.5                  | mA         | XTAL1 at V <sub>SS</sub> ,<br>Vin=0.45V         |
| IL1    | Input Leakage Current To AD0-7 EA                          |      | ±10                   | μΑ         | 0.45V <vin<v<sub>CC</vin<v<sub>                 |
| IIH1   | Input High Current to RST/VPD For<br>Reset                 |      | 500                   | μA         | $Vin = V_{CC} - 1.5V$                           |
| ICC    | Power Supply Current                                       |      | . 175                 | mA         | All outputs disconnected                        |
| CIO    | Capacitance of I/O Buffer                                  |      | 10                    | pF         | $f_{\rm C} = 1$ MHz, $T_{\rm A} = 25^{\circ}$ C |

DC CHARACTERISTICS (T<sub>A</sub> = 0°C to 70°C,  $V_{CC}$  = 4.5V to 5.5V,  $V_{SS}$  = 0V)

See page 6 for Notes.

intel

Note 1: Vol is degraded when the 8032AH/8052AH rapidly discharges external capacitance. This AC noise is most pronounced during emission of address data. When using external memory, locate the latch or buffer as close to the 8032AH/8052AH as possible.

| Datum      | Emitting<br>Ports | Degraded<br>I/O Lines         | VOL<br>(peak)<br>(max)<br>0.8V |  |
|------------|-------------------|-------------------------------|--------------------------------|--|
| Address    | A8-15, AD0-7      | P1, Control<br>Functions      |                                |  |
| Write Data | AD07              | P1, Control<br>Functions, ALE | 0.8v                           |  |

#### **EXTERNAL CLOCK DRIVE CHARACTERISTICS (XTAL2)**

|        |                   |                                       | Variable Clock $f = 3.5$ MHz to 12 MHz |      |  |
|--------|-------------------|---------------------------------------|----------------------------------------|------|--|
| Symbol | Parameter         | Min                                   | Max                                    | Unit |  |
| TCLCL  | Oscillator Period | 83.3                                  | 286                                    | ns   |  |
| TCHCX  | High Time         | 20                                    |                                        | ns   |  |
| TCLCX  | Low Time          | 20                                    | ,                                      | ns   |  |
| TCLCH  | Rise Time         | · · · · · · · · · · · · · · · · · · · | 20                                     | ns   |  |
| TCHCL  | Fall Time         |                                       | 20                                     | ns   |  |



# intel®

AC CHARACTERISTICS  $T_A = 0^{\circ}C$  to 70°C,  $V_{CC} = 5V \pm 10\%$ ,  $V_{SS} = 0V$ ,  $C_L$  for AD0-7, ALE and PSEN Outputs = 100 pF,  $C_L$  for all other outputs = 80 pF)

#### **PROGRAM MEMORY CHARACTERISTICS**

|        |                              | 12  |     |      |           | able Clock<br>3.5 MHz to 12 MHz |      |  |
|--------|------------------------------|-----|-----|------|-----------|---------------------------------|------|--|
| Symbol | Parameter                    | Min | Max | Unit | Min       | Max                             | Unit |  |
| TLHLL  | ALE Pulse Width              | 127 |     | ns   | 2TCLCL-40 |                                 | ns   |  |
| TAVLL  | Address Setup to ALE         | 43  |     | ns   | TCLCL-40  |                                 | ns   |  |
| TLLAX  | Address Hold After ALE       | 48  |     | ns   | TCLCL-35  |                                 | ns   |  |
| TLLIV  | ALE to Valid Instr In        |     | 233 | ns   |           | 4TCLCL-100                      | ns   |  |
| TLLPL  | ALE TO PSEN                  | 58  |     | 'ns  | TCLCL-25  |                                 | ns   |  |
| TPLPH  | PSEN Pulse Width             | 215 |     | ns   | 3TCLCL-35 |                                 | ns   |  |
| TPLIV  | PSEN To Valid Instr In       |     | 125 | ns   |           | 3TCLCL-125                      | ns   |  |
| ΤΡΧΙΧ  | Input Instr Hold After PSEN  | .0  |     | ns   | 0         |                                 | ns   |  |
| TPXIZ  | Input Instr Float After PSEN |     | 63  | ns   | `         | TCLCL-20                        | ns   |  |
| TPXAV  | Address Valid After PSEN     | 75  |     | ns   | TCLCL-8   |                                 | ns   |  |
| TAVIV  | Address To Valid Instr In    |     | 302 | ns   |           | 5TCLCL-115                      | ns   |  |
| TAZPL  | Address Float To PSEN        | 0   |     | ns   | 0         |                                 | ns   |  |

#### **EXTERNAL DATA MEMORY CHARACTERISTICS**

|        |                             | 12 MHz Clock |       |      | Variable Clock<br>1/TCLCL = 3.5 MHz to 12 MHz |                   |      |
|--------|-----------------------------|--------------|-------|------|-----------------------------------------------|-------------------|------|
| Symbol | Parameter                   | Min          | Max   | Unit | Min                                           | Max               | Unit |
| TRLRH  | RD Pulse Width              | 400          |       | ns.  | 6TCLCL-100                                    |                   | ns   |
| TWLWH  | WR Pulse Width              | 400          |       | ns   | 6TCLCL-100                                    |                   | ns   |
| TLLAX  | Address Hold After ALE      | 48           | ,     | ns   | TCLCL-35                                      |                   |      |
| TRLDV  | RD To Valid Data In         |              | 250   | ns   |                                               | 5TCLCL-165        | ns   |
| TRHDX  | Data Hold After RD          | 0            |       | ns   | 0                                             |                   | ns   |
| TRHDZ  | Data Float After RD         |              | 97    | ns   |                                               | 2TCLCL-70         | ns   |
| TLLDV  | ALE To Valid Data In        |              | 517   | ns   |                                               | 8TCLCL-150        | ns   |
| TAVDV  | Address To Valid Data In    |              | 585   | ns   |                                               | 9TCLCL-165        | ns   |
| TLLWL  | ALE To WR or RD             | 200          | . 300 | ns   | 3TCLCL-50                                     | 3TCLCL + 50       | ns   |
| TAVWL  | Address To SR or RD         | 203          |       | ns   | 4TCLCL-130                                    | 4 5. <sup>-</sup> | ns   |
| TWHLH  | WR or RD High To ALE High   | 43           | 123   | ns   | TCLCL-40                                      | TCLCL + 40        | ns   |
| TDVWX  | Data Valid To WR Transition | 23           |       | ns   | TCLCL-60                                      |                   | ns   |
| TQVWH  | Data Setup Before WR        | 433          |       | ns   | 7TCLCL-150                                    |                   | ns   |
| TWHQX  | Data Hold After WR          | 33           |       | ns   | TCLCL-50                                      |                   | ns   |
| TRLAZ  | Address Float After RD      |              | 0     | ns   |                                               | 0                 | ns   |

1. N. W. .

#### AC TIMING DIAGRAMS







AC inputs during testing are driven at 2.4V for a logic "1" and 0.45V for a logic "0". Timing measurements are made at 2.0V for a logic "1" and 0.8V for a logic "0". For timing purposes, the float state is defined as the point at which an AD0-7 pin sinks 2.4mA or sources 400µA at the voltage test levels.

intel®

8052AH-BASIC

#### CLOCK WAVEFORMS INTERNAL STATE A STATE 5 STATE 6 STATE 1 STATE 2 STATE 3 STATE 4 STATE 5 CLOCK P1 P1 | P2 P1 P2 **P**2 Dì **D**2 D1 P2 D1 P2 D1 P2 P1 **D**2 XTAL 2 ALE THESE SIGNALS ARE NOT ACTIVATED DURING THE EXECUTION OF A MOVX INSTRUCTION EXTERNAL PROGRAM MEMORY FETCH PSEN DATA PCL OUT DATA DATA PCL OUT PCL OUT AD0-7 SAMPLED SAMPLED SAMPLED FLOAT FLOAT FI OAT INDICATES ADDRESS TRANSIONS A8-15 READ CYCLE RD PCL OUT (IF PROGRAM **00H IS EMITTED** MEMORY IS EXTERNAL) DURING THIS PERIOD DPL OR RI DATA AD0-7 SAMPLED OUT FLOAT A8--15 WRITE CYCLE WR PCL OUT (EVEN IF PROGRAM MEMORY IS INTERNAL) DPL OR RI AD0-7 OUT DATA OUT PCL OUT (IF PROGRAM MEMORY IS EXTERNAL) A8-15 PORT OPERATION MOV PORT. SRC OLD DATA NEW DATA MOV DEST. P1 (INCLUDES INTO, INT1, TO, T1) P1. P1, PIN SAMPLED SERIAL PORT SHIFT CLOCK PIN SAMPLED TXD (MODE 0) RXD SAMPLED RXD SAMPLED

This diagram indicates when signals are clocked internally. The time it takes the signals to propagate to the pins, however, ranges from 25 to 125 ns. This propagation delay is dependent on variables such as temperature and pin loading. Propagation also varies from output to output and component to component. Typically though, ( $T_A = 25^{\circ}$ C, fully loaded) RD and WR propagation delays are approximately 50 ns. The other signals are typically 85 ns. Propagation delays are incorporated in the AC specifications.

9-23

# 80C51BH/80C51BH-2 CHMOS SINGLE COMPONENT 8-BIT MICROCONTROLLER with Factory Mask-Programmable ROM

# 80C31BH/80C31BH-2 CHMOS SINGLE COMPONENT 8-BIT CONTROL-ORIENTED CPU WITH RAM AND I/O

80C51BH/80C31BH — 3.5 to 12 MHz V<sub>CC</sub> = 5V  $\pm$  20% 80C51BH-2/80C31BH-2 — 0.5 to 12 MHz V<sub>CC</sub> = 5V  $\pm$  20%

- 128 X 8 RAM
- 32 Programmable I/O Lines
- Two 16-Bit Timer/Counters
- 64K Program Memory Space

- Boolean Processor
- 5 Interrupt Sources
- Programmable Serial Port
- 64K Data Memory Space

The MCS®-51 CHMOS products are fabricated on Intel's advanced CHMOS III process and are functionally compatible with the standard MCS-51 HMOS and EPROM products. CHMOS III is a technology which combines the high speed and density characteristics of HMOS with the low power attributes of CMOS. This combination expands the effectiveness of the powerful MCS-51 architecture and instruction set.

Like the MCS-51 EPROM and HMOS, the MCS-51 CHMOS products have the following features: 4K of ROM (80C51BH/80C51BH-2 only); 128 bytes of RAM; 32 I/O lines; two 16-bit timer/counters; a five-source two-level interrupt structure; a full duplex serial port; and on-chip oscillator and clock circuitry. In addition, the MCS-51 CHMOS products have two software selectable modes of reduced activity for further power reduction — Idle and Power Down.

Idle mode freezes the CPU while allowing the RAM, timer/counters, serial port and interrupt system to continue functioning. Power Down mode saves the RAM contents but freezes the oscillator causing all other chip functions to be inoperative.





Figure 2. Configurations

# IDLE AND POWER DOWN OPERATION

Figure 3 shows the internal Idle and Power Down clock configuration. As illustrated, Power Down operation freezes the oscillator. Idle mode operation allows the interrupt, serial port, and timer blocks to continue to function while the clock to the CPU is halted.



Figure 3. Idle and Power Down Hardware

These special modes are activated by software via the Special Function Register, PCON. Its hardware address is 87H. PCON is not bit addressable.

PCON: Power Control Register

| (MSB) |   |   |         |     |    | (LSB) |
|-------|---|---|---------|-----|----|-------|
| SMOD  | _ | — | <br>GF1 | GF0 | PD | IDL   |

Symbol Position Name and Function

| SMOD          | PCON.7 | Double Baud rate bit. When set to a 1, the baud rate is doubled when the serial port is being used in either modes 1, 2 or 3. |
|---------------|--------|-------------------------------------------------------------------------------------------------------------------------------|
| , <del></del> | PCON.6 | (Reserved)                                                                                                                    |
|               | PCON.5 | (Reserved)                                                                                                                    |
|               | PCON.4 | (Reserved)                                                                                                                    |
| GF1           | PCON.3 | General-purpose flag bit.                                                                                                     |
| GF0           | PCON.2 | General-purpose flag bit.                                                                                                     |
| PD            | PCON.1 | Power Down bit. Setting this bit activates power down operation.                                                              |
| IDL           | PCON.0 | Idle mode bit. Setting this bit activates idle mode operation.                                                                |
|               |        |                                                                                                                               |

If 1's are written to PD and IDL at the same time, PD takes precedence. The reset value of PCON is (0XXX0000).

#### **Idle Mode**

The instruction that sets PCON.0 is the last instruction executed in the normal operating mode before Idle mode is activated. Once in the Idle mode, the CPU status is preserved in its entirety: the Stack Pointer, Program Counter, Program Status Werd, Accumulator, RAM, and all other registers maintain their data during Idle. Table 1 describes the status of the external pins during Idle mode.

There are two ways to terminate the Idle mode. Activation of any enabled interrupt will cause PCON.0 to be cleared by hardware, terminating Idle mode. The interrupt is serviced, and following RETI, the next instruction to be executed will be the one following the instruction that wrote a 1 to PCON.0.

The flag bits GF0 and GF1 may be used to determine whether the interrupt was received during normal execution or during the Idle mode. For example, the instruction that writes to PCON.0 can also set or clear one or both flag bits. When Idle mode is terminated by an enabled interrupt, the service routine can examine the status of the flag bits.

The second way of terminating the Idle mode is with a hardware reset. Since the oscillator is still running, the hardware reset needs to be active for only 2 machine cycles (24 oscillator periods) to complete the reset operation.

#### **Power Down Mode**

The instruction that sets PCON.1 is the last executed prior to going into power down. Once in power down, the oscillator is stopped. Only the contents of the onchip RAM is preserved. The Special Function Registers are not saved. A hardware reset is the only way of exiting the power down mode.

In the Power Down mode, V<sub>CC</sub> may be lowered to minimize circuit power consumption. Care must be taken to ensure the voltage is not reduced until the

power down mode is entered, and that the voltage is restored before the hardware reset is applied which frees the oscillator. Reset should not be released until the oscillator has restarted and stabilized.

Table 1 describes the status of the external pins while in the power down mode. It should be noted that if the power down mode is activated while in external program memory, the port data that is held in the Special Function Register P2 is restored to Port 2. If the data is a 1, the port pin is held high during the power down mode by the strong pullup, p1, shown in figure 4.

# 80C51BH I/O Ports

The I/O port drive of the 80C51BH is similar to the 8051. The I/O buffers for Ports 1, 2, and 3 are implemented as shown in figure 4.

When the port latch contains a 0, all pFETS in figure 4 are off while the nFET is turned on. When the port latch makes a 0-to-1 transition, the nFET turns off. The strong pullup pFET, p1, turns on for two oscillator periods, pulling the output high very rapidly. As the output line is drawn high, pFET p3 turns on through the inverter to supply the  $I_{OH}$  source current. This inverter and p3 form a latch which holds the 1 and is supported by p2.

When Port 2 is used as an address port, for access to external program of data memory, any address bit that contains a 1 will have its strong pullup turned on for the entire duration of the external memory access.

When an I/O pin on Ports 1, 2, or 3 is used as an input, the user should be aware that the external circuit must sink current during the logical 1-to-0 transition. The maximum sink current is specified as ITL under the D.C. Specifications. When the input goes below approximately 2V, p3 turns off to save ICC current. Note, when returning to a logical 1, p2 is the only internal pullup that is on. This will result in a slow rise time if the user's circuit does not force the input

| Mode          | Program Memory | ALE | PSEN | PORT0     | PORT1     | PORT2     | PORT3     |
|---------------|----------------|-----|------|-----------|-----------|-----------|-----------|
| ldle          | Internal       | · 1 | 1    | Port Data | Port Data | Port Data | Port Data |
| Idle          | External       | 1   | 1    | Floating  | Port Data | Address   | Port Data |
| Power<br>Down | Internal       | 0   | · 0  | Port Data | Port Data | Port Data | Port Data |
| Power<br>Down | External       | 0   | 0    | Floating  | Port Data | Port Data | Port Data |

Table 1. Status of the external pins during Idle and Power Down modes



Figure 4. I/O Buffers in the 80C51BH (Ports 1, 2, 3)

line high. For additional information, refer to the chapter entitled "Design Considerations When Using CHMOS" in the 1984 Intel Microcontroller Handbook.

# **PIN DESCRIPTIONS**

#### Vcc

Supply voltage during normal, Idle, and Power Down operations.

#### VSS

Circuit ground.

#### Port 0

Port 0 is an 8-bit open drain bi-directional I/O port. Port 0 pins that have 1's written to them float, and in that state can be used as high-impedance inputs.

Port 0 is also the multiplexed low-order address and data bus during accesses to external Program and Data Memory. In this application it uses strong internal pullups when emitting 1's. Port 0 also outputs the code bytes during program verification in the 80C51BH. External pullups are required during program verification.

#### Port 1

Port 1 is an 8-bit bi-directional I/O port with internal pullups. Port 1 pins that have 1's written to them are

pulled high by the internal pullups, and in that state can be used as inputs. As inputs, Port 1 pins that are externally being pulled low will source current (IIL, on the data sheet) because of the internal pullups.

Port 1 also receives the low-order address bytes during program verification.

#### Port 2

Port 2 is an 8-bit bi-directional I/O port with internal pullups. Port 2 pins that have 1's written to them are pulled high by the internal pullups, and in that state can be used as inputs. As inputs, Port 2 pins that are externally being pulled low will source current (IIL, on the data sheet) because of the internal pullups.

Port 2 emits the high-order address byte during fetches from external Program Memory and during accesses to external Data Memory that use 16-bit addresses (MOVX @DPTR). In this application it uses strong internal pullups when emitting 1's. During accesses to external Data Memory that use 8-bit addresses (MOVX @Ri), Port 2 emits the contents of the P2 Special Function Register.

#### Port 3

Port 3 is an 8-bit bi-directional I/O port with internal pullups. Port 3 pins that have 1's written to them are pulled high by the internal pullups, and in that state can be used as inputs. As inputs, Port 3 pins that are externally being pulled low will source current (IIL, on the data sheet) because of the pullups.

Port 3 also serves the functions of various special features of the MCS-51 Family, as listed below:

| Port Pin | Alternate Function                     |
|----------|----------------------------------------|
| P3.0     | RXD (serial input port)                |
| P3.1     | TXD (serial output port)               |
| P3.2     | INTO (external interrupt 0)            |
| P3.3     | INT1 (external interrupt 1)            |
| P3.4     | T0 (Timer 0 external input)            |
| P3.5     | T1 (Timer 1 external input)            |
| P3.6     | WR (external data memory write strobe) |
| P3.7     | RD (external data memory read strobe)  |
|          |                                        |

# RST

Reset input. A high on this pin for two machine cycles while the oscillator is running resets the device. An internal diffused resistor to  $V_{SS}$  permits Power-On reset using only an external capacitor to  $V_{CC}$ .

# ALE

Address Latch Enable output pulse for latching the low byte of the address during accesses to external memory.

In normal operation ALE is emitted at a constant rate of 1/6 the oscillator frequency, and may be used for external timing or clocking purposes. Note, however, that one ALE pulse is skipped during each access to external Data Memory.



Figure 5. Crystal Oscillator

#### PSEN

Program Store Enable is the read strobe to external Program Memory.

When the 80C51BH is executing code from external Program Memory, PSEN is activated twice each machine cycle, except that two PSEN activations are skipped during each access to external Data Memory.

# EA

External Access enable. EA must be externally held low in order to enable the device to fetch code from external Program Memory locations 0000H to 0FFFH.

# XTAL1

Input to the inverting oscillator amplifier and input to the internal clock generator circuits.

# XTAL2

Output from the inverting oscillator amplifier.

# **OSCILLATOR CHARACTERISTICS**

XTAL1 and XTAL2 are the input and output respectively, of an inverting amplifier which is configured for use as an on-chip oscillator, as shown in Figure 5. Either a quartz crystal or ceramic resonator may be used. More detailed information concerning the use of the on-chip oscillator is available in Application Note AP-155, "Oscillators for Microcontrollers."

To drive the device from an external clock source, XTAL1 should be driven while XTAL2 is left unconnected as shown in figure 6. There are no requirements on the duty cycle of the external clock signal, since the input to the internal clocking circuitry is through a divide-by-two flip-flop, but minimum and maximum high and low times specified on the Data Sheet must be observed.



Figure 6. External Drive Configuration

# **ABSOLUTE MAXIMUM RATINGS\***

| Ambient Temperature Under Bias 0°C to 70°C                                      |
|---------------------------------------------------------------------------------|
| Storage Temperature65°C to +150°C                                               |
| Voltage on Any Pin to $V_{SS} \dots -0.5V$ to $V_{CC} + 1V$                     |
| Voltage on V <sub>CC</sub> to V <sub>SS</sub> $\dots \dots \dots -0.5$ V to +7V |
| Power Dissipation 1.0W                                                          |

\*NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

| Symbol           | Parameter                                            | Min                    | Max                  | Unit | Test Conditions                              |
|------------------|------------------------------------------------------|------------------------|----------------------|------|----------------------------------------------|
| VIL              | Input Low Voltage                                    | - 0.5                  | 0.2V <sub>CC</sub> 1 | V    |                                              |
| VIH              | Input High Voltage<br>(Except XTAL1, RST)            | 0.2V <sub>CC</sub> +.9 | V <sub>CC</sub> +0.5 | V    |                                              |
| VIH1             | Input High Voltage to<br>XTAL1, RST                  | 0.7V <sub>CC</sub>     | V <sub>CC</sub> +0.5 | V    | -                                            |
| VOL              | Output Low Voltage<br>(Ports 1, 2, 3)                |                        | 0.45                 | V    | IOL = 1.6 mA                                 |
| VOL1             | Output Low Voltage<br>(Port 0, ALE, PSEN)            |                        | 0.45                 | V    | $I_{OL} = 3.2 \text{ mA} (\text{Note 1})$    |
| VOH              | Output High Voltage<br>(Ports 1, 2, 3)               | 2.4                    |                      | v    | $I_{OH} = -80 \mu A V_{CC} = 5V \pm 10\%$    |
|                  |                                                      | 0.75V <sub>CC</sub>    |                      | V    | I <sub>OH</sub> = -30μA                      |
|                  |                                                      | 0.9V <sub>CC</sub>     |                      | V    | I <sub>OH</sub> = -10μA                      |
| VOH1             | Output High Voltage                                  | 2.4                    |                      | V    | $I_{OH} = -400 \mu A V_{CC} = 5V \pm 10\%$   |
|                  | (Port 0 in External Bus<br>Mode, ALE, PSEN)          | 0.75V <sub>CC</sub>    |                      | V    | $I_{OH} = -150 \mu A$                        |
|                  | WOUL, ALL, I OLN)                                    | 0.9V <sub>CC</sub>     |                      | V    | $I_{OH} = -40 \mu A$ (Note 2)                |
| ΙL               | Logical 0 Input Current<br>(Ports 1, 2, 3)           |                        | - 50                 | μÂ   | V <sub>in</sub> = 0.45V                      |
| ŀτL              | Logical 1 to 0 transition<br>Current (Ports 1, 2, 3) |                        | - 500                | μA   | V <sub>in</sub> = 2.0V                       |
| ILI              | Input Leakage Current<br>(Port 0, EA)                |                        | ±10                  | μA   | 0.45 < Vin < V <sub>CC</sub>                 |
| R <sub>RST</sub> | RST Pulldown Resistor                                | 40                     | 125                  | Kohm |                                              |
| CIO              | Pin Capacitance                                      |                        | 10                   | pF   | test freq = 1 MHz, T <sub>A</sub> =25°C      |
| IPD              | Power Down Current                                   |                        | 50                   | μA   | $V_{CC} = 2 \text{ to } 6V \text{ (Note 3)}$ |

# Maximum Operating I<sub>CC</sub> (mA) (note 4)

#### 4V 5V 6V Vcc Freq. 3 0.5 MHz 1.6 2.2 3.5 MHz 4.3 5.7 7.5 8 MHz 8.3 11 14 12 MHz 16 20 12

## Maximum Idle I<sub>CC</sub> (mA) (note 5)

| VCC     | 4V  | 5V  | 6V  |
|---------|-----|-----|-----|
| Freq.   |     |     |     |
| 0.5 MHz | 0.6 | 0.9 | 1.2 |
| 3.5 MHz | 1.1 | 1.6 | 2.2 |
| 8 MHz   | 1.8 | 2.7 | 3.7 |
| 12 MHz  | 2.5 | 3.7 | 5   |

- Note 1: Capacitive loading on Ports 0 and 2 may cause spurious noise pulses to be superimposed on the V<sub>OL</sub>s of ALE, and Ports 1 and 3. The noise is due to the external bus capacitance discharging into the Port 0 and Port 2 pins when these pins make a 1-to-0 transition during bus operations. In the worst case (capacitive loading > 100 pF), the noise pulse on ALE line may exceed 0.8V. In such cases it may be desirable to qualify ALE with a Schmitt Trigger, or use an address latch with a Schmitt Trigger STROBE input.
- Note 2: Capacitive loading on Ports 0 and 2 may cause the V<sub>OH</sub> on ALE and PSEN to momentarily fall below the .9V<sub>CC</sub> specification when the address bits are stabilizing.
- Note 3: Power Down I<sub>CC</sub> is measured with all output pins disconnected; EA = PORT0 = V<sub>CC</sub>; XTAL2 N.C.; RST = V<sub>SS</sub>.
- Note 4: I<sub>CC</sub> is measured with all output pins disconnected; XTAL1 driven with TCLCH, TCHCL = 10 ns, V<sub>II</sub>=V<sub>SS</sub>+.5v, V<sub>Ih</sub>=V<sub>CC</sub>-.5v; XTAL2 N.C.; EA=RST=PORT0=V<sub>CC</sub>.
- Note 5: Idle I<sub>CC</sub> is measured with all output pins disconnected; XTAL1 driven with TCLCH, TCHCL = 10 ns, V<sub>iI</sub> = V<sub>SS</sub> + .5v, V<sub>ih</sub> = V<sub>CC</sub> .5v; XTAL2 N.C.; EA = PORT0 = V<sub>CC</sub>; RST = V<sub>SS</sub>.

# A.C. CHARACTERISTICS ( $T_A = 0^{\circ}C$ to 70°C; $V_{SS} = 0V$ ; $V_{CC} = 5V \pm 20\%$ ; Load Capacitance for Port 0, ALE, and PSEN = 100 pF, Load Capacitance for All Other Outputs = 80 pF)

## **EXTERNAL PROGRAM AND DATA MEMORY CHARACTERISTICS**

| Symbol  | Parameter                    | Min        | Max          | Units |
|---------|------------------------------|------------|--------------|-------|
| 1/TCLCL | Oscillator Freq (80C51BH)    | 3.5        | 12           | MHz   |
|         | Oscillator Freq (80C51BH-2)  | 0.5        | 12           | MHz   |
| TLHLL   | ALE Pulse Width              | 2TCLCL-40  |              | ns    |
| TAVLL   | Address Valid to ALE Low     | TCLCL-40   |              | ns    |
| TLLAX   | Address Hold After ALE Low   | TCLCL-35   |              | ns    |
| TLLIV   | ALE Low to Valid Instr In    |            | 4TCLCL-150   | ns    |
| TLLPL   | ALE Low to PSEN Low          | TCLCL-25   |              | ns    |
| TPLPH   | PSEN Pulse Width             | 3TCLCL-35  |              | ns    |
| TPLIV   | PSEN Low to Valid Instr In   |            | 3TCLCL-150   | ns    |
| TPXIX   | Input Instr Hold After PSEN  | 0          |              | ns    |
| TPXIZ   | Input Instr Float After PSEN |            | TCLCL-20     | ns    |
| TPXAV   | PSEN to Address Valid        | TCLCL-8    |              | ns    |
| TAVIV   | Address to Valid Instr In    |            | 5TCLCL-150   | ns    |
| TPLAZ   | PSEN Low to Address Float    |            | 0            | ns    |
| TRLRH   | RD Pulse Width               | 6TCLCL-100 |              | ns    |
| TWLWH   | WR Pulse Width               | 6TCLCL-100 |              | ns    |
| TRLDV   | RD Low to Valid Data In      |            | 5TCLCL - 165 | ns    |
| TRHDX   | Data Hold After RD           | 0 .        |              | ns    |
| TRHDZ   | Data Float After RD          | 1          | 2TCLCL-70    | 'ns   |
| TLLDV   | ALE Low to Valid Data In     |            | 8TCLCL-150   | ns    |

# EXTERNAL PROGRAM MEMORY READ CYCLE



## **EXTERNAL DATA MEMORY READ CYCLE**



# A.C. CHARACTERISTICS

#### EXTERNAL PROGRAM AND DATA MEMORY CHARACTERISTICS (Continued)

| Symbol | Parameter                   | Min          | Max          | Units |
|--------|-----------------------------|--------------|--------------|-------|
| TAVDV  | Address to Valid Data In    |              | 9TCLCL - 165 | ns    |
| TLLWL  | ALE Low to RD or WR Low     | 3TCLCL-50    | 3TCLCL+50    | ns    |
| TAVWL  | Address to RD or WR Low     | 4TCLCL - 130 |              | ns    |
| TQVWX  | Data Valid to WR Transition | TCLCL-60     |              | ns    |
| TQVWH  | Data Valid to WR High       | 7TCLCL 150   |              | ns    |
| TWHQX  | Data Held After WR          | TCLCL-50     |              | ns    |
| TRLAZ  | RD Low to Address Float     |              | 0            | ns    |
| TWHLH  | RD or WR High to ALE High   | TCLCL-40     | TCLCL + 50   | ns    |

# **EXTERNAL CLOCK DRIVE**

| Symbol  | Parameter                   | Min | Max | Units |
|---------|-----------------------------|-----|-----|-------|
| 1/TCLCL | Oscillator Freq (80C51BH)   | 3.5 | 12  | MHz   |
|         | Oscillator Freq (80C51BH-2) | 0.5 | 12  | MHz   |
| TCHCX   | High Time                   | 20  |     | ns    |
| TCLCX   | Low Time                    | 20  |     | ns    |
| TCLCH   | Rise Time                   |     | 20  | ns    |
| TCHCL   | Fall Time                   |     | 20  | ns    |

## EXTERNAL CLOCK DRIVE



# EXTERNAL DATA MEMORY WRITE CYCLE



# SERIAL PORT TIMING - SHIFT REGISTER MODE

A.C. CHARACTERISTICS: (T<sub>A</sub> = 0°C to 70°C; V<sub>SS</sub> = 0V; V<sub>CC</sub> = 5V  $\pm$  20%; Load Capacitance = 80 pF)

| Symbol | Parameter                                | Min           | Max         | Units |
|--------|------------------------------------------|---------------|-------------|-------|
| TXLXL  | Serial Port Clock Cycle Time             | 12TCLCL       |             | μs    |
| TQVXH  | Output Data Setup to Clock Rising Edge   | 10TCLCL - 133 |             | ns    |
| TXHQX  | Output Data Hold After Clock Rising Edge | 2TCLCL-117    |             | ns    |
| TXHDX  | Input Data Hold After Clock Rising Edge  | 0             |             | ns    |
| TXHDV  | Clock Rising Edge to Input Data Valid    |               | 10TCLCL-133 | ns    |

# SHIFT REGISTER TIMING WAVEFORMS



| ARITH                                  | METIC OPERA                                                      | TIONS                                                                                                                                                                                                                                            |                       |                       | LOGIC                    | CAL OPERATIO                                           | NS (CONTINUED)                                                                                                                                                                                   |                       |                       |
|----------------------------------------|------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------|--------------------------|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------|
| Mnemo                                  | nic                                                              | Description                                                                                                                                                                                                                                      | Byte                  | Cyc                   | Mnem                     | onic                                                   | Destination                                                                                                                                                                                      | Byte                  | Cyc                   |
| ADD                                    | A,Rn                                                             | Add register to                                                                                                                                                                                                                                  | •                     | •                     | ORL                      | A,@Rı                                                  | OR indirect RAM to                                                                                                                                                                               |                       |                       |
|                                        |                                                                  | Accumulator                                                                                                                                                                                                                                      | 1                     | 1                     |                          | -                                                      | Accumulator                                                                                                                                                                                      | 1                     | 1                     |
| ADD                                    | A, direct                                                        | Add direct byte to                                                                                                                                                                                                                               |                       |                       | ORL                      | A,#data                                                | OR immediate data to                                                                                                                                                                             |                       |                       |
|                                        |                                                                  | Accumulator                                                                                                                                                                                                                                      | 2                     | 1                     |                          |                                                        | Accumulator                                                                                                                                                                                      | 2                     | 1                     |
| ADD                                    | A,@Ri                                                            | Add indirect RAM to                                                                                                                                                                                                                              |                       |                       | ORL                      | direct.A                                               | OR Accumulator to                                                                                                                                                                                |                       |                       |
|                                        | - ie ii                                                          | Accumulator                                                                                                                                                                                                                                      | 1                     | ì                     |                          |                                                        | direct byte                                                                                                                                                                                      | 2                     | 1                     |
| ADD                                    | A,#data                                                          | Add immediate data to                                                                                                                                                                                                                            |                       |                       | ORL                      | direct.#data                                           | OR immediate data to                                                                                                                                                                             |                       |                       |
|                                        |                                                                  | Accumulator                                                                                                                                                                                                                                      | 2                     | 1                     |                          | ,                                                      | direct byte                                                                                                                                                                                      | 3                     | 2                     |
| ADDC                                   | A.Rn                                                             | Add register to                                                                                                                                                                                                                                  |                       |                       | XRL                      | A,Rn                                                   | Exclusive-OR register to                                                                                                                                                                         |                       |                       |
|                                        | ,                                                                | Accumulator with Carry                                                                                                                                                                                                                           | 1                     | 1                     |                          |                                                        | Accumulator                                                                                                                                                                                      | 1                     | 1                     |
| ADDC                                   | A, direct                                                        | Add direct byte to A                                                                                                                                                                                                                             |                       |                       | XRL                      | A, direct                                              | Exclusive-OR direct                                                                                                                                                                              |                       |                       |
|                                        |                                                                  | with Carry flag                                                                                                                                                                                                                                  | 2                     | 1                     |                          |                                                        | byte to Accumulator                                                                                                                                                                              | 2                     | 1                     |
| ADDC                                   | A.@Ri                                                            | Add indirect RAM to A                                                                                                                                                                                                                            |                       |                       | XRL                      | A,@Ri                                                  | Exclusive-OR indirect                                                                                                                                                                            |                       |                       |
|                                        | , i.e.i.                                                         | with Carry flag                                                                                                                                                                                                                                  | 1                     | 1                     |                          | , en                                                   | RAM to A                                                                                                                                                                                         | 1                     | 1                     |
| ADDC                                   | A,#data                                                          | Add immediate data to                                                                                                                                                                                                                            | •                     |                       | XRL                      | A.#data                                                | Exclusive-OR                                                                                                                                                                                     |                       |                       |
|                                        | , in cara                                                        | A with Carry flag                                                                                                                                                                                                                                | 2                     | 1                     |                          |                                                        | immediate data to A                                                                                                                                                                              | 2                     | 1                     |
| SUBB                                   | A,Rn                                                             | Subtract register from A                                                                                                                                                                                                                         |                       | ΄,                    | XRL                      | direct,A                                               | Exclusive-OR Accumu-                                                                                                                                                                             | -                     |                       |
| 0000                                   | /                                                                | with Borrow                                                                                                                                                                                                                                      | 1                     | 1                     |                          | a                                                      | lator to direct byte                                                                                                                                                                             | 2                     | 1                     |
| SUBB                                   | A, direct                                                        | Subtract direct byte                                                                                                                                                                                                                             |                       | '                     | XRL                      | direct,#data                                           | Exclusive-OR im-                                                                                                                                                                                 | -                     |                       |
| 0000                                   | A, direct                                                        | from A with Borrow                                                                                                                                                                                                                               | 2                     | . 1                   | A. 12                    | un cot, "dutu                                          | mediate data to direct                                                                                                                                                                           | 3                     | 2                     |
| SUBB                                   | A,@Ri                                                            | Subtract indirect RAM                                                                                                                                                                                                                            | 2                     |                       | CLR                      | А                                                      | Clear Accumulator                                                                                                                                                                                | 1                     | 1                     |
| 3066                                   | A,@hi                                                            | from A with Borrow                                                                                                                                                                                                                               | 1                     | 1                     | CPL                      | Â                                                      | Complement                                                                                                                                                                                       |                       |                       |
| SUBB                                   | A,#data                                                          | Subtract immed data                                                                                                                                                                                                                              | ,                     | '                     | OFL                      | ^                                                      | Accumulator                                                                                                                                                                                      | 1                     | 1                     |
| 3066                                   | A,#Uala                                                          | from A with Borrow                                                                                                                                                                                                                               | 2                     | 1                     | RL                       | А                                                      | Rotate Accumulator Left                                                                                                                                                                          | -                     | 1                     |
| INC                                    | А                                                                |                                                                                                                                                                                                                                                  |                       | 1                     | RLC                      | Â                                                      | Rotate A Left through                                                                                                                                                                            |                       |                       |
| INC                                    | Rn                                                               | Increment Accumulator                                                                                                                                                                                                                            | 1                     | 1                     | InLC                     | A                                                      | the Carry flag                                                                                                                                                                                   | 1                     | 1                     |
|                                        |                                                                  | Increment register                                                                                                                                                                                                                               |                       | 1                     | RR                       | А                                                      | Rotate Accumulator                                                                                                                                                                               |                       |                       |
| INC                                    | direct                                                           | Increment direct byte                                                                                                                                                                                                                            | 2<br>1                |                       | nn                       | A                                                      |                                                                                                                                                                                                  | 1                     | 1                     |
| INC                                    | @Ri                                                              | Increment indirect RAM                                                                                                                                                                                                                           |                       | 1                     |                          | А                                                      | Right                                                                                                                                                                                            |                       | 1                     |
| INC                                    | DPTR                                                             | Increment Data Pointer                                                                                                                                                                                                                           | 1                     | 2                     | RRC                      | A                                                      | Rotate A Right through                                                                                                                                                                           | 4                     | 1                     |
| DEC                                    | A                                                                | Decrement Accumulator                                                                                                                                                                                                                            |                       | 1                     | 014/4 0                  | •                                                      | Carry flag                                                                                                                                                                                       | 1                     | 1                     |
| DEC                                    | íRn -                                                            | Decrement register                                                                                                                                                                                                                               | 1                     | 1                     | SWAP                     | A                                                      | Swap nibbles within the                                                                                                                                                                          |                       |                       |
| DEC                                    | direct                                                           | Decrement direct byte                                                                                                                                                                                                                            | 2                     | 1                     |                          |                                                        | Accumulator                                                                                                                                                                                      | <u>_</u> 1            | 1                     |
| DEC                                    | @Rı                                                              | Decrement indirect                                                                                                                                                                                                                               |                       |                       |                          |                                                        |                                                                                                                                                                                                  |                       |                       |
|                                        |                                                                  | RAM                                                                                                                                                                                                                                              | 1                     | 1                     | DATA                     | TRANSFER                                               |                                                                                                                                                                                                  |                       |                       |
| MUL                                    | AB                                                               | Multiply A & B                                                                                                                                                                                                                                   | 1                     | 4                     | Mnem                     | onic                                                   | Description                                                                                                                                                                                      | Byte                  | Cyc                   |
| DIV                                    | AB                                                               | Divide A by B                                                                                                                                                                                                                                    | 1                     | 4                     | моу                      | A,Rn                                                   | Move register to                                                                                                                                                                                 | -                     | -                     |
| DA                                     | A                                                                | Decimal Adjust                                                                                                                                                                                                                                   |                       |                       |                          |                                                        | Accumulator                                                                                                                                                                                      | 1                     | 1                     |
|                                        |                                                                  | Accumulator                                                                                                                                                                                                                                      | 1                     | 1                     | моч                      | A,direct                                               | Move direct byte to                                                                                                                                                                              |                       |                       |
|                                        |                                                                  | NG                                                                                                                                                                                                                                               |                       |                       |                          | ,                                                      | Accumulator                                                                                                                                                                                      | 2                     | 1                     |
| LOGIC                                  | AL OPERATIO                                                      | NS                                                                                                                                                                                                                                               |                       |                       | Моу                      | A,@Ri                                                  | Move indirect RAM to                                                                                                                                                                             |                       |                       |
|                                        | nia                                                              | Destination                                                                                                                                                                                                                                      | Byte                  | Cyc                   |                          | - i e -                                                | Accumulator                                                                                                                                                                                      | 1                     | 1                     |
| Mnemo                                  | AUC                                                              |                                                                                                                                                                                                                                                  |                       |                       | моу                      |                                                        |                                                                                                                                                                                                  |                       |                       |
| Mnemo<br>ANL                           | A,Rn                                                             | AND register to                                                                                                                                                                                                                                  | -                     |                       |                          | A #data                                                | Moy immediate data to                                                                                                                                                                            |                       |                       |
|                                        |                                                                  |                                                                                                                                                                                                                                                  | 1                     | 1                     | MOV                      | A,#data                                                | Mov immediate data to<br>Accumulator                                                                                                                                                             | 2                     | 1                     |
|                                        | A,Rn                                                             | AND register to<br>Accumulator                                                                                                                                                                                                                   | 1                     | 1                     |                          | i.                                                     | Accumulator                                                                                                                                                                                      | 2                     | 1                     |
| ANL                                    |                                                                  | AND register to                                                                                                                                                                                                                                  | 1                     | 1                     | MOV                      | A,#data<br>,<br>Rn,A                                   | Accumulator<br>Move Accumulator to                                                                                                                                                               | _                     |                       |
| ANL                                    | A,Rn<br>A,dırect                                                 | AND register to<br>Accumulator<br>AND direct byte to                                                                                                                                                                                             |                       |                       | моу                      | Rn,A                                                   | Accumulator<br>Move Accumulator to<br>register                                                                                                                                                   | 2<br>1                | 1<br>1                |
| ANL<br>ANL                             | A,Rn                                                             | AND register to<br>Accumulator<br>AND direct byte to<br>Accumulator<br>AND indirect RAM to                                                                                                                                                       |                       |                       |                          | i.                                                     | Accumulator<br>Move Accumulator to<br>register<br>Move dırect byte to                                                                                                                            | 1                     | 1                     |
| ANL<br>ANL<br>ANL                      | A,Rn<br>A,dırect<br>A,@Rı                                        | AND register to<br>Accumulator<br>AND direct byte to<br>Accumulator<br>AND indirect RAM to<br>Accumulator                                                                                                                                        | 2                     | 1                     | моv<br>моv               | Rn,A<br>Rn,direct                                      | Accumulator<br>Move Accumulator to<br>register<br>Move direct byte to<br>register                                                                                                                | _                     |                       |
| ANL<br>ANL                             | A,Rn<br>A,dırect                                                 | AND register to<br>Accumulator<br>AND direct byte to<br>Accumulator<br>AND indirect RAM to<br>Accumulator<br>AND immediate data to                                                                                                               | 2<br>1                | 1                     | моу                      | Rn,A                                                   | Accumulator<br>Move Accumulator to<br>register<br>Move direct byte to<br>register<br>Move immediate data to                                                                                      | 1<br>2                | 1<br>2                |
| ANL<br>ANL<br>ANL<br>ANL               | A,Rn<br>A,dırect<br>A,@Rı<br>A,#data                             | AND register to<br>Accumulator<br>AND direct byte to<br>Accumulator<br>AND indirect RAM to<br>Accumulator<br>AND immediate data to<br>Accumulator                                                                                                | 2                     | 1                     | моу<br>моу<br>моу        | Rn,A<br>Rn,direct<br>Rn,#data                          | Accumulator<br>Move Accumulator to<br>register<br>Move direct byte to<br>register<br>Move immediate data to<br>register                                                                          | 1                     | 1                     |
| ANL<br>ANL<br>ANL                      | A,Rn<br>A,dırect<br>A,@Rı                                        | AND register to<br>Accumulator<br>AND direct byte to<br>Accumulator<br>AND indirect RAM to<br>Accumulator<br>AND immediate data to<br>Accumulator<br>AND Accumulator to                                                                          | 2<br>1<br>2           | 1<br>1<br>1           | моv<br>моv               | Rn,A<br>Rn,direct                                      | Accumulator<br>Move Accumulator to<br>register<br>Move direct byte to<br>register<br>Move immediate data to<br>register<br>Move Accumulator to                                                   | 1<br>2<br>2           | 1<br>2<br>1           |
| ANL<br>ANL<br>ANL<br>ANL<br>ANL        | A,Rn<br>A,dırect<br>A,@Rı<br>A,#data<br>direct,A                 | AND register to<br>Accumulator<br>AND direct byte to<br>Accumulator<br>AND indirect RAM to<br>Accumulator<br>AND immediate data to<br>Accumulator<br>AND Accumulator to<br>direct byte                                                           | 2<br>1                | 1                     | MOV<br>MOV<br>MOV<br>MOV | Rn,A<br>Rn,direct<br>Rn,#data<br>direct,A              | Accumulator<br>Move Accumulator to<br>register<br>Move direct byte to<br>register<br>Move immediate data to<br>register<br>Move Accumulator to<br>direct byte                                    | 1<br>2                | 1<br>2                |
| ANL<br>ANL<br>ANL<br>ANL               | A,Rn<br>A,dırect<br>A,@Rı<br>A,#data                             | AND register to<br>Accumulator<br>AND direct byte to<br>Accumulator<br>AND indirect RAM to<br>Accumulator<br>AND immediate data to<br>Accumulator<br>AND Accumulator to<br>direct byte<br>AND immediate data to                                  | 2<br>1<br>2<br>2      | 1<br>1<br>1<br>1      | моу<br>моу<br>моу        | Rn,A<br>Rn,direct<br>Rn,#data                          | Accumulator<br>Move Accumulator to<br>register<br>Move direct byte to<br>register<br>Move immediate data to<br>register<br>Move Accumulator to<br>direct byte<br>Move register to direct         | 1<br>2<br>2<br>2      | 1<br>2<br>1<br>1      |
| ANL<br>ANL<br>ANL<br>ANL<br>ANL<br>ANL | A,Rn<br>A,dırect<br>A,@Rı<br>A,#data<br>direct,A<br>direct,#data | AND register to<br>Accumulator<br>AND direct byte to<br>Accumulator<br>AND indirect RAM to<br>Accumulator<br>AND immediate data to<br>Accumulator<br>AND Accumulator to<br>direct byte<br>AND immediate data to<br>direct byte                   | 2<br>1<br>2           | 1<br>1<br>1           | MOV<br>MOV<br>MOV<br>MOV | Rn,A<br>Rn,direct<br>Rn,#data<br>direct,A<br>direct,Rn | Accumulator<br>Move Accumulator to<br>register<br>Move direct byte to<br>register<br>Move immediate data to<br>register<br>Move Accumulator to<br>direct byte<br>Move register to direct<br>byte | 1<br>2<br>2           | 1<br>2<br>1           |
| ANL<br>ANL<br>ANL<br>ANL<br>ANL        | A,Rn<br>A,dırect<br>A,@Rı<br>A,#data<br>direct,A                 | AND register to<br>Accumulator<br>AND direct byte to<br>Accumulator<br>AND indirect RAM to<br>Accumulator<br>AND immediate data to<br>Accumulator<br>AND Accumulator to<br>direct byte<br>AND immediate data to<br>direct byte<br>OR register to | 2<br>1<br>2<br>2<br>3 | 1<br>1<br>1<br>1<br>2 | MOV<br>MOV<br>MOV<br>MOV | Rn,A<br>Rn,direct<br>Rn,#data<br>direct,A              | Accumulator<br>Move Accumulator to<br>register<br>Move direct byte to<br>register<br>Move Accumulator to<br>direct byte<br>Move register to direct<br>byte<br>Move direct byte to                | 1<br>2<br>2<br>2<br>2 | 1<br>2<br>1<br>1<br>2 |
| ANL<br>ANL<br>ANL<br>ANL<br>ANL<br>ANL | A,Rn<br>A,dırect<br>A,@Rı<br>A,#data<br>direct,A<br>direct,#data | AND register to<br>Accumulator<br>AND direct byte to<br>Accumulator<br>AND indirect RAM to<br>Accumulator<br>AND immediate data to<br>Accumulator<br>AND Accumulator to<br>direct byte<br>AND immediate data to<br>direct byte                   | 2<br>1<br>2<br>2      | 1<br>1<br>1<br>1      | MOV<br>MOV<br>MOV<br>MOV | Rn,A<br>Rn,direct<br>Rn,#data<br>direct,A<br>direct,Rn | Accumulator<br>Move Accumulator to<br>register<br>Move direct byte to<br>register<br>Move immediate data to<br>register<br>Move Accumulator to<br>direct byte<br>Move register to direct<br>byte | 1<br>2<br>2<br>2      | 1<br>2<br>1<br>1      |

# Table 2. MCS®-51 Instruction Set Description

# Table 2. MCS®-51 Instruction Set Description (Continued)

| DATA T | RANSFER (CO  | NTINUED)                                |      |     |
|--------|--------------|-----------------------------------------|------|-----|
| Mnemo  | •            | Description                             | Byte | Cvc |
| MOV    | direct.#data | Move immediate data to                  | Dyle | 0,0 |
|        | anoot, naata | direct byte                             | 3    | 2   |
| MOV    | @Ri.A        | Move Accumulator to                     | •    | -   |
|        | 0            | indirect RAM                            | 1    | 1   |
| MOV    | @Ri,direct   | Move direct byte to                     |      |     |
|        |              | indirect RAM                            | 2    | 2   |
| MOV    | @Rı,#data    | Move immediate data to                  |      |     |
|        |              | indirect RAM                            | 2    | 1   |
| MOV    | DPTR,#data16 | Load Data Pointer with                  | ~    | ~   |
| моус   | A,@A+DPTR    | a 16-bit constant                       | 3    | 2   |
| MOVC   | A,@ATDPIR    | Move Code byte relative<br>to DPTR to A | 1    | 2   |
| моус   | A,@A+PC      | Move Code byte relative                 |      | 2   |
|        |              | to PC to A                              | 1    | 2   |
| MOVX   | A,@Ri        | Move External RAM (8-                   | ·    | -   |
|        |              | bit addr) to A                          | 1    | 2   |
| MOVX   | A,@DPTR      | Move External RAM (16-                  |      |     |
|        |              | bit addr) to A                          | 1    | 2   |
| MOVX   | @Ri,A        | Move A to External RAM                  |      |     |
|        |              | (8-bit addr)                            | 1    | 2   |
| MOVX   | @DPTR,A      | Move A to External RAM                  | 1    | ~   |
| PUSH   | direct       | (16-bit addr)<br>Push direct byte onto  | 1    | 2   |
| FUSH   | unect        | stack                                   | 2    | 2   |
| POP    | direct       | Pop direct byte from                    | 2    | 2   |
| 1.0    | anoot        | stack                                   | 2    | 2   |
| хсн    | A,Rn         | Exchange register with                  | · -  | -   |
|        |              | Accumulator                             | 1    | 1   |
| хсн    | A, direct    | Exchange direct byte                    |      |     |
|        |              | with Accumulator                        | 2    | 1   |
| хсн    | A,@Ri        | Exchange indirect RAM                   |      |     |
| VOUD   |              | with A                                  | 1    | 1   |
| XCHD   | A,@Ri        | Exchange low-order                      |      |     |
|        |              | Digit ind RAM w A                       | 1    | 1   |
| BOOLE  |              | MANIPULATION                            |      |     |
| Mnemo  | nic          | Description                             | Byte | Cvc |
| CLR    | C            | Clear Carry flag                        | 1    | 1   |
| CLR    | bit          | Clear direct bit                        | 2    | 1   |
| SETB   | C            | Set Carry flag                          | 1    | 1   |
| SETB   | bit          | Set direct Bit                          | 2    | 1   |
| CPL    | C            | Complement Carry flag                   | 1    | 1   |
| CPL    | bit          | Complement direct bit                   | 2    | 1   |
| ANL    | C,bit        | AND direct bit to Carry                 |      |     |
|        | <b>a</b>     | flag                                    | 2    | 2   |
| ANL    | C,/bit       | AND complement of                       | •    | ~   |
|        | C/hit        | direct bit to Carry                     | 2    | 2   |
| ORL    | C/bit        | OR direct bit to Carry                  | 2    | 2   |
| ORL    | C./bit       | flag<br>OR complement of                | 2    | 2   |
|        | 0,/01        | direct bit to Carry                     | .2   | 2   |
| моу    | C,/bit       | Move direct bit to Carry                | 5    | ~   |
|        |              | flag                                    | 2    | 1   |
| MOV    | bit,C        | Move Carry flag to                      |      |     |
|        | •            | direct bit                              | 2    | 2   |
| l      | 1            |                                         |      |     |
| L      |              |                                         |      |     |

| PRC        | GR    | AM AND MAC                      | HINE CONTROL                                                                                                    |        |        |
|------------|-------|---------------------------------|-----------------------------------------------------------------------------------------------------------------|--------|--------|
| Mne        | mo    | nic                             | Description                                                                                                     | Byte   | Cyc    |
| ACA        | ۱LL   | addr11                          | Absolute Subroutine                                                                                             | -      | •      |
|            |       |                                 | Call                                                                                                            | 2      | 2      |
|            |       | addr16                          | Long Subroutine Call                                                                                            | 3      | 2<br>2 |
| RET        |       |                                 | Return from subroutine                                                                                          |        |        |
| RET        |       |                                 | Return from interrupt                                                                                           | 1      | 2      |
| AJM        |       | addr11<br>addr16                | Absolute Jump                                                                                                   | 2<br>3 | 2      |
| SJM        |       | rel                             | Long Jump<br>Short Jump (relative                                                                               | 3      | 2      |
| 1001       |       |                                 | addr)                                                                                                           | 2      | 2      |
| JMP        | )     | @A+DPTR                         | Jump indirect relative to the DPTR                                                                              | _      | -      |
| JZ         |       | rel                             | Jump if Accumulator is                                                                                          | _1     | 2      |
| JNZ        |       | rel                             | Zero<br>Jump if Accumulator is                                                                                  | 2      | 2      |
|            |       |                                 | Not Zero                                                                                                        | 2      | 2      |
| JC         |       | rel                             | Jump if Carry flag is set                                                                                       | 2      | 2      |
| JNC        | ;     | rel                             | Jump if No Carry flag                                                                                           | 2      | 2      |
| JB         |       | bit,rel                         | Jump if direct Bit set                                                                                          | 3      | 2      |
| JNB        | 5     | bit,rel                         | Jump if direct Bit Not                                                                                          |        |        |
|            |       |                                 | set                                                                                                             | 3      | 2      |
| JBC        |       | bit,rel                         | Jump if direct Bit is set                                                                                       | ×.,    |        |
|            |       |                                 | & Clear bit                                                                                                     | 3      | 2      |
| CJN        | IE    | A,direct,rel                    | Compare direct to A &                                                                                           |        |        |
|            |       |                                 | Jump if Not Equal                                                                                               | 3      | 2      |
| CJN        | IE    | A,#data,rel                     | Comp, immed, to A &                                                                                             | ~      | ~      |
|            |       |                                 | Jump if Not Equal                                                                                               | 3      | 2      |
| CJN        | IE    | Rn,#data,rel                    | Comp, immed, to reg &                                                                                           | ~      | ~      |
| CJN        |       |                                 | Jump if Not Equal                                                                                               | 3      | 2      |
| 1001       |       | whi,#uala,iei                   | Comp, immed, to ind, & Jump if Not Equal                                                                        | 3      | ż      |
| DJN        | 7     | Rn,rel                          | Decrement register &                                                                                            | 0      | 2      |
|            | -     |                                 | Jump if Not Zero                                                                                                | 2      | 2      |
| DJN        | Z     | direct.rel                      | Decrement direct &                                                                                              | -      | -      |
|            |       |                                 | Jump if Not Zero                                                                                                | 3      | 2      |
| NOF        | 2     |                                 | No operation                                                                                                    | 1      | 1      |
| Note<br>Rn | es oi | n data addressi<br>—Working reg |                                                                                                                 |        |        |
| direc      | ct    | —128 internal                   | RAM locations, any I/O<br>tatus register                                                                        | port,  |        |
| @Rı        |       |                                 | ernal RAM location addre                                                                                        | essed  | by     |
| #dat       |       | -8-bit consta                   | int included in instruction                                                                                     |        |        |
| #dat       | a16   |                                 | ant included as bytes 2 8                                                                                       | 13 of  |        |
| bit        |       | instruction<br>                 | e flags, any I/O pin, conti                                                                                     | rol or |        |
| Nat        |       |                                 | ressing modes:                                                                                                  |        |        |
| addr       |       | -Destination                    | address for LCALL & LJ<br>e within the 64-K program                                                             |        | ay     |
|            |       | memory add                      | dress space                                                                                                     |        |        |
| Addr       | r11   | within the s                    | address for ACALL & AJI<br>ame 2-K page of program                                                              | n      | ll be  |
|            |       |                                 | the first byte of the follow                                                                                    | ving   |        |
| rel        |       | instruction<br>S.IMP and a      | Ill conditional jumps inclu                                                                                     | ude a  | n 8-   |
| 10         |       |                                 | te, Range is +127-128 byt                                                                                       |        |        |
|            |       |                                 | te of the following in                                                                                          |        |        |
| All m      | nner  | -                               | phted  Intel Corporation                                                                                        |        |        |
| L          |       |                                 | (m. 1911 - 1911 - 1911 - 1911 - 1911 - 1911 - 1911 - 1911 - 1911 - 1911 - 1911 - 1911 - 1911 - 1911 - 1911 - 19 |        | 1      |

| Hex<br>Code | Number<br>of Bytes | Mnemonic | Operands            | ] .[ | Hex<br>Code | Number<br>of Bytes | Mnemonic | Operands        |
|-------------|--------------------|----------|---------------------|------|-------------|--------------------|----------|-----------------|
| 00          | 1                  | NOP      |                     | -1 F | 33          | 1                  | RLC      | Α               |
| 01          | 2                  | AJMP     | code addr           |      | 34          | 2                  | ADDC     | A.#data         |
| 02          | 3                  | LJMP     | code addr           | 1 1  | . 35        | 2                  | ADDC     | A,data addr     |
| 03          | 1                  | RR       | Α                   |      | 36          | 1                  | ADDC     | A,@R0           |
| 04          | 1                  | INC      | Α                   | 1    | 30          | 1                  | ADDC     | -               |
| 05          | 2                  | INC      | data addr           | 1 1  | 38          | 1                  | ADDC     | A,@R1           |
| 06          | 1                  | INC      | @R0                 |      | 39          |                    |          | A,R0            |
| 07          | 1                  | INC      | @R1                 |      |             | 1                  | ADDC     | A,R1            |
| 08          | 1                  | INC      | RO                  |      | 3A          |                    | ADDC     | A,R2            |
| 09          | 1                  | INC      | R1                  |      | 3B          | 1                  | ADDC `   | A,R3            |
| 03<br>0A    | 1                  | INC      | R2                  |      | 3C          | 1                  | ADDC     | A,R4            |
| 0B          | 1                  | INC      | R3                  |      | 3D          | 1                  | ADDC     | A,R5            |
| 0C          |                    |          | R3<br>R4            |      | 3E          | 1                  | ADDC     | A,R6            |
|             | , 1                | INC      |                     |      | 3F          | . 1                | ADDC     | A,R7            |
| 0D          | 1                  | INC      | R5                  |      | 40          | 2                  | JC       | code addr       |
| 0E          | 1                  | INC      | R6                  |      | 41          | 2                  | AJMP     | code addr       |
| 0F          | 1                  | INC      | R7                  |      | 42          | 2                  | ORL      | data addr,A     |
| 10          | 3                  | JBC      | bit addr, code addr |      | 43          | 3                  | ORL      | data addr,#data |
| 11          | 2                  | ACALL    | code addr           |      | 44          | 2                  | ORL      | A,#data         |
| 12          | 3                  | LCALL    | code addr           |      | 45          | 2                  | ORL      | A,data addr     |
| 13          | 1                  | RRC      | Α                   |      | 46          | 1                  | ORL      | A,@R0           |
| 14          | 1                  | DEC      | Α                   |      | 47          | 1                  | ORL      | A,@R1           |
| 15          | 2                  | DEC      | data addr           |      | 48          | 1                  | ORL      | A,R0            |
| 16          | 1                  | DEC      | @R0                 |      | 49          | 1                  | ORL      | A,R1            |
| 17          | 1                  | DEC      | @R1                 |      | 4A          | 1                  | ORL      | A,R2            |
| 18          | <b>.</b> 1         | DEC      | RO                  |      | 4B          | 1                  | ORL      | A,R3            |
| 19          | 1                  | DEC      | R1                  |      | 4C          | 1                  | ORL      | A,R4            |
| 1A          | 1                  | DEC      | R2                  |      | 40<br>4D    | 1                  | ORL      | A,R5            |
| 1B          | 1                  | DEC      | R3                  |      | 4D<br>4E    | 1                  | ORL      |                 |
| 10          | 1                  | DEC      | R4                  |      | 4E<br>4F    | 1                  |          | A,R6            |
| 1D          | 1                  | DEC      | R5                  |      |             |                    | ORL      | A,R7            |
| 1E          | 1                  | DEC      | R6                  | 1 1  | 50          | 2                  | JNC      | code addr       |
| 1F          | 1                  | DEC      | R7                  |      | 51          | 2                  | ACALL    | code addr       |
| 20          | 3                  | JB       | bit addr, code addr |      | 52          | 2                  | ANL      | data addr,A     |
| 20          | 2                  | AJMP     | code addr           |      | 53          | 3                  | ANL      | data addr,#data |
| 21          | 2                  | RET      |                     |      | 54          | 2                  | ANL      | A,#data         |
| 22          |                    |          | A                   |      | 55          | 2                  | ANL      | A,data addr     |
|             | 1                  | RL       | A                   |      | 56          | 1                  | ANL      | A,@R0           |
| 24          | 2                  | ADD      | A,#data             |      | 57          | 1                  | ANL      | A@R1            |
| 25          | 2                  | ADD      | A,data addr         |      | 58          | 1                  | ANL      | A,R0            |
| 26          | 1                  | ADD      | A,@R0               |      | 59          | 1 ′                | ANL      | A,R1            |
| 27          | 1                  | ADD      | A,@R1               |      | 5A          | 1                  | ANL      | A,R2            |
| 28          | 1                  | ADD      | A,R0                |      | 5B          | 1                  | ANL      | A,R3            |
| 29          | 1                  | ADD      | A,R1                |      | 5C          | 1                  | ANL      | A,R4            |
| 2A          | 1                  | ADD      | A,R2                |      | 5D          | 1                  | ANL      | A,R5            |
| 2B          | 1                  | ADD      | A,R3                |      | 5E          | 1                  | ANL      | A,R6            |
| 2C          | 1                  | ADD      | A,R4                |      | 5F          | 1                  | ANL      | A,R7            |
| 2D -        | 1                  | ADD      | A,R5                |      | 60          | 2                  | JZ       | code addr       |
| 2E          | 1                  | ADD      | A,R6                |      | 61          | 2                  | AJMP     | code addr       |
| 2F          | 1                  | ADD      | A,R7                |      | 62          | 2                  | XRL      | data addr.A     |
| 30          | 3                  | JNB      | bit addr, code addr |      | 63          | 3                  | XRL      | data addr,#data |
| 31          | 2                  | ACALL    | code addr           |      | 64          | 2                  | XRL      | A,#data         |
| 32          | 1                  | RETI     |                     |      | 65          | 2                  | XRL      |                 |
|             | •                  |          |                     |      | 03          | ۷                  | ANL      | A,data addr     |

# Table 3. Instruction Opcodes in Hexidecimal Order

A,R1 A,R2 A,R3 A,R4 A,R5 A,R6 A,R7 C,/bit addr C,bit addr DPTR AB

@R0,data adr @R1,data addr R0,data addr R1,data addr R2,data addr R3,data addr R4,data addr R5,data addr R5,data addr R6,data addr R7,data addr C,/bit addr C

A,#data.code addr A,data addr,code addr @R0,#data,code addr @R1,#data,code addr R0,#data,code addr R1.#data.code addr R2,#data,code addr R3,#data.code addr R4,#data,code addr R5,#data,code addr R6,#data,code addr R7,#data,code addr data addr code addr bit addr С А A,data addr A,@R0 A,@R1 A,R0 A,R1 A,R2 A,R3

Operands

## Table 3. Instruction Opcodes in Hexidecimal Order (Continued)

| Hex<br>Code | Number<br>of Bytes | Mnemonic | Operands             |     | Hex<br>Code | Number<br>of Bytes | Mnemonio |
|-------------|--------------------|----------|----------------------|-----|-------------|--------------------|----------|
| 66          | 1                  | XRL      | A,@R0                | ] ] | 99          | 1                  | SUBB     |
| 57          | 1                  | XRL      | A,@R1                |     | 9A          | 1                  | SUBB     |
| 8           | 1                  | XRL      | A,R0                 |     | 9B          | 1                  | SUBB     |
| )           | 1                  | XRL      | A,R1                 |     | 9C          | 1                  | SUBB     |
| 4           | 1                  | XRL      | A,R2                 |     | 9D          | 1                  | SUBB     |
| В           | 1                  | XRL      | A,R3                 |     | 9E          | 1                  | SUBB     |
| C           | 1                  | XRL      | A,R4                 |     | 9F          | 1                  | SUBB     |
| 6D          | 1                  | XRL      | A,R5                 |     | A0          | 2                  | ORL      |
| 6E          | 1                  | XRL      | A,R6                 |     | A1          | 2                  | AJMP     |
| 6F          | 1                  | XRL      | A,R7                 |     | A2          | 2                  | MOV      |
| 70          | 2                  | JNZ      | code addr            |     | A3          | 1                  | INC      |
| 71          | 2                  | ACALL    | code addr            |     | A4          | 1                  | MUL      |
| 72          | 2                  | ORL      | C,bit addr           |     | A5          |                    | reserved |
| 73          | 1                  | JMP      | @A+DPTR              |     | A6          | 2                  | MOV      |
| 74          | 2                  | MOV      | A,#data              |     | A7          | 2                  | MOV      |
| 75          | 3                  | MOV      | data addr,#data      |     | A8          | 2                  | MOV      |
| 76          | 2                  | MOV      | @R0,#data            |     | A9          | 2                  | MOV      |
| 77          | 2                  | MOV      | @R1,#data            |     | AA          | 2                  | MOV      |
| 78          | 2                  | MOV      | R0,#data             |     | AB          | 2                  | MOV      |
| 79          | 2                  | MOV      | R1,#data             |     | AC          | 2                  | MOV      |
| 7 <b>A</b>  | 2                  | MOV      | R2,#data             |     | AD          | 2                  | MOV      |
| 7B          | 2                  | MOV      | R3,#data             |     | AE          | 2                  | MOV      |
| 7C          | 2                  | MOV      | R4,#data             |     | AF          | 2                  | MOV      |
| 7D          | 2                  | MOV      | R5,#data             |     | B0          | 2                  | ANĽ      |
| 7E          | 2                  | MOV      | R6,#data             |     | B1          | 2                  | ACALL    |
| 7F          | 2                  | MOV      | R7,#data             |     | B2          | 2                  | CPL      |
| 30          | 2                  | SJMP     | code addr            |     | B3          | 1                  | CPL      |
| 31          | 2                  | AJMP     | code addr            |     | B4          | 3                  | CJNE     |
| 82          | 2                  | ANL      | C,bit addr           |     | B5          |                    | CJNE     |
| 83          | 1                  | MOVC     | A,@A+PC              |     | B6          | 3                  | CJNE     |
| 84          | 1                  | DIV      | AB                   |     | B7          | 3                  | CJNE     |
| 85          | 3                  | MOV      | data addr, data addr |     | B8          | 3                  | CJNE     |
| 86          | 2                  | MOV      | data addr,@R0        |     | B9          | 3                  | CJNE     |
| 87          | 2                  | MOV      | data addr,@R1        |     | BA          | 3                  | CJNE     |
| 88          | 2                  | MOV      | data addr,R0         |     | BB          | 3                  | CJNE     |
| 89          | 2                  | MOV      | data addr,R1         |     | BC          | 3                  | CJNE     |
| 8A          | 2                  | MOV      | data addr,R2         |     | BD          | 3                  | CJNE     |
| 8B 、        | 2                  | MOV      | data addr,R3         |     | BE          | 3                  | CJNE     |
| 8C          | 2                  | MOV      | data addr,R4         |     | BF          | 3                  | CJNE     |
| 8D          | 2                  | MOV      | data addr,R5         |     | C0          | 2                  | PUSH     |
| 8E .        | 2                  | MOV      | data addr,R6         |     | C1          | 2                  | AJMP     |
| 8F          | 2                  | MOV      | data addr,R7         |     | C2          | 2                  | CLR      |
| 90          | 3                  | MOV      | DPTR,#data           |     | C3          | 1                  | CLR      |
| 91          | 2                  | ACALL    | code addr            |     | C4          | 1                  | SWAP     |
| 92          | 2                  | MOV      | bit addr,C           |     | C5          | 2                  | хсн      |
| 93          | 1                  | MOVC     | A,@A+DPTR            |     | C6          | 1                  | хсн      |
| 94          | 2                  | SUBB     | A,#data              |     | C7          | 1                  | хсн      |
| 95          | 2                  | SUBB     | A,data addr          |     | C8          | 1                  | ХСН      |
| 96          | 1                  | SUBB     | A,@R0                |     | C9          | 1                  | хсн      |
| 97          | 1                  | SUBB     | A,@R1                |     | CA          | 1                  | ХСН      |
| 98          | 1                  | SUBB     | A,R0                 |     | CB          | 1                  | хсн      |

| Hex<br>Code | Number<br>of Bytes | Mnemonic | Operands            |
|-------------|--------------------|----------|---------------------|
| CC          | 1                  | ХСН      | A,R4                |
| CD          | 1                  | ХСН      | A,R5                |
| CE          | 1                  | хсн      | A,R6                |
| CF          | 1                  | хсн      | A,R7                |
| DO          | 2                  | POP      | data addr           |
| D1          | 2                  | ACALL    | code addr           |
| D2          | 2 .                | SETB     | bit addr            |
| D3          | 1 '                | SETB     | С                   |
| D4          | 1                  | DA       | A                   |
| D5          | 3                  | DJNZ     | data addr,code addr |
| D6          | 1                  | XCHD     | A,@R0               |
| D7          | 1                  | XCHD     | A,@R1               |
| D8          | 2                  | DJNZ     | R0,code addr        |
| D9          | 2                  | DJNZ     | R1,code addr        |
| DA          | 2                  | DJNZ     | R2,code addr        |
| DB          | 2                  | DJNZ     | R3,code addr        |
| DC          | 2                  | DJNZ     | R4,code addr        |
| DD          | 2                  | DJNZ     | R5,code addr        |
| DE          | 2                  | DJNZ     | R6,code addr        |
| DF          | 2                  | DJNZ     | R7,code addr        |
| E0          | 1                  | MOVX     | A,@DPTR             |
| E1          | 2                  | AJMP     | code addr           |
| E2          | 1                  | MOVX     | A,@R0               |
| E3          | 1                  | MOVX     | A,@R1               |
| E4          | 1                  | CLR      | Α                   |
| E5          | 2                  | MOV      | A,data addr         |

# Table 3. Instruction Opcodes in Hexidecimal Order (Continued)

| Hex<br>Code | Number<br>of Bytes | Mnemonic | Operands    |
|-------------|--------------------|----------|-------------|
| E6          | 1                  | MOV      | A,@R0       |
| E7          | 1                  | MOV      | A,@R1       |
| E8          | 1                  | MOV      | A,R0        |
| E9          | 1                  | MOV      | A,R1        |
| EA          | 1,                 | MOV      | A,R2        |
| EB          | 1 -                | MOV      | A,R3        |
| EC          | 1                  | MOV      | A,R4        |
| ED          | 1.                 | MOV      | A,R5        |
| EE          | 1                  | MOV      | A,R6        |
| EF          | 1                  | MOV      | A.R7        |
| FO          | 1                  | MOVX     | @DPTR,A     |
| F1          | 2                  | ACALL    | code addr   |
| F2          | 1                  | MOVX     | @R0,A       |
| F3          | 1                  | MOVX     | @R1,A       |
| F4          | 1                  | CPL      | Α           |
| F5          | . 2                | MOV      | data addr,A |
| F6          | 1                  | MOV      | @R0,A       |
| F7          | 1                  | MOV      | @R1,A       |
| F8          | 1                  | MOV      | R0,A        |
| F9          | 1 .                | MOV      | R1,A        |
| FA          | 1.                 | MOV      | R2,A        |
| FB          | 1                  | MOV      | R3,A        |
| FC          | <b>1</b> →         | MOV      | R4,A        |
| FD          | 1                  | MOV      | R5,A        |
| FE          | 1                  | MOV      | R6,A        |
| FF          | 1                  | MOV      | R7,A        |

# intel

# 8031AH/8051AH 8032AH/8052AH 8751H/8751H

# EXPRESS

# Extended Temperature Range

Burn-in

The Intel EXPRESS system offers enhancements to the operational specifications of the MCS®-51 family of microcontrollers. These EXPRESS products are designed to meet the needs of those applications whose operating requirements exceed commercial standards.

The EXPRESS program includes the commercial standard temperature range with burn-in, and an extended temperature range with or without burn-in.

With the commercial standard temperature range operational characteristics are guaranteed over the temperature range of 0°C to 70°C. With the extended temperature range option, operational characteristics are guaranteed over the range of -40°C to +85°C.

The optional burn-in is dynamic, for a minimum time of 160 hours at 125°C with V<sub>CC</sub> = 5.5V  $\pm$ 0.5V, following guidelines in MIL-STD-883, Method 1015.

Package types and EXPRESS versions are identified by a one- or two-letter prefix to the part number. The prefixes are listed in Table 1.

For the extended temperature range option, this data sheet specifies the parameters which deviate from their commercial temperature range limits. The commercial temperature range data sheets are applicable for all parameters not listed here.

#### Electrical Deviations from Commercial Specifications for Extended Temperature Range

D.C. and A.C. parameters not included here are the same as in the commercial temperature range data sheets.

| Symbol | Parameter                                                              | Min  | Max                  | Unit           | Test Conditions                                      |
|--------|------------------------------------------------------------------------|------|----------------------|----------------|------------------------------------------------------|
| VIL    | Input Low Voltage                                                      | -0.5 | 0.75                 | v              |                                                      |
| VIH    | Input High Voltage (Except XTAL2, RST)                                 | 2.1  | V <sub>CC</sub> +0.5 | v              |                                                      |
| ICC    | Power Supply Current:<br>8051AH,8031AH<br>8052AH,8032AH<br>8751H,8751H |      | 135<br>175<br>265    | ma<br>ma<br>ma | All Outputs<br>Disconnected;<br>EA = V <sub>CC</sub> |

#### **D.C. CHARACTERISTICS:** $(T_A = -40^{\circ}C \text{ to } +85^{\circ}C; V_{CC} = 5V \pm 10\%; V_{SS} = 0V)$

| Prefix | Package Type | Temperature Range | Burn-In |
|--------|--------------|-------------------|---------|
| Р      | plastic      | commercial        | ňo      |
| · D    | cerdip       | commercial        | no      |
| С      | ceramic      | commercial        | no      |
| TP     | plastic      | extended          | no      |
| TD     | cerdip       | extended          | no      |
| TC     | ceramic      | extended          | no      |
| QP     | plastic      | commercial        | yes     |
| QD     | cerdip       | commercial        | yes     |
| QC     | ceramic      | commercial        | yes     |
| LP     | plastic      | extended          | yes     |
| LD ,   | cerdip       | extended          | yes     |
| LC     | ceramic      | extended          | yes     |

## Table 1 — Prefix Identification

Please note:

• Commercial temperature range is 0° to 70°C. Extended temperature range is -40° to +85°C.

• Burn-in is dynamic, for a minimum time of 160 hours at 125°C,  $V_{CC} = 5.5V \pm 0.5V$ , following guidelines in MIL-STD-883 Method 1015 (Test Condition D).

- The following devices are not available in plastic packages: 8751H,8751H
- The following devices are not available in ceramic packages: 8051AH,8031AH 8052AH,8032AH

Examples: P8031AH indicates 8031AH in a plastic package and specified for commercial temperature range, without burn-in. LD8751H indicates 8751H in a cerdip package and specified for extended temperature range with burn-in.

# MCS®-51 Application Notes

10

|         |   |          |   |   | <br> |
|---------|---|----------|---|---|------|
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         | 4 |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          | ~ |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
| х.<br>Х |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
| ,<br>,  |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   | <i>i</i> |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   | 1 |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |
|         |   |          |   |   |      |

e e stander i 1960 por 1960 e service e service service de la service de la service de la service en else

| 1. 16 Mg 1 1 19 1 1 1 1 1 |  |          |                                       |   | • • |
|---------------------------|--|----------|---------------------------------------|---|-----|
|                           |  | 1879 - N | , , , , , , , , , , , , , , , , , , , | 1 |     |
|                           |  |          |                                       |   |     |

·

,

An Introduction to the Intel MCS®-51 Single-Chip Microcomputer Family

# Contents

| 1. | INTRODUCTION         10-2           Family Overview         10-2           Microcomputer Background Concepts         10-3                                                                                                                                                                                                                               |
|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2. | ARCHITECTURE AND ORGANIZATION       10-5         Central Processing Unit       10-6         Memory Spaces       10-9         Input/Output Ports       10-10         Special Peripheral Functions       10-11                                                                                                                                            |
| 3. | INSTRUCTION SET AND<br>ADDRESSING MODES.10-15Data Addressing Modes10-15Addressing Mode Combinations10-18Advantages of Symbolic Addressing10-18Arithmetic Instruction Usage10-19Multiplication and Division10-20Logical Byte Operations10-20Program Control10-21Operate-and-Branch Instructions10-22Stack Operations10-22Table Look-Up Instructions10-23 |
| 4. | BOOLEAN PROCESSING INSTRUCTIONS10-25Direct Bit Addressing10-25Bit Manipulation Instructions10-25Solving Combinatorial Logic Equations10-26                                                                                                                                                                                                              |
| 5. | ON-CHIP PERIPHERAL FUNCTIONS         10-28           I/O Ports         10-28           Serial Port and Timer         10-29                                                                                                                                                                                                                              |
| 6. | SUMMARY 10-30                                                                                                                                                                                                                                                                                                                                           |



Figure 1a. 8051 Microcomputer Pinout Diagram

#### **1. INTRODUCTION**

In 1976 Intel introduced the MCS-48<sup>™</sup> family, consisting of the 8048, 8748, and 8035 microcomputers. These parts marked the first time a complete microcomputer system, including an eight-bit CPU, 1024 8-bit words of ROM or EPROM program memory, 64 words of data memory, I/O ports and an eight-bit timer/counter could be integrated onto a single silicon chip. Depending only on the program memory contents, one chip could control a limitless variety of products, ranging from appliances or automobile engines to text or data processing equipment. Follow-on products stretched the MCS-48<sup>™</sup> architecture in several directions: the 8049 and 8039 doubled the amount of on-chip memory and ran 83% faster; the 8021 reduced costs by executing a subset of the 8048 instructions with a somewhat slower clock; and the 8022 put a unique two-channel 8-bit analog-to-digital converter on the same NMOS chip as the computer, letting the chip interface directly with analog transducers.

Now three new high-performance single-chip microcomputers—the Intel® 8051, 8751, and 8031—extend the advantages of Integrated Electronics to whole new product areas. Thanks to Intel's new HMOS technology, the MCS-51<sup>TM</sup> family provides four traves the program memory and twice the data memory as the 8048 on a single chip. New I/O and peripheral capabilities both increase the range of applicability and reduce total system cost. Depending on the use, processing throughput increases by two and one-half to ten times.

This Application Note is intended to introduce the reader to the MCS-51<sup>TM</sup> architecture and features. While it does not assume intimacy with the MCS-48<sup>TM</sup> product line on the part of the reader, he/she should be familiar with



Figure 1b. 8051 Microcomputer Logic Symbol

some microprocessor (preferably Intel's, of course) or have a background in computer programming and digital logic.

#### **Family Overview**

Pinout diagrams for the 8051, 8751, and 8031 are shown in Figure 1. The devices include the following features:

- Single-supply 5 volt operation using HMOS technology.
- 4096 bytes program memory on-chip (not on 8031).
- 128 bytes data memory on-chip.
- Four register banks.
- 128 User-defined software flags.
- 64 Kilobytes each program and external RAM addressability.
- One microsecond instruction cycle with 12 MHz crystal.
- 32 bidirectional I/O lines organized as four 8-bit ports (16 lines on 8031).
- Multiple mode, high-speed programmable Serial Port.
- Two multiple mode, 16-bit Timer/Counters.
- Two-level prioritized interrupt structure.
- Full depth stack for subroutine return linkage and data storage.
- Augmented MCS-48<sup>™</sup> instruction set.
- Direct Byte and Bit addressability.
- Binary or Decimal arithmetic.
- Signed-overflow detection and parity computation.
- Hardware Multiple and Divide in 4 usec.
- Integrated Boolean Processor for control applications.
- Upwardly compatible with existing 8048 software.

All three devices come in a standard 40-pin Dual In-Line Package, with the same pin-out, the same timing, and the same electrical characteristics. The primary difference between the three is the on-chip program memory—different types are offered to satisfy differing user requirements.

The 8751 provides 4K bytes of ultraviolet-Erasable, Programmable Read Only Memory (EPROM) for program development, prototyping, and limited production runs. (By convention, IK means  $2^{10} = 1024$ . Ik—with a lower case "k"—equals  $10^3 = 1000$ .) This part may be individually programmed for a specific application using Intel's Universal PROM Programmer (UPP). If software bugs are detected or design specifications change the same part may be "erased" in a matter of minutes by exposure to ultraviolet light and reprogrammed with the modified code. This cycle may be repeated indefinitely during the design and development phase.

The final version of the software must be programmed into a large number of production parts. The 8051 has 4K bytes of ROM which are mask-programmed with the customer's order when the chip is built. This part is considerably less expensive, but cannot be erased or altered after fabrication.

The 8031 does not have any program memory on-chip, but may be used with up to 64K bytes of external standard or multiplexed ROMs, PROMs, or EPROMs. The 8031 fits well in applications requiring significantly larger or smaller amounts of memory than the 4K bytes provided by its two siblings.

(The 8051 and 8751 automatically access external program memory for all addresses greater than the 4096 bytes on-chip. The External Access input is an override for all internal program memory—the 8051 and 8751 will each emulate an 8031 when pin 31 is low.)

Throughout this Note, "8051" is used as a generic term. Unless specifically stated otherwise, the point applies equally to all three components. Table 1 summarizes the quantitative differences between the members of the MCS-48<sup>Tm</sup> and MCS-51<sup>Tm</sup> families.

The remainder of this Note discusses the various MCS-51<sup>™</sup> features and how they can be used. Software and/or hard-

ware application examples illustrate many of the concepts. Several isolated tasks (rather than one complete system design example) are presented in the hope that some of them will apply to the reader's experiences or needs.

A document this short cannot detail all of a computer system's capabilities. By no means will all the 8051 instructions be demonstrated; the intent is to stress new or unique MCS-51<sup>TM</sup> operations and instructions generally used in conjunction with each other. For additional hardware information refer to the Intel MCS-51<sup>TM</sup> Family User's Manual, publication number 121517. The assembler, language and use of ASM51, the MCS-51<sup>TM</sup> assembler, are further described in the MCS-51<sup>TM</sup> Macro Assembler User's Guide, publication number 9800937.

The next section reviews some of the basic concepts of microcomputer design and use. Readers familiar with the 8048 may wish to skim through this section or skip directly to the next, "ARCHITECTURE AND ORGANIZATION."

#### **Microcomputer Background Concepts**

Most digital computers use the binary (base 2) number system internally. All variables, constants, alphanumeric characters, program statements, etc., are represented by groups of binary digits ("bits"), each of which has the value 0 or 1. Computers are classified by how many bits they can move or process at a time.

The MCS-51<sup>TM</sup> microcomputers contain an eight-bit central processing unit (CPU). Most operations process variables eight bits wide. All internal RAM and ROM, and virtually all other registers are also eight bits wide. An eight-bit ("byte") variable (shown in Figure 2) may assume one of  $2^8 = 256$  distinct values, which usually represent integers between 0 and  $\cdot 255$ . Other types of numbers, instructions, and so forth are represented by one or more bytes using certain conventions.

For example, to represent positive and negative values, the most significant bit (D7) indicates the sign of the other seven bits—0 if positive, 1 if negative—allowing integer variables between -128 and +127. For integers with extremely large magnitudes, several bytes are manipulated together as "multiple precision" signed or unsigned integers—16, 24, or more bits wide.

| EPROM<br>Program<br>Memory | ROM<br>Program<br>Memory | External<br>Program<br>Memory | Program<br>Memory<br>(Int/Max) | Data<br>Memory<br>(Bytes) | Instr.<br>Cycle<br>Time | Input/<br>Output<br>Pins | Interrupt<br>Sources | Reg.<br>Banks |
|----------------------------|--------------------------|-------------------------------|--------------------------------|---------------------------|-------------------------|--------------------------|----------------------|---------------|
|                            | 8021                     |                               | 1K/1K                          | 64                        | 8.4 µSec                | 21                       | 0                    | 1             |
|                            | 8022                     | _                             | 2K/2K                          | 64                        | 8.4 µSec                | 28                       | • 2                  | · 1           |
| 8748                       | 8048                     | 8035                          | 1K/4K                          | 64                        | $2.5 \mu \text{Sec}$    | 27                       | . 2                  | · 2           |
|                            | 8049                     | 8039                          | 2K/4K                          | 128                       | 1.36 µSec               | 27                       | 2                    | 2             |
| 8751                       | 8051                     | 8031                          | 4K/64K                         | 128                       | $1.0 \mu \text{Sec}$    | 32                       | 5                    | 4             |

Table 1. Features of Intel's Single-Chip Microcomputers

AFN-01502A-05

The letters "MCS" have traditionally indicated a system or family of compatible Intel® microcomputer components, including CPUs, memories, clock generators, I/O expanders, and so forth. The numerical suffix indicates the microprocessor or microcomputer which serves as the cornerstone of the family. Microcomputers in the MCS-48<sup>™</sup> family currently include the 8048-series (8035, 8048, & 8748), the 8049-series (8039 & 8049), and the 8021 and 8022; the family also includes the 8243, an I/O expander compatible with each of the microcomputers. Each computer's CPU is derived from the 8048. with essentially the same architecture, addressing modes, and instruction set, and a single assembler (ASM48) serves each.

The first members of the MCS-51<sup>™</sup> family are the 8051, 8751, and 8031. The architecture of the 8051-series, while derived from the 8048, is not strictly compatible; there are more addressing modes, more instructions, larger address spaces, and a few other hardware differences. In this Application Note the letters "MCS-51" are used when referring to architectural features of the 8051-series-features which would be included on possible future microcomputers based on the 8051 CPU. Such products could have different amounts of memory (as in the 8048/8049) or different peripheral functions (as in the 8021 and 8022) while leaving the CPU and instruction set intact. ASM51 is the assembler used by all microcomputers in the 8051 family.

Two digit decimal numbers may be "packed" in an eightbit value, using four bits for the binary code of each digit. This is called Binary-Coded Decimal (BCD) representation, and is often used internally in programs which interact heavily with human beings.

Alphanumeric characters (letters, numbers, punctuation marks, etc.) are often represented using the American Standard Code for Information Interchange (ASCII) convention. Each character is associated with a unique seven-bit binary number. Thus one byte may represent

|       |    | 1.4 |    |    |    |    |    |
|-------|----|-----|----|----|----|----|----|
| <br>0 | 1  | 0   | 1  | 0, | 0  | 0  | 1  |
| D7    | D6 | D5  | D4 | D3 | D2 | D1 | DO |

Figure 2. Representation of Bits Within an Eight-Bit "Byte" (Value shown = 01010001 Binary = 81 decimal). a single character, and a word or sequence of letters may be represented by a series (or "string") of bytes. Since the ASCII code only uses 128 characters, the most significant bit of the byte is not needed to distinguish between characters. Often D7 is set to 0 for all characters. In some coding schemes, D7 is used to indicate the "parity" of the other seven bits—set or cleared as necessary to ensure that the total number of "1" bits in the eight-bit code is even ("even parity") or odd ("odd parity"). The 8051 includes hardware to compute parity when it is needed.

A computer program consists of an ordered sequence of specific, simple steps to be executed by the CPU one-ata-time. The method or sequence of steps used collectively to solve the user's application is called an "algorithm."

The program is stored inside the computer as a sequence of binary numbers, where each number corresponds to one of the basic operations ("opcodes") which the CPU is capable of executing. In the 8051, each program memory location is one byte. A complete instruction consists of a sequence of one or more bytes, where the first defines the operation to be executed and additional bytes (if needed) hold additional information, such as data values or variable addresses. No instruction is longer than three bytes.

The way in which binary opcodes and modifier bytes are assigned to the CPU's operations is called the computer's "machine language." Writing a program directly in machine language is time-consuming and tedious. Human beings think in words and concepts rather than encoded numbers, so each CPU operation and resource is given a name and standard abbreviation ("mnemonic"). Programs are more easily discussed using these standard mnemonics, or "assembly language," and may be typed into an Intel® Intellec® 800 or Series II® microcomputer development system in this form. The development system can mechanically translate the program from assembly language "source" form to machine language "object" code using a program called an "assembler." The MCS-51<sup>TM</sup> assembler is called ASM51.

There are several important differences between a computer's machine language and the assembly language used as a tool to represent it. The machine language or instruction set is the set of operations which the CPU can perform while a program is executing ("at run-time"), and is strictly determined by the microcomputer hardware design.

The assembly language is a standard (though more-orless arbitrary) set of symbols including the instruction set mnemonics, but with additional features which further simplify the program design process. For example, ASM51 has controls for creating and formatting a program listing, and a number of directives for allocating variable storage and inserting arbitrary bytes of data into the object code for creating tables of constants. In addition, ASM51 can perform sophisticated mathematical operations, computing addresses or evaluating arithmetic expressions to relieve the programmer from this drudgery. However, these calculations can only use information known at "assembly time."

For example, the 8051 performs arithmetic calculations at run-time, eight bits at a time. ASM51 can do similar operations 16 bits at a time. The 8051 can only do one simple step per instruction, while ASM51 can perform complex calculations in each line of source code. However, the operations performed by the assembler may only use parameter values fixed at assembly-time, not variables whose values are unknown until program execution begins.

For example, when the assembly language source line,

#### ADD A,#(LOOP\_COUNT + 1) \* 3

is assembled, ASM51 will find the value of the previously-defined constant "LOOP\_COUNT" in an internal symbol table, increment the value, multiply the sum by three, and (assuming it is between -256 and 255 inclusive) truncate the product to eight bits. When this instruction is *executed*, the 8051 ALU will just add that resulting constant to the accumulator.

Some similar differences exist to distinguish number system ("radix") specifications. The 8051 does all computations in binary (though there are provisions for then converting the result to decimal form). In the course of writing a program, though, it may be more convenient to specify constants using some other radix, such as base 10. On other occasions, it is desirable to specify the ASCII code for some character or string of characters without refering to tables. ASM51 allows several representations for constants, which are converted to binary as each instruction is assembled.

For example, binary numbers are represented in the

assembly language by a series of ones and zeros (naturally), followed by the letter "B" (for Binary); octal numbers as a series of octal digits (0-7) followed by the letter "O" (for Octal) or "Q" (which doesn't stand for anything, but *looks* sort of like an "O" and is less likely to be confused with a zero).

Hexadecimal numbers are represented by a series of hexadecimal digits (0-9, A-F), followed by (you guessed it) the letter "H." A "hex" number must begin with a decimal digit; otherwise it would look like a user-defined symbol (to be discussed later). A "dummy" leading zero may be inserted before the first digit to meet this constraint. The character string "BACH" could be a legal label for a Baroque music synthesis routine; the string "0BACH" is the hexadecimal constant BAC<sub>16</sub>. This is a case where adding 0 makes a big difference.

Decimal numbers are represented by a sequence of decimal digits, optionally followed by a "D." If a number has no suffix, it is assumed to be decimal—so it had better not contain any non-decimal digits. "0BAC" is not a legal representation for anything.

When an ASCII code is needed in a program, enclose the desired character between two apostrophes (as in '#') and the assembler will convert it to the appropriate code (in this case 23H). A string of characters between apostrophes is translated into a series of constants; 'BACH' becomes 42H, 41H, 43H, 48H.

These same conventions are used throughout the associated Intel documentation. Table 2 illustrates some of the different number formats.

#### 2. ARCHITECTURE AND ORGANIZATION

Figure 3 blocks out the MCS-51<sup>™</sup> internal organization. Each microcomputer combines a Central Processing Unit, two kinds of memory (data RAM plus program ROM or EPROM), Input/Output ports, and the mode,

| Bit Pattern     | Binary    | Octal    | Hexa-<br>Decimal | Decimal | Signed<br>Decimal |
|-----------------|-----------|----------|------------------|---------|-------------------|
| 0 0 0 0 0 0 0 0 | 0B        | 0Q<br>1Q | 00H              | 0       | . 0               |
| 0000001         | 1B        | +lQ      | 01H              | 1       | +1                |
|                 |           |          |                  | • :     |                   |
| 00000111        | 111B      | 7Q       | 07H              | /       | +7                |
| 0 0 0 0 1 0 0 0 | 1000B     | 10Q      | 08H              | 8       | +8                |
| 00001001        | 1001B     | 11Q      | 09H              | 9       | +9                |
| 00001010        | 1010B     | 12Q      | 0AH              | 10      | +10               |
|                 |           |          |                  |         |                   |
| 00001111        | 1111B     | 17Q      | 0FH              | 15      | +15               |
| 00010000        | 10000B    | 20Q      | 10H              | 16      | +16               |
|                 |           |          |                  | ••      |                   |
| 0111111         | 1111111B  | 177Q     | 7FH              | 127     | +127              |
| 10000000        | 1000000B  | 200Q     | 80H              | 128     | -128              |
| 1000001         | 10000001B | 201Q     | 81H              | 129     | -127              |
|                 |           |          |                  |         |                   |
| 11111110        | 11111110B | 376Q     | 0FEH             | 254 .   | -2                |
| 1111111         | 1111111B  | 377Q     | 0FFH             | 255     | -1                |

**Table 2. Notations Used to Represent Numbers** 



Figure 3. Block Diagram of 8051 Internal Structure

status, and data registers and random logic needed for a variety of peripheral functions. These elements communicate through an eight-bit data bus which runs throughout the chip, somewhat akin to indoor plumbing. This bus is buffered to the outside world through an I/Oport when memory or I/O expansion is desired.

Let's summarize what each block does; later chapters dig into the CPU's instruction set and the peripheral registers in much greater detail.

#### **Central Processing Unit**

The CPU is the "brains" of the microcomputer, reading the user's program and executing the instructions stored therein. Its primary elements are an eight-bit Arithmetic/ Logic Unit with associated registers A, B, PSW, and SP, and the sixteen-bit Program Counter and "Data Pointer" registers.



#### Arithmetic Logic Unit

The ALU can perform (as the name implies) arithmetic and logic functions on eight-bit variables. The former include basic addition, subtraction, multiplication, and division; the latter include the logical operations AND, OR, and Exclusive-OR, as well as rotate, clear, complement, and so forth. The ALU also makes conditional branching decisions, and provides data paths and temporary registers used for data transfers within the system. Other instructions are built up from these primitive functions: the addition capability can increment registers or automatically compute program destination addresses; subtraction is also used in decrementing or comparing the magnitude of two variables.

These primitive operations are automatically cascaded and combined with dedicated logic to build complex instructions such as incrementing a sixteen-bit register pair. To execute one form of the compare instruction, for example, the 8051 increments the program counter three times, reads three bytes of program memory, computes a register address with logical operations, reads internal data memory twice, makes an arithmetic comparison of two variables, computes a sixteen-bit destination address, and decides whether or not to make a branch—all in two microseconds!

An important and unique feature of the MCS-51 architecture is that the ALU can also manipulate one-bit as well as eight-bit data types. Individual bits may be set, cleared, or complemented, moved, tested, and used in logic computations. While support for a more primitive data type may initially seem a step backwards in an era of increasing word length, it makes the 8051 especially well suited for controller-type applications. Such algorithms *inherently* involve Boolean (true/false) input and output variables, which were heretofore difficult to implement with standard microprocessors. These features are collectively referred to as the MCS-51<sup>TM</sup> "Boolean Processor," and are described in the so-named chapter to come.

Thanks to this powerful ALU, the 8051 instruction set fares well at both real-time control and data intensive algorithms. A total of 51 separate operations move and manipulate three data types: Boolean (1-bit), byte (8-bit), and address (16-bit). All told, there are eleven addressing modes—seven for data, four for program sequence control (though only eight are used by more than just a few specialized instructions). Most operations allow several addressing modes, bringing the total number of instructions (operation/addressing mode combinations) to 111, encompassing 255 of the 256 possible eight-bit instruction opcodes.

#### Instruction Set Overview

Table 4 lists these 111 instructions classified into five groups:

- Arithmetic Operations
- Logical Operations for Byte Variables
- Data Transfer Instructions
- Boolean Variable Manipulation
- Program Branching and Machine Control

MCS-48<sup>TM</sup> programmers perusing Table 4 will notice the absence of special categories for Input/Output, Timer/ Counter, or Control instructions. These functions are all still provided (and indeed many new functions are added), but as special cases of more generalized operations in other categories. To explicitly list all the useful instructions involving I/O and peripheral registers would require a table approximately four times as long.

Observant readers will also notice that all of the 8048's page-oriented instructions (conditional jumps, JMPP, MOVP, MOVP3) have been replaced with corresponding but non-paged instructions. The 8051 instruction set is entirely *non*-page-oriented. The MCS-48<sup>TM</sup> "MOVP" instruction replacement and all conditional jump instructions operate relative to the program counter, with the actual jump address computed by the CPU during instruction execution. The "MOVP3" and "JMPP" replacements are now made relative to another sixteen-bit register, which allows the effective destination to be anywhere in the program memory space, regardless of where the instruction itself is located. There are even three-byte jump and call instructions allowing the destination to be *anywhere* in the 64K program address space.

The instruction set is designed to make programs efficient both in terms of code size and execution speed. No instruction requires more than three bytes of program memory, with the majority requiring only one or two bytes. Virtually all instructions execute in either one or two instruction cycles—one or two microseconds with a 12-MHz crystal—with the sole exceptions (multiply and divide) completing in four cycles.

Many instructions such as arithmetic and logical functions or program control, provide both a short and a long form for the same operation, allowing the programmer to optimize the code produced for a specific application. The 8051 usually fetches two instruction bytes per instruction cycle, so using a shorter form can lead to faster execution as well.

For example, any byte of RAM may be loaded with a constant with a three-byte, two-cycle instruction, but the commonly used "working registers" in RAM may be initialized in one cycle with a two-byte form. Any bit anywhere on the chip may be set, cleared, or complemented by a single three-byte logical instruction using two cycles. But critical control bits, I/O pins, and software flags may be controlled by two-byte, single cycle instructions. While three-byte jumps and calls can "go anywhere" in program memory, nearby sections of code may be reached by shorter relative or absolute versions.

| (MSB)    |    |         |     |                   |        |        | (L   | SB)      |                     | Symbol | Desition | Name and Si                    | anificanco                                                  |
|----------|----|---------|-----|-------------------|--------|--------|------|----------|---------------------|--------|----------|--------------------------------|-------------------------------------------------------------|
| CY       | AC | FO      | RS1 | RSO               | ov     |        | Τ    | Р        |                     | OV     | PSW.2    | Overflow flag.                 | •                                                           |
| -        |    | osition |     | me ar             |        | gnific | and  | ce       | 1                   |        | 1 3 11.2 | Set/cleared by metic instructi | hardware during arith-<br>ons to indicate overflow          |
| CY       | P  | SW.7    |     | rry fla<br>/clear |        | / hard | war  | e or sof | ftware              |        |          | conditions.                    |                                                             |
|          |    |         | du  |                   | rtain  |        |      | ic and I |                     | ,      | PSW.1    | (reserved)                     |                                                             |
| <i>,</i> |    |         | ,   |                   |        |        | ,    |          |                     | Р      | PSW.0    | Parity flag.                   | ر                                                           |
| AC       | P  | SW.6    |     | xiliary           |        |        |      | during   | addition            |        |          |                                | hardware each instruc-                                      |
|          |    |         | or  |                   | ction  | instr  | ucti | ons to i | addition<br>ndicate |        |          |                                | ndicate an odd/even<br>ne" bits in the accumu-<br>n parity. |
| F0       | p  | SW.5    | Fla | g O               |        |        |      |          |                     |        | Note     | the contents of (              | RS1, RS0) enable the                                        |
|          | 1. | 3 **.5  | Set |                   |        |        |      | oftware  | as a                |        | NOLE     |                                | banks as follows:                                           |
| •        |    |         |     |                   |        |        | Ũ    | ,        |                     |        |          | (0,0)Bank 0                    | (00H-07H)                                                   |
| RS1      | P  | SW.4    |     |                   |        |        |      |          | its 1 & 0.          |        |          | (0,1)-Bank 1                   | (08H-0FH)                                                   |
|          | -  |         |     |                   |        |        |      | to dete  |                     |        |          | (1,0)-Bank 2                   | (10H-17H)                                                   |
| RS       | P: | SW.3    | wo  | rking             | regist | er ba  | nk ( | see Not  | e).                 |        |          | (1,1)-Bank 3                   | (18H-1FH)                                                   |

#### Figure 4. PSW—Program Status Word Organization

A significant side benefit of an instruction set more powerful than those of previous single-chip microcomputers is that it is easier to generate applications-oriented software. Generalized addressing modes for byte and bit instructions reduce the number of source code lines written and debugged for a given application. This leads in turn to proportionately lower software costs, greater reliability, and faster design cycles.

#### Accumulator and PSW

The 8051, like its 8048 predecessor, is primarily an accumulator-based architecture: an eight-bit register called the accumulator ("A") holds a source operand and receives the result of the arithmetic instructions (addition, subtraction, multiplication, and division). The accumulator can be the source or destination for logical operations and a number of special data movement instructions, including table look-ups and external RAM expansion. Several functions apply exclusively to the accumulator: rotates, parity computation, testing for zero, and so on.

Many instructions implicitly or explicitly affect (or are affected by) several status flags, which are grouped together to form the Program Status Word shown in Figure 4.

(The period within entries under the Position column is called the "dot operator," and indicates a particular bit position within an eight-bit byte. "PSW,5" specifies bit 5 of the PSW. Both the documentation and ASM51 use this notation.)

The most "active" status bit is called the carry flag (abbreviated "C"). This bit makes possible multiple precision arithmetic operations including addition, subtraction,

and rotates. The carry also serves as a "Boolean accumulator" for one-bit logical operations and bit manipulationinstructions. The overflow flag (OV) detects when arithmetic overflow occurs on signed integer operands, making two's complement arithmetic possible. The parity flag (P) is updated after every instruction cycle with the evenparity of the accumulator contents.

The CPU does not control the two register-bank select bits, RS1 and RS0. Rather, they are manipulated by software to enable one of the four register banks. The usage of the PSW flags is demonstrated in the Instruction Set chapter of this Note.

Even though the architecture is accumulator-based, provisions have been made to bypass the accumulator in common instruction situations. Data may be moved from any location on-chip to any register, address, or indirect address (and vice versa), any register may be loaded with a constant, etc., all without affecting the accumulator. Logical operations may be performed against registers or variables to alter fields of bits—without using or affecting the accumulator. Variables may be incremented, decremented, or tested without using the accumulator. Flags and control bits may be manipulated and tested without affecting anything else.

#### Other CPU Registers

A special eight-bit register ("B") serves in the execution of the multiply and divide instructions. This register is used in conjunction with the accumulator as the second input operand and to return eight-bits of the result.

The MCS-51 family processors include a hardware stack within internal RAM, useful for subroutine linkage, AFN-01502A-10 passing parameters between routines, temporary variable storage, or saving status during interrupt service routines. The Stack Pointer (SP) is an eight-bit pointer register which indicates the address of the last byte pushed onto the stack. The stack pointer is automatically incremented or decremented on all push or pop instructions and all subroutine calls and returns. In theory, the stack in the 8051 may be up to a full 128 bytes deep. (In practice, even simple programs would use a handful of RAM locations for pointers, variables, and so forth—reducing the stack depth by that number.) The stack pointer defaults to 7 on reset, so that the stack will start growing up from location 8, just like in the 8048. By altering the pointer contents the stack may be relocated anywhere within internal RAM.

Finally, a 16-bit register called the data pointer (DPTR) serves as a base register in indirect jumps, table look-up instructions, and external data transfers. The high- and low-order halves of the data pointer may be manipulated as separate registers (DPH and DPL, respectively) or together using special instructions to load or increment all sixteen bits. Unlike the 8048, look-up tables can therefore start anywhere in program memory and be of arbitrary length.



#### Memory Spaces

Program memory is separate and distinct from data memory. Each memory type has a different addressing mechanism, different control signals, and a different function.

The program memory array (ROM or EPROM), like an elephant, is extremely large and never forgets information, even when power is removed. Program memory is used for information needed each time power is applied: initialization values, calibration constants, keyboard layout tables, etc., as well as the program itself. The program memory has a sixteen-bit address bus; its elements are addressed using the Program Counter or instructions which generate a sixteen-bit address.

To stretch our analogy just a bit, data memory is like a mouse: it is smaller and therefore quicker than program memory, and it goes into a random state when electrical power is applied. On-chip data RAM is used for variables which are determined or may change while the program is running.

A computer spends most of its time manipulating variables, not constants, and a relatively small number of variables at that. Since eight-bits is more than sufficient to uniquely address 128 RAM locations, the on-chip RAM address register is only one byte wide. In contrast to the program memory, data memory accesses need a single eight-bit value—a constant or another variable to specify a unique location. Since this is the basic width of the ALU and the different memory types, those resources can be used by the addressing mechanisms, contributing greatly to the computer's operating efficiency.

The partitioning of program and data memory is extended to off-chip memory expansion. Each may be added independently, and each uses the same address and data busses, but with different control signals. External program memory is gated onto the external data bus by the PSEN (Program Store Enable) control output, pin 29. External data memory is read onto the bus by the  $\overline{RD}$ output, pin 17, and written with data supplied from the microcomputer by the  $\overline{WR}$  output, pin 16. (There is no control pin to write external program ROM, which is by definition Read Only.) While both types may be expanded to up to 64K bytes, the external data memory may optionally be expanded in 256 byte "pages" to preserve the use of P2 as an I/O port. This is useful with a relatively small expansion RAM (such as the Intel® 8155) or for addressing external peripherals.

Single-chip controller programs are finalized during the project design cycle, and are not modified after production. Intel's single-chip microcomputers are not "von Neumann" architectures common among main-frame and mini-computer systems: the MCS-51<sup>TH</sup> processor *data* memory—on-chip and external—may *not* be used for program code. Just as there is no write-control signal for program memory, there is no way for the CPU to execute instructions out of RAM. In return, this concession allows an architecture optimized for efficient controller applications: a large, fixed program located in ROM, a hundred or so variables in RAM, and different methods for efficiently addressing each.

(Von Neumann machines are helpful for software development and debug. An 8051 system could be modified to have a single off-chip memory space by gating together the two memory-read controls ( $\overrightarrow{PSEN}$  and  $\overrightarrow{RD}$ ) with a two-input AND gate (Figure 5). The CPU could then write data into the common memory array using  $\overrightarrow{WR}$  and AFN-01502A-11



#### Figure 5. Combining External Program and Data Memory Arrays

external data transfer instructions, and read instructions or data with the AND gate output and data transfer or program memory look-up instructions.)

In addition to the memory arrays, there is (yet) another (albeit sparsely populated) physical address space. Connected to the internal data bus are a score of specialpurpose eight-bit registers scattered throughout the chip. Some of these—B, SP, PSW, DPH, and DPL—have been discussed above. Others—I/O ports and peripheral function registers—will be introduced in the following sections. Collectively, these registers are designated as the "special-function register" address space. Even the accumulator is assigned a spot in the special-function register address space for additional flexibility and uniformity.

Thus, the MCS-51<sup>™</sup> architecture supports several distinct "physical" address spaces, functionally separated at the hardware level by different addressing mechanisms, read and write control signals, or both:

- On-chip program memory;
- On-chip data memory;
- Off-chip program memory;
- Off-chip data memory;
- On-chip special-function registers.

What the *programmer sees*, though, are "logical" address spaces. For example, as far as the programmer is concerned, there is only one type of program memory, 64K bytes in length. The fact that it is formed by combining on- and off-chip arrays (split 4K/60K on the 8051 and 8751) is "invisible" to the programmer; the CPU automatically fetches each byte from the appropriate array, based on its address.

(Presumably, future microcomputers based on the MCS-51<sup>™</sup> architecture may have a different physical split, with more or less of the 64K total implemented on-chip. Using the MCS-48<sup>™</sup> family as a precedent, the 8048's 4K potential program address space was split 1K/3K between on- and off-chip arrays; the 8049's was split 2K/2K.)

Why go into such tedious details about address spaces? The logical addressing modes are described in the Instruction Set chapter in terms of physical address spaces. Understanding their differences now will pay off in understanding and using the chips later.



#### Input/Output Ports

The MCS-51<sup>TM</sup> I/O port structure is extremely versatile. The 8051 and 8751 each have 32 I/O pins configured as four eight-bit parallel ports (P0, P1, P2, and P3). Each pin will input or output data (or both) under software control, and each may be referenced by a wide repertoire of byte and bit operations.

In various operating or expansion modes, some of these I/O pins are also used for special input or output functions. Instructions which access external memory use Port 0 as a multiplexed address/data bus: at the beginning of an external memory cycle eight bits of the address are output on P0; later data is transferred on the same eight pins. External data transfer instructions which supply a sixteen-bit address, and any instruction accessing external program memory, output the high-order eight bits on P2 during the access cycle. (The 8031 *always* uses the pins of P0 and P2 for external addressing, but P1 and P3 are available for standard I/O.)

The eight pins of Port 3 (P3) each have a special function. Two external interrupts, two counter inputs, two serial data lines, and two timing control strobes use pins of P3 as described in Figure 6. Port 3 pins corresponding to functions not used are available for conventional 1/O.

Even within a single port, I/O functions may be combined in many ways: input and output may be performed using different pins at the same time, or the same pins at different times; in parallel in some cases, and in serial in others; as test pins, or (in the case of Port 3) as additional special functions.

| (MSB) |       |        |                |                                    |         | (LSB)    |                      |        |          |                                                                                     |
|-------|-------|--------|----------------|------------------------------------|---------|----------|----------------------|--------|----------|-------------------------------------------------------------------------------------|
| RD    | WR    | T1     | TO IN          | T1 INTO                            | TXD     | RXD      |                      |        | ,        |                                                                                     |
| Symb  | ol Po | sition | Name           | and Sig                            | nifica  | nce      |                      | Symbol | Position | Name and Significance                                                               |
| RD    | P3.   | .7     | pulse g        | lata con<br>generateo<br>al data r | l by ha | rdware   |                      | INTI   | P3.3     | Interrupt 1 input pin. Low-level or falling-edge triggered.                         |
| WR    | P3.   | .6     |                | data con<br>generated              |         |          | Active low<br>e when | INT0   | P3.2     | Interrupt 0 input pin. Low-level or falling-edge triggered.                         |
|       |       |        |                | al data r                          |         |          |                      | TXD    | P3.1     | Transmit Data pin for serial port in<br>UART mode. Clock output in shift            |
| TI    | P3.   | .5     | Timer/<br>pin. | counter                            | l exte  | rnal inj | put or test          |        | · .      | register mode.                                                                      |
| Т0    | P3.   | .4     | •              | counter                            | 0 exte  | rnal inj | put or test          | RXD    | P3.0     | Receive Data pin for serial port in UART mode. Data I/O pin in shift register mode. |





#### **Special Peripheral Functions**

There are a few special needs common among controloriented computer systems:

- keeping track of elapsed real-time;
- maintaining a count of signal transitions;
- measuring the precise width of input pulses;
- communicating with other systems or people;
- closely monitoring asynchronous external events.

Until now, microprocessor systems needed peripheral chips such as timer/counters, USARTs, or interrupt controllers to meet these needs. The 8051 integrates all of these capabilities on-chip!

#### Timer/Counters

There are two sixteen-bit multiple-mode Timer/Counters on the 8051, each consisting of a "High" byte (corresponding to the 8048 "T" register) and a low byte (similar to the 8048 prescaler, with the additional flexibility of being software-accessible). These registers are called, naturally enough, TH0, TL0, TH1, and TL1. Each pair may be independently software programmed to any of a dozen modes with a mode register designated TMOD (Figure 7), and controlled with register TCON (Figure 8).

The timer modes can be used to measure time intervals, determine pulse widths, or initiate events, with one-microsecond resolution, up to a maximum interval of 65,536 instruction cycles (over 65 milliseconds). Longer delays may easily be accumulated through software. Configured as a counter, the same hardware will accumulate external events at frequencies from D.C. to 500 KHz, with up to sixteen bits of precision.

#### Serial Port Interface

Each microcomputer contains a high-speed, full-duplex, serial port which is software programmable to function in four basic modes: shift-register I/O expander, 8-bit UART, 9-bit UART, or interprocessor communications link. The UART modes will interface with standard I/O devices (e.g. CRTs, teletypewriters, or modems) at data rates from 122 baud to 31 kilobaud. Replacing the standard 12 MHz crystal with a 10.7 MHz crystal allows 110 baud. Even or odd parity (if desired) can be included with simple bit-handling software routines. Inter-processor communications in distributed systems takes place at 187 kilobaud with hardware for automatic address/data message recognition. Simple TTL or CMOS shift registers provide low-cost I/O expansion at a super-fast 1 Megabaud. The serial port operating modes are controlled by the contents of register SCON (Figure 9).

#### Interrupt Capability and Control

(Interrupt capability is generally considered a CPU function. It is being introduced here since, from an applications point of view, interrupts relate more closely to peripheral and system interfacing.)

| MSB)  |                            |                                                        |                          |                             | (LSB)                    | M1 | MO | Operating               | Mode                                                                                         |
|-------|----------------------------|--------------------------------------------------------|--------------------------|-----------------------------|--------------------------|----|----|-------------------------|----------------------------------------------------------------------------------------------|
| TIMER | M1 M0                      | GATE                                                   | C/T                      | M1                          | MO                       | 0  | 0  | MCS-48 T<br>bit prescal | imer. "TLx" serves as five-<br>er.                                                           |
|       |                            |                                                        |                          |                             |                          | 0  | 1  |                         | r/counter. "THx" and "TLx"<br>ed; there is no prescaler.                                     |
| GATE  | Cotin                      |                                                        | 1 11/6                   |                             | Time                     | 1  | 0  | holds a va              | reload timer/counter. "THx"<br>lue which is to be reloaded<br>' each time it overflows.      |
| GALE  | "x" is<br>high a<br>cleare | g contro<br>enabled<br>and "TR<br>d, time<br>ever "The | i ònly<br>x" co<br>r/cou | while<br>ntrol l<br>nter is | "INT<br>oit is s<br>enab | is | 1. | (Timer 0)               | TL0 is an eight-bit timer/<br>counter controlled by the<br>standard Timer 0 control<br>bits. |
| C/T   | Time:<br>syster            | or Cou<br>operat<br>n clock)                           | ion (in<br>. Set i       | nput f<br>for Co            | rom in<br>ounter         |    |    |                         | TH0 is an eight-bit timer<br>only controlled by Timer 1<br>control bits.                     |
|       | tion (                     | input fr                                               | om                       | x inj                       | put pi                   | t  | 1  | (Timer 1)               | Timer/counter 1 stopped.                                                                     |

,

Figure 7. TMOD—Timer/Counter Mode Register

| (MSB) |       |        |      |        |        |          | (LSB)  | 1                             |        |          |                                                                                 |
|-------|-------|--------|------|--------|--------|----------|--------|-------------------------------|--------|----------|---------------------------------------------------------------------------------|
| TF1   | TR1   | TFO    | TRO  | IE1    | IT1    | IE0      | ITO    |                               |        |          |                                                                                 |
|       |       |        |      |        |        |          |        |                               | Symbol | Position | Name and Significance                                                           |
| Symbo | ol Pa | sition | Na   | me ar  | nd Sig | nifica   | ince   |                               | IEI    | TCON.3   | Interrupt I Edge flag. Set by hardware                                          |
| F1    | тс    | CON.7  | on   | timer/ |        | er ove   | rflow. | by hardware<br>Cleared        |        |          | when external interrupt edge detected.<br>Cleared when interrupt processed.     |
|       |       |        |      |        |        | <b>F</b> |        |                               | ITI    | TCON.2   | Interrupt 1 Type control bit. Set/cleared                                       |
| [R]   | тс    | CON.6  | by s |        |        |          |        | et/cleared<br>ounter          |        |          | by software to specify falling edge/low<br>level triggered external interrupts. |
|       |       |        |      |        |        |          |        |                               | IE0    | TCON.1   | Interrupt 0 Edge flag. Set by hardware                                          |
| rf0   | т     | CON.5  | on   | timer/ |        | er ove   | rflow. | by hardware<br>Cleared        |        |          | when external interrupt edge detected.<br>Cleared when interrupt processed.     |
|       |       |        |      |        | •      | •        |        | 4                             | IT0    | TCON.0   | Interrupt 0 Type control bit. Set/cleared                                       |
| rro   | тс    | CON.4  |      |        |        |          |        | et/cleared by<br>iter on/off. |        |          | by software to specify falling edge/low level triggered external interrupts.    |

Figure 8. TCON—Timer/Counter Control/Status Register

| (MSB) |       |        |     |                   |       |        |       | (LSI            | B)   |      |       |     |        |          |                                                                                      |
|-------|-------|--------|-----|-------------------|-------|--------|-------|-----------------|------|------|-------|-----|--------|----------|--------------------------------------------------------------------------------------|
| SMO   | SM1   | SM2    | REN | TB8               | R     | 98     | ті    | R               | -    |      |       |     |        |          |                                                                                      |
| Symbo | ol Po | sition | Na  | me a              | nd S  | Sigr   | ifica | ince            | 2    |      |       |     | Symbol | Position | Name and Significance                                                                |
| SM0   | SC    | CON.7  |     | rial po<br>/clear |       |        |       |                 |      |      |       |     | R B8   | SCON.2   | Receive Bit 8. Set/cleared by hardware to indicate state of ninth data bit received. |
| SMI   | SC    | CON.6  | Ser | ial po            | ort N | 1od    | e cor | ntrol           | l bi | t 1  |       |     |        |          |                                                                                      |
|       |       |        | Set | /clear            | ed l  | oy so  | oftwa | are (           | see  | e no | ote). |     | TI     | SCON.1   | Transmit Interrupt flag. Set by hard-<br>ware when byte transmitted. Cleared         |
| SM2   | so    | CON.5  |     | ial po<br>tware   |       |        |       |                 |      |      |       |     |        |          | by software after servicing.                                                         |
|       |       |        | for | whicl             | h bit | : 8 is | zero  | э. <sup>•</sup> |      |      |       |     | RI     | SCON.0   | Received Interrupt flag. Set by hard-<br>ware when byte received. Cleared by         |
| REN   | so    | CON.4  |     | ceiver<br>softwa  |       |        |       |                 |      |      |       |     |        |          | software after servicing.                                                            |
|       |       |        |     | a rece            |       |        |       | ,               |      |      |       |     |        | Note     | the state of (SM0,SM1) selects:                                                      |
|       |       |        |     |                   | -     |        |       |                 |      |      |       |     |        |          | (0,0)—Shift register I/O expansion.                                                  |
| ГВ8   | SC    | CON.3  |     | insmit            |       |        |       |                 |      |      |       |     |        |          | (0,1)-8 bit UART, variable data rate.                                                |
|       |       |        |     | re to c           |       |        |       |                 |      |      |       |     |        |          | (1,0)-9 bit UART, fixed data rate.                                                   |
|       |       |        | bit | transi            | mitt  | ed i   | 1 9-b | it U            | AF   | RT   | mod   | le. |        |          | (1,1)-9 bit UART, variable data rate.                                                |

#### Figure 9. SCON—Serial Port Control/Status Register

These peripheral functions allow special hardware to monitor real-time signal interfacing without bothering the CPU. For example, imagine serial data is arriving from one CRT while being transmitted to another, and one timer/counter is tallying high-speed input transitions while the other measures input pulse widths. During all of this the CPU is thinking about something else.

But how does the CPU know when a reception, transmission, count, or pulse is finished? The 8051 programmer can choose from three approaches.

TCON and SCON contain status bits set by the hardware when a timer overflows or a serial port operation is completed. The first technique reads the control register into the accumulator, tests the appropriate bit, and does a conditional branch based on the result. This "polling" scheme (typically a three-instruction sequence though additional instructions to save and restore the accumulator may sometimes be needed) will surely be familiar to programmers used to multi-chip microcomputer systems and peripheral controller chips. This process is rather cumbersome, especially when monitoring multiple peripherals.

As a second approach, the 8051 can perform a conditional branch based on the state of any control or status bit or input pin in a single instruction; a four instruction sequence could poll the four simultaneous happenings mentioned above in just eight microseconds.

Unfortunately, the CPU must still drop what it's doing to test these bits. A manager cannot do his own work well if he is continuously monitoring his subordinates; they should interrupt him (or her) only when they need attention or guidance. So it is with machines: ideally, the CPU would not have to worry about the peripherals until they require servicing. At that time, it would postpone the background task long enough to handle the appropriate device, then return to the point where it left off.

This is the basis of the third and generally optimal solution, hardware interrupts. The 8051 has five interrupt sources: one from the serial port when a transmission or reception is complete; two from the timers when overflows occur, and two from input pins INT0 and INT1. Each source may be independently enabled or disabled to allow polling on some sources or at some times, and each may be classified as high or low priority. A high priority source can interrupt a low priority service routine; the manager's boss can interrupt conferences with subordinates. These options are selected by the interrupt enable and priority control registers, IE and IP (Figures 10 and 11).

Each source has a particular program memory address associated with it (Table 3), starting at 0003H (as in the 8048) and continuing at eight-byte intervals. When an event enabled for interrupts occurs the CPU automatically executes an internal subroutine call to the corresponding address. A user subroutine starting at this location (or jumped to from this location) then performs the instructions to service that particular source. After completing the interrupt service routine, execution returns to the background program.

#### Table 3. 8051 Interrupt Sources and Service Vectors

| Interrupt<br>Source | Service Routine<br>Starting Address |
|---------------------|-------------------------------------|
| (Reset)             | 0000H                               |
| External 0          | 0003H                               |
| Timer/Counter 0     | 000BH                               |
| External 1          | 0013H                               |
| Timer/Counter 1     | 001BH                               |
| Serial Port         | 0023H                               |

| (MSB)<br>EA | -   -        | (LSB)<br>ES ET1 EX1 ET0 EX0                                                                                      |        |          |                                                                                                                 |
|-------------|--------------|------------------------------------------------------------------------------------------------------------------|--------|----------|-----------------------------------------------------------------------------------------------------------------|
| Symbol      | Position     | Name and Significance                                                                                            | Symbol | Position | Name and Significance                                                                                           |
| EA          | IE.7         | Enable All control bit. Cleared by software to disable all interrupts, independent of the state of IE.4-IE.0.    | EXI    | IE.2     | Enable External interrupt 1 control bit.<br>Set/cleared by software to enable/<br>disable interrupts from INT1. |
|             | IE.6<br>IE.5 | (reserved)<br>(reserved)                                                                                         | ET0    | IE.1     | Enable Timer 0 control bit. Set/cleared<br>by software to enable/disable interrupts<br>from timer/counter 0     |
| ES          | IE.4         | Enable Serial port control bit.<br>Set/cleared by software to enable/<br>disable interrupts from TI or RI flags. | EX0    | IE.0     | Enable External interrupt 0 control bit.<br>Set/cleared by software to enable/<br>disable interrupts from INT0. |
| ETI         | IE.3         | Enable Timer 1 control bit. Set/cleared<br>by software to enable/disable interrupts<br>from timer/counter 1.     |        |          |                                                                                                                 |

# Figure 10. IE—Interrupt Enable Register

| (MSB)<br> | -   -    | (LSB)<br>PS PT1 PX1 PT0 PX0                                                                                                 |        |          |                                                                                                                             |
|-----------|----------|-----------------------------------------------------------------------------------------------------------------------------|--------|----------|-----------------------------------------------------------------------------------------------------------------------------|
| Symbol    | Position | Name and Significance                                                                                                       | Symbol | Position | Name and Significance                                                                                                       |
|           | IP.7     | (reserved)                                                                                                                  | PX1    | IP.2     | External interrupt 1 Priority control                                                                                       |
|           | IP.6     | (reserved)                                                                                                                  |        |          | bit. Set/cleared by software to specify                                                                                     |
| <u>`</u>  | IP.5     | (reserved)                                                                                                                  |        |          | high/low priority interrupts for INT1.                                                                                      |
| PS        | IP.4     | Serial port Priority control bit.<br>Set/cleared by software to specify<br>high/low priority interrupts for Serial<br>port. | РТ0    | IP.I     | Timer 0 Priority control bit.<br>Set/cleared by software to specify<br>high/low priority interrupts for<br>timer/counter 0. |
| PT1       | IP.3     | Timer 1 Priority control bit.<br>Set/cleared by software to specify<br>high/low priority interrupts for<br>timer/counter 1. | PX0    | IP.0     | External interrupt 0 Priority control<br>bit. Set/cleared by software to specify<br>high/low priority interrupts for INTO.  |

# Figure 11. IP-Interrupt Priority Control Register

#### Table 4. MCS-51<sup>™</sup> Instruction Set Description

| ADDC A.direct       Add direct byte to A with Carry flag       2       1       MOVX @DPTR.A.       Move A to External         ADDC A.#data       Add indirect RM to A with Carry flag       1       PUSH       Arm       External       Add interct byte from A with Borrow       1       YCH       Arm       Exchange direct byte from A with Borrow       1       XCH       A.direct       Pop direct byte from A with Borrow       1       XCH       A.direct       Exchange direct byte       2       Arm       Exchange direct byte       1       XCH       A.direct       Exchange direct byte       1       1       XCH       A.direct       MithPiLATION         INC       Aret       Increment direct BAM       1       1       SETB       Note A to Starry flag       1       4       CPL       C       Cerry flag       Cerry flag       Cerry flag       Cerry flag       ANL       A.direct       Mith Addirect BAM       1       SETB       Set flag       Cery flag       Cery flag       Cery flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                   | _                |                                                                    |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|------------------|--------------------------------------------------------------------|
| ADD       A. Adveret       Add trest pict o Accumulator       1       Image: Constraint of the constraint o                   | -                                 | Rute             | Cyc                                                                |
| ADD       A.direct       Add direct byte to Accumulator       2       1       MOVC       A.@PR       Move Code byte rel         ADD       A.@Ri       Add indirect RAM to Accumulator       1       MOVX       A.@PR       Move External RA         ADDC       A.m       Add insect byte to A with Carry flag       2       1       MOVX       @OPTR.A       Move A to External         ADDC       A.met       Add insect byte to A with Carry flag       2       1       MOVX       @OPTR.A       Move A to External         ADDC       A.feata       Add insect byte to A with Borrow       1       XCH       A.direct       Exchange register w         SUBB       A.@Ri       Subtract inseries data to A with Carrow       1       XCH       A.direct       Exchange inseries         INC       R       Increment Accumulator       1       1       BOOLEAN VARIABLE MANIPULATION         INC       A       Increment accumulator       1       1       CLR       Sternal RA         INC       A       Increment accumulator       1       1       Sternal RA       Move A to External RA         INC       A       Increment accumulator       1       1       XCH       A.direct       Achaeta       Achaeta       Achaeta                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                   | Byte             |                                                                    |
| ADD       A.@Ri       Add indirect RAM to Accumulator       1       MOVX       A.@DT       Move External RA         ADDC       A.Rin       Add immediate data to Accumulator       1       MOVX       A@DT       Move External RA         ADDC       A.Rinet       Add intercity ico A with Carry flag       1       MOVX       @Ri.A       Move A to External         ADDC       A.dteret       Add intercity ico A with Carry flag       1       POP       direct       Pop direct by ico A ito External         ADDC       A.dteret       Subfract indirect BAM from A with Borrow       2       XCH       A.deret       Exchange indirect by ico A ito External         SUBB       A.drect       Subtract indirect RAM from A w Borrow       1       XCH       A.deret       Exchange indirect by ico A ito A ito A with Carry flag       1       BOOLEAN VARIABLE MANIPULATION         INC       @Ri       Increment Accumulator       1       1       CLR       C       Clear Carry flag         DEC       An Decrement accumulator       1       1       CLR       C       Clear Carry flag         DEC       GRi       Decrement accumulator       1       1       CLR       C C ito Correption         DEC       GRi       Decrement accumulator       1       1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                   | - 1              | 2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2 |
| ADD       A.#data       Add immediate data to Accumulator       2       1       MOVX       A.@DPT       Move External RAI         ADDC       A.direct       Add direct byte to A with Carry flag       1       MOVX       @DPTR.A.       Move A to External         ADDC       A.@Ri       Add indirect RAW to A with Carry flag       1       PUSH       MoVX       @DPTR.A.       Move A to External         ADDC       A.@Ri       Subtract register form A with Parrow       2       1       PUSH       Addrect       Push direct byte form         SUBB       A.@Rit       Subtract indirect Brance       Raineet       Exchange direct byte       Push       Addrect       Exchange direct byte       Stange direct byte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                   |                  | 4                                                                  |
| ADDC       And       Add register to Accumulator with Carry flag       1       MOVX       @R1.A       Move A to External         ADDC       A.@R1       Add inmediate for A with Carry flag       1       PUSH       direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push direct       Push dir                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | al RAM (8-bit addr) to A          |                  | 2                                                                  |
| ADDC       Adjeret       Add direct byte to A with Carry flag       1       MÖVX       ÖDPTR.A.       Möve Å to External         ADDC       A.gdata       Add indirect RAM to A with Carry flag       1       PUSH       direct       Pop direct       Por direct       Pop direct <td></td> <td>1</td> <td>2</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                   | 1                | 2                                                                  |
| ADDC       A@Rita       Add immediate data to A with Carry flag       1       PUSH       direct       Direct byte form         SUBB       A.Rin       Subtract direct byte from A with Borrow       1       XCH       A.A.       Exchange register         SUBB       A.Girect       Subtract direct byte from A with Borrow       1       XCH       A.direct       Exchange indirect       Byte         SUBB       A.@Ri       Subtract indirect RAM from A w Borrow       1       XCH       A.direct       Exchange indirect       BoolEaN VARIABLE MANIPULATION         INC       An       Increment Accumulator       1       CLR       C Cear Carry flag         DEC       An       Decrement register       1       1       CLR       C Cear Carry flag         DEC       Girect       Decrement register       1       1       CLR       C Cear Carry flag         DEC       Girect       Decrement register       1       1       CLR       C Cear Carry flag         DEC       Girect       Decrement register       1       1       SETB       bit       Set flarect bit       Complement Carry         MUL       AB       Multiply A & B       1       4       ANL       CPL       Complement Carry       Complement Carry                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | xternal RAM (8-bit addr)          | 1                | 2                                                                  |
| ADDC       Adda       Adda       Adda       Memory       2       1       POP       durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pop durect       Pup durect       Pop durect       Pup dure       Pup dure <t< td=""><td>xternal RAM (16-bit addr)</td><td>1</td><td>2</td></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | xternal RAM (16-bit addr)         | 1                | 2                                                                  |
| ADDC       Addia       Addiance data to A with Carty flag       2       1       POP       direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Pop direct       Exchange direct by to the set of the                                                                                                                                                                                                                                                                                                                                                                          | ovte onto stack                   | 2                | 2                                                                  |
| SUBB A.Rn       Subtract arc register from A with Borrow       1       1       XCH       A.Rn       Exchange register         SUBB A.@Ri       Subtract indirect RAM from A w Borrow       1       XCH       A.@Ri       Exchange indirect Brite         SUBB A.@Ri       Subtract indirect RAM from A w Borrow       1       XCH       A.@Ri       Exchange indirect Brite         INC       An       Increment accumulator       1       Increment accumulator       1         INC       An       Increment direct brite       2       Increment accumulator       1       CLR       C       Clear direct brite       2         DEC       An       Decrement direct brite       2       1       SETB       Dit       Cel ard direct brite         DEC       @Rite       Decrement indirect brite       1       2       CFL       C       Complement Carry flag         DEC       @Rite       Decrement indirect brite       1       4       ANL       C.bit       AND direct brite       2       CFL       C       Complement Carry flag         DEC       @Rite       Decrement indirect brite       1       4       ANL       C.bit       AND direct brite       0       0       0       0       0       0       0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | te from stack                     | 2                | 2                                                                  |
| SUBB A.direct       Subtract infrect RAM from A with Borrow       2       1       XCH A.@Ri       Exchange indrect R         SUBB A.#data       Subtract infrect RAM from A with Borrow       1       1       XCH A.@Ri       Exchange indrect R         SUBB A.#data       Subtract infrect RAM from A with Borrow       2       1       XCH A.@Ri       Exchange indrect R         INC A       Increment register       1       1       BOOLEAN VARIABLE MANIPULATION         INC @Ri       Increment indirect NAM       1       1       Minemonic       Description         DEC A       Decrement indirect NAM       1       1       Clar Carr flag       Clar Carr flag         DEC direct       Decrement indirect NAM       1       1       CLR C       Carr flag         DEC direct       Decrement indirect NAM       1       2       CPL bit       Cerr flag         DEC direct       Decrement indirect NAM       1       4       CPL bit       Complement Garci         DIV AB       Durde A by B       1       4       ANL C, bit       AND direct bit to Carr         DAA       Decimal Adjust Accumulator       1       1       ANL C, bit       AND direct bit to Carr         ANL       A.Greet       AND direct tyle to Accumulator       1 <td></td> <td>1</td> <td>1</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                   | 1                | 1                                                                  |
| SUBB A.@Ri       Subtract indirect RAM from A w Borrow       1       XCH A.@Ri       Exchange indirect R         SUBB A.@Ri       Subtract indirect data from A w Borrow       1       1         INC A       Increment Accumulator       1       1         INC Grient Increment direct byte       2       1       XCH A.@Ri       Exchange indirect R         INC @Ri       Increment direct RAM       1       1       CLR       Clar Carry Iag         DEC A       Decrement direct byte       2       1       SETB       Decrement Carry Iag         DEC direct       Decrement direct byte       2       1       SETB       Carry Iag       Complement Carry         NUL AB       Muliphy A & B       1       4       ANL       Cobit       AND complement Carry         NUL AB       Dirde A by B       1       4       ANL       Cobit       AND complement Carry         NUL AB       Dirde A by B       1       4       ANL       Cobit       AND complement Carry         NUL AGR       AND register to Accumulator       1       1       ANL       Cobit       AND complement Orector         ANL       Adrect       AND direct byte to Accumulator       1       1       1         ANL Adreat       <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | rect byte with Accumulator        | 2                | i                                                                  |
| SUBB       A.#data       Subtract mmed data from A w Borrow       2       1       XCHD       A.@Ri       Exchange low-order         INC       Amorement register       1       1       BODLEAN VARIABLE MANIPULATION       1         INC       @Ri       Increment register       1       1       BODLEAN VARIABLE MANIPULATION         DEC       A       Decrement register       1       1       CLR       Clar Carry lag         DEC       An       Decrement register       1       1       CLR       Clar direct bit       Sci direct bit         DEC       @incet       Decrement indirect byte       2       1       SET       Bot       Complement direct direct bit         DEC       @incet       Decrement indirect byte       2       1       SET       Bot       Complement direct direct bit       Complement direct direct direct direct bit       Complement direct direct direct direct bit       Complement direct dire                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                   | ĩ                | i                                                                  |
| INC     A     Increment Accumulator     I       INC     BOOLEAN VARIABLE MANIPULATION     I       INC     Greet     Increment direct byte     2       INC     Greet     Increment direct byte     2       DEC     A     Decrement egister     1     I       DEC     A     Decrement egister     1     I       DEC     Greet     Decrement direct byte     2     1       SEE     B     I     4     CLR     C       DEC     Greet     Decrement direct byte     2     1     SETB     Dit       DEC     Greet     Decrement direct byte     2     1     SETB     Dit     Clear Garry flag       DEC     Greet     Decrement direct byte     1     4     CLL     No     Complement Garry       NUL     AB     Divide A by B     1     4     ANL     C.bit     AND don't bit to Ca       DA     Decimal Adjust Accumulator     1     1     ANL     C.bit     OR direct bit to Ca       ANL     A.drect     AND egister to Accumulator     1     1     ANL     A.drect AND odirect byte       ANL     A.drect     AND indirect AMA to Accumulator     1     1     Antern form subrou       ANL <td></td> <td>i</td> <td>i</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                   | i                | i                                                                  |
| INC       Rn       Increment register       1       BOOLEAN VARIABLE MANIPULATION         INC       @Rt       Increment indirect byte       2       1         INC       @Rt       Increment indirect byte       2       1         DEC       A       Decrement accumulator       1       1       CLR       C       Clear Carry flag         DEC       direct       Decrement indirect RAM       1       1       SETB       bit       Clear direct bit         DEC       @rect but       Decrement indirect Byte       2       ISETB       bit       Set direct bit         DEC       @rect but       Decrement indirect Byte       1       4       CPL       C       Complement Garry flag         MUL       AB       Multiply A & B       1       4       ANL       C.bit       AND direct bit to C         DA       Decimal Adjust Accumulator       1       1       ANL       C.bit       OR complement of MOV       ORL       C.bit       OR complement of MOV       ORL       C.bit       Move Carry flag       OR       ANL       Actrest to Accumulator       1       ANL       Actrest to Accumulator       1       ANL       Actrest to Accumulator       1       ANL       Actrest to Accumulator <td< td=""><td>v-order Digit ind KAIW w/A</td><td></td><td></td></td<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | v-order Digit ind KAIW w/A        |                  |                                                                    |
| INC     direct     Increment direct byte     2     1       INC     @Ri     Increment direct RAM     1     1     CLR     C     Clear Carry flag       DEC     An     Decrement register     1     1     CLR     bt     Clear direct bit       DEC     Becrement direct Byte     2     1     SETB     bt     Clear Carry flag       DEC     Becrement direct RAM     1     1     SETB     bt     Set Carry flag       INC     DPTR     Increment Data Pointer     1     2     CPL     C     Complement Carry       MUL     AB     Multiply Ag     1     4     ANL     C.bit     AND direct bit to C       DA     Decimal Adjust Accumulator     1     1     ANL     C.bit     OR direct bit to Carry       AA     Decimal Adjust Accumulator     1     1     ANL     C.bit     OR direct bit to Carry       ANL     A.Greet     ND direct byte to Accumulator     1     1     Immonic     Description       ANL     A.Greet     AND direct byte to Accumulator     1     1     Immonic     Description       ANL     A.Greet     A AND direct byte     2     1     CALL     addr1     Abobute Subrounce       ANL     Areet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ION                               |                  |                                                                    |
| INC       @Ri       Increment indirect RAM       1       1       Mmemoric       Description         DEC       A       Decrement accumulator       1       1       CLR       C       Clear Carry flag         DEC       Arrect       Decrement indirect RAM       1       1       SETB       Set Garry flag         DEC       @Ri       Decrement indirect RAM       1       1       SETB       Set Garry flag         DEC       @Ri       Decrement indirect RAM       1       1       SETB       Set Garry flag         INC       DPTR       Increment Data Ponter       1       2       CPL       C       Complement Garry flag         MUL       AB       Multiply A & B       1       4       ANL       C.bit       AND complement direct         DIV       AB       Devide A by B       1       4       ANL       C.bit       OR complement of         DIV       AB       Devide A by B       1       4       ANL       C.bit       OR complement of         ORL       C.Cont       OR complement of       ORL       C.bit       OR complement of         All creation       A.freation       AND imeed to a comunitor       1       Imeet bit Complement of       ORL <td>IUN</td> <td></td> <td></td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | IUN                               |                  |                                                                    |
| DEC       A.N.       Decrement Accumulator       I       CLR       C       Clear Carry flag         DEC       Becrement direct byte       2       1       SETB       but       Clear direct but         DEC       Becrement direct byte       2       1       SETB       but       Clear direct but         DEC       Becrement indirect RAM       1       1       2       CPL       C       Complement Garry flag         NUL       AB       Multiply A & B       1       4       CPL       C       Complement direct         DIV       AB       Duvide A by B       1       4       ANL       C, but       AND complement direct         DA       Decimal Adjust Accumulator       1       1       ANL       C, but       OR complement of         ANL       A.Remonic       Destination       Byte Cyc       Move Carry flag       ORL       C, but       OR complement of         ANL       A.Greet       AND direct RAM to Accumulator       1       1       Acrest May Carry flag       ORL       C, but       OR complement of       ORL       C, but       OR complement of       ORL       C, but       OR complement of       ORL       C, but       Move Carry flag       ORL       Acrest Adata                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                   | Buto             | Cyc                                                                |
| DEC       Rn       Decrement register       1       1       CLR       bit       Clear direct bit         DEC       @Ri       Decrement indirect RAM       1       1       SETB       Dit       Set direct Bit         DEC       @Ri       Decrement indirect RAM       1       1       SETB       Dit       Set direct Bit         MUL       AB       Multiply A & B       1       4       CPL       Dit       Complement Carry         MUL       AB       Divide A by B       1       4       CPL       Dit       AND direct bit to Carry flag         DA       Decimal Adjust Accumulator       1       1       ANL       C, bit       AND direct bit to Carry flag         LOGICAL OPERATIONS       Breaster       Memonic       Destination       Breaster       Move Carry flag       ORL       C, bit       ORve Carry flag       ORL       ANL       A.Garta       AND pregister to Accumulator       1       1       ACALL addr1       Absolute Subroutin Carry         ANL       A.GRL       AND indirect Paste       Accumulator       1       I       ACALL addr1       Absolute Subroutin Carry         ANL       A.GRL       Addret AND Accumulator       1       I       ACALL addr1       Absolute Subrout                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | flag                              | Dyte             | cre                                                                |
| DEC       Order       Decrement drect byte       2       1       SETB       C       Set Carry flag         INC       DPTR       Increment Data Pointer       1       2       CPL       C       Complement Gary         MUL       AB       Multiply A & B       1       2       CPL       C       Complement direct         DIV       AB       Divide A by B       1       4       ANL       C.bit       AND complement direct         DA       Decimal Adjust Accumulator       1       1       ANL       C.bit       OR direct bit to Car         LOGICAL OPERATIONS       ORL       C.bit       OR complement of       ORL       C.bit       OR complement of         ANL       A.direct       AND direct byte to Accumulator       1       I       More More       Move Carry flag to         ANL       A.direct       AND direct byte to Accumulator       1       I       More More       Description         ANL       A.direct       AND complement of otect byte       2       I       ACALL addr11       Absolute Subrotume         All       A.direct       AND direct BAM to Accumulator       1       I       Return from subrotum         ORL       A.direct       AGR       OR indirect BA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                   | ÷                | ł                                                                  |
| DEC       OR       Decrement indirect RAM       i       SET B       but       Set direct Bit         INC       DPTR       Increment Data Pointer       1       2       CPL       C       Complement Carry         MUL       AB       Divide A by B       1       4       ANL       C.bit       AND direct bit to C         DV       AB       Divide A by B       1       4       ANL       C.bit       AND direct bit to Caronplement Carry         DA       Decimal Adjust Accumulator       1       1       ANL       C.bit       AND direct bit to Caronplement of Move Carry flag to         ANL       A.firect       AND indirect byte to Accumulator       1       1       Indirect Move Carry flag to         ANL       A.fieta       AND indirect RAM to Accumulator       1       1       PROGRAM AND MACHINE CONTROL         ANL       direct.#data       AND indirect RAM to Accumulator       1       1       RET       Return from subrou         AL       direct.#data       AND indirect RAM to Accumulator       1       RET       Return from subrou       Return from subrou         All       direct.#data       AND incert byte       2       1       ACALL addr11       Absolute Subroutine Ca         ORL       A,fieta                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                   | 2                |                                                                    |
| INC       DPTR       Increment Data Pointer       i       2       CPL       C       Complement Carry         MUL       AB       Multiply A & B       I       4       CPL       bit       Complement direct I         DV       AB       Divide A by B       I       4       ANL       C,bit       AND complement direct I         DA       A       Decimal Adjust Accumulator       I       I       ANL       C,bit       AND complement of ORL         LOGICAL OPERATIONS       Destination       Byte Cyc       MOV       C,bit       OR complement of ORL       C,bit       OR complement of ORL       C,bit       OR complement of ORL       ORL       C,bit       OR complement of ORL       ANL       A,direct       AND commulator       I       I       PROGRAM AND MACHINE CONTROL         ANL       A,direct       AND indirect RAM to Accumulator       I       I       Mnemonic       Description         ANL       direct,#data       AND immediate data to direct byte       3       2       L/CALL addr16       Acure from subrou         ORL       A,direct       OR register to Accumulator       1       1       AMP addr11       Absolute Jump       ORL       Cyc       Mort mole addired ta to acure byte       2       1 <td< td=""><td></td><td>1</td><td>!</td></td<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                   | 1                | !                                                                  |
| INC       DPTR       Increment Data Pointer       1       2       CPL       C       Complement Carry         MUL       AB       Multiply & & B       1       4       CPL       bit       Complement direct 1         DIV       AB       Divide A by B       1       4       ANL       C, bit       AND complement of and the complement and the complement and the complement and the complement and                                                                                                                                                                                                                                |                                   | 2                | 1                                                                  |
| MULABMultiply A & B1Complement direct bit to CDIVABDivide A by B14ANLC.bitAND direct bit to CDAADecimal Adjust Accumulator11ANLC.bitAND complement directLOGICAL OPERATIONSOR.LC.bitOR direct bit to CORLC.bitOR direct bit to CMnemonicDesinationByte CycMOVMove Carry flag toANLA.BrAND direst byte to Accumulator21PROGRAM AND MACHINE CONTROLANLA.GRiAND direst byte to Accumulator21MemonicDescriptionANLA.WataAND direst byte to Accumulator21ACALL addrllAbsolute SubroutinANLA.WataAND direst byte to Accumulator11ACALL addrllAbsolute SubroutinANLdirect.#dataAND mediate data to direct byte32LCALL addrllAbsolute SubroutinORLA.GirectOR indirect RAM to Accumulator11AlMP addrllAbsolute JumpORLA.@RiOR indirect RAM to Accumulator11JMPGdrlLong JumpORLA.GirectAccumulator to direct byte32JMPFelStott Jump if AccumulatorORLA.@RiOR indirect RAM to Accumulator1JMPGdrlJump if AccumulatorORLA.GirectAccumulator to direct byte32JMPGdrlJump if AccumulatorRLA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                   | 1                | 1                                                                  |
| DivABDivide A by B14ANLC, bitAND complement ofDAADecimal Adjust Accumulator11ANLC, bitAND complement ofLOGICAL OPERATIONSORLC, bitOR contenent ofORLC, bitOR direct bit to CaMnemonicDestinationByte CycMOVbit, CMove carry flag toANLA.GRIAND increts the to Accumulator11ANLA.GRIAND increts RAM to Accumulator11ANLA.GRIAND increts RAM to Accumulator11ANLA.RnAND increts RAM to Accumulator11ANLA.RnAND increts RAM to Accumulator11AccalL addr11ANLdirect, AdataAND inmediate data to direct byte21ACCALL addr16Long Subroutine CaORLA.GRIA.GRIAnd incret RAM to Accumulator11AIMP addr16Long JumpORLA.GRIOR indirect RAM to Accumulator11AJMP addr11Absolute Subroutine CaORLA.GRIOR indirect RAM to Accumulator11AJMP addr11Absolute JumpORLA.directOR indirect RAM to Accumulator11JNP indirect relationORLA.directOR interet BAY to Accumulator11JNP indirect relationORLA.directOR interet RAM to Accumulator11JNP indirect relationORLA.directOR interet BAY to Accumulato                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                   | 2                | 1                                                                  |
| DA       Decimal Adjust Accumulator       I       I       ANL       C. bit       AND complement of<br>ORL         LOGICAL OPERATIONS       Destination       Byte       Cyc       MOV       C. bit       OR complement of<br>ORL         Mnemonic       Destination       Byte Cyc       MOV       C. bit       OR complement of<br>ORL         ANL       A.Rn       AND register to Accumulator       1       I       Move direct bit to C         ANL       A.Girect       AND indirect RAM to Accumulator       1       I       Move direct bit to C         ANL       A.Girect       AND indirect RAM to Accumulator       1       I       Memonic       Description         ANL       direct.#data       AND indirect RAM to Accumulator       1       1       RET       Return from subrou         ORL       A.Rn       OR register to Accumulator       2       I       AALL addr11       Absolute Subroutin C         ORL       A.@Ri       OR interct Mut to Accumulator       2       I       RACLL addr11       Absolute Subroutin C         ORL       A.@Ri       OR interct.Ad to accumulator       1       1       I       I       I       I         ORL       A.@Ri       OR interct.Ad to fact byte to Accumulator       1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                   | 2<br>2<br>2<br>2 |                                                                    |
| Description       Description       ORL       C. bit       OR direct bit to Car         LOGICAL OPERATIONS       ORL       C. bit       OR direct bit to Car         Mnemonic       Destination       Byte       Cyc       MOV       Chit       Move direct bit to Car         ANL       A.Greet       AND register to Accumulator       1       I       PROGRAM AND MACHINE CONTROL         ANL       A.Greet       AND direct byte to Accumulator       2       I       ACALL       addr16       Long Subroutine Ca         ANL       A.Greet       AND immediate data to direct byte       3       2       LCALL       addr16       Long Subroutine Ca         ANL       direct,#data       AND immediate data to direct byte       3       2       LCALL       addr16       Long Subroutine Ca         ORL       A.Greet       OR direct byte to Accumulator       1       I       RET       Return from subrou         ORL       A.direct       OR direct Byte to Accumulator       2       I       MP addr16       Long Jump       Immediate data to direct byte       3       2       JMP       addr16       Long Jump indirect relativ         ORL       directif data       OR immediate data to direct byte       3       2       JMP       @A+DPTR<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ement of direct bit to Carry      | 2                | 2<br>2<br>2<br>2                                                   |
| LOGICAL OPERATIONS       ORL       C, bit       OR complement of MOV         Mnemonic       Destination       Byte       Cyc       MOV       bit. C       Move Carry flag to MOV         ANL       A.Rn       AND register to Accumulator       1       I       MOV       bit. C       Move Carry flag to Move Carry flag to MOV         ANL       A.@Ri       AND indirect RAM to Accumulator       1       I       Memonic       Description         ANL       direct.#data       AND indirect RAM to Accumulator       1       I       Memonic       Description         ANL       direct.#data       AND indirect RAM to Accumulator       1       I       RET       Return from intern         A.Rn       OR register to Accumulator       2       I.CALL       addr11       Absolute Subroutine Ca         ORL       A.@Ri       OR indirect RAM to Accumulator       2       I.SMP       addr11       Absolute Jump         ORL       A.@Ri       OR indirect RAM to Accumulator       2       I.SMP       edit       Jum indirect relation         ORL       A.@Ri       OR indirect RAM to Accumulator       2       JMP       @A+DPTR       Jump in Accumulator         ORL       direct.#data       Colis Casse Casse Casse Casse Casse Casse Casse Casse Cas                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                   | 2                | 2                                                                  |
| MnemonicDestinationByteOverC.bitMove direct bit to CANLA.RnAND register to Accumulator11Nover CycMOVbit.CMove Carry flag toANLA.GeretAND direct byte to Accumulator11PROGRAM AND MACHINE CONTROLANLA.GeretAND indirect RAM to Accumulator11MnemonicDescriptionANLA.GeretAND inmediate data to direct byte21LCALL addr11Absolute Subroutine CaANLdirect.AAND inmediate data to direct byte32LCALL addr16Long Subroutine CaANLdirect.fdataAND inmediate data to direct byte32LCALL addr16Long Subroutine CaORLA.GeretOR inmediate data to Accumulator11RETReturn from subrouORLA.GeretOR inmediate data to Accumulator21SIMPaddr16Long JumpORLA.FedataOR immediate data to direct byte32JMPaddr16Long Jump (relative)ORLdirect.AOR accumulator1JZrelJump indirect relative)XILAcenteXILJump indirect relative)XRLA.GerieExclusive-OR direct byte32JMP@Ar116Long Jump indirect relative)XRLA.GerieExclusive-OR direct byte to Accumulator1JZrelJump indirect relative)XRLA.GerieExclusive-OR direct RAM to Accumulator1JZrel<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                   | 2                | 5                                                                  |
| MnemonicDestinationByte CycMÖVbit.CMöve Carry flag toANLA.QenAND indirect payte to Accumulator21PROGRAM AND MACHINE CONTROLANLA.@RiAND indirect RAM to Accumulator111ANLA.@RiAND indirect RAM to Accumulator11ANLdirect.#dataAND indirect RAM to Accumulator11ANLdirect.#dataAND indirect RAM to Accumulator21ANLdirect.#dataAND indirect RAM to Accumulator21ANLdirect.#dataOR indirect RAM to Accumulator11RETReturn from subrouCRCRJMPORLA.@RiOR indirect RAM to Accumulator11A.#dataOR indirect RAM to Accumulator11JMPORLdirect.#dataOR imediate data to Accumulator1JZORLdirect.#dataOR imediate data to direct byte32JMPrelShort Jump (FelativeORLdirect.#dataOR immediate data to direct byte32JMRrelJump if Accumulator1JZrelJump if Accumulator1JZrelJump if AccumulatorXRLA.@RiCextrewoR register to Accumulator1JZrelJMRrelJump if Accumulator1JZrelJump if AccumulatorXRLA.@RiOR inmediate data to direct byte31JNCrel<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                   | ź                | î                                                                  |
| ANL       A.Rn       AND register to Accumulator       1       1         ANL       A.Gurect       AND indirect byte to Accumulator       1       1         ANL       A.Gurect       AND indirect RAM to Accumulator       1       1         ANL       A.Gurect       AND indirect RAM to Accumulator       1       1         ANL       A.Gurect       AND indirect RAM to Accumulator       2       1       ACALL addr11       Absolute Subroutine CA         ANL       direct, A       AND inmediate data to direct byte       3       2       LCALL addr16       Long Subroutine CA         ANL       direct, A       AD direct RAM to Accumulator       1       1       RET       Return from subrou         ORL       A.direct       OR direct byte to Accumulator       1       1       AJMP       addr16       Long Subroutine CA         ORL       A.direct.       OR inmediate data to direct byte       3       2       JMP       addr16       Long Jump indirect relativ         VRL       A.feata       OR inmediate data to direct byte       3       2       JMP       @A+DPTR       Jump indirect relativ         XRL       direct.       Recta       Recta       Recta       Jump indirect relativ       Jump indirect relativ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                   | 2                | 1                                                                  |
| ANL       A.direct       AND direct byte to Accumulator       2       1       PROGRAM AND MACHINE CONTROL         ANL       A.@Ri       AND infrect RAM to Accumulator       1       1       PROGRAM AND MACHINE CONTROL         ANL       A.#data       AND infrect RAM to Accumulator       2       1       Mnemonic       Description         ANL       direct,#data       AND infrect RAM to Accumulator       2       1       ACALL addr16       Long Subroutine Cc         ORL       A.Rin       OR register to Accumulator       1       1       RETI       Return from subrouine Cc         ORL       A.Girect       OR indirect RAM to Accumulator       1       LJMP       addr16       Long Jump         ORL       A.@Ri       OR indirect RAM to Accumulator       1       LJMP       addr16       Long Jump         ORL       direct.#data       OR indirect RAM to Accumulator       1       JZ       ref       Jump if Accumulator         XRL       A.@Ri       OR indirect RAM to Accumulator       1       JZ       ref       Jump if Accumulator         XRL       A.@Ri       Exclusive-OR interdiate data to A       1       JZ       ref       Jump if Accumulator         XRL       A.@Rit       Exclusive-OR interdiate data to A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | flag to direct bit                | 2                | 2                                                                  |
| ANL       A.@Ri       AND indirect RAM to Accumulator       1       1       Mnemonic       Description         ANL       Ardata       AND inmediate data to Accumulator       2       1       Mnemonic       Description         ANL       direct.#data       AND inmediate data to direct byte       2       1       ACALL addr16       Long Subroutine CA         ANL       direct.#data       AND inmediate data to direct byte       3       2       LCALL addr16       Long Subroutine CA         ORL       A.@Ri       OR register to Accumulator       1       I       RET       Return from subrou         ORL       A.@Ri       OR inmediate data to Accumulator       1       I       AJMP       addr16       Long Subroutine CA         ORL       A.@Ri       OR inmediate data to Accumulator       1       JZ       rel       Jump indirect relativ         ORL       direct.#data       OR inmediate data to freet byte       3       2       JMP       @A+DPTR       Jump indirect relativ         XRL       A.direct       Exclusive-OR indirect RAM to Accumulator       1       JZ       rel       Jump if Accumulator         XRL       A.direct       Exclusive-OR inmediate data to direct byte       2       1       JNC       rel <td< td=""><td></td><td></td><td></td></td<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                   |                  |                                                                    |
| ANL       A.#data       AND immediate data to Accumulator       2       1       Mnemonic       Description         ANL       direct. A       AND commediate data to direct byte       3       2       L CALL addr11       Absolute Subroutine Cc         ORL       A.Rn       OR register to Accumulator       1       RETI       Return from subrou         ORL       A.Genct       OR direct byte to Accumulator       2       1       AJMP       addr16       Long Subroutine Cc         ORL       A.@Ri       OR indirect RAM to Accumulator       1       1       AJMP       addr16       Long Jump         ORL       direct.#data       OR indirect RAM to Accumulator       1       1       JMP       addr16       Long Jump (relative         ORL       direct.#data       OR indirect RAM to Accumulator       1       JZ       rel       Jump if Accumulator         XRL       A.Girect       Exclusive-OR inceto tyte       2       JNC       rel       Jump if Accumulator         XRL       A.@Ri       Exclusive-OR inmediate data to A       1       JC       rel       Jump if Carry flag         XRL       A.@Ri       Exclusive-OR inmediate data to a forect byte       2       JNB       bit.rel       Jump if direct Bits      X                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ROL                               |                  |                                                                    |
| ANL       Arect.A       AND Immediate of arect byte       2       1       ACALL addr11       Absolute Subrouting         ANL       direct.#data       AND immediate data to direct byte       3       2       LCALL addr16       Long Subroutine CA         ANL       direct.#data       AND immediate data to direct byte       3       2       LCALL       addr11       Absolute Subroutine CA         ORL       A.Giret       OR register to Accumulator       1       RET       Return from interru         ORL       A.direct       OR direct byte to Accumulator       1       AJMP       addr16       Long Jump         ORL       A.#data       OR immediate data to Accumulator       2       I.MP       addr16       Long Jump       freative         ORL       direct.#data       OR immediate data to direct byte       3       2       JMP       el A-DPTR       Jump indirect relative         XRL       A.freet       Exclusive-OR register to Accumulator       1       JZ       rel       Jump if Accumulator         XRL       A.direct       Exclusive-OR immediate data to A       1       JC       rel       Jump if No Carry fit         XRL       A.#data       Exclusive-OR immediate data to direct       2       JNB       bit.rel       Jump                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                   | •                | ~                                                                  |
| ANL       direct.#data       AND immediate data to direct byte       3       2       LCALL addr16       Long Subroutine Cc         ORL       A.Rn       OR register to Accumulator       1       1       RETI       Return from subrou         ORL       A.direct       OR indirect RAM to Accumulator       1       1       RETI       Return from subrou         ORL       A.@Ri       OR indirect RAM to Accumulator       1       LJMP       addr16       Long Jump         ORL       direct.#data       OR indirect RAM to Accumulator       1       LJMP       addr16       Long Jump         ORL       direct.#data       OR inmediate data to direct byte       2       JMP       @A+DPTR       Jump indirect relative         ORL       direct.#data       OR inmediate data to A cumulator       1       JZ       rel       Jump if Accumulator         XRL       A.direct       Exclusive-OR inmediate data to A       1       JC       rel       Jump if Accumulator         XRL       A.@Ri       Exclusive-OR inmediate data to A       2       JNC       rel       Jump if Carry flag         XRL       direct.#data       Exclusive-OR inmediate data to direct       3       JNB       bit.rel       Jump if direct Bit S         XRL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                   | Byte             | Cyc                                                                |
| ORL       A.Rn       OP register to Accumulator       1       2       RET       Return from subrou         ORL       A.direct       OR direct byte to Accumulator       1       RET       Return from subrou         ORL       A.@Ri       OR direct byte to Accumulator       1       LIMP       addr11       Absolute Jump         ORL       A.@Ri       OR immediate data to Accumulator       1       LIMP       addr16       Long Jump         ORL       direct.A       OR comulator to direct byte       2       JMP       @A+DPTR       Jump indirect relativ         ORL       direct.4       OR immediate data to direct byte       3       2       JMP       @A+DPTR       Jump indirect relativ         XRL       A.direct       Exclusive-OR register to Accumulator       1       JZ       rel       Jump if Accumulator         XRL       A.@@Ri       Exclusive-OR infinediate data to A       2       1       JNC       rel       Jump if Ocarry fit         XRL       direct.#data       Exclusive-OR infinediate data to direct byte       2       JNB       bit.rel       Jump if direct Bit N         CLR       Complement Accumulator       1       I       CUNE       A.direct,rel       Compare direct to A         RL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                   | 2                | Ż                                                                  |
| ORL     A.Rn     OR register to Accumulator     I     I     RET     Return from subrou       ORL     A.direct     OR indirect Byte to Accumulator     I     I     RET     Return from subrou       ORL     A.@Ri     OR indirect RAM to Accumulator     I     I     AJMP     addr11     Absolute Jump       ORL     A.#data     OR inmediate data to Accumulator     I     I     LJMP     addr11     Absolute Jump       ORL     Mirect.A     OR inmediate data to Accumulator     I     I     JMP     ref     Short Jump (relative       ORL     Airect     OR inmediate data to direct byte     2     I     JNP     ref     Jump indirect relative       ORL     A.@Ri     Exclusive-OR register to Accumulator     1     JZ     ref     Jump if Accumulator       XRL     A.@Ri     Exclusive-OR rimmediate data to A     1     JNC     ref     Jump if Ocrary fit       XRL     A.#data     Exclusive-OR inmediate data to direct byte     2     1     JNB     bit.ref     Jump if direct Bit N       CLR     A     Clear Accumulator     I     I     JC     ref     Jump if direct Bit N       CLR     A     Clear Accumulator     I     I     JBC     bit.ref     Jump if direct Bit N <td></td> <td>3</td> <td>2</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                   | 3                | 2                                                                  |
| ORL     A.direct     OR direct byte to Accumulator     2     1     RETI     Return from interru       ORL     A.@Ri     OR immediate data to Accumulator     1     AJMP     addr16     Long Jump       ORL     direct.A     OR immediate data to Accumulator     2     1     LMP     addr16     Long Jump       ORL     direct.A     OR immediate data to direct byte     2     1     SJMP     rel     Short Jump (relative)       ORL     direct.4     OR immediate data to direct byte     2     1     JUP     @A-DPTR     Jump indirect relative       XRL     A.@rect     Exclusive-OR direct byte to Accumulator     1     JZ     rel     Jump if Accumulator       XRL     A.@ret     Exclusive-OR immediate data to A     1     JC     rel     Jump if Carry flag       XRL     A.@ret     Exclusive-OR immediate data to direct     2     JNB     bit.rel     Jump if direct Bit is       XRL     direct.#data     Exclusive-OR immediate data to direct     1     JB     bit.rel     Jump if direct Bit is       XRL     direct.#data     Exclusive-OR immediate data to direct     1     JBC     bit.rel     Jump if direct Bit is       CPL     A     Complement Accumulator     1     I     CJNE     R.#data.rel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | subroutine                        | 1                | 2                                                                  |
| ORL       A.@Ri       OR indices of recting and a securation of the construction of the construct | interrupt                         | 1                | 2                                                                  |
| ORL       A#data       OR immediate data to Accumulator       2       1       LJMP       addr16       Long Jump         ORL       direct.A       OR Accumulator to direct byte       2       1       SJMP       rel       Short Jump (relative)         ORL       direct.A       OR Accumulator to direct byte       3       2       JMP       @A+DPTR       Jump indirect relative         XRL       A.Rin       Exclusive-OR register to Accumulator       1       1       JZ       rel       Jump if Accumulator         XRL       A.@Ri       Exclusive-OR interet byte to Accumulator       1       JNZ       rel       Jump if Accumulator         XRL       A.@Ri       Exclusive-OR interdiate data to A       1       JNC       rel       Jump if Carry flag         XRL       A.@data       Exclusive-OR interdiate data to direct       2       JNB       bit.rel       Jump if direct Bit is         XRL       direct.#data       Exclusive-OR interdiate data to direct       3       2       JNB       bit.rel       Jump if direct Bit is         CPL       A       Complement Accumulator       1       I       CINE       A.direct.rel       Comp immed to rediate data to direct         R       A       Rotate A.cetimulator       1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                   | 2                | 2                                                                  |
| ORL       direct.A       OR Accumulator to direct byte       2       i       SJMP       rel       Short Jump (relative or classic)         ORL       direct.A       OR accumulator to direct byte       3       2       JMP       @A+DPTR       Jump infaccumulator         VRL       A.Rn       Exclusive-OR register to Accumulator       1       JZ       rel       Jump infaccumulator         XRL       A.direct       Exclusive-OR register to Accumulator       1       JZ       rel       Jump infaccumulator         XRL       A.d@Ri       Exclusive-OR indirect RAM to A       1       JC       rel       Jump infaccumulator         XRL       A.#data       Exclusive-OR indirect RAM to A       1       JNC       rel       Jump infaccumulator         XRL       direct.#data       Exclusive-OR indirect RAM to A       1       JNC       rel       Jump infaccumulator         XRL       direct.#data       Exclusive-OR inmediate data to direct byte       2       JNB       bit.rel       Jump infaccumulator         CLR       A       Clear Accumulator       1       JBC       bit.rel       Jump infaccumulator         RL       A       Rotate Accumulator       1       JBC       bit.rel       Jump infaccumulator                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ii p                              | ĩ                | õ                                                                  |
| ORL       direct, Mata       OR       interch Mata       OR       interch Mata       Immediate data to direct byte       2       2       JMP       @A+DPTR       Jump indirect relative         XRL       A.Rn       Exclusive-OR register to Accumulator       1       1       JZ       rel       Jump indirect relative         XRL       A.Qirect       Exclusive-OR direct byte to Accumulator       1       1       JZ       rel       Jump indirect relative         XRL       A.@Ri       Exclusive-OR direct byte to Accumulator       1       1       JC       rel       Jump indirect relative         XRL       A.@Ri       Exclusive-OR inmediate data to A       2       1       JNC       rel       Jump indirect mata         XRL       direct.#data       Exclusive-OR inmediate data to direct       3       1       JNB       bit.rel       Jump indirect Bit is         XRL       direct.#data       Exclusive-OR inmediate data to direct       3       1       JNB       bit.rel       Jump indirect Bit is         CPL       A       Complement Accumulator       1       1       CJNE       A.direct.rel       Comp immed to a         RL       A       Rotate A Rught through Carry flag       1       1       CJNE       Rn.#data.re                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | (relative addr)                   | 2                | 5                                                                  |
| SRL       A.R.n       Exclusive-OR register to Accumulator       1       JZ       rel       Jump if Accumulator         XRL       A.G.Ri       Exclusive-OR register to Accumulator       1       JNZ       rel       Jump if Accumulator         XRL       A.G.Ri       Exclusive-OR register to Accumulator       2       I       JNZ       rel       Jump if Accumulator         XRL       A.G.@Ri       Exclusive-OR indirect RAM to A       1       I       JC       rel       Jump if Accumulator         XRL       A.G.@Ri       Exclusive-OR indirect RAM to A       1       JNC       rel       Jump if Accumulator         XRL       A.G.@Ri       Exclusive-OR indirect RAM to A       1       JNC       rel       Jump if Accumulator         XRL       direct.A       Exclusive-OR indirect RAM to A       1       JNC       rel       Jump if direct Bit S         XRL       direct.#data       Exclusive-OR indirect rel       3       2       JNB       bit.rel       Jump if direct Bit S         CLR       A       Complement Accumulator       1       I       CINE       A.d.#data.rel       Comp immed to register         RLC       A       Rotate A Left through the Carry flag       1       DJNZ       Rn.rel       Doeremen                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                   |                  | 5                                                                  |
| XRL       A.direct       Exclusive-OR direct byte to Accumulator       1       JNZ       rel       Jump if Accumulator         XRL       A.@Ri       Exclusive-OR direct byte to Accumulator       1       JC       rel       Jump if Accumulator         XRL       A.@Ri       Exclusive-OR immediate data to A       1       JC       rel       Jump if Accumulator         XRL       A.@Ri       Exclusive-OR immediate data to A       2       JNC       rel       Jump if No Carry flip         XRL       Airect.#data       Exclusive-OR immediate data to direct byte       2       JNB       bit.rel       Jump if direct Bit is         XRL       Airect.#data       Exclusive-OR immediate data to direct       3       JNB       bit.rel       Jump if direct Bit is         CPL       A       Complement Accumulator       1       1       DBC       bit.rel       Jump if direct Bit is         CPL       A       Rotate A Left through the Carry flag       1       CJNE       R.#data.rel       Comp immed to register         RC       A       Rotate A Right through Carry flag       1       DJNZ       Bit.rel       Dump if on carry flag         SWAP       A       Swap nibbles within the Accumulator       1       DJNZ       Rineronic       Doperation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                   | -                | 2                                                                  |
| XRL       A.@Ri       Exclusive-OR indirect RAM to A       1       JC       rel       Jump if Carry flag it         XRL       A.@Ri       Exclusive-OR indirect RAM to A       1       JC       rel       Jump if Carry flag it         XRL       A.#data       Exclusive-OR indirect RAM to A       2       1       JNC       rel       Jump if No Carry flag         XRL       direct.A       Exclusive-OR indirect Bit N       2       1       JNB       bit.rel       Jump if direct Bit N         CLR       A       Complement Accumulator       1       JBC       bit.rel       Jump if direct Bit N         CLR       A       Complement Accumulator       1       1       JBC       bit.rel       Jump if direct Bit N         CLR       A       Complement Accumulator       1       CINE       A.#data.rel       Comp immed to reg         RL       A       Rotate A Left through the Carry flag       1       CINE       R.#data.rel       Comp immed to reg         RR       A       Rotate A Left through Carry flag       1       DJNZ       R.n.rel       Doerement register /         SWAP       A       Swap nibbles within the Accumulator       1       DJNZ       R.n.rel       Doerentit ret /       NOP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                   | 2                | 4                                                                  |
| XRL       A.@Ri       Exclusive-OR indirect RAM to A       1       1       JC       ref       Jump if Carry flag is         XRL       A.#data       Exclusive-OR inmediate data to A       2       1       JNC       ref       Jump if Carry flag is         XRL       A.#data       Exclusive-OR inmediate data to direct       3       2       JNB       bit.rel       Jump if direct Bit se         XRL       direct.#data       Exclusive-OR inmediate data to direct       3       2       JNB       bit.rel       Jump if direct Bit se         CPL       A       Complement Accumulator       1       1       BC       bit.rel       Jump if direct Bit se         CPL       A       Rotate Accumulator Left       1       1       CINE       A.drect.rel       Complement documulator Right         R       R       Rotate Accumulator Right       1       DJNZ       Rn.#data.rel       Comp immed to register         SWAP       A       Swap mbbles within the Accumulator       1       DJNZ       direct.rel       Decrement register         MOV       A.Rn       Move register to Accumulator       1       DJNZ       direct.rel       No operation         RMR       Memonic       Description       Byte Cyc       Rn <t< td=""><td></td><td>2</td><td>2</td></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                   | 2                | 2                                                                  |
| XRL       direct.A       Exclusive-OR       Accumulator to direct byte       2       1       JB       btt.rel       jump if direct Bit se         XRL       direct.Hata       Exclusive-OR       Accumulator to direct byte       3       2       JB       btt.rel       jump if direct Bit se         XRL       direct.Hata       Exclusive-OR       Accumulator       1       JBC       btt.rel       jump if direct Bit se         CLR       A       Complement Accumulator       1       1       CINE       A.direct.rel       Compare direct to A         RL       A       Rotate Accumulator Left       1       CINE       R.i.Rata.rel       Comp immed to reg         RR       A       Rotate A ccumulator Right       1       CINE       R.i.Rata.rel       Comp immed to reg         RR       A       Rotate A cumulator Right       1       DJNZ       Rn.rel       Decrement register to register         SWAP       A       Swap nibbles within the Accumulator       1       DJNZ       Rn.rel       Decrement direct & Mov         Move register to Accumulator       1       1       direct 1/28 internal RAM locations, any 1 C       Nooperation         MOV       A.Ginet to Accumulator       1       direct 1/28 internal RAM locatons, and 1 C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | y flag is set                     | 2                | 2                                                                  |
| XRL       direct.A       Exclusive-OR Accumulator to direct byte       2       1       JB       bit.rel       Jump if direct Bit se         XRL       direct.#data       Exclusive-OR immediate data to direct       3       2       JNB       bit.rel       Jump if direct Bit se         CLR       A       Clear Accumulator       1       1       JBC       bit.rel       Jump if direct Bit se         CPL       A       Complement Accumulator       1       1       BC       bit.rel       Jump if direct Bit se         RL       A       Rotate Accumulator Left       1       1       CNE       A:data.rel       Comp immed to A         RL       A       Rotate Accumulator Right       1       1       CNE       A:#data.rel       Comp immed to ne         RR       A       Rotate Accumulator Right       1       1       DJNZ       Rn.rel       Decrement register         SWAP       A       Swap mbbles within the Accumulator       1       DJNZ       direct.rel       Decrement register         MOV       A.Rn       Move register to Accumulator       1       1       direct       128       Morking register RO-R7         MOV       A.GRI       Move indirect byte to Accumulator       1       1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Carry flag                        | 2                | 2                                                                  |
| XRL       direct.#data       Exclusive-OR immediate data to direct       3       2       JNB       but.rel       Jump if direct Bit N         CLR       A       Clear Accumulator       1       JBC       but.rel       Jump if direct Bit N         CPL       A       Complement Accumulator       1       I       JBC       but.rel       Jump if direct Bit N         RL       A       Rotate Accumulator       1       I       CJNE       A.#data.rel       Complement Accumulator         RL       A       Rotate A Left through the Carry flag       1       I       CJNE       A.#data.rel       Comp immed to reg         RR       A       Rotate A Left through Carry flag       1       DJNZ       Rn.rel       Decrement register       Decrement register       Decrement register       Decrement register       Decrement register       Divizi direct.rel       Decrement gitter to Accumulator       NOP       No peration       NOP       No peration       NOP       No peration       NOP       NO peration       NOV       A.gention       A.gention       A.gention       A.gention       NOP       NO peration       NOP       NO peration       NOP       NO peration       NO P       NO peration       NO P       NO peration       NO P       NO peration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | t Bit set                         | 3                | 2                                                                  |
| CLR     Clear Accumulator     1     JBC     bitrel     Jump i farreet Bit is       CPL     A     Complement Accumulator     1     I     DBC     bitrel     Jump i farreet Bit is       CPL     A     Complement Accumulator     1     I     CJNE     A.direct,rel     Compare direct to A       RL     A     Rotate Accumulator     1     I     CJNE     A.direct,rel     Comp immed to A       RL     A     Rotate A Left through the Carry flag     1     CJNE     R.m.#data.rel     Comp immed to reg       RR     A     Rotate A cacumulator register     1     I     DJNZ     Rn.rel     Decrement direct &       SWAP     A     Swap nibbles within the Accumulator     1     I     DJNZ     Rn.rel     Decrement direct &       DATA TRANSFER     Nove     Nove     Nove     Nove     Nove     Nove offections, any I'C       MOV     A.Grect     Move register to Accumulator     1     I     direct internal RAM locations, any I'C       MOV     A.Grect     Move immediate data to Accumulator     2     I     @Ri     Hatan Included as bytes 2 &       MOV     A.grect     Move immediate data to register     2     I     Bott constant included as bytes 2 &       MOV     Rn.direct byte to re                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                   | 3                | 2                                                                  |
| CPL       A       Complement Accumulator       1       CJNE       A.dreet.rel       Complement Accumulator         RL       A       Rotate Accumulator Left       1       CJNE       A.dreet.rel       Comp immed to reg         RL       A       Rotate Accumulator Left       1       CJNE       R.#data.rel       Comp immed to reg         RR       A       Rotate Accumulator Right       1       1       CJNE       R.#data.rel       Comp immed to reg         RR       A       Rotate A cleft through Carry flag       1       DJNZ       Rn.rel       Decrement register         SWAP       A       Swap nibbles within the Accumulator       1       DJNZ       direct.rel       Decrement register         DATA TRANSFER       NOP       Notes on data addressing modes:       NOP       Noverations.any 1       NOV         MOV       A.@Ri       Move erigister to Accumulator       1       direct internal RAM locations.ang 1       Move internediate data to Accumulator       2       @Ri       Indirect internal RAM locations.ang 1         MOV       A.@Ri       Move intrect RAM to Accumulator       1       #data       8-bit constant included as bytes 2 &         MOV       A.@Ri       Move intrediate data to Accumulator       1       #data       8-bit co                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | t Bit is set & Clear bit          | 3                | 2                                                                  |
| RL     A     Rotaire Accumulator Left     I     I     CINE     A:#data.rel     Comp immed to A       RLC     A     Rotaire A.Left through the Carry flag     I     CINE     R.#data.rel     Comp immed to A       RR     A     Rotaire A.Left through the Carry flag     I     I     CINE     @R.#data.rel     Comp immed to A       RR     A     Rotaire Accumulator Right     I     I     CINE     @R.#data.rel     Comp immed to ne       SWAP     A     Swap mbbles within the Accumulator     I     I     DJNZ     direct.rel     Decrement register       DATA TRANSFER     No     Swap mbbles within the Accumulator     I     I     Onregister RO-R7     No operation       MOV     A.Rn     Move register to Accumulator     I     I     I direct     128 internal RAM locations, any I'C       MOV     A.@Ri     Move indirect RAM to Accumulator     I     I direct     128 internal RAM locations, any I'C       MOV     A.@Ri     Move indirect RAM to Accumulator     I     I direct     Bota in cloation addressing modes:       MOV     R.Ri     Move indirect RAM to Accumulator     I     I diata     8-bit constant included as bytes 2 & MOV       MOV     R.n.direct     Move inmediate data to Accumulator     I     I didata     8-bit c                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ect to A & Jump if Not Equal      | ž                | 2                                                                  |
| R1C     A     Rotate A Left through the Carry flag     1     CJNE     R.m. Attata.rel     Comp immed to reg       RR     A     Rotate A Ccumulator Right     1     1     CJNE     R.m.tata.rel     Comp immed to reg       RR     A     Rotate A Ccumulator Right     1     1     DJNZ     R.n.rel     Decrement register 4       SWAP     A     Swap nibbles within the Accumulator     1     1     DJNZ     direct.rel     Decrement direct & NOP       DATA TRANSFER     Notes on data addressing modes:     NOP     Nove frame     Nove frame     Nove frame       MOV     A.Rn     Move register to Accumulator     1     1     direct 128 internal RAM locations, any 1 C       MOV     A.direct     Move indirect RAM to Accumulator     2     1     #data     -8-bit constant included as bytes 2 & MOV       MOV     A.#data     Move immediate data to Accumulator     2     #data     -8-bit constant included as bytes 2 & MOV       MOV     Rndirect     Move immediate data to register     1     1     bit     128 software flags, any 1 O pin, cont       MOV     Rndirect     Move immediate data to register     2     2     Nove immediate data to register     2       MOV     Rndirect     Move immediate data to register     2     2 <td< td=""><td>d to A &amp; lump if Not Equal</td><td>3</td><td>2</td></td<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | d to A & lump if Not Equal        | 3                | 2                                                                  |
| RR     A     Rotate Accumulator Right     I     I     CINE     @RIt#data.rel     Comp immed to unt<br>DJNZ       RRC     A     Rotate A Right through Carry flag     I     DJNZ     Burect.rel     Decrement register       SWAP     A     Swap nibbles within the Accumulator     I     I     DJNZ     direct.rel     Decrement register       DATA TRANSFER     Nope     Nope     Nope     Nope     No operation       MOV     A.Rn     Move register to Accumulator     I     I     direct     128 internal RAM locations, any I*C       MOV     A.Grect     Move indirect byte to Accumulator     I     I     direct     128 internal RAM locations, any I*C       MOV     A.@Ri     Move indirect RAM to Accumulator     I     I     fdata     -8-bit constant included as bytes 2 & A       MOV     Rn.direct     Move indirect Byte to accumulator     I     I     fdata     -8-bit constant included as bytes 2 & A       MOV     Rn.diveret byte to register     I     I     bit     128 oftware flags, any I O pin, cont       MOV     Rn.diveret.     Move immediate data to register     I     I     bit     128 oftware flags, and I O pic. LCALL & Move immediate data to register       MOV     Rn.direct.     Move immediate data to register     I     I     <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | d to ma B hump if Not Equal       | 2                | ź                                                                  |
| RRC     A     Rotate A Right through Carry flag     1     DJNZ     R.r.el     Decrement register A       SWAP     A     Swap nibbles within the Accumulator     1     1     DJNZ     direct.rel     Decrement register A       DATA TRANSFER     Notes on data addressing modes:     No     Notes on data addressing modes:     No       MOV     A.Rn     Move register to Accumulator     1     1     direct 128 internal RAM locations, any I C       MOV     A.GRit     Move direct byte to Accumulator     2     1     #data16     16-bit constant included in instruction       MOV     A.#data     Move immediate data to Accumulator     2     1     #data16     16-bit constant included as bytes 2 &       MOV     Rndurect     Move indicate data to register     2     2     2       MOV     Rn.#data     Move immediate data to register     2     2       MOV     Rn.#data     Move immediate data to register     2     2       MOV     Rn.#data     Move immediate data to register     2     2       MOV     Rn.#data     Move immediate data to register     2     2       MOV     Rn.#data     Move immediate data to register     2     2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | a to reg or Jump II Not Equal     | 3                | ź                                                                  |
| NWAP         A         Notes of treatment direct &<br>NOP         DJNZ         direct.rel         Decrement direct &<br>No operation           DATA TRANSFER         NoP         NOP         NOP         No operation           Memonic         Description         Byte Cyc         Rn         Working register R0-R7           MOV         A.Girect         Move register to Accumulator         1         1         direct         128 internal RAM locations, any 1°C           MOV         A.@Ri         Move indirect RAM to Accumulator         2         1         mdata         -8-bit constant included as bytes 2 &<br>MOV Rn.A         Move cacumulator to register         1         1         128 oftware flags, any 1 O pin, cont           MOV         Rn.direct         Move immediate data to register         2         2         Notes on program addressing modes:           MOV         Rn.direct         Move immediate data to register         2         2         Notes on program addressing modes:           MOV         Rn.direct byte to date to direct byte         2         1         addr16 Destination addressing modes:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                   | د                | 222222222222222222222222222222222222222                            |
| SWAP A     Swap nibbles within the Accumulator     I     I     DJVZ     direct.rel     Decrement direct & Nop       DATA TRANSFER     Notes on data addressing modes:     Notes on data addressing modes:     Notes on data addressing modes:       Memonic     Description     Byte Cyc     Rn     Working register R0-R7       MOV     A.Rn     Move register to Accumulator     2     I     @Ri     Indirect internal RAM locations, any IC       MOV     A.@Ri     Move indirect RAM to Accumulator     2     I     @Ri     Indirect internal RAM location addr       MOV     A.@Ri     Move indirect RAM to Accumulator     1     #data     8-bit constant included as bytes 2&       MOV     Rn.diver Accumulator to register     1     1     bit     128 software flags, any I O pin, cont       MOV     Rn.direct     Move immediate data to register     2     2     2       MOV     Rn.direct     Move immediate data to register     2     1     addresing modes:       MOV     Rn.#data     Move cumulator to direct byte     2     1     addresing modes:       MOV     Rn.ditata     Move indirect byte to register     2     2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | egister & Jump if Not Zero        | 2                | 2                                                                  |
| DATA TRANSFER         NOP         No operation           Mnemonic         Description         Byte         Cyc         Rn         Working register R0-R7           MOV         A.Rn         Move register to Accumulator         1         1         128 internal RAM locations, any 1°C           MOV         A.direct         Move indirect RAM to Accumulator         2         1         @Ri         Indirect internal RAM location addr           MOV         A.@Ri         Move immediate data to Accumulator         1         #data         8-bit constant included in instruction           MOV         A.#data         Move immediate data to Accumulator         2         1         #data 16         6-bit constant included as bytes 2 &           MOV         Rn.A         Move cancumulator to register         1         1         128 software flags, any 1 O pin, cont           MOV         Rn.direct         Move immediate data to register         2         2           MOV         Rn.#data         Move immediate data to register         2         1           MOV         Rn.#data         Move immediate data to register         2         1           MOV         Rn.#data         Move intercumulator to direct byte         2         1           MOV         Rn.#datata         Mov                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | irect & Jump if Not Zero          | 3                | 2                                                                  |
| Mnemonic         Description         Byte         Cyc         Rn         Working register RO-R7           MOV         A,Rn         Move direct byte to Accumulator         1         1         direct         128 internal RAM locations, any 1°C           MOV         A,direct         Move direct byte to Accumulator         2         1         @Ri         Indirect internal RAM locations, any 1°C           MOV         A,@Ri         Move indirect RAM to Accumulator         1         #data         -8-bit constant included in instruction           MOV         A,#data         Move immediate data to Accumulator         2         1         #data16         16-bit constant included as bytes 2 & MOV           MOV         Rn,A         Move direct byte to register         2         2            MOV         Rn,direct         Move immediate data to register         2         2            MOV         Rn,direct         Move immediate data to register         2         2            MOV         Rn,direct         Move immediate data to register         2         1         Notes on program addressing modes:           MOV         Rn,#data         Move immediate data to register         2         1         Notes on program addressing modes:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1                                 | 1                | 1                                                                  |
| Mnemonic         Description         Byte         Cyc         Rn         Working register R0-R7           MOV         A,Rn         Move register to Accumulator         1         1         direct         128 internal RAM locations, any 1°C           MOV         A,direct         Move direct byte to Accumulator         2         1         @Ri         Indirect internal RAM locations, any 1°C           MOV         A,@at         Move indirect RAM to Accumulator         1         #data         -8-bit constant included in instruction           MOV         A,#data         Move immediate data to Accumulator         2         1         #data16         16-bit constant included as bytes 2 & MOV           MOV         Rn,A         Move direct byte to register         2         2         Notes on program addressing modes:           MOV         Rn,4irect         Move immediate data to register         2         2           MOV         Rn,4irect         Move immediate data to register         2         1           MOV         Rn,4irect         Move immediate data to register         2         1           MOV         Rn,4irect         Move incumulator to direct byte         2         1           MOV         Rn,4irect         Move incumulator to direct         2         1 <td></td> <td></td> <td></td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                   |                  |                                                                    |
| MOV         A.Rn         Move register to Accumulator         1         i         direct         128 internal RAM locations, any 1°C           MOV         A.direct         Move direct byte to Accumulator         2         1         @Ri         Indirect internal RAM location addr           MOV         A.@Ri         Move indirect RAM to Accumulator         1         #data         -8-bit constant included in instruction           MOV         A.#data         Move immediate data to Accumulator         1         #data 16         16-bit constant included as bytes 2 &           MOV         Rn.A         Move direct byte to register         1         1         bit         128 software flags, any 1 O pin, cont           MOV         Rn.Hittata         Move cumulator to register         2         2           MOV         Rn.#data         Move immediate data to register         2         2           MOV         Rn.#data         Move immediate data to register         2         1         Notes on program addressing modes:           MOV         Rn.#data         Move indirect data to register         2         1         addr16         Destination address for LCALL &                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                   |                  |                                                                    |
| MOV         A.dtrect         Move direct byte to Accumulator         2         I         @Rt         Indirect internal RAM location addr           MOV         A.@Ri         Move indirect RAM to Accumulator         1         #data         -8-bit constant included in instruction           MOV         A.#data         Move indirect RAM to Accumulator         2         1         #data16         16-bit constant included as bytes 2.&           MOV         Rn.A         Move Accumulator to register         1         1         128 software flags, any 1 O pin, cont           MOV         Rn.#data         Move immediate data to register         2         2           MOV         Rn.#data         Move immediate data to register         2         1           MOV         Rn.#data         Move indirect byte to register         2         2           MOV         Rn.#data         Move indirect data to register         2         2           MOV         Rn.#data         Move cumulator to direct byte         2         1         addr16         Destination addressing modes:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                   |                  |                                                                    |
| MOV         A.dtrect         Move direct byte to Accumulator         2         I         BR1         Indirect internal RAM location åddr           MOV         A.@Ri         Move indirect RAM to Accumulator         1         #data         -8-bit constant included in instruction           MOV         A.#data         Move immediate data to Accumulator         2         1         #data16         16-bit constant included as bytes 2 & & & & & & & & & & & & & & & & & &                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                   |                  | ter                                                                |
| MOV         A.@Ri         Move indirect RAM to Accumulator         I         #data         -8-bit constant included in instruction           MOV         A.#data         Move immediate data to Accumulator         2         I         #data16         16-bit constant included as bytes 2 &           MOV         R.n.A         Move direct byte to register         1         1         bit         128 software flags, any 1 O pin, cont           MOV         Rn.#data         Move direct byte to register         2         2           MOV         Rn.#data         Move immediate data to register         2         1           MOV         Rn.#data         Move immediate data to register         2         1           MOV         Rn.#data         Move immediate data to register         2         1           MOV         Rn.#data         Move immediate data to register         2         1           MOV         Rn.#data         Move immediate data to register         2         1         addr16         Destination address for LCALL &                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                   |                  |                                                                    |
| MOV         A.#data         Move immediate data to Accumulator         2         I         #data16         16-bit constant included as bytes 2.&           MOV         Rn.A         Move Accumulator to register         1         1         bit         128 software flags, any 1 O pin, cont           MOV         Rn.direct         Move immediate data to register         2         2           MOV         Rn.#data         Move immediate data to register         2         1           MOV         Rn.#data         Move immediate data to register         2         1           MOV         Rn.#data         Move cumulator to direct byte         2         1         addr16         Destination address for LCALL &                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                   |                  |                                                                    |
| MOV         Rn.A         Move Accumulator to register         I         I         bit         128 software flags, any I O pin, cont           MOV         Rn.drect         Move direct byte to register         2         2           MOV         Rn.#data         Move immediate data to register         2         I         Notes on program addressing modes:           MOV         Rin.#data         Move cumulator to direct byte         2         I         addr16         Destination address for LCALL &                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | tes 2 & 3 of instruction          |                  |                                                                    |
| MOV         Rn.direct         Move direct byte to register         2         2           MOV         Rn.#data         Move immediate data to register         2         1         Notes on program addressing modes:           MOV         Rn.#data         Move cumulator to direct byte         2         1         addr16         Destination address for LCALL &                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                   |                  |                                                                    |
| MOV direct.A Move Accumulator to direct byte 2 1 addr16 Destination address for LCALL &                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | n, control of status bit          |                  |                                                                    |
| MOV direct.A Move Accumulator to direct byte 2 1 addr16 Destination address for LCALL &                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                   |                  |                                                                    |
| MOV         oirect.A         move Accumulator to direct byte         2         1         addr16         Destination address for LCALL &           MOV         direct.Rn         Move register to direct byte         2         2         the 64-Klobyte program memory address for ACALL &           MOV         direct.@Ri         Move indirect RAM to direct byte         3         2         addr11         Destination address for ACALL &           MOV         direct.@Ri         Move indirect RAM to direct byte         3         2         2-Kilobyte page of program memory address for add                                                                                                                                                                                                                                                           |                                   |                  |                                                                    |
| MOV         direct. Kn         Move register to direct byte         2         2         the 64-Kilobyte program memory ad           MOV         direct.direct         Move direct byte to direct         3         2         addr11         Destination address for ACALL &           MOV         direct.@Rt         Move indirect RAM to direct byte         2         2         -Kilobyte page of program memory           MOV         direct.@Rt         Move immediate data to direct byte         3         2         -Kilobyte page of program memory                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                   | ere v            | /ithin                                                             |
| MOV         direct.direct         Move direct byte to direct         3         2         addr11         Destination address for ACALL &           MOV         direct.@Ri         Move indirect RAM to direct byte         2         2         2-Kilobyte page of program memory instruction           MOV         direct.#data         Move immediate data to direct byte         3         2         instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                   |                  |                                                                    |
| MOV         direct.@Ri         Move indirect RAM to direct byte         2         2         2-Kilobyte page of program memory instruction           MOV         direct.#data         Move immediate data to direct byte         3         2         instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ALL & AJMP will be within         | the              | same                                                               |
| MOV direct #data Move immediate data to direct byte 3 2 instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | nemory as the first byte of the   | follo            | wing                                                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                   |                  |                                                                    |
| MOV @RI,A Move Accumulator to indirect RAM 1 1 rel SJMP and all conditional jumps incl                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | nns include an 8-bit offset byte  | Ra               | 100 15                                                             |
| MOV @Rt.direct Move direct byte to indirect RAM 2 2 +127 -128 bytes relative to first byte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                   |                  | · 6- 13                                                            |
| MOV @Ri, Hata Move immediate data to indirect RAM 2 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | st oyte of the following fistruct |                  |                                                                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | moration 1070                     |                  |                                                                    |
| MOV DPTR,#data16 Load Data Pointer with a 16-bit constant 3 2 All mnemonics copyrighted © Intel Corporatio                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | poration 1979                     |                  |                                                                    |

### 3. INSTRUCTION SET AND ADDRESSING MODES

The 8051 instruction set is extremely regular, in the sense that most instructions can operate with variables from several different physical or logical address spaces. Before getting deeply enmeshed in the instruction set proper, it is important to understand the details of the most common data addressing modes. Whereas Table 4 summarizes the instructions set broken down by functional group, this chapter starts with the addressing mode classes and builds to include the related instructions.

#### **Data Addressing Modes**

MCS-51 assembly language instructions consist of an operation mnemonic and zero to three operands separated by commas. In two operand instructions the destination is specified first, then the source. Many byte-wide data AFN-01502A-17 operations (such as ADD or MOV) inherently use the accumulator as a source operand and/or to receive the result. For the sake of clarity the letter "A" is specified in the source or destination field in all such instructions. For example, the instruction,

#### ADD A,<source>

will add the variable<source>to the accumulator, leaving the sum in the accumulator.

The operand designated "<source>" above may use any of four common logical addressing modes:

- Register—one of the working registers in the currently enabled bank.
- Direct—an internal RAM location, I/O port, or special-function register.
- Register-indirect—an internal RAM location, pointed to by a working register.
- Immediate data an eight-bit constant incorporated into the instruction.

The first three modes provide access to the internal RAM and Hardware Register address spaces, and may therefore be used as source or destination operands; the last mode accesses program memory and may be a source operand only.

(It is hard to show a "typical application" of any instruction without involving instructions not yet described. The following descriptions use only the self-explanatory ADD and MOV instructions to demonstrate how the four addressing modes are specified and used. Subsequent examples will become increasingly complex.)

#### Register Addressing

The 8051 programmer has access to eight "working registers," numbered R0-R7. The least-significant three-bits of the instruction opcode indicate one register within this logical address space. Thus, a function code and operand address can be combined to form a short (one byte) instruction (Figure 12.a).

The 8051 assembly language indicates register addressing with the symbol Rn (where n is from 0 to 7) or with a symbolic name previously defined as a register by the EQUate or SET directives. (For more information on assembler directives see the Macro Assembler Reference Manual.)

Example 1—Adding Two Registers Together

There are four such banks of working registers, only one of which is active at a time. Physically, they occupy the first 32 bytes of on-chip data RAM (addresses 0-1FH). PSW bits 4 and 3 determine which bank is active. A hardware reset enables register bank 0; to select a different bank the programmer modifies PSW bits 4 and 3 accordingly.

Example 2-Selecting Alternate Memory Banks

MOV PSW, #000100008 SELECT BANK 2

Register addressing in the 8051 is the same as in the 8048 family, with two enhancements: there are four banks rather than one or two, and 16 instructions (rather than 12) can access them.

#### Direct Byte Addressing

Direct addressing can access any on-chip variable or hardware register. An additional byte appended to the opcode specifies the location to be used (Figure 12.b).

Depending on the highest order bit of the direct address byte, one of two physical memory spaces is selected. When the direct address is between 0 and 127 (00H-7FH) one of the 128 low-order on-chip RAM locations is used. (Future microcomputers based on the MCS-51<sup>TM</sup> architecture may incorporate more than 128 bytes of on-chip RAM. Even if this is the case, only the low-order 128 bytes will be directly addressable. The remainder wouldbe accessed indirectly or via the stack pointer.)

Example 3-Adding RAM Location Contents

DIRADR ADD CONTENTS OF RAM LOCATION 41H TO CONTENTS OF RAM LOCATION 40H DIRADR MOV A,40H ADD A,41H MOV 40H,A

All I/O ports and special function, control, or status registers are assigned addresses between 128 and 255 (80H-0FFH). When the direct address byte is between these limits the corresponding hardware register is accessed. For example, Ports 0 and 1 are assigned direct addresses 80H and 90H, respectively. A complete list is presented in Table 5. Don't waste your time trying to memorize the addresses in Table 5. Since programs using absolute addresses for function registers would be difficult to write or understand, ASM51 allows and understands the abbreviations listed instead.

Example 4—Adding Input Port Data to Output Port Data

| -        |                   |                         |  |
|----------|-------------------|-------------------------|--|
| , PRTADR |                   | A INPUT ON PREVIOUSLY   |  |
| PRTADR   | MOV<br>ADD<br>MOV | A. PO<br>A. P1<br>P0. A |  |

Direct addressing allows all special-function registers in the 8051 to be read, written, or used as instruction operands. In general, this is the *only* method used for accessing I/O ports and special-function registers. If direct addressing is used with special-function register addresses other than those listed, the result of the instruction is undefined. The 8048 does not have or need any generalized direct addressing mode, since there are only five special registers (BUS, P1, P2, PSW, & T) rather than twenty. Instead, 16 special 8048 opcodes control output bits or read or write each register to the accumulator. These functions are all subsumed by four of the 27 direct addressing instructions of the 8051.

| Table 5. | 8051 | Hardware | Register | Direct | Addresses |
|----------|------|----------|----------|--------|-----------|
|----------|------|----------|----------|--------|-----------|

| Register | Address | Function                     |  |
|----------|---------|------------------------------|--|
| P0       | 80H*    | Port 0                       |  |
| SP       | 81 H    | Stack Pointer                |  |
| DPL      | 82H     | Data Pointer (Low)           |  |
| DPH      | 83H     | Data Pointer (High)          |  |
| TCON     | 88H*    | Timer register               |  |
| TMOD     | 89H     | Timer Mode register          |  |
| TLO      | 8AH     | Timer 0 Low byte             |  |
| TLI      | 8BH     | Timer I Low byte             |  |
| TH0      | 8CH     | Timer 0 High byte            |  |
| THI      | 8DH     | Timer 1 High byte            |  |
| P1       | 90H*    | Port 1                       |  |
| SCON     | 98H*    | Serial Port Control register |  |
| SBUF     | 99H     | Serial Port data Buffer      |  |
| P2       | 0A0H*   | Port 2                       |  |
| IE       | 0A8H*   | Interrupt Enable register    |  |
| P3       | 0B0H*   | Port 3                       |  |
| IP       | 0B8H*   | Interrupt Priority register  |  |
| PSW      | 0D0H*   | Program Status Word          |  |
| ACC      | 0E0H*   | Accumulator (direct address) |  |
| В        | 0F0H*   | B register                   |  |

\*= bit addressable register.

#### Register-Indirect Addressing

How can you handle variables whose locations in RAM are determined, computed, or modified while the program is running? This situation arises when manipulating sequential memory locations, indexed entries within tables in RAM, and multiple precision or string operations. Register or Direct addressing cannot be used, since their operand addresses are fixed at assembly time.

The 8051 solution is "register-indirect RAM addressing." R0 and R1 of each register bank may operate as index or pointer registers, their contents indicating an address into RAM. The internal RAM location so addressed is the actual operand used. The least significant bit of the instruction opcode determines which register is used as the "pointer" (Figure 12.c).

In the 8051 assembly language, register-indirect addressing is represented by a commercial "at" sign ("@") preceding R0, R1, or a symbol defined by the user to be equal to R0 or R1.

#### Example 5—Indirect Addressing



Indirect addressing on the 8051 is the same as in the 8048 family, except that all eight bits of the pointer register contents are significant; if the contents point to a non-existent memory location (i.e., an address greater than 7FH on the 8051) the result of the instruction is undefined. (Future microcomputers based on the MCS-51<sup>TM</sup> architecture could implement additional memory in the on-chip RAM logical address space at locations above 7FH.) The 8051 uses register-indirect addressing for five new instructions plus the 13 on the 8048.

#### Immediate Addressing

When a source operand is a constant rather than a variable (i.e.—the instruction uses a value known at assembly time), then the constant can be incorporated into the instruction. An additional instruction byte specifies the value used (Figure 12.d).

The value used is fixed at the time of ROM manufacture or EPROM programming and may not be altered during program execution. In the assembly language immediate operands are preceded by a number sign ("#"). The operand may be either a numeric string, a symbolic variable, or an arithmetic expression using constants.

## Example 6-Adding Constants Using Immediate Addressing

| , IMMADR    | TO THE COM | DNSTANT 12 (DE<br>NSTANT 34 (DE)<br>IN ACCUMULATI | CIMAL) |
|-------------|------------|---------------------------------------------------|--------|
| ,<br>IMMADR |            | #12<br>#34                                        |        |

The preceding example was included for consistency; it has little practical value. Instead, ASM51 could compute the sum of two constants at assembly time.

#### Example 7-Adding Constants Using ASM51 Capabilities





Figure 12. Data Addressing Machine Code Formats

AEN-01502A-19

#### **Addressing Mode Combinations**

The above examples all demonstrated the use of the four data-addressing modes in two-operand instructions (MOV. ADD) which use the accumulator as one operand. The operations ADDC, SUBB, ANL, ORL, and XRL (all to be discussed later) could be substituted for ADD in each example. The first three modes may be also be used for the XCH operation or, in combination with the Immediate Addressing mode (and an additional byte), loaded with a constant. The one-operand instructions INC and DEC, DJNZ, and CJNE may all operate on the accumulator, or may specify the Register, Direct. and Register-indirect addressing modes. Exception: as in the 8048, DJNZ cannot use the accumulator or indirect addressing. (The PUSH and POP operations cannot inherently address the accumulator as a special register either. However, all three can directly address the accumulator as one of the twenty special-function registers by putting the symbol "ACC" in the operand field.)

#### Advantages of Symbolic Addressing

Like most assembly or higher-level programming languages, ASM51 allows instructions or variables to be given appropriate, user-defined symbolic names. This is done for instruction lines by putting a label followed by a colon (":") before the instruction proper, as in the above examples. Such symbols must start with an alphabetic character (remember what distinguished BACH from 0BACH?), and may include any combination of letters, numbers, question marks ("?") and underscores ("\_"). For very long names only the first 31 characters are relevant.

Assembly language programs may intermix upper- and lower-case letters arbitrarily, but ASM51 converts both to upper-case. For example, ASM51 will internally process an "I" for an "i" and, of course, "A\_TOOTH" for "a tooth."

The underscore character makes symbols easier to read and can eliminate potential ambiguity (as in the label for a subroutine to switch two entires on a stack, "S\_EXCHANGE"). The underscore is significant, and would distinguish between otherwise-identical character strings.

ASM51 allows *all* variables (registers, ports, internal'or external RAM addresses, constants, etc.) to be assigned labels according to these rules with the EQUate or SET directives.

Example 8—Symbolic Addressing of Variables Defined as RAM Locations

> VAR\_0 SET 20H VAR\_1 SET 21H , SYMB\_1 ADD CONTENTS OF VAR\_1 TO CONTENTS OF VAR\_0 , SYMB\_1 MOV A, VAR\_0 ADD A, VAR\_1 MOV VAR\_0, A

Notice from Table 4 that the MCS-51<sup>™</sup> instruction set has relatively few instruction mnemonics (abbreviations) for the programmer to memorize. Different data types or addressing modes are determined by the operands specified, rather than variations on the mnemonic. For example, the mnemonic "MOV" is used by 18 different instructions to operate on three data types (bit, byte, and address). The fifteen versions which move byte variables between the logical address spaces are diagrammed in Figure 13. Each arrow shows the direction of transfer from source to destination.

Notice also that for most instructions allowing register addressing there is a corresponding direct addressing instruction and vice versa. This lets the programmer begin writing 8051 programs as if (s)he has access to 128 different registers. When the program has evolved to the point where the programmer has a fairly accurate idea how often each variable is used, he/she may allocate the working registers in each bank to the most "popular" variables. (The assembly cross-reference option will show exactly how often and where each symbol is referenced.) If symbolic addressing is used in writing the source program only the lines containing the symbol definition will need to be changed; the assembler will produce the appropriate instructions even though the rest of the program is left untouched. Editing only the first two lines of Example 8 will shrink the six-byte code segment produced in half.

How are instruction sets "counted"? There is no standard practice; different people assessing the same CPU using different conventions may arrive at different totals.

Each operation is then broken down according to the different addressing modes (or combinations of addressing modes) it can accommodate. The "CLR" mnemonic is used by two instructions with respect to bit variables ("CLR C" and "CLR bit") and once ("CLR A") with regards to bytes. This expansion yields the 111 separate instructions of Table 4.

The method used for the MCS-51® instruction set first breaks it down into "operations": a basic function applied to a single data type. For example, the four versions of the ADD instruction are grouped to form one operation addition of eight-bit variables. The six forms of the ANL instruction for *byte* variables make up a different operation; the two forms of ANL which operate on *bits* are considered still another. The MOV mnemonic is used by three different operation classes, depending on whether bit, byte, or 16-bit values are affected. Using this terminology the 8051 can perform 51 different operations.



Figure 13. Road map for moving data bytes

Example 9—Redeclaring Example 8 Symbols as Registers

| VAR_0<br>VAR_1 | SET<br>SET        | RO<br>R1                         |
|----------------|-------------------|----------------------------------|
| SYM8_2         |                   | TENTS OF VAR_1<br>ENTS OF VAR_0  |
| SYMB_2         | MOV<br>ADD<br>MOV | A, VAR_0<br>A, VAR_1<br>VAR_0, A |

# Arithmetic Instruction Usage — ADD, ADDC, SUBB and DA

The ADD instruction adds a byte variable with the accumulator, leaving the result in the accumulator. The carry flag is set if there is an overflow from bit 7 and cleared otherwise. The AC flag is set to the carry-out from bit 3 for use by the DA instruction described later. ADDC adds the previous contents of the carry flag with the two byte variables, but otherwise is the same as ADD.

The SUBB (subtract with borrow) instruction subtracts the byte variable indicated and the contents of the carry flag together from the accumulator, and puts the result back in the accumulator. The carry flag serves as a "Borrow Required" flag during subtraction operations; when a greater value is subtracted from a lesser value (as in subtracting 5 from 1) requiring a borrow into the highest order bit, the carry flag is set; otherwise it is cleared.

When performing signed binary arithmetic, certain combinations of input variables can produce results which seem to violate the Laws of Mathematics. For example, adding 7FH (127) to itself produces a sum of 0FEH, which is the two's complement representation of -2 (refer back to Table 2)! In "normal" arithmetic, two positive values can't have a negative sum. Similarly, it is normally impossible to subtract a positive value from a negative value and leave a positive result — but in two's complement there are instances where this too may happen. Fundamentally, such anomolies occur when the magnitude of the resulting value is too great to "fit" into the seven bits allowed for it; there is no one-byte two's complement representation for 254, the true sum of 127 and 127. The MCS-51<sup>™</sup> processors detect whether these situations occur and indicate such errors with the OV flag. (OV may be tested with the conditional jump instructions JB and JNB, described under the Boolean Processor chapter.)

At a hardware level, OV is set if there is a carry out of bit 6 but not out of bit 7, or a carry out of bit 7 but not out of bit 6. When adding signed integers this indicates a negative number produced as the sum of two positive operands, or a positive sum from two negative operands; on SUBB this indicates a negative result after subtracting a negative number from a positive number, or a positive result when a positive number is subtracted from a negative number.

The ADDC and SUBB instructions incorporate the previous state of the carry (borrow) flag to allow multiple precision calculations by repeating the operation with successively higher-order operand bytes. In either case, the carry must be cleared before the first iteration.

If the input data for a multiple precision operation is an unsigned string of integers, upon completion the carry flag will be set if an overflow (for ADDC) or underflow (for SUBB) occurs. With two's complement signed data (i.e., if the most significant bit of the original input data indicates the sign of the string), the overflow flag will be set if overflow or underflow occurred.

## Example 10—String Subtraction with Signed Overflow Detection

| , SUBSTR    | SUBTRAC | T STRING                       | INDICATED BY R1             |  |  |  |
|-------------|---------|--------------------------------|-----------------------------|--|--|--|
|             | FROM ST | FROM STRING INDICATED BY RO TO |                             |  |  |  |
|             | PRECISI | IN INDICA                      | TED BY R2                   |  |  |  |
|             |         |                                | UNDERFLOW WHEN DONE         |  |  |  |
| ,           | CHECKIN |                                |                             |  |  |  |
| ,<br>SUBSTR | CLR     | с                              | BORROW= 0                   |  |  |  |
| SUBS1       | MOV     | A, ERO                         |                             |  |  |  |
| 30831       | SUBB    |                                | SUBTRACT NEXT PLACE         |  |  |  |
|             |         |                                | SUBIRACI NEXT FLACE         |  |  |  |
|             | MOV     | ERO, A                         |                             |  |  |  |
|             | INC     | RO                             | , BUMP POINTERS             |  |  |  |
|             | INC     | R1                             |                             |  |  |  |
|             | DJNZ    | R2, SUBS1                      | LOOP AS NEEDED              |  |  |  |
|             |         | WHEN DON                       | E, TEST IF OVERFLOW OCCURED |  |  |  |
|             |         | ON LAST                        | ITERATION OF LOOP           |  |  |  |
|             | JNB     | OV. OV OK                      |                             |  |  |  |
|             | UND     | 00.00_04                       |                             |  |  |  |
| ,           |         |                                | (DVERFLOW RECOVERY ROUTINE) |  |  |  |
| ov_ok       | RET     |                                | RETURN                      |  |  |  |
|             |         |                                |                             |  |  |  |

Decimal addition is possible by using the DA instruction in conjunction with ADD and/or ADDC. The eight-bit binary value in the accumulator resulting from an earlier addition of two variables (each a packed BCD digit-pair) is adjusted to form two BCD digits of four bits each. If the contents of accumulator bits 3-0 are greater than nine (xxxx1010-xxxx1111), or if the AC flag had been set, six is added to the accumulator producing the proper BCD digit in the low-order nibble. (This addition might itself set — but would not clear — the carry flag.) If the carry flag is set, or if the four high-order bits now exceed nine (1010xxxx-1111xxxx), these bits are incremented by six. The carry flag is left set if originally set or if either addition of six produces a carry out of the highest-order bit, indicating the sum of the original two BCD variables, is greater than or equal to decimal 100.

Example 11—Two Byte Decimal Add with Registers and Constants

```
,BCDADD ADD THE CONSTANT 1.234 (DECIMAL) TO THE
, CONTENTS OF REGISTER PAIR (R3>(R2)
, (ALREADY A 4 BCD-DIGIT VARIABLE)
, RCDADD MOV A.R2
```

```
        MOV
        A, R2

        ADD
        A, #34H

        DA
        A

        MOV
        R2, A

        MOV
        A, R3

        ADDC
        A, #12H

        DA
        A

        MOV
        R3, A
```

#### Multiplication and Division

The instruction "MUL AB" multiplies the unsigned eight-bit integer values held in the accumulator and Bregisters. The low-order byte of the sixteen-bit product is left in the accumulator, the higher-order byte in B. If the high-order eight-bits of the product are all zero the overflow flag is cleared; otherwise it is set. The programmer can poll OV to determine when the B register is non-zero and must be processed.

"DIV AB" divides the unsigned eight-bit integer in the accumulator by the unsigned eight-bit integer in the B-register. The integer part of the quotient is returned in the accumulator; the remainder in the B-register. If the B-register originally contained 00H then the overflow flag will be set to indicate a division error, and the values returned will be undefined. Otherwise OV is cleared.

The divide instruction is also useful for purposes such as radix conversion or separating bit fields of the accumulator. A short subroutine can convert an eight-bit unsigned binary integer in the accumulator (between 0 & 255) to a three-digit (two byte) BCD representation. The hundred's digit is returned in one register (HUND) and the ten's and one's digits returned as packed BCD in another (TENONE).

#### Example 12—Use of DIV Instruction for Radix Conversion

| ,<br>,<br>, | TO 3-DI<br>HUNDRED | GIT PACK | INARY VARIABLE IN ACC<br>ED BOD FORMAT<br>Left IN Variable 'Hund',<br>Places IN 'fenome' |
|-------------|--------------------|----------|------------------------------------------------------------------------------------------|
| ,<br>HUND   | EQU                | 218      |                                                                                          |
|             |                    |          |                                                                                          |
| TENONE      | EQU                | 22H      |                                                                                          |
| ,           |                    |          |                                                                                          |
| BINBCD      | MOV                | B,#100   | DIVIDE BY 100 TO                                                                         |
|             | DIV                | AB       | , DETERMINE NUMBER OF HUNDREDS                                                           |
|             | MOV                | HUND, A  |                                                                                          |
|             | MOV                | A. #10   | DIVIDE REMAINDER BY 10 TO                                                                |
|             | XCH                | A, B     | DETERMINE # OF TENS LEFT                                                                 |
|             | DIV                | AB       | TENS DIGIT IN ACC. REMAINDER IS ONES                                                     |
|             | DIV                | MD       |                                                                                          |
|             |                    |          | , DIGIT                                                                                  |
|             | SWAP               | A        |                                                                                          |
|             | ADD                | A, B     | , PACK BCD DIGITS IN ACC                                                                 |
|             | MOV                | TENONE,  | A                                                                                        |
|             | RET                |          | · · · · · · · · · · · · · · · · · · ·                                                    |
|             |                    |          |                                                                                          |

The divide instruction can also separate eight bits of data / in the accumulator into sub-fields. For example, packed BCD data may be separated into two nibbles by dividing the data by 16, leaving the high-nibble in the accumulator and the low-order nibble (remainder) in B. The two digits may then be operated on individually or in conjunction with each other. This example receives two packed BCD digits in the accumulator and returns the product of the two individual digits in packed BCD format in the accumulator.

| Example | 13—Implementing a BCD Multiply Using |  |
|---------|--------------------------------------|--|
|         | MPY and DIV                          |  |

| , MULBCD | FIND TH | EIR PROD | DIGITS RECEIVED IN ACC,<br>UCT, AND RETURN PRODUCT<br>ORMAT IN ACC |
|----------|---------|----------|--------------------------------------------------------------------|
| MULBCD   | MOV     | B, #10H  | DIVIDE INPUT BY 16                                                 |
|          | DIV     | AB       | A & B HOLD SEPARATED DIGITS                                        |
|          |         | 2        | (EACH RIGHT JUSTIFIED IN REGISTER)                                 |
|          | MUL     | AB       | A HOLDS PRODUCT IN BINARY FORMAT (0 -                              |
|          |         |          | ,99(DECIMAL) = 0 - 63H)                                            |
|          | MOV     | B,#10    | DIVIDE PRODUCT BY 10                                               |
|          | DIV     | AB       | , A HOLDS # OF TENS, B HOLDS REMAINDER                             |
|          | SWAP    | A        | t.                                                                 |
|          | ORL     | A, B     | PACK DIGITS                                                        |
|          | RET     |          |                                                                    |

#### Logical Byte Operations — ANL, ORL, XRL

The instructions ANL, ORL, and XRL perform the logical functions AND, OR, and/or Exclusive-OR on the two byte variables indicated, leaving the results in the first. No flags are affected. (A word to the wise — do not vocalize the first two mnemonics in mixed company.)

These operations may use all the same addressing modes as the arithmetics (ADD, etc.) but unlike the arithmetics, they are not restricted to operating on the accumulator. Directly addressed bytes may be used as the destination with either the accumulator or a constant as the source. These instructions are useful for clearing (ANL), setting (ORL), or complementing (XRL) one or more bits in a RAM, output ports, or control registers. The pattern of bits to be affected is indicated by a suitable mask byte. Use immediate addressing when the pattern to be affected is known at assembly time (Figure 14); use the accumulator versions when the pattern is computed at run-time.

I/O ports are often used for parallel data in formats other than simple eight-bit bytes. For example, the low-order five bits of port 1 may output an alphabetic character code (hopefully) without disturbing bits 7-5. This can be a simple two-step process. First, clear the low-order five pins with an ANL instruction; then set those pins corresponding to ones in the accumulator. (This example assumes the three high-order bits of the accumulator are originally zero.)

#### Example 14—Reconfiguring Port Size with Logical Byte Instructions





In this example, low-order bits remaining high may "glitch" low for one machine cycle. If this is undesirable, use a slightly different approach. First, set all pins corresponding to accumulator one bits, then clear the pins corresponding to zeroes in low-order accumulator bits. Not all bits will change from original to final state at the same instant, but no bit makes an intermediate transition.

Example 15—Reconfiguring I/O Port Size without Glitching

| ALT_PX | ORL | P1, A         |
|--------|-----|---------------|
|        | ORL | A, #11100000B |
|        | ANL | P1. A         |
|        | RET |               |
|        |     | 1             |

#### Program Control — Jumps, Calls, Returns

Whereas the 8048 only has a single form of the simple jump instruction, the 8051 has three. Each causes the program to unconditionally jump to some other address. They differ in how the machine code represents the destination address.

LJMP (Long Jump) encodes a sixteen-bit address in the second and third instruction bytes (Figure 15.a); the destination may be anywhere in the 64 Kilobyte program memory address space.

The two-byte AJMP (Absolute Jump) instruction encodes its destination using the same format as the 8048: address bits 10 through 8 form a three bit field in the opcode and address bits 7 through 0 form the second byte (Figure 15.b). Address bits 15-12 are unchanged from the (incremented) contents of the P.C., so AJMP can only be used when the destination is known to be within the same 2K memory block. (Otherwise ASM51 will point out the error.)

A different two-byte jump instruction is legal with any nearby destination, regardless of memory block boundaries or "pages." SJMP (Short Jump) encodes the destination with a program counter-relative address in the second byte (Figure 15.c). The CPU calculates the





destination at run-time by adding the signed eight-bit displacement value to the incremented P.C. Negative offset values will cause jumps up to 128 bytes backwards; positive values up to 127 bytes forwards. (SJMP with 00H in the machine code offset byte will proceed with th following instruction).

In keeping with the 8051 assembly language goal of minimizing the number of instruction mnemonics, there is a "generic" form of the three jump instructions. ASM51 recognizes the mnemonic JMP as a "pseudo-instruction," translating it into the machine instructions LJMP, AJMP, or SJMP, depending on the destination address.

Like SJMP, all conditional jump instructions use relative addressing. JZ (Jump if Zero) and JNZ (Jump if Not Zero) monitor the state of the accumulator as implied by their names, while JC (Jump on Carry) and JNC (Jump on No Carry) test whether or not the carry flag is set. All four are two-byte instructions, with the same format as Figure 15.c. JB (Jump on Bit), JNB (Jump on No Bit) and JBC (Jump on Bit then Clear Bit) can test any status bit or input pin with a three byte instruction; the second byte specifies which bit to test and the third gives the relative offset value.

There are two subroutine-call instructions, LCALL (Long Call) and ACALL (Absolute Call). Each increments the P.C. to the first byte of the following instruction, then pushes it onto the stack (low byte first). Saving both bytes increments the stack pointer by two. The subroutine's starting address is encoded in the same ways as LJMP and AJMP. The generic form of the call operation is the mnemonic CALL, which ASM51 will translate into LCALL or ACALL as appropriate.

The return instruction RET pops the high- and low-order bytes of the program counter successively from the stack, decrementing the stack pointer by two. Program execution continues at the address previously pushed: the first byte of the instruction immediately following the call.

When an interrupt request is recognized by the 8051 hardware, two things happen. Program control is automatically "vectored" to one of the interrupt service routine starting addresses by, in effect, forcing the CPU to process an LCALL instead of the next instruction. This automatically stores the return address on the stack. (Unlike the 8048, no status information is automatically saved.)

Secondly, the interrupt logic is disabled from accepting any other interrupts from the same or lower priority. After completing the interrupt service routine, executing an RETI (Return from Interrupt) instruction will return execution to the point where the background program was interrupted — just like RET — while restoring the interrupt logic to its previous state.

#### **Operate-and-branch instructions — CJNE, DJNZ**

Two groups of instructions combine a byte operation with a conditional jump based on the results.

CJNE (Compare and Jump if Not Equal) compares two byte operands and executes a jump if they disagree. The carry flag is set following the rules for subtraction: if the unsigned integer value of the first operand is less than that of the second it is set; otherwise, it is cleared. However, neither operand is modified.

The CJNE instruction provides, in effect, a oneinstruction "case" statement. This instruction may be executed repeatedly, comparing the code variable to a list of "special case" value: the code segment following the instruction (up to the destination label) will be executed only if the operands match. Comparing the accumulator or a register to a series of constants is a convenient way to check for special handling or error conditions; if none of the cases match the program will continue with "normal" processing.

A typical example might be a word processing device which receives ASCII characters through the serial port and drives a thermal hard-copy printer. A standard routine translates "printing" characters to bit patterns, but control characters ( $\langle DEL \rangle \langle CR \rangle \langle LF \rangle \langle BEL \rangle$  $\langle ESC \rangle$  or  $\langle SP \rangle$ ) must invoke corresponding special routines. Any other character with an ASCII code less than 20H should be translated into the  $\langle NUL \rangle$  value, 00H, and processed with the printing characters.

Example 16-Case Statements Using CJNE

| CHAR   | EQU  | R7 , CHARACTER CODE VARIABLE                                              |   |
|--------|------|---------------------------------------------------------------------------|---|
| INTERP | CJNE | CHAR, #7FH, INTP_1                                                        |   |
|        |      | (SPECIAL ROUTINE FOR RUBOUT CODE)                                         |   |
|        | RET  |                                                                           |   |
| INTP_1 | CJNE | CHAR, #07H, INTP_2                                                        | , |
| ,      |      | (SPECIAL ROUTINE FOR BELL CODE)                                           |   |
|        | RET  | · · · · · · · · · · · · · · · · · · ·                                     |   |
| INTP_2 | CJNE | CHAR, #OAH, INTP_3                                                        |   |
| ,      |      | (SPECIAL ROUTINE FOR LFEED CODE)                                          |   |
|        | RET  |                                                                           |   |
| INTP_3 | CUNE | CHAR, #ODH, INTP_4                                                        |   |
| ,      |      | (SPECIAL ROUTINE FOR RETURN CODE)                                         |   |
|        | RET  |                                                                           |   |
| INTP_4 | CUNE |                                                                           |   |
| •      |      | (SPECIAL ROUTINE FOR ESCAPE CODE)                                         |   |
|        | RET  | ANA                                                                       |   |
| INTP_5 | CONE | CHAR, #20H, INTP_6<br>(SPECIAL ROUTINE FOR SPACE CODE)                    |   |
|        |      | (SPECIAL RUUTINE FUR SPACE CUDE)                                          |   |
|        | RET  | PRINTA UNA IS ACRE > DOU                                                  |   |
| INTP_6 | MOV  | PRINTC , JUMP IF CODE > 20H<br>CHAR, #0 , REPLACE CONTROL CHARACTERS WITH |   |
|        | MUV  |                                                                           |   |
| PRINTC |      | , NULL CODE<br>, PROCESS STANDARD PRINTING                                |   |
| PRINTC |      | , CHARACTER                                                               |   |
| ,      | RET  | , CHARACIER                                                               |   |
|        | REI  |                                                                           |   |
|        |      |                                                                           |   |

DJNZ (Decrement and Jump if Not Zero) decrements the register or direct address indicated and jumps if the result is not zero, without affecting any flags. This provides a simple means for executing a program loop a given number of times, or for adding a moderate time delay (from 2 to 512 machine cycles) with a single instruction. For example, a 99-usec. software delay loop can be added to code forcing an 1/O pin low with only two instructions.

Example 17—Inserting a Software Delay with DJNZ

| CLR  | WR      |
|------|---------|
| MOV  | R2, #49 |
| DJNZ | R2, \$  |
| SETB | WR      |

The dollar sign in this example is a special character meaning "the address of this instruction." It is useful in eliminating instruction labels on the same or adjacent source lines. CJNE and DJNZ (like all conditional jumps) use program-counter relative addressing for the destination address.

#### Stack Operations — PUSH, POP

The PUSH instruction increments the stack pointer by one, then transfers the contents of the single byte variable indicated (direct addressing only) into the internal RAM location addressed by the stack pointer. Conversely, POP copies the contents of the internal RAM location addressed by the stack pointer to the byte variable indicated, then decrements the stack pointer by one.

(Stack Addressing follows the same rules, and addresses the same locations as Register-indirect. Future microcomputers based on the MCS-51<sup>TM</sup> CPU could have up to 256 bytes of RAM for the stack.)

Interrupt service routines must not change any variable or hardware registers modified by the main program, or else the program may not resume correctly. (Such a change might look like a spontaneous random error.) Resources used or altered by the service routine (Accumulator, PSW, etc.) must be saved and restored to their previous value before returning from the service routine. PUSH and POP provide an efficient and convenient way to save register states on the stack.

## Example 18—Use of the Stack for Status Saving on Interrupts

| LOC_TMP | EQU    | •      | REMEMBER LOCATION COUNTER                                 |
|---------|--------|--------|-----------------------------------------------------------|
| ,       | ORG    | 0003H  | STARTING ADDRESS FOR INTERRUPT ROUTINE                    |
|         | LJMP   | SERVER | JUMP TO ACTUAL SERVICE ROUTINE LOCATED                    |
| ,       |        |        |                                                           |
|         | ORG    |        | , RESTORE LOCATION COUNTER                                |
| SERVER  | PUSH ` | PSW    |                                                           |
|         | PUSH   | ACC    | SAVE ACCUMULATOR (NOTE DIRECT ADDRESSING                  |
|         |        |        | NOTATION)                                                 |
|         | PUSH   | 8      | SAVE B REGISTER                                           |
|         | PUSH   | DPL    | SAVE DATA POINTER                                         |
|         | PUSH   | DPH    | 1                                                         |
|         | MOV    |        | DO1000B SELECT REGISTER BANK 1                            |
|         |        |        |                                                           |
| ,       |        |        |                                                           |
| ,       | POP    | DPH    | RESTORE REGISTERS IN REVERSE ORDER                        |
|         | POP    | DPL    | RESIDE REGISTERS IN REVENSE URDER                         |
|         |        |        |                                                           |
|         | POP    | в      | · · ·                                                     |
|         | POP    | ACC    |                                                           |
|         | POP    | PSW    | RESTORE PSW AND RE-SELECT ORIGINAL                        |
|         | RETI   |        | , RETURN TO MAIN PROGRAM/AND RESTORE<br>, INTERRUPT LOGIC |

If the SP register held IFH when the interrupt was detected, then while the service routine was in progress the stack would hold the registers shown in Figure 16; SP would contain 26H.

The example shows the most general situation; if the service routine doesn't alter the B-register and data pointer, for example, the instructions saving and restoring those registers would not be necessary.

The stack may also pass parameters to and from subroutines. The subroutine can indirectly address the parameters derived from the contents of the stack pointer.



Figure 16. Stack contents during interrupt

One advantage here is simplicity. Variables need not be allocated for specific parameters, a potentially large number of parameters may be passed, and different calling programs may use different techniques for determining or handling the variables.

For example, the following subroutine reads out a parameter stored on the stack by the calling program, uses the low order bits to access a local look-up table holding bit patterns for driving the coils of a four phase stepper motor, and stores the appropriate bit pattern back in the same position on the stack before returning. The accumulator contents are left unchanged.

Example 19—Passing Variable Parameters to Subroutines Using the Stack

| NXTPOS | MOV  | RO, SP                                                  |  |
|--------|------|---------------------------------------------------------|--|
|        | DEC  | RO , ACCESS LOCATION PARAMETER PUSHED INTO              |  |
|        | DEC  | RO .                                                    |  |
|        | хсн  | A, @RO , READ INPUT PARAMETER AND SAVE<br>, ACCUMULATOR |  |
|        | ANL  | A, #O3H , MASK ALL BUT LOW-ORDER TWO BITS               |  |
|        | ADD  | A, #2 , ALLOW FOR OFFSET FROM MOVE TO TABLE             |  |
|        | MOVC | A, @A+PC , READ LOOK-UP TABLE ENTRY                     |  |
|        | XCH  | A, GRO , PASS BACK TRANSLATED VALUE AND RESTORE         |  |
|        |      | , ACC                                                   |  |
|        | RET  | , RETURN TO BACKGROUND PROGRAM                          |  |
| STPTBL | DB   | 01101111B , POSITION 0                                  |  |
|        | DB   | 01011111B , POSITION 1                                  |  |
|        | DB   | 10011111B , POSITION 2                                  |  |
|        | DB   | 10101111B , POSITION 3                                  |  |

The background program may reach this subroutine with several different calling sequences, all of which PUSH a value before calling the routine and POP the result after. A motor on Port 1 may be initialized by placing the desired position (zero) on the stack before calling the subroutine and outputing the results directly to a port afterwards.

Example 20—Sending and Receiving Data Parameters Via the Stack

> CLR A PUSH ACC CALL NXTPOS POP P1

If the position of the motor is determined by the contents of variable POSM1 (a byte in internal RAM) and the position of a second motor on Port 2 is determined by the data input to the low-order nibble of Port 2, a sixinstruction sequence could update them both.

Example 21—Loading and Unloading Stack Direct from I/O Ports

|    | · · · · · · · · · · · · · · · · · · · |                             |
|----|---------------------------------------|-----------------------------|
| 11 | EQU                                   | 51                          |
|    | PUSH<br>CALL<br>POP<br>PUSH           | POSM1<br>NXTPOS<br>P1<br>P2 |
|    | POP                                   | NXTPOS<br>P2                |
|    |                                       |                             |

POS

## Data Pointer and Table Look-up instructions — MOV, INC, MOVC, JMP

The data pointer can be loaded with a 16-bit value using the instruction MOV DPTR, #data16. The data used is stored in the second and third instruction bytes, highorder byte first. The data pointer is incremented by INC DPTR. A 16-bit increment is performed; an overflow from the low byte will carry into the high-order byte. Neither instruction affects any flags.

The MOVC (Move Constant) instructions (MOVC A,@A+DPTR and MOVC A,@A+PC) read into the accumulator bytes of data from the program memory logical address space. Both use a form of indexed addressing: the former adds the unsigned eight-bit accumulator contents with the sixteen-bit data pointer register, and uses the resulting sum as the address from which the byte is fetched. A sixteen-bit addition is performed; a carry-out from the low-order eight bits may propagate through higher-order bits, but the contents of the DPTR are not altered. The latter form uses the incremented program counter as the "base" value instead of the DPTR (figure 17). Again, neither version affects the flags.





AFN-01502A-25

Each can be part of a three step sequence to access lookup tables in ROM. To use the DPTR-relative version, load the Data Pointer with the starting address of a lookup table; load the accumulator with (or compute) the index of the entry desired; and execute MOVC A,@A+DPTR. Unlike the similar MOVP3 instructions in the 8048, the table may be located anywhere in program memory. The data pointer may be loaded with a constant for short tables. Or to allow more complicated data structures, or tables with more than 256 entries, the values for DPH and DPL may be computed or modified with the standard arithmetic instruction set.

The PC-relative version has the advantage of not affecting the data pointer. Again, a look-up sequence takes three steps: load the accumulator with the index; compensate for the offset from the look-up instruction to the start of the table by adding the number of bytes separating them to the accumulator; then execute the MOVC A,@A+PC instruction.

Let's look at a non-trivial situation where this instruction would be used. Some applications store large multidimensional look-up tables of dot matrix patterns, nonlinear calibration parameters, and so on in a linear (onedimensional) vector in program memory. To retrieve data from the tables, variables representing matrix indices must be converted to the desired entry's memory address. For a matrix of dimensions (MDIMEN x NDIMEN) starting at address BASE and respective indices INDEXI and INDEXJ, the address of element (INDEXI, INDEXJ) is determined by the formula,

Entry Address = BASE + (NDIMEN x INDEXI)'+ INDEXJ

The code shown below can access any array with less than 255 entries (i.e., an 11x21 array with 231 elements). The table entries are defined using the Data Byte ("DB") directive, and will be contained in the assembly object code as part of the accessing subroutine itself.

#### Example 22—Use of MPY and Data Pointer Instructions to Access Entries from a Multidimensional Look-Up Table in ROM

|          |          |           | •                                      |
|----------|----------|-----------|----------------------------------------|
| , MATRX1 | LOAD CO  | INSTANT P | READ FROM TWO DIMENSIONAL LOOK-UP      |
| ,        | TABLE I  | N PROGRA  | AM MEMORY INTO ACCUMULATOR             |
|          | USING    | OCAL TAL  | BLE LOOK-UP INSTRUCTION, MOVE A, @A+PC |
|          |          |           | R OF TABLE ENTRIES IS ASSUMED TO       |
|          |          |           | LESS THAN ABOUT 250 ENTRIES )          |
|          |          |           | THIS EXAMPLE IS ( 11 X 21 )            |
|          |          |           | ADDRESS IS GIVEN BY THE FORMULA,       |
|          |          |           | $(21 \times INDEXI) + (INDEXJ)$        |
|          | 2 101102 |           |                                        |
| INDEXI   | EQU      | R6        | FIRST COORDINATE OF ENTRY (0-10)       |
| INDEXJ   | EQU      | 23H       | SECOND COORDINATE OF ENTRY (0-20)      |
| ,        |          |           |                                        |
| MATR X 1 | MOV      | A, INDE   | XI ,                                   |
|          | MOV      | B,#21     | <b>v</b>                               |
|          | MUL      | AB        |                                        |
|          |          | A, INDE   |                                        |
|          |          |           | RUCTION BYTE BETWEEN "MOVC" AND        |
| ,        | ENTRY    | 0,0)      |                                        |
|          | INC.     | A         |                                        |
|          | MOVC '   | A, @A+P(  | C                                      |
|          | RET      |           |                                        |
| BASE 1   | DB       | 1         | , (entry 0,0)                          |
|          | DB       | 2         | , (entry O, 1)                         |
| ,        |          |           |                                        |
|          | DB       | 21        | , (entry 0,20)                         |
|          | DB       | 22        | , (entry 1,0)                          |
| ,        |          |           |                                        |
|          | DB       | 42        | , (entry 1,20)                         |
| ,        |          |           |                                        |
| ,        |          |           |                                        |
|          | DB       | 231       | , (entry 10, 20)                       |

There are several different means for branching to sections of code determined or selected at run time. (The single destination addresses incorporated into conditional and unconditional jumps are, of course, determined at assembly time). Each has advantages for different applications.

The most common is an N-way conditional jump based on some variable, with all of the potential destinations known at assembly time. One of a number of small routines is selected according to the value of an index variable determined while the program is running. The most efficient way to solve this problem is with the MOVC and an indirect jump instruction, using a short table of one byte offset values in ROM to indicate the relative starting addresses of the several routines.

JMP @A+DPTR is an instruction which performs an indirect jump to an address determined during program execution. The instruction adds the eight-bit unsigned accumulator contents with the contents of the sixteen-bit data pointer, just like MOVC A,@A+DPTR. The resulting sum is loaded into the program counter and is used as the address for subsequent instruction fetches. Again, a sixteen-bit addition is performed; a carry out from the low-order eight bits may propagate through the higher-order bits. In this case, neither the accumulator contents nor the data pointer is altered.

The example subroutine below reads a byte of RAM into the accumulator from one of four alternate address spaces, as selected by the contents of the variable MEMSEL. The address of the byte to be read is determined by the contents of R0 (and optionally R1). It might find use in a printing terminal application, where four different model printers all use the same ROM code but use different types and sizes of buffer memory for different speeds and options.

#### Example 23—N-Way Branch and Computed Jump Instructions via JMP @ ADPTR

| MEMSEL  | EQU      | R3                                             |
|---------|----------|------------------------------------------------|
| JUMP_4  | MOV      | A, MEMSEL                                      |
|         | MOV      | DPTR, #JMPTBL .                                |
|         | MOVC     | A, @A+DPTR                                     |
|         | JMP      | @A+DPTR                                        |
| JMP TBL | DB       | MEMSPO-JMPTBL                                  |
|         | DB       | MEMSP1~JMPTBL                                  |
|         | DB       | MEMSP2-JMPTBL                                  |
|         | DB       | MEMSP3-JMPTBL                                  |
| MEMSPO  | MOV      | A. CRO , READ FROM INTERNAL RAM                |
|         | RET      | · ,                                            |
| MEMSP 1 | MOVX     | A. ORO , READ FROM 256 BYTES OF EXTERNAL RAM   |
|         | RET      | · · · · · · · · · · · · · · · · · · ·          |
| MEMSP2  | MOV      | DPL, RO                                        |
|         | MOV DPH. | R1                                             |
|         | MOVX     | A, ODPTR , READ FROM 64K BYTES OF EXTERNAL RAM |
|         | RET      | · · · · ·                                      |
| MEMSP3  | MOV      | À, R1                                          |
|         | ANL      | A, #07H                                        |
|         | ANL      | P1, #11111000B                                 |
|         | ORL      | P1, A                                          |
|         | MOVX     | A. GRO , READ FROM 4K BYTES OF EXTERNAL RAM    |
|         | RET      | · · · · · · · · · · · · · · · · · · ·          |

Note that this approach is suitable whenever the size of jump table plus the length of the alternate routines is less than 256 bytes. The jump table and routines may be located anywhere in program memory, 'independent of 256-byte program memory pages.

For applications where up to 128 destinations must be selected, all of which reside in the same 2K page of program memory which may be reached by the two-byte absolute jump instructions, the following technique may be used. In the above mentioned printing terminal example, this sequence could "parse" 128 different codes for ASCII characters arriving via the 8051 serial port.

## Example 24—N-Way Branch with 128 Optional Destinations

| OPTION | EGU  | R3                                        |
|--------|------|-------------------------------------------|
|        |      |                                           |
|        |      |                                           |
| JMP128 | MOV  | A, OPTION                                 |
|        | RL   | A , MULTIPLY BY 2 FOR 2 BYTE JUMP TABLE   |
|        | MOV  | DPTP, #INSTBL , FIRST ENTRY IN JUMP TABLE |
|        | JMP  | RA+DPTR , JUMP INTO JUMP TABLE            |
|        |      |                                           |
| INSTBL | AJMP | PROCOO , 128 CONSECUTIVE                  |
|        | AJMP | PROCO1 , AJMP INSTRUCTIONS                |
|        | AJMP | PROCO2                                    |
|        |      |                                           |
|        |      |                                           |
|        | AJMP | PROC7E                                    |
|        | AJMP | PROC7F                                    |

The destinations in the jump table (PROC00-PROC7F) are not all necessarily unique routines. A large number of special control codes could each be processed with their own unique routine, with the remaining printing characters all causing a branch to a common routine for entering the character into the output queue.

In those rare situations where even 128 options are insufficient, or where the destination routines may cross a 2K page boundary, the above approach may be modified slightly as shown below.

Example 25-256-Way Branch Using Address Look-Up Tables

| RTEMP            | EQU               | R7                              |                                       |
|------------------|-------------------|---------------------------------|---------------------------------------|
| JMP256           | MOV<br>MOV<br>CLR | DPTR, #ADRTBL<br>A, OPTION<br>C | FIRST ENTRY IN TABLE OF ADDRESSES     |
|                  | RLC<br>JNC<br>INC | A<br>LOW128<br>DPH              | , MULTIPLY BY 2 FOR 2 BYTE JUMP TABLE |
| L0W128           |                   | RTEMP, A                        | SAVE ACC FOR HIGH BYTE READ           |
|                  | MOVC<br>XCH.      | A, @A+DPTR<br>A, RTEMP          | READ LOW BYTE FROM JUMP TABLE         |
|                  | INC               | A                               |                                       |
|                  | MOVC<br>PUSH      | A, CA+DPTR<br>ACC               | GET LOW-ORDER BYTE FROM TABLE         |
|                  | MOV               | A, RTEMP                        |                                       |
|                  | PUSH              | A, CA+UP IR                     | GET HIGH-ORDER BYTE FROM TABLE        |
|                  |                   | ACC PUSHES HA                   | AVE PRODUCED                          |
|                  | A "RETU           | RN ADDRESS" OF                  | THE STACK WHICH CORRESPONDS           |
|                  |                   | DESIRED START                   |                                       |
| ,                |                   |                                 | POPPING THE STACK                     |
| ,                | INTO TH           | E PC                            |                                       |
|                  | RET               |                                 |                                       |
| ADRITEL          | DW                |                                 | 0 256 CONSECUTIVE DATA                |
|                  | DW                | PROCO1 , WORI                   | S INDICATING STARTING ADDRESSES       |
|                  |                   |                                 |                                       |
|                  | DW                | PROCFF                          |                                       |
|                  |                   |                                 |                                       |
|                  | DUMMY C           | ODE ADDRESS DE                  | FINITIONS NEEDED BY ABOVE             |
|                  | THO EXA           | MPLES                           |                                       |
|                  |                   |                                 |                                       |
| PROCOO           | NOP               |                                 |                                       |
| PROCO1           | NOP               |                                 |                                       |
| PROCO2<br>PROC7E | NOP               |                                 |                                       |
| PROC7E           | NOP               |                                 |                                       |
| PROCFF           | NOP               |                                 |                                       |
| . NOUT P         |                   |                                 |                                       |

#### 4. BOOLEAN PROCESSING INSTRUCTIONS

The commonly accepted terms for tasks at either end of the computational vs. control application spectrum are, respectively, "number-crunching" and "bit-banging". Prior to the introduction of the MCS-51<sup>™</sup> family, nice number-crunchers made bad bit-bangers and vice versa. The 8051 is the industry's first single-chip microcomputer designed to crunch **and** bang. (In some circles, the latter technique is also referred to as "bit-twiddling". Either is correct.)

#### **Direct Bit Addressing**

A number of instructions operate on Boolean (one-bit) variables, using a direct bit addressing mode comparable to direct byte addressing. An additional byte appended to the opcode specifies the Boolean variable, I/O pin, or control bit used. The state of any of these/bits may be tested for "true" or "false" with the conditional branch instructions JB (Jump on Bit) and JNB (Jump on Not Bit). The JBC (Jump on Bit/ and Clear) instruction combines a test-for-true with an unconditional clear.

As in direct byte addressing, bit 7 of the address byte switches between two physical address spaces. Values between 0 and 127 (00H-7FH) define bits in internal RAM locations 20H to 2FH (Figure 18a); address bytes between 128 and 255 (80H-0FFH) define bits in the 2 x "special-function" register address space (Figure 18b). If no 2 x "special-function" register corresponds to the direct bit address used the result of the instruction is undefined.

Bits so addressed have many wondrous properties. They may be set, cleared, or complemented with the two byte instructions SETB, CLR, or CPL. Bits may be moved to and from the carry flag with MOV. The logical ANL and ORL functions may be performed between the carry and either the addressed bit or its complement.

#### **Bit Manipulation Instructions — MOV**

The "MOV" mnemonic can be used to load an addressable bit into the carry flag ("MOV C, bit") or to copy the state of the carry to such a bit ("MOV bit, C"). These instructions are often used for implementing serial I/O algorithms via software or to adapt the standard I/O port structure.

It is sometimes desirable to "re-arrange" the order of 1/O pins because of considerations in laying out printed circuit boards. When interfacing the 8051 to an immediately adjacent device with "weighted" input pins, such as keyboard column decoder, the corresponding pins are likely to be not aligned (Figure 19).

There is a trade-off in "scrambling" the interconnections with either interwoven circuit board traces or through software. This is extremely cumbersome (if not impossible) to do with byte-oriented computer architectures. The 8051's unique set of Boolean instructions makes it simple to move individual bits between arbitrary locations.

|        | Bit Addr |    |    |     |      |    |    |       | .) Hardware      | Reg | lister Bi | Addree     |         |          |          |            |       |   |
|--------|----------|----|----|-----|------|----|----|-------|------------------|-----|-----------|------------|---------|----------|----------|------------|-------|---|
| A<br>E | (MSB)    |    |    |     |      |    |    | (LSB) | irect<br>yte (MS |     |           |            |         | dresses  |          |            | (LSB) |   |
| 1      |          |    |    |     |      |    |    |       | FFH              |     |           |            |         |          |          |            |       | I |
|        | Ŧ        |    |    |     |      |    |    | :     | FOH F            | 7   | F6        | F5         | F4      | F3       | F2       | F1         | FO    |   |
|        | 7F       | 7E | 7D | 70  | 7B   | 7A | 79 | 78    | еон е            | 7   | E6        | E5         | E4      | E3       | E2       | E1         | EO    |   |
| •      | 77       | 76 | 75 | 74  | 73   | 72 | 71 | 70    |                  |     |           |            |         |          |          |            |       |   |
| 4      | 6F       | 6E | 6D | 6C  | 6B   | 6A | 69 | 68    | оон D            | 57  | D6        | D5         | D4      | D3       | D2       | D1         | DO    |   |
| 1      | 67       | 66 | 65 | 64  | 63   | 62 | 61 | 60    |                  |     |           |            |         |          | <b>.</b> |            | L     |   |
| •      | 5F       | 5E | 5D | 5C  | 5B   | 5A | 59 | 58    |                  |     |           |            |         |          |          |            |       |   |
| 4      | 57       | 56 | 55 | 54  | 53   | 52 | 51 | 50    | ван –            | -   | -         | _          | BC      | BB       | BA       | <b>B</b> 9 | 88    |   |
| 1      | 4F       | 4E | 4D | 4C  | 48   | 4A | 49 | 48    |                  |     |           |            | <b></b> |          |          |            | 4     |   |
|        | 47       | 46 | 45 | 44  | 43   | 42 | 41 | 40    | вон в            | 17  | B6        | <b>B</b> 5 | B4      | B3       | B2       | 81         | BO    |   |
|        | 3F       | 3E | 3D | 3C  | 3B   | 3A | 39 | 38    |                  |     |           |            |         |          |          |            | 4     |   |
|        | 37       | 36 | 35 | 34  | 33   | 32 | 31 | 30    | АВН А            | F   | -         | -          | AC      | AB       | AA       | A9         | A8    |   |
|        | 2F       | 2E | 2D | 2C  | 2B   | 2A | 29 | 28    |                  |     |           | L          | L       | <b>.</b> | <b></b>  |            | •     |   |
|        | 27       | 26 | 25 | 24  | 23   | 22 | 21 | 20    |                  | 7   | A6        | A5         | A4      | A3       | A2       | A1         | AO    |   |
|        | 1F       | 1E | 1D | 1C  | 1B   | 1A | 19 | 18    |                  |     |           | · · · · ·  |         |          |          |            |       |   |
|        | 17       | 16 | 15 | 14  | 13   | 12 | 11 | 10    | е на             | F   | , 9E      | 9D         | 9C      | 9B       | 9A       | 99         | 98    |   |
|        | OF       | OE | 0D | 00  | 08   | 0A | 09 | 08    |                  |     |           |            |         | L        |          |            | L     |   |
|        | 07       | 06 | 05 | 04  | 03   | 02 | 01 | 00    | юн 9             | 7   | 96        | 95         | 94      | 93       | 92       | 91         | 90    |   |
|        |          |    |    |     |      |    |    |       |                  |     |           | L          |         |          | <b>.</b> |            | L     |   |
|        |          |    |    | Bar | 1k 3 |    |    |       | ан а             | F   | 8E        | 8D         | 8C      | 8B       | 8A       | 89         | 88    |   |
|        |          |    |    | _   |      |    |    |       |                  |     |           |            |         |          |          |            |       |   |
|        |          |    |    | Bar | ik 2 |    |    |       | юн 8             | 7   | 86        | 85         | 84      | 83       | 82       | 81         | 80    |   |
|        |          |    |    |     |      |    |    |       | <b>6</b>         |     |           |            |         |          |          | L          | 4     |   |
|        |          |    |    | Bar | ık 1 |    |    |       |                  |     |           |            |         |          |          |            |       |   |
|        | <u> </u> |    |    |     |      |    |    |       |                  |     |           |            |         |          |          |            |       |   |
|        |          |    |    | Bar | ik O |    |    |       |                  |     |           |            |         |          |          |            |       |   |

Figure 18. Bit Address Maps



Example 26-Re-ordering I/O Port Configuration

| OUT_PZ | RRC | Α .    | MOVE ORIGINAL ACC O INTO CY   |
|--------|-----|--------|-------------------------------|
|        | MOV | P2 6,C | STORE CARRY TO PIN P26        |
|        | RRC | A      | , MOVE ORIGINAL ACC 1 INTO CY |
|        | MOV | P2 5.C | STORE CARRY TO PIN P25        |
|        | RRC | A      | , MOVE DRIGINAL ACC 2 INTO CY |
|        | MOV | P2 4,C | STORE CARRY TO PIN P24        |
|        | RRC | A      | , MOVE ORIGINAL ACC 3 INTO CY |
|        | MOV | P2 3,C | STORE CARRY TO PIN P23        |
|        | RRC | A      | , MOVE ORIGINAL ACC 4 INTO CY |
|        | MOV | P2 2,C | STORE CARRY TO PIN P22        |
|        | RET |        |                               |

#### Solving Combinatorial Logic Equations - ANL, ORL

Virtually all hardware designers are familiar with the problem of solving complex functions using combinatorial logic. The technologies involved may vary greatly, from multiple contact relay logic, vacuum tubes, TTL, or CMOS to more esoteric approaches like fluidics, but in each case the goal is the same: a Boolean (true/false) function is computed on a number of Boolean variables.

## 10-26





Figure 20 shows the logic diagram for an arbitrary function of six variables named U through Z using standard logic and relay logic symbols. Each is a solution of the equation,

$$Q = (U \cdot (V + W)) + (X \cdot \overline{Y}) + \overline{Z}$$

(While this equation could be reduced using Karnaugh Maps or algebraic techniques, that is not the purpose of this example. Even a minor change to the function equation would require re-reducing from scratch.)

Most digital computers can solve equations of this type with standard word-wide logical instructions and conditional jumps. Still, such software solutions seem somewhat sloppy because of the many paths through the program the computation can take.

Assume U and V are input pins being read by different input ports, W and X are status bits for two peripheral controllers (read as I/O ports), and Y and Z are software flags set or cleared earlier in the program. The end result must be written to an output pin on some third port.

For the sake of comparison we will implement this function with software drawn from three proper subsets of the MCS-51<sup>™</sup> instruction set. The first two implementations follow the flow chart shown in Figure 21. Program flow would embark on a route down a testand-branch tree and leaves either the "True" or "Not True" exit ASAP. These exits then write the output port with the data previously written to the same port with the result bit respectively one or zero.

In the first case, we assume there are no instructions for addressing individual bits other than special flags like the carry. This is typical of many older microprocessors and mainframe computers designed for number-crunching. MCS-51<sup>™</sup> mnemonics are used here, though for most other machines the issue would be even further clouded by their use of operation-specific mnemonics like INPUT, OUTPUT, LOAD, STORE, etc., instead of the universal MOV.



Figure 21. Flow chart for tree-branching logic implementation

#### Example 27—Software Solution to Logic Function of Figure 20, Using only Byte-Wide Logical Instructions

| , BFUNC 1<br>,<br>,<br>, | VARIABLE<br>BITS IN<br>JUMPS BA<br>(APPROAC<br>BYTE AND | RANDOM LOGIC FUNCTION OF 6<br>SBY LOADING AND MASKING THE APPROPRIATE<br>THE ACCUMULATOR. THEN EXECUTING CONDITIONAL<br>SED ON ZERO CONDITION<br>H USED BY BYTE-ORIENTED ARCHITECTURES )<br>MASK VALUES CORRESPOND TO RESPECTIVE<br>RESS AND BIT POSITION |
|--------------------------|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OUTBUF                   | EQU                                                     | 22H , OUTPUT PIN STATE MAP                                                                                                                                                                                                                                |
| ,<br>TESTV               | MOV<br>ANL<br>JNZ<br>MOV<br>ANL<br>JZ                   | A, P2<br>A, #00000100B<br>TESTU<br>A, #00100000B<br>TESTX                                                                                                                                                                                                 |
| TESTU                    | MOV<br>ANL<br>JNZ                                       | A, P1<br>A, #00000010B<br>SETG                                                                                                                                                                                                                            |
| TESTX                    | MOV<br>ANL<br>JZ<br>MOV<br>ANL<br>JZ                    | A, TCON<br>A, 400001000B<br>TESTZ<br>A, 2004<br>A, 400000001B<br>SFT0<br>SFT0                                                                                                                                                                             |
| TESTZ                    |                                                         | A, 21H<br>A, #00000010B<br>SETG                                                                                                                                                                                                                           |
| CLRG                     | MOV<br>ANL<br>JMP                                       | A, DUTBUF<br>A, #11110111B<br>DUTG                                                                                                                                                                                                                        |
| SETQ                     | MOV<br>ORL                                              | A, CUTBUF<br>A, #00001000B                                                                                                                                                                                                                                |
| OUTG                     | MOV                                                     | DUTBUF, A<br>P3, A                                                                                                                                                                                                                                        |

Cumbersome, to say the least, and error prone. It would be hard to prove the above example worked in all cases without an exhaustive test.

Each move/mask/conditional jump instruction sequence may be replaced by a single bit-test instruction thanks to direct bit addressing. But the algorithm would be equally convoluted.

#### Example 28—Software Solution to Logic Function of Figure 20, Using only Bit-Test Instructions

| / BFUNC2 | SOLVE A | RANDOM LOGIC FUNCTION OF 6        |
|----------|---------|-----------------------------------|
| ,        |         | ES BY DIRECTLY POLLING EACH BIT   |
|          |         | CH USING MCS-51 UNIQUE BIT-TEST   |
|          |         | TION CAPABILITY )                 |
|          | SYMBOLS | USED IN LOGIC DIAGRAM ASSIGNED TO |
|          |         | DNDING 8051 BIT ADDRESSES         |
| ,        |         |                                   |
| Ú.       | BIT     | P1 1                              |
| v        | BIT     | P2 2                              |
| w        | BIT     | TFO                               |
|          | BIT     | IE1                               |
| Y        | BIT     | 20H 0                             |
| z        | BIT     | 21H 1                             |
| G        | BIT     | P3 3                              |
| ,        |         |                                   |
| TEST_V   | JB      | V, TEST_U                         |
|          | JNB     | W, TEST_X                         |
| TEST_U   | JB      | U. SET_G                          |
| TEST_X   | JNB     | X. TEST_Z                         |
|          | JNB     | Y, SET_0                          |
| TEST_Z   | JNB     | Z, SET_Q                          |
| CLR_G    | CLR     | Q                                 |
|          | JMP     | NXTTST                            |
| SET_Q    | SETB    | Q                                 |
| NXTTST   |         | (CONTINUATION OF PROGRAM)         |

A more elegant and efficient 8051 implementation uses the Boolean ANL and ORL functions to generate the output function using straight-line code. These instructions perform the corresponding logical operations between the carry flag ("Boolean Accumulator") and the addressed bit, leaving the result in the carry. Alternate forms of each instruction (specified in the assembly language by placing a slash before the bit name) use the complement of the bit's state as the input operand. These instructions may be "strung together" to simulate a multiple input logic gate. When finished, the carry flag contains the result, which may be moved directly to the destination or output pin. No flow chart is needed — it is simple to code directly from the logic diagrams in Figure 20.

Example 29-Software Solution to Logic Function of

|      | F                        | figure 2                              | 20, Using the MCS-51 (TM)                                                                                            |
|------|--------------------------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------|
|      | ţ,                       | Jnique                                | Logical Instructions on Boolean                                                                                      |
|      | ١                        | /ariabl                               | les                                                                                                                  |
| UNC3 | VARIABLE                 | S USING                               | LOGIC FUNCTION OF 6<br>STRAIGHT-LINE LOGICAL INSTRUCTIONS<br>AN VARIABLES                                            |
|      | ANL                      | C, V<br>C, W<br>C, U<br>FO, C<br>C, X | , OUTPUT OF OR GATE<br>, OUTPUT OF TOP AND GATE<br>, SAVE INTERMEDIATE STATE                                         |
|      | ANL<br>ORL<br>ORL<br>MOV | C, /Y<br>C, FO<br>C, /Z<br>G, C       | , OUTPUT OF BOTTOM AND GATE<br>,INCLUDE VALUE SAVED ABOVE<br>,INCLUDE LAST INPUT VARIABLE<br>,OUTPUT COMPUTED RESULT |

Simplicity itself. Fast, flexible, reliable, easy to design, and easy to debug.

The Boolean features are useful and unique enough to warrant a complete Application Note of their own. Additional uses and ideas are presented in Application Note AP-70, Using the Intel<sup>®</sup> MCS-51<sup>®</sup> Boolean Processing Capabilities, publication number 121519.

#### 5. ON-CHIP PERIPHERAL FUNCTION OPERATION AND INTERFACING

#### I/O Ports

The I/O port versatility results from the "quasibidirectional" output structure depicted in Figure 22. (This is effectively the structure of ports 1, 2, and 3 for normal I/O operations. On port 0 resistor R2 is disabled except during multiplexed bus operations, providing



Figure 22. Pseudo-bidirectional I/O port circuitry AFN-01502A-30 essentially open-collector outputs. For full electrical characteristics see the User's Manual.)

An output latch bit associated with each pin is updated by direct addressing instructions when that port is the destination. The latch state is buffered to the outside world by R1 and Q1, which may drive a standard TTL input. (In TTL terms, Q1 and R1 resemble an opencollector output with a pull-up resistor to Vcc.)

R2 and Q2 represent an "active pull-up" device enabled momentarily when a 0 previously output changes to a 1. This "jerks" the output pin to a 1 level more quickly than the passive pull-up, improving rise-time significantly if the pin is driving a capacitive load. Note that the active pull-up is **only** activated on 0-to-1 transitions at the output latch (unlike the 8048, in which Q2 is activated whenever a 1 is written out).

Operations using an input port or pin as the source operand use the logic level of the pin itself, rather than the output latch contents. This level is affected by both the microcomputer itself and whatever device the pin is connected to externally. The value read is essentially the "OR-tied" function of Q1 and the external device. If the external device is high-impedence, such as a logic gate input or a three state output in the third state, then reading a pin will reflect the logic level previously output. To use a pin for input, the corresponding output latch must be set. The external device may then drive the pin with either a high or low logic signal. Thus the same port may be used as both input and output by writing ones to all pins used as output on an input operation.

In one operand instructions (INC, DEC, DJNZ and the Boolean CPL) the output latch rather than the input pin level is used as the source data. Similarly, two operand instructions using the port as both one source and the destination (ANL, ORL, XRL) use the output latches. This ensures that latch bits corresponding to pins used as inputs will not be cleared in the process of executing these instructions.

The Boolean operation JBC tests the output latch bit, rather than the input pin, in deciding whether or not to jump. Like the byte-wise logical operations, Boolean operations which modify individual pins of a port leave the other bits of the output latch unchanged.

A good example of how these modes may play together may be taken from the host-processor interface expected by an 8243 1/O expander. Even though the 8051 does not include 8048-type instructions for interfacing with an 8243, the parts can be interconnected (Figure 23) and the protocol may be emulated with simple software.

#### Example 30—Mixing Parallel Output, Input, and Control Strobes on Port 2

| . IN8243 | INPUT D | ATA FROM  | AN 8243 I /O EXPANDER   |
|----------|---------|-----------|-------------------------|
| ,        |         | ED TO P2. |                         |
| ,        | P25 % P | 24 MIMIC  | CS / & PROG             |
|          | P27-P26 | USED AS   | INPUTS                  |
| ,        | PORT TO | BF READ   | IN ACC                  |
|          |         |           |                         |
| IN8243   | OP'     | A. #11010 | 00008                   |
|          | MOV     | P2. A     | OUTPUT INSTRUCTION CODE |
|          | CLP     | P/2 4     | FALLING EDGE OF PROG    |
|          | OPL     | H2, #0000 | DIIIIB SET FOR INPUT    |
|          | MON     | V' 65     | READ INPUT DATA         |
|          | SETU    | PP 4      | RETURN PROG HIGH        |
|          | SEFB    | PP 5      | DE-SELECT CHIP          |

#### Serial Port and Timer applications

Configuring the 8051's Serial Port for a given data rate and protocol requires essentially three short sections of software. On power-up or hardware reset the serial port and timer control words must be initialized to the appropriate values. Additional software is also needed in the transmit routine to load the serial port data register and in the receive routine to unload the data as it arrives.

This is best illustrated through an arbitrary example. Assume the 8051 will communicate with a CRT operating at 2400 baud (bits per second). Each character is transmitted as seven data bits, odd parity, and one stop bit. This results in a character rate of 2400/10=240 characters per second.

For the sake of clarity, the transmit and receive subroutines are driven by simple-minded software status polling code rather than interrupts. (It might help to refer back to Figures 7-9 showing the control word formats.) The serial port must be initialized to 8-bit UART mode (M0, M1=01), enabled to receive all messages (M2=0, REN=1). The flag indicating that the transmit register is free for more data will be artificially set in order to let the output software know the output register is available. This can all be set up with one instruction.

#### Example 31 — Serial Port Mode and Control Bits SPINIT INITIALIZE SERIAL PORT FOR B-BIT UART MODE & SET TRANSMIT READY FLAG



Timer 1 will be used in auto-reload mode as a data rate generator. To achieve a data rate of 2400 baud, the timer must divide the 1 MHz internal clock by 32 x (desired data rate):

$$\frac{1 \times 10^6}{(32) (2400)}$$

which equals 13.02 rounded down to 13 instruction cycles. The timer must reload the value -13, or 0F3H. (ASM51 will accept both the signed decimal or hexadecimal representations.)

Example 32-Initializing Timer Mode and Control Bits

| TIINIT | AUTO-RE            | IZE TIMER 1 FOR<br>LOAD AT 32*2400 HZ<br>D AS GATED 16-BIT COUNTER ) |
|--------|--------------------|----------------------------------------------------------------------|
| TIINIT | MOV<br>MOV<br>SETB | TCDN, #11010010B<br>TH1, #-13<br>TR1                                 |

A simple subroutine to transmit the character passed to it in the accumulator must first compute the parity bit, insert it into the data byte, wait until the transmitter is available, output the character, and return. This is nearly as easy said as done.

#### Example 33—Code for UART Output, Adding Parity, Transmitter Loading

| , SP_OUT<br>; |            | PARITY TO ACC AND<br>T WHEN SERIAL PORT | READY |
|---------------|------------|-----------------------------------------|-------|
| SP_OUT        | MOV<br>CPL | С, Р<br>С                               |       |
|               | MOV        | ACC 7, C                                | /     |
|               | JNB        | TI,\$                                   |       |
|               | CLR        | ті                                      |       |
|               | MOV        | SBUF, A                                 |       |
|               | RET        |                                         |       |

A simple minded routine to wait until a character is received, set the carry flag if there is an odd-parity error, and return the masked seven-bit code in the accumulator is equally short.

Example 34—Code for UART Reception and Parity Verification

| , SP_IN |     | NEXT CHARACTER FROM SERIAL PORT<br>ARRY IFF ODD-PARITY ERROR |
|---------|-----|--------------------------------------------------------------|
| SP_IN   |     | RI,\$                                                        |
|         | MOV | A, SBUF                                                      |
|         | MOV | С, Р                                                         |
|         | CPL | C                                                            |
|         | ANL | A, #7FH                                                      |

#### 6. SUMMARY

This Application Note has described the architecture, instruction set, and on-chip peripheral features of the first three members of the MCS-51<sup>™</sup> microcomputer family. The examples used throughout were admittedly (and necessarily) very simple. Additional examples and techniques may be found in the MCS-51<sup>™</sup> User's Manual and other application notes written for the MCS-48<sup>™</sup> and MCS-51<sup>™</sup> families.

Since its introduction in 1977, the MCS-48<sup>TM</sup> family has become the industry standard single-chip microcomputer. The MCS-51<sup>TM</sup> architecture expands the addressing capabilities and instruction set of its predecessor while ensuring flexibility for the future, and maintaining basic software compatability with the past.

Designers already familiar with the 8048 or 8049 will be able to take with them the education and experience gained from past designs as ever-increasing system performance demands force them to move on to state-ofthe-art products, Newcomers will find the power and regularity of the 8051 instruction set an advantage in streamlining both the learning and design processes.

Microcomputer system designers will appreciate the 8051 as basically a single-chip solution to many problems which previously required board-level computers. Designers of real-time control systems will find the high execution speed, on-chip peripherals, and interrupt capabilities vital in meeting the timing constraints of products previously requiring discrete logic designs. And designers of industrial controllers will be able to convert ladder diagrams directly from tested-and-true TTL or relay-logic designs to microcomputer software, thanks to the unique Boolean processing capabilities.

It has not been the intent of this note to gloss over the difficulty of designing microcomputer-based systems. To be sure, the hardware and software design aspects of any new computer system are nontrivial tasks. However, the system speed and level of integration of the MCS-51<sup>TM</sup> microcomputers, the power and flexibility of the instruction set, and the sophisticated assembler and other support products combine to give both the hardware and software designer as much of a head start on the problem as possible.

Using the Intel MCS®-51 Boolean Processing Capabilities

## Contents

| 1. | INTRODUCTION                                                         |
|----|----------------------------------------------------------------------|
| 2. | BOOLEAN PROCESSOR OPERATION 10-32                                    |
|    | Processing Elements                                                  |
|    | Instruction Set                                                      |
|    | Simple Instruction Combinations                                      |
| 3. | BOOLEAN PROCESSOR APPLICATIONS 10-41                                 |
|    | Design Example #1 — Bit Permutation 10-42                            |
|    | Design Example #2 — Software Serial I/O 10-45<br>Design Example #3 — |
|    | Combinatorial Logic Equations                                        |
|    | Design Example #4 —<br>Automotive Dashboard Functions                |
|    | Design Example #5                                                    |
|    | Complex Control Functions                                            |
|    |                                                                      |
| 4. | <b>SUMMARY</b> 10-60                                                 |
|    | <b>APPENDIX A</b>                                                    |

### **1. INTRODUCTION**

The Intel microcontroller family now has three new members the Intel® 8031, 8051, and 8751 single-chip microcomputers. These devices, shown in Figure 1, will allow whole new classes of products to benefit from recent advances in Integrated Electronics. Thanks to Intel's new HMOS® technology, they provide larger program and data memory spaces, more flexible 1 O and peripheral' capabilities, greater speed, and lower system cost than any previous-generation single-chip microcomputer.

|                        |              | ) ·                                    |
|------------------------|--------------|----------------------------------------|
| P10 - C1.              | U            | 40 - VCC                               |
| P11 - C 2              |              | 39 <b>D</b> - P0 0 .                   |
| P12 - C 3              |              | 38 D - P0 1                            |
| P13 - C4               |              | 37 D - P0 2                            |
| P14 - C 5              |              | 36 🔁 — P0 3                            |
| , P15 — 🗖 6            |              | 35 🗖 — PO 4                            |
| P1.6 — 🗖 7             |              | 34 🔁 — P0 5                            |
| <sup>•</sup> P17 – C 8 |              | .33 p - P0 6                           |
| VPD/RST - C 9          |              | 32 <b>D</b> - P0 7                     |
| P3 0/RXD - C 10        |              | 31 D VDD/EA                            |
| P3 1/TXD — 🗖 11        |              | 30 - PROG/ALE                          |
| P3 2/INTO - C 12       | 8031         | 29 - PSEN                              |
| P3.3/INTI - C 13       | 8051<br>8751 | 28 <b>D</b> - P2 7                     |
| P3 4/TO — 🗖 14         |              | 27 D - P2 6                            |
| P3 5/TI — 🗖 15         |              | 26 - P2 5                              |
| P3 6/WR - C 16         |              | 25 - P2 4                              |
| P3 7/RD - C 17         |              | 24 🗖 — P2 3                            |
| XTAL2 - 🗖 18           |              | 23 🗖 — P2 2                            |
| XTAL1 - C 19           |              | 22 - P2 1                              |
| VSS C 20               |              | 21 🗖 — P2 0                            |
| L                      |              | •••••••••••••••••••••••••••••••••••••• |

Figure 1. 8051 Family Pinout Diagram.

Table 1 summarizes the quantitative differences between the members of the MCS-48<sup>™</sup> and 8051 families. The 8751 contains 4K bytes of EPROM program memory fabricated on-chip, while the 8051 replaces the EPROM with 4K bytes of lower-cost mask-programmed ROM. The 8031 has no program memory on-chip; instead, it accesses up to 64K bytes of program memory from external memory. Otherwise, the three new family members are identical. Throughout this Note, the term "8051" will represent all members of the 8051 Family, unless specifically stated otherwise. The CPU in each microcomputer is one of the industry's fastest and most efficient for numerical calculations on byte operands. But controllers often deal with bits, not bytes: in the real world, switch contacts can only be open or closed, indicators should be either lit or dark, motors are either turned on or off, and so forth. For such control situations the most significant aspect of the MCS-51<sup>™</sup> architecture is its complete hardware support for one-bit, or *Boolean* variables (named in honor of Mathematician George Boole) as a separate data type.

The 8051 incorporates a number of special features which support the direct manipulation and testing of individual bits and allow the use of single-bit variables in performing logical operations. Taken together, these features are referred to as the MCS-51<sup>™</sup> Boolean Processor. While the bit-processing capabilities alone would be adequate to solve many control applications, their true power comes when they are used in conjunction with the microcomputer's byte-processing and numerical capabilities.

Many concepts embodied by the Boolean Processor will certainly be new even to experienced microcomputer system designers. The purpose of this Application Note is to explain these concepts and show how they are used. It is assumed the reader has read Application Note AP-69, An Introduction to the Intel<sup>®</sup> MCS-51<sup>™</sup> Single-Chip Microcomputer Family, publication number 121518, or has been exposed to Intel's single-chip microcomputer product lines.

For detailed information on these parts refer to the Intel MCS-51<sup>™</sup> Family User's Manual, publication number 121517. The instruction set, assembly language, and use of the 8051 assembler (ASM51) are further described in the MCS-51<sup>™</sup> Macro Assembler User's Guide, publication number 9800937.

## 2. BOOLEAN PROCESSOR OPERATION

The Boolean Processing capabilities of the 8051 are based on concepts which have been around for some time. Digital computer systems of widely varying designs all have four functional elements in common (Figure 2):

| EPROM<br>Program<br>Memory | ROM<br>Program<br>Memory | External<br>Program<br>Memory | Program<br>Memory<br>(Int/Max) | Data<br>Memory<br>(Bytes) | Instr.<br>Cycle<br>Time | Input/<br>Output<br>Pins | Interrupt<br>Sources | Reg.<br>Banks |
|----------------------------|--------------------------|-------------------------------|--------------------------------|---------------------------|-------------------------|--------------------------|----------------------|---------------|
| The st                     | 8021                     |                               | 1K 1K                          | 64                        | 10 µSec                 | 21                       | 0                    | 1             |
|                            | 8022                     |                               | 2K 2K                          | 64                        | 10 µSec                 | 28                       | 2                    | 1             |
| 8748                       | 8048                     | 8035                          | 1K 4K                          | 64                        | 2.5 µSec                | 27                       | 2                    | 2             |
|                            | 8049                     | 8039                          | 2K 4K                          | 128                       | 1.36µSec                | 27                       | 2                    | 2             |
| 8751                       | 8051                     | 8031                          | 4K 64K                         | 128                       | 1.0 µSec                | 32                       | 5                    | 4             |

Table 1. Features of Intel's Single-chip Microcomputers.

- a central processor (CPU) with the control, timing, and logic circuits needed to execute stored instructions;
- a memory to store the sequence of instructions making up a program or algorithm;
- data memory to store variables used by the program; and
- some means of communicating with the outside world.



#### Figure 2. Block Diagram for Abstract Digital Computer.

The CPU usually includes one or more accumulators or special registers for computing or storing values during program execution. The instruction set of such a processor generally includes, at a minimum, operation classes to perform arithmetic or logical functions on program variables, move variables from one place to another, cause program execution to jump or conditionally branch based on register or variable states, and instructions to call and return from subroutines. The program and data memory functions sometimes share a single memory space, but this is not always the case. When the address spaces are separated, program and data memory need not even have the same basic word width.

A digital computer's flexibility comes in part from combining simple fast operations to produce more complex (albeit slower) ones, which in turn link together eventually solving the problem at hand. A four-bit CPU executing multiple precision subroutines can, for example, perform 64-bit addition and subtraction. The subroutines could in turn be building blocks for floating-point multiplication and division routines. Eventually, the four-bit CPU can simulate a far more complex "virtual" machine.

In fact, *any* digital computer with the above four functional elements can (given time) complete *any* algorithm (though the proverbial room full of chimpanzees at word processors might first re-create Shakespeare's classics and this Application Note)! This fact offers little consolation to product designers who want programs to run as quickly as possible. By definition, a real-time control algorithm *must* proceed quickly enough to meet the preordained speed constraints of other equipment.

One of the factors determining how long it will take a microcomputer to complete a given chore is the number of instructions it must execute. What makes a given computer architecture particularly well-or poorly-suited for a class of problems is how well its instruction set matches the tasks to be performed. The better the "primative" operations correspond to the steps taken by the control algorithm, the lower the number of instructions needed, and the quicker the program will run. All else being equal, a CPU supporting 64-bit arithmetic directly could clearly perform floating-point math faster than a machine bogged-down by multiple-precision subroutines. In the same way, direct support for bit manipulation naturally leads to more efficient programs handling the binary input and output conditions inherent in digital control problems.

### **Processing Elements**

The introduction stated that the 8051's bit-handling capabilities alone would be sufficient to solve some control applications. Let's see how the four basic elements of a digital computer - a CPU with associated registers, program memory, addressable data RAM, and I/O capability - relate to Boolean variables.

*CPU*. The 8051 CPU incorporates special logic devoted to executing several bit-wide operations. All told, there are 17 such instructions, all listed in Table 2. Not shown are 94 other (mostly byte-oriented) 8051 instructions.

*Program Memory*. Bit-processing instructions are fetched from the same program memory as other arithmetic and logical operations. In addition to the instructions of Table 2, several sophisticated program control features like multiple addressing modes, subroutine nesting, and a twolevel interrupt structure are useful in structuring Boolean Processor-based programs.

Boolean instructions are one, two, or three bytes long, depending on what function they perform. Those involving only the carry flag have either a single-byte opcode or an opcode followed by a conditional-branch destination byte (Figure 3.a). The more general instructions add a "direct address" byte after the opcode to specify the bit affected, yielding two or three byte encodings (Figure 3.b). Though this format allows potentially 256 directly addressable bit locations, not all of them are implemented in the 8051 family.

| Mnem  | nonic         | Description                                                                                    | Byte        | Сус                   |
|-------|---------------|------------------------------------------------------------------------------------------------|-------------|-----------------------|
| SETB  | С             | Set Carry flag                                                                                 | 1           | 1                     |
| SETB  | bit           | Set direct Bit                                                                                 | 2           | 1                     |
| CI R  | C             | Clear Carry flag                                                                               | I           | 1                     |
|       | bit           | Clear direct bit                                                                               | 2           | 1                     |
| CPI   | C             | Complement Carry flag                                                                          | 1           | 1                     |
| CPI.  | bit           | Complement direct bit                                                                          | 2           | 1                     |
| MOV   | C.bit         | Move direct bit to Carry flag                                                                  | 2           | 1                     |
| MOV   | bit.C         | Move Carry flag to direct bit                                                                  | 2           | 2                     |
| ANL   | C.bit         | AND direct bit to Carry flag                                                                   | 2           | 2                     |
| ANI   | C. bit        | AND complement of direct bit to Carry flag                                                     | 2           | 2<br>2                |
| ORI.  | C.bit         |                                                                                                | 2           | 2                     |
| ORL.  | C. bit        |                                                                                                | 2           | 2                     |
| 0111  |               | Carry flag                                                                                     | -           | -                     |
| JC    | rel           | Jump if Carry is flag is set                                                                   | - 2         | 2                     |
| JNC   | rel           | Jump if No Carry flag                                                                          | 2           | 2<br>2<br>2<br>2<br>2 |
| JB    | bit,rel       | Jump if direct Bit set                                                                         | 2<br>3<br>3 | 2                     |
| JNB   | bit.rel       | Jump if direct Bit Not set                                                                     | 3           | 2                     |
| JBC   | bit.rel       | Jump if direct Bit is set & Clear bit                                                          | 3           | 2                     |
| Addre | ss mo         | de abbreviations:                                                                              |             |                       |
| C -   | Carry         | flag.                                                                                          |             |                       |
| bit — | 128 so<br>bit | oftware flags, any I O pin, contr                                                              | ol or s     | status                |
| rel – | Rang          | nditional jumps include an 8-bit<br>e is +127 -128 bytes relative to f<br>llowing instruction. |             | -                     |

Table 2. MCS-51<sup>™</sup> Boolean Processing Instruction Subset.

All mnemonics copyrighted<sup>©</sup> Intel Corporation 1980

Data Memory. The instructions in Figure 3.b can operate directly upon 144 general purpose bits forming the Boolean processor "RAM." These bits can be used as sofware flags or to store program variables. Two operand instructions use the CPU's carry flag ("C") as a special one-bit register; in a sense, the carry is a "Boolean accumulator" for logical operations and data transfers.

*Input/Output.* All 32 1'O pins can be addressed as individual inputs, outputs, or both, in any combination. Any pin can be a control strobe output, status (Test) input, or serial 1 O link implemented via software. An additional 33 individually addressable bits reconfigure, control, and monitor the status of the CPU and all on-chip peripheral functions (timer 'counters, serial port modes, interrupt logic, and so forth).



#### Figure 3. Bit Addressing Instruction Formats.

#### **Direct Bit Addressing**

The most significant bit of the direct address byte selects one of two groups of bits. Values between 0 and 127 (00H and 7FH) define bits in a block of 32 bytes of on-chip RAM, between RAM addresses 20H and 2FH (Figure 4.a). They are numbered consecutively from the lowestorder byte's lowest-order bit through the highest-order byte's highest-order bit.

Bit addresses between 128 and 255(80H and 0FFH) correspond to bits in a number of special registers, mostly used for 1/0 or peripheral control. These positions are numbered with a different scheme than RAM: the five high-order address bits match those of the register's own address, while the three low-order bits identify the bit position within that register (Figure 4.b).



Figure 4. Bit Address Maps.

Notice the column labeled "Symbol" in Figure 5. Bits with special meanings in the PSW and other registers have corresponding symbolic names. General-purpose (as opposed to carry-specific) instructions may access the carry like any other bit by using the mnemonic CY in place of C, P0, P1, P2, and P3 are the 8051's four 1/O ports; secondary functions assigned to each of the eight pins of P3 are shown in Figure 6.

Figure 7 shows the last four bit addressable registers. TCON (Timer Control) and SCON (Serial port Control) control and monitor the corresponding peripherals, while IE (Interrupt Enable) and IP (Interrupt Priority) enable and prioritize the five hardware interrupt sources. Like the reserved hardware register addresses, the five bits not implemented in IE and IP should not be accessed; they can *not* be used as software flags.

| (MSB)             | )                   | (LSB)                                                                                                                                             |    |        | ,<br>,                                                                                                                                                        |
|-------------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|----|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| СҮ                | AC                  | F0 RS1 RS0 OV — P                                                                                                                                 | ov | PSW.2  | Overflow flag.                                                                                                                                                |
| <b>Symb</b><br>CY | ol Positic<br>PSW.7 | n Name and significance<br>Carry flag.<br>Set/cleared by hardware or soft-<br>ware during certain arithmetic and                                  |    | F3W.2  | Set/cleared by hardware during<br>arithmetic instructions to indicate<br>overflow conditions.                                                                 |
|                   |                     | logical instructions.                                                                                                                             | _  | PSW.1  | (reserved)                                                                                                                                                    |
| AC                | PSW.6               | Auxiliary Carry flag.<br>Set/cleared by hardware during<br>addition or subtraction instruc-<br>tions to indicate carry or borrow<br>out of bit 3. | Ρ  | PSW:0  | Parity flag.<br>Set/cleared by hardware each in<br>struction cycle to indicate an odd/<br>even number of "one" bits in the<br>accumulator, i.e., even parity. |
| F0                | PSW.5               | Flag 0.<br>Set/cleared/tested by software as<br>a user-defined status flag.                                                                       |    | Note - | the contents of (RS1, RS0) enable<br>the working register banks a<br>follows:                                                                                 |
| RS1<br>RS0        | PSW.4<br>PSW.3      | 3                                                                                                                                                 |    | 2<br>1 | (0,0) - Bank 0 (00H-07H)<br>(0,1) - Bank 1 (08H-0FH)<br>(1,0) - Bank 2 (10H-17H)<br>(1,1) - Bank 3 (18H-1FH)                                                  |

## Figure 5. PSW - Program Status Word organization.

| (MSB)       | )              |        |                              |                   |                     |         | (LSB)  |      |              | 1                                                                 |
|-------------|----------------|--------|------------------------------|-------------------|---------------------|---------|--------|------|--------------|-------------------------------------------------------------------|
| RD          | WR             | T1     | то                           | INT1              | INT0                | тхр     | RXD    | ``   |              |                                                                   |
| Symbo<br>RD | P3.7           |        | ame a<br>ead da              | -                 |                     |         |        | INT1 | P3.3         | Interrupt 1 input pin.                                            |
| שו          | F <b>J</b> . 7 | A<br>h | ctive I<br>ardwa<br>nemory   | ow pi<br>re wh    | ulse ge<br>en ex    | enerat  |        |      | г <b>о.о</b> | Low-level or falling-edge triggered.                              |
| ٧R          | P3.6           | W<br>A | /rite da<br>ctive I<br>ardwa | ita con<br>owi pu | itrol ou<br>ulse ge | enerat  |        | INT0 | P3 2         | Interrupt 0 input pin.<br>Low-level or falling-edge<br>triggered. |
|             |                | n      | emory                        |                   |                     |         | uuuu   | TXD  | P3.1         | Transmit Data pin for serial<br>in UART mode. Clock outp          |
| -1<br>-     | P3.5           |        | imer/c<br>est pin.           | ounter            | 1 exte              | rnal ir | put or | RXD  | P3.0         | shift register mode<br>Receive Data pin for serial po             |
| 0           | P3.4           | •      | imer/c<br>est pin.           | ounter            | 0 exte              | rnal ir | put or | ŅΛŬ  | F3.0         | UART mode. Data I/O pin in register mode.                         |

### Figure 6. P3 - Alternate I/O Functions of Port 3.

| MSB)                             |                                    |                                                                 |                                                                                                                       |                                                                                                             |                                                                                                                      |                                                                              | (LSB)                                                                      |           |                  |                                                                                                                                                                                                                                                                                           |
|----------------------------------|------------------------------------|-----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|----------------------------------------------------------------------------|-----------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TF1                              | TR1                                | TF0                                                             | TR0                                                                                                                   | IE1                                                                                                         | IT1                                                                                                                  | IE0                                                                          | ІТО                                                                        | IE1       | TCON.3           | Interrupt 1 Edge flag.<br>Set by hardware when external                                                                                                                                                                                                                                   |
| TF1                              |                                    | DN.7 T                                                          | <b>lame a</b><br>ïmer 1<br>et by h                                                                                    | overfl                                                                                                      | ow Fla                                                                                                               |                                                                              |                                                                            |           |                  | interrupt edge detected. Cleare when interrupt processed.                                                                                                                                                                                                                                 |
| TR1                              | тсс                                | w                                                               | mer/co<br>hen in<br>imer 1                                                                                            | terrup                                                                                                      | t proce                                                                                                              | essed.                                                                       | eared                                                                      | IT1       | TCON.2           | Interrupt 1 Type control bit.<br>Set/cleared by software to<br>specify falling edge/low level<br>triggered external interrupts.                                                                                                                                                           |
|                                  | ŕ                                  |                                                                 | et/clea<br>mer/co                                                                                                     | •                                                                                                           |                                                                                                                      |                                                                              | turn                                                                       | IE0       | TCON.1           | Interrupt 0 Edge flag.                                                                                                                                                                                                                                                                    |
| TFO                              | тсс                                | S                                                               | imer 0<br>et by h<br>mer/co                                                                                           | nardwa                                                                                                      | ire on                                                                                                               | •                                                                            | eared                                                                      |           |                  | Set by hardware when external interrupt edge detected. Cleare when interrupt processed.                                                                                                                                                                                                   |
| -                                |                                    | w                                                               | hen in                                                                                                                | terrup                                                                                                      | t proce                                                                                                              | essed.                                                                       | eared                                                                      | ТО        | TCON.0           | Interrupt 0 Type control bit.<br>Set/cleared by softrware to                                                                                                                                                                                                                              |
| rro                              | TCC                                | S                                                               | imer 0<br>et/clea<br>mer/cc                                                                                           | red by                                                                                                      | / softw                                                                                                              | are to                                                                       | turn                                                                       |           |                  | specify falling edge/low level triggered external interrupts.                                                                                                                                                                                                                             |
|                                  | <b>ON -</b> 1                      | limer/                                                          | Counte                                                                                                                | er Con                                                                                                      | trol/st                                                                                                              | atus re                                                                      | egister.                                                                   |           |                  |                                                                                                                                                                                                                                                                                           |
| a.) 10                           |                                    |                                                                 |                                                                                                                       |                                                                                                             |                                                                                                                      |                                                                              |                                                                            |           |                  |                                                                                                                                                                                                                                                                                           |
| -                                |                                    |                                                                 |                                                                                                                       |                                                                                                             |                                                                                                                      |                                                                              | (LSB)                                                                      |           | ,                |                                                                                                                                                                                                                                                                                           |
|                                  | SM1                                | SM2                                                             | REN                                                                                                                   | TB8                                                                                                         | RB8                                                                                                                  | ті                                                                           | (LSB)<br>RI                                                                |           |                  |                                                                                                                                                                                                                                                                                           |
| MSB)<br>SM0<br>Symbo             | SM1                                | ition N                                                         | lame a                                                                                                                | nd sig                                                                                                      | nificar                                                                                                              | nce                                                                          | RI                                                                         |           |                  |                                                                                                                                                                                                                                                                                           |
| MSB)<br>SMO<br>Symbo<br>SMO      | SM1<br>DI Pos<br>SCO               | ition N<br>DN,7 S<br>S<br>n                                     | lame a<br>Serial p<br>Set/clea                                                                                        | ort Mo<br>ared b                                                                                            | n <b>ificar</b><br>ode col<br>y softw                                                                                | n <b>ce</b><br>ntrol b<br>vare (s                                            | RI<br>bit 0.                                                               | RB8       | SCON.2           | Receive Bit 8.<br>Set/cleared by hardware to indicate state of ninth data bit received.                                                                                                                                                                                                   |
| MSB)<br>SMO<br>Symbo<br>SMO      | SM1<br>DI Pos<br>SCO               | ition N<br>DN.7 S<br>n<br>DN.6 S                                | lame a<br>Serial p<br>Set/clea                                                                                        | ort Mo                                                                                                      | nificar<br>ode con<br>y softw                                                                                        | n <b>ce</b><br>ntrol b<br>vare (s                                            | RI<br>bit 0.<br>ee<br>bit 1.                                               | RB8<br>TI |                  | Set/cleared by hardware to ind<br>cate state of ninth data bit<br>received.<br>Transmit Interrupt flag.                                                                                                                                                                                   |
| MSB)<br>SMO<br>Symbo<br>SMO      | SM1<br>DI Pos<br>SCC<br>SCC        | ition N<br>DN.7 S<br>DN.6 S<br>DN.6 S<br>n<br>DN.5 S            | Jame a<br>Serial p<br>Set/clea<br>ote).<br>Serial p<br>Set/clea<br>ote).<br>Serial p                                  | ort Mo<br>ared b                                                                                            | nificar<br>ode con<br>y softw<br>ode con<br>y softw                                                                  | ntrol b<br>vare (s<br>ntrol b<br>vare (s                                     | RI<br>pit 0.<br>aee<br>pit 1.<br>aee                                       |           |                  | Set/cleared by hardware to ind<br>cate state of ninth data bit<br>received.<br>Transmit Interrupt flag.<br>Set by hardware when byte                                                                                                                                                      |
| MSB)<br>SMO<br>Symbo<br>SMO      | SM1<br>DI Pos<br>SCC<br>SCC        | ition N<br>DN.7 S<br>DN.6 S<br>DN.6 S<br>S<br>DN.5 S<br>S<br>ti | Jame a<br>Serial p<br>Set/clea<br>ote).<br>Serial p<br>Set/clea<br>ote).<br>Serial p                                  | ort Ma<br>ared b<br>ort Ma<br>ared b<br>ort Ma<br>softwa                                                    | nificar<br>ode col<br>y softw<br>ode col<br>y softw<br>ode col<br>re to d                                            | n <b>ce</b><br>ntrol b<br>vare (s<br>ntrol b<br>vare (s<br>ntrol b<br>isable | RI<br>bit 0.<br>ee<br>bit 1.<br>ee<br>bit 2.<br>recep-                     |           | SCON.1           | Set/cleared by hardware to ind<br>cate state of ninth data bit<br>received.<br>Transmit Interrupt flag.<br>Set by hardware when byte<br>transmitted. Cleared by softwar<br>after servicing.<br>Receive Interrupt flag.<br>Set by hardware when byte re-                                   |
| MSB)<br>SM0                      | SM1<br>Pos<br>SCC<br>SCC           | ition N<br>DN.7 S<br>DN.7 S<br>S<br>DN.5 S<br>ti<br>z<br>DN.4 F | lame a<br>Serial p<br>Set/clea<br>lote).<br>Serial p<br>Set/clea<br>lote).<br>Serial p<br>Set by s<br>on of f<br>ero. | and sig<br>ort Mo<br>ared b<br>ort Mo<br>ared b<br>ort Mo<br>softwa<br>rames<br>er Enal<br>ared b           | nificar<br>ode col<br>y softw<br>ode col<br>y softw<br>ode col<br>re to d<br>for wh<br>ole cor<br>y softw            | ntrol b<br>vare (s<br>ntrol b<br>vare (s<br>ntrol b<br>ntrol b<br>vare to    | RI<br>bit 0.<br>eee<br>bit 1.<br>eee<br>bit 2.<br>recep-<br>it 8 is<br>it. | ті        | SCON.1           | Set/cleared by hardware to ind<br>cate state of ninth data bit<br>received.<br>Transmit Interrupt flag.<br>Set by hardware when byte<br>transmitted. Cleared by softwar<br>after servicing.<br>Receive Interrupt flag.<br>Set by hardware when byte re-                                   |
| MSB)<br>SM0<br>SM0<br>SM1<br>SM2 | SM1<br>DI Pos<br>SCC<br>SCC<br>SCC | DN.6 S<br>DN.6 S<br>DN.5 S<br>DN.5 S<br>DN.4 F<br>S<br>CN.4 F   | Jame a<br>Serial p<br>Set/clea<br>tote).<br>Serial p<br>Set/clea<br>tote).<br>Serial p<br>Set by s<br>on of f<br>ero. | and sig<br>ort Mo<br>ared b<br>ort Mo<br>ared b<br>ort Mo<br>softwa<br>rames<br>er Enal<br>ared b<br>disabl | nificar<br>ode col<br>y softw<br>ode col<br>y softw<br>ode col<br>re to d<br>for wh<br>ole cor<br>y softw<br>e seria | ntrol b<br>vare (s<br>ntrol b<br>vare (s<br>ntrol b<br>ntrol b<br>vare to    | RI<br>bit 0.<br>eee<br>bit 1.<br>eee<br>bit 2.<br>recep-<br>it 8 is<br>it. | ті        | SCON.1<br>SCON.0 | Set/cleared by hardware to indicate state of ninth data bit<br>received.<br>Transmit Interrupt flag.<br>Set by hardware when byte<br>transmitted. Cleared by softwar<br>after servicing.<br>Receive Interrupt flag.<br>Set by hardware when byte re-<br>ceived. Cleared by software after |

## Figure 7. Peripheral Configuration Registers.

| (MSB)              |                                       | `    |                                                                               |                                                  |                                           |                              | (LSB)        |     |      |                                                                                                                               |
|--------------------|---------------------------------------|------|-------------------------------------------------------------------------------|--------------------------------------------------|-------------------------------------------|------------------------------|--------------|-----|------|-------------------------------------------------------------------------------------------------------------------------------|
| EA                 | -                                     | ·    | ES                                                                            | ET1                                              | EX1                                       | ET1                          | EX0          |     |      |                                                                                                                               |
| <b>Symbo</b><br>EA | I Posi<br>IE 7                        |      | Name a<br>Enable<br>Cleared<br>interrup<br>state of                           | All con<br>by sol<br>ts, inde                    | trol bit<br>tware<br>epende               | t.<br>to disa                |              | EX1 | IE.2 | Enable External interrupt 1<br>control bit. Set/cleared by<br>software to enable/disable<br>interrupts from INT1.             |
| <br><br>ES         | IE.6<br>IE.5<br>IE 4                  |      | (reserve<br>Enable S<br>Set/clea                                              | Serial p                                         |                                           |                              | oit          | ET0 | IE.1 | Enable Timer 0 control bit.<br>Set/cleared by software to<br>enable/ disable interrupts from<br>timer/counter 0.              |
| ET1                | IE 3                                  |      | enable/<br>TI or RI<br>Enable <sup>-</sup><br>Set/clea<br>enable/<br>timer/cc | disable<br>flags.<br>Timer<br>ired by<br>disable | e interi<br>1 conti<br>softwa<br>e interi | rupts f<br>rol bit<br>are to |              | EX0 | IE 0 | Enable External interrupt 0<br>control bit. Set/cleared by<br>software to enable/disable<br>interrupts from INT0.             |
| c.) IE             | - Inte                                | rrup | Enable                                                                        | Regis                                            | ter.                                      |                              |              | ,   |      | . **. · · · ·                                                                                                                 |
| MSB)<br>—          | ,                                     |      | PS                                                                            | PT1                                              | PX1                                       | РТО                          | (LSB)<br>PX0 |     |      |                                                                                                                               |
| Symbo              | I <b>Posi</b><br>IP.7<br>IP.6<br>IP.5 |      | Name a<br>(reserve<br>(reserve<br>(reserve                                    | ed)<br>ed)                                       | nifican                                   | ce                           |              | PX1 | IP.2 | External interrupt 1 Priority<br>control bit. Set/cleared by<br>software to specify high/low<br>priority interrupts for INT1. |
| PS                 | IP 4                                  |      | Serial p<br>Set/clea<br>specify<br>interrup                                   | ared.by<br>high/lo                               | softw                                     | are to<br>prity              |              | PT0 | IP 1 | Timer 0 Priority control bit.<br>Set/cleared by software to<br>specify high/low priority<br>interrupts for timer/counter 0.   |
| PT1                | IP.3                                  | ,    | Timer 1<br>Set/clea<br>specify<br>interrup                                    | ared by<br>high/lo                               | softw                                     | are to<br>prity              |              | PX0 | IP.0 | External interrupt 0 Priority<br>control bit. Set/cleared by<br>software to specify high/low<br>priority interrupts for INT0. |

#### Figure 7. (continued)

Addressable Register Set. There are 20 special function registers in the 8051, but the advantages of bit addressing only relate to the 11 described below. Five potentially bit-addressable register addresses (0C0H, 0C8H, 0D8H, 0E8H, & 0F8H) are being reserved for possible future expansion in microcomputers based on the MCS-51<sup>TM</sup> architecture. Reading or writing non-existent registers in the 8051 series is pointless, and may cause unpredictable results. Byte-wide logical operations can be used to manipulate bits in all *non*-bit addressable registers and RAM.

The accumulator and B registers (A and B) are normally involved in byte-wide arithmetic, but their individual bits can also be used as 16 general software flags. Added with the 128 flags in RAM, this gives 144 general purpose variables for bit-intensive programs. The program status word (PSW) in Figure 5 is a collection of flags and machine status bits including the carry flag itself. Byte operations acting on the PSW can therefore affect the carry.

### **Instruction Set**

Having looked at the bit variables available to the Boolean Processor, we will now look at the four classes of instructions that manipulate these bits. It may be helpful to refer back to Table 2 while reading this section.

State Control. Addressable bits or flags may be set, cleared, or logically complemented in one instruction cycle with the two-byte instructions SETB, CLR, and CPL. (The "B" affixed to SETB distinguishes it from the assembler "SET" directive used for symbol definition.) SETB and CLR are analogous to loading a bit with a constant: 1 or 0. Single byte versions perform the same three operations on the carry.

The MCS-51<sup>TM</sup> assembly language specifies a bit address in any of three ways:

- by a number or expression corresponding to the direct bit address (0-255);
- by the name or address of the register containing the bit, the *dot operator* symbol (a period: "."), and the bit's position in the register (7-0);
- in the case of control and status registers, by the predefined assembler symbols listed in the first columns of Figures 5-7.

Bits may also be given user-defined names with the assembler "BIT" directive and any of the above techniques. For example, bit 5 of the PSW may be cleared by any of the four instructions,

| USR_FLG BIT | PSW.5   | : User Symbol Definition |
|-------------|---------|--------------------------|
| :           |         |                          |
| CLR         | 0D5H    | : Absolute Addressing    |
| CLR         | PSW.5   | : Use of Dot Operator    |
| · CLR       | F0      | ; Pre-Defined Assembler  |
|             |         | ; Symbol                 |
| CLR         | USR_FLG | : User-Defined Symbol    |

Data Transfers. The two-byte MOV instructions can transport any addressable bit to the carry in one cycle, or copy the carry to the bit in two cycles. A bit can be moved between two arbitrary locations via the carry by combining the two instructions. (If necessary, push and pop the PSW to preserve the previous contents of the carry.) These instructions can replace the multi-instruction sequence of Figure 8, a program structure appearing in controller applications whenever flags or outputs are conditionally switched on or off.

Logical Operations. Four instructions perform the logical-AND and logical-OR operations between the carry and another bit, and leave the results in the carry. The instruction mnemonics are ANL and ORL; the absence or presence of a



Figure 8. Bit Transfer Instruction Operation.

slash mark ("/") before the source operand indicates whether to use the positive-logic value or the logical complement of the addressed bit. (The source operand itself is never affected.)

Bit-test Instructions. The conditional jump instructions "JC rel" (Jump on Carry) and "JNC rel" (Jump on Not Carry) test the state of the carry flag, branching if it is a one or zero, respectively. (The letters "rel" denote relative code addressing.) The three-byte instructions "JB bit, rel" and "JNB bit,rel" (Jump on Bit and Jump on Not Bit) test the state of *any* addressable bit in a similar manner. A fifth instruction combines the Jump on Bit and Clear operations. "JBC bit,rel" conditionally branches to the indicated address, then clears the bit in the same two cycle instruction. This operation is the same as the MCS-48<sup>TM</sup> "JTF" instructions.

All 8051 conditional jump instructions use program counter-relative addressing, and all execute in two cycles. The last instruction byte encodes a signed displacement ranging from -128 to +127. During execution, the CPU adds this value to the incremented program counter to produce the jump destination. Put another way, a conditional jump to the immediately following instruction would encode 00H in the offset byte.

A section of program or subroutine written using only relative jumps to nearby addresses will have the same machine code independent of the code's location. An assembled routine may be repositioned anywhere in memory, even crossing memory page boundaries, without having to modify the program or recompute destination addresses. To facilitate this flexibility, there is an unconditional "Short Jump" (SJMP) which uses relative addressing as well. Since a pro-

10-39

grammer would have quite a chore trying to compute relative offset values from one instruction to another, ASM51 automatically computes the displacement needed given only the destination address or label. An error message will alert the programmer if the destination is "out of range."

(The so-called "Bit Test" instructions implemented on many other microprocessors simply perform the logical-AND operation between a byte variable and a constant mask, and set or clear a zero flag depending on the result. This is essentially equivalent to the 8051 "MOV C,bit" instruction. A second instruction is then needed to conditionally branch based on the state of the zero flag. This does *not* constitute abstract bit-addressing in the MCS-51<sup>TM</sup> sense. A flag exists only as a field within a register; to reference a bit the programmer must know and specify both the encompassing register and the bit's position therein. This constraint severely limits the flexibility of symbolic bit addressing and reduces the machine's code-efficiency and speed.)

Interaction with Other Instructions. The carry flag is also affected by the instructions listed in Table 3. It can be rotated through the accumulator, and altered as a side effect of arithmetic instructions. Refer to the User's Manual for details on how these instructions operate.

#### **Simple Instruction Combinations**

By combining general purpose bit operations with certain addressable bits, one can "custom build" several hundred useful instructions. All eight bits of the PSW can be tested directly with conditional jump instructions to monitor (among other things) parity and overflow status. Programmers can take advantage of 128 software flags to keep track of operating modes, resource usage, and so forth.

The Boolean instructions are also the most efficient way to control or reconfigure peripheral and 1 O registers. All 32 I/O lines become "test pins," for example, tested by conditional jump instructions. Any output pin can be toggled (complemented) in a single instruction cycle. Setting or clearing the Timer Run flags (TR0 and TR1) turn the timer/counters on or off; polling the same flags elsewhere lets the program determine if a timer is running. The respective overflow flags (TF0 and TF1) can be tested to determine when the desired period or count has elapsed, then cleared in preparation for the next repetition. (For the record, these bits are all part of the TCON register, Figure 7.a. Thanks to symbolic bit addressing, the programmer only needs to remember the mnemonic associated with each function. In other words, don't bother memorizing control word layouts.)

In the MCS-48® family, instructions corresponding to some of the above functions require specific opcodes. Ten different opcodes serve to clear/complement the software flags F0 and F1, enable/disable each interrupt, and start/stop the timer. In the 8051 instruction set, just three opcodes (SETB,

| Table | 3. | Other | Instructions | Affecting | the | Carry |
|-------|----|-------|--------------|-----------|-----|-------|
|       |    |       | Flag.        |           |     | '     |

|            |                 | Flag.                                        |      |     |
|------------|-----------------|----------------------------------------------|------|-----|
| Mnemoni    | c               | Description                                  | Byte | Cyc |
| ADD A.R    | n               | Add register to                              |      |     |
|            |                 | Accumulator                                  | 1    | 1   |
| ADD A.d    | irect           | Add direct byte to                           |      |     |
|            |                 | Accumulator                                  | 2    | 1   |
| ADD A.@    | 0 <b>R</b> i    | Add indirect RAM to                          |      |     |
|            |                 | Accumulator                                  | 1    | 1   |
| ADD A.#    | data            | Add immediate data to Accumulator            | 2    | 1   |
| ADDC A, R  | 'n              | Add register to                              | 2    | 1   |
| ADDC A,N   | .11             | Accumulator with Carry                       |      |     |
|            |                 | flag                                         | 1    | 1   |
| ADDCA, o   | lirect          | Add direct byte to                           | •    | •   |
|            |                 | Accumulator with Carry                       |      |     |
|            |                 | flag                                         | 2    | 1   |
| ADDC A.@   | Rı              | Add indirect RAM to                          |      |     |
|            |                 | Accumulator with Carry                       |      |     |
|            |                 | flag                                         | 1    | Ţ   |
| ADDC A,#   | data            | Add immediate data to                        |      |     |
|            |                 | Acc with Carry flag                          | 2    | 1   |
| SUBB A.R   | n               | Subtract register from                       |      |     |
|            |                 | Accumulator with                             |      |     |
|            |                 | borrow                                       | 1    | 1   |
| SUBB A.d   | irect           | Subtract direct byte<br>from Acc with borrow | 2    | 1   |
| SUBB A.@   | D.              | Subtract indirect RAM                        | 2    | I   |
| SUDD A.@   | <sup>U</sup> RI | from Acc with borrow                         | I    | 1   |
| SUBB A.#   | data            | Subtract immediate data                      |      | •   |
|            | aata            | from Acc with borrow                         | 2    | 1   |
| MUL AB     |                 | Multiply A & B                               | ī    | 4   |
| DIV AB     |                 | Divide A by B                                | i    | 4   |
| DA A       |                 | Decimal Adjust                               |      |     |
|            |                 | Accumulator                                  | 1    | 1   |
| DIG .      |                 |                                              |      |     |
| RLC A      |                 | Rotate Accumulator                           |      |     |
|            |                 | Left through the Carry                       | 1    | 1   |
| RRC A      |                 | flag<br>Rotate Accumulator                   | '    | 1   |
|            |                 | Right through Carry flag                     | I    | 1   |
|            |                 | Right through Carry hag                      |      |     |
| CJNE A.d   | rect rel        | Compare direct byte to                       |      |     |
| C0 12 /110 |                 | Acc & Jump if Not                            |      |     |
|            |                 | Equal                                        | 3    | 2   |
| CJNE A,#   | data.rel        | Compare immediate to                         |      |     |
|            |                 | Acc & Jump if Not                            |      |     |
|            |                 | Equal                                        | 3    | 2   |
| CJNE Rn.   | #data.rel       | Compare immed to                             |      |     |
|            |                 | register & Jump if Not                       |      |     |
|            |                 | Equal                                        | 3    | 2   |
| CJNE @R    | 1,#data.re      | Compare immed to                             |      |     |
|            |                 | indirect & Jump if Not                       | •    | 2   |
|            |                 | Equal                                        | 3    | 2   |
|            |                 |                                              |      |     |
|            |                 |                                              |      |     |

All mnemonics copyrighted © Intel Corporation 1980

CLR, CPL) with a direct bit address appended perform the same functions. Two test instructions (JB and JNB) can be combined with bit addresses to test the software flags, the 8048 I/O pins T0, T1, and INT, and the eight accumulator bits, replacing 15 more different instructions.

Table 4.a shows how 8051 programs implement software flag and machine control functions associated with special

using awkward sequences of other basic operations. As mentioned earlier, any CPU can solve any problem given enough time.

Quantitatively, the differences between a solution allowed by the 8051 and those required by previous architectures are numerous. What the 8051 Family buys you is a faster, cleaner, lower-cost solution to microcontroller applications.

The opcode space freed by condensing many specific 8048

| 8048<br>Instruction | Bytes         |        | Bytes Cycles uSec |     | 8x51<br>Instruc | tion      | Bytes  | Cycles & uSec                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|---------------------|---------------|--------|-------------------|-----|-----------------|-----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Flag Control        |               |        |                   |     |                 |           |        | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| CLR C               |               | 1      | 1,                | 2.5 | CLR             | С         | 1      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| CPL FO              |               | 1      | I                 | 2.5 | CPL             | F0        | 2      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| Flag Testing        |               |        |                   |     |                 |           |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| JNC of              | fset          | 2      | 2                 | 5.0 | JNC             | rel       | 2      | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| JF0 of              | fset          | 2<br>2 | 2                 | 5.0 | JB              | F0,rel    | 2<br>3 | . 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| JB7 of              | fset          | 2      | 2                 | 5.0 | JB              | ACC.7,rel | 3      | . 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| Peripheral Pol      | ing           |        |                   |     |                 |           |        | 4999 - 2999 - 2999 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 - 200 |  |
|                     | fset          | 2      | 2                 | 5.0 | JB              | T0,rel    | 3      | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| JNI of              | fset          | 2      | 2                 | 5.0 | JNB -           | INT0, rel | 3      | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| JTF of              | fset          | 2      | 2                 | 5.0 | JBC             | TF0,rel   | 3      | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| Machine and F       | eripheral Con | ntrol  |                   |     |                 |           |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| STRT T              | •             | 1      | 1                 | 2.5 | SETB            | TR0       | 2      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| EN I                |               | 1      | 1                 | 2.5 | SETB            | EX0       | 2<br>2 | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|                     | INTI          | 1      | 1                 | 2.5 | CLR             | ET0       | 2      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |

#### Table 4.a. Contrasting 8048 and 8051 Bit Control and Testing Instructions.

Table 4.b. Replacing 8048 instruction sequences with single 8x51 instructions.

| 8048<br>Instructions                         | Bytes | s Cycles | uSec | 8051<br>Instructions | Bytes | Cycles & uSec |
|----------------------------------------------|-------|----------|------|----------------------|-------|---------------|
| Flag Control<br>Set carry:<br>CLR C<br>CPL C | -     | 2 2      | 5.0  | SETB C               | 1     | , ' <b>1</b>  |
| Set Software Flag:<br>CLR F0<br>CPL F0       | =     | 2 2      | 5.0  | SETB F0              | 2     | 1             |

opcodes in the 8048. In every case the MCS-51<sup>m</sup> solution requires the same number of machine cycles, and executes 2.5 times faster.

## 3. BOOLEAN PROCESSOR APPLICATIONS

So what? Then what does all this buy you?

Qualitatively, nothing. All the same capabilities could be (and often have been) implemented on other machines instructions into a few general operations has been used to add new functionality to the MCS-51<sup>TM</sup> architecture - both for byte and bit operations. 144 software flags replace the 8048's two. These flags (and the carry) may be directly set, not just cleared and complemented, and all can be tested for either state, not just one. Operating mode bits previously inaccessible may be read, tested, or saved. Situations where the 8051 instruction set provides new capabilities are contrasted with 8048 instruction sequences in Table 4.b. Here the 8051 speed advantage ranges from 5x to 15x!

|                    |                        |      |       | 1      | Table 4b. ( | Continued      | l)        |       | 1             |
|--------------------|------------------------|------|-------|--------|-------------|----------------|-----------|-------|---------------|
| 8048<br>Instructio | ons                    | r    | Bytes | Cycles | uSec        | 8x51<br>Instru | uctions   | Bytes | Cycles & uSec |
| Turn Off O         |                        |      |       |        | v           |                |           |       |               |
| ANL                | P1,#0FBH               | Ξ    | 2     | 2      | 5.0         | CLR            | P1.2      | 2     | 1             |
| Complemen<br>IN    | nt Output Pin:<br>A,Pl |      |       |        |             |                |           |       |               |
|                    | A,#04H                 |      |       |        |             |                |           |       |               |
| OUTL               |                        | . =  | 4     | 6      | 15.0        | CPL            | P1.2      | 2     | 1             |
| Clear Flag         | in RAM:                |      |       |        | a.          |                |           |       |               |
|                    | R0,#FLGAD              | R    |       | ,      | L.          |                |           |       |               |
| MOV                | A,@R0                  |      |       |        |             |                |           |       |               |
| ANL                | A,#FLGMAS              | SΚ   |       |        |             |                |           |       |               |
| MOV                | @R0.A                  | =    | 6     | 6      | 15.0        | CLR            | USER_FLG  | 2     | 1             |
| Flag Testin        | g.                     |      |       |        |             |                |           |       |               |
| Jump if So         | ftware Flag is (       | ):   |       |        |             |                | ,         |       |               |
| JF0                | \$+4                   |      |       |        | ,           |                |           |       |               |
| JMP                | offset                 | =    | 4     | 4      | 10.0        | JNB            | F0,rel    | 3     | 2             |
| lumn if Ac         | cumulator bit i        | s 0. |       |        |             |                |           |       |               |
| CPL                |                        | 5 0. |       |        |             |                |           |       |               |
| JB7                | offset                 |      |       |        |             |                |           |       |               |
| CPL                | A                      | =    | 4     | 4      | 10.0        | JNB            | ACC.7,rel | 3     | 2             |
| Peripheral         | Polling                |      |       |        |             |                |           |       | 1. P. P.      |
|                    | it Pin is Groun        | ded  |       |        |             |                |           |       |               |
| IN                 | A,P1                   |      |       |        |             | 1              |           |       |               |
| CPL                | A                      |      |       |        |             |                |           |       |               |
| JB3                | offset                 | Ξ    | 4     | 5      | 12.5        | JNB            | P1.3,rel  | 3     | 2             |
| Test if Inter      | rrupt Pin is Hi        | gh:  |       |        |             |                |           |       |               |
| JNI                | \$+4                   | -    |       | ,      |             | 1              |           |       |               |
| JMP                | offset                 | =    | 4     | 4      | 10.0        | JB             | INT0,rel  | 3     | 2             |

Combining Boolean and byte-wide instructions can produce great synergy. An MCS-51<sup>™</sup> based application will prove to be:

- simpler to write since the architecture correlates more closely with the problems being solved;
- easier to debug because more individual instructions have no unexpected or undesirable side-effects;
- more byte efficient due to direct bit addressing and program counter relative branching;
- faster running because fewer bytes of instruction need to be fetched and fewer conditional jumps are processed;
- lower cost because of the high level of systemintergration within one component.

These rather unabashed claims of excellence shall not go unsubstantiated. The rest of this chapter examines less trivial tasks simplified by the Boolean processor. The first three compare the 8051 with other microprocessors; the last two go into 8051-based system designs in much greater depth.

## **Design Example #1 - Bit Permutation**

First off, we'll use the bit-transfer instructions to permute a lengthy pattern of bits.

A steadily increasing number of data communication products use encoding methods to protect the security of sensitive information. By law, interstate financial transactions involving the Federal banking system must be transmitted using the Federal Information Processing *Data Encryption Standard* (DES).

Basically, the DES combines eight bytes of "plaintext" data (in binary, ASCII, or any other format) with a 56-bit "key", producing a 64-bit encrypted value for transmission. At the receiving end the same algorithm is applied to the incoming data using the same key, reproducing the original eight byte message. The algorithm used for these permutations is fixed; different user-defined keys ensure data privacy. It is not the purpose of this note to describe the DES in any detail. Suffice it to say that encryption/decryption is a long, iterative process consisting of rotations, exclusive -OR operations, function table look-ups, and an extensive (and quite bizarre) sequence of bit permutation, packing, and unpacking steps. (For further details refer to the June 21, 1979 issue of **Electronics** magazine.) The bit manipulation steps are included, it is rumored, to impede a general purpose digital supercomputer trying to "break" the code. Any algorithm implementing the DES with previous generation microprocessors would spend virtually all of its time diddling bits. The bit manipulation performed is typified by the Key Schedule Calculation represented in Figure 9. This step is repeated 16 times for each key used in the course of a transmission. In essence, a seven-byte, 56-bit "Shifted Key Buffer" is transformed into an eight-byte, "Permutation Buffer" without altering the shifted Key. The arrows in Figure 9 indicate a few of the translation steps. Only six bits of each byte of the Permutation Buffer are used; the two high-order bits of each byte are cleared. This means only 48 of the 56 Shifted Key Buffer bits are used in any one iteration.



Figure 9. DES Key Schedule Transformation.



Figure 10.a. Flowchart for Key permutation attempted with a byte processor.

Different microprocessor architectures would best implement this type of permutation in different ways. Most approaches would share the steps of Figure 10.a:

- Initialize the Permutation Buffer to default state (ones or zeroes);
- Isolate the state of a bit of a byte from the Key Buffer. Depending on the CPU, this might be accomplished by rotating a word of the Key Buffer through a carry flag or testing a bit in memory or an accumulator against a mask byte;
- Perform a conditional jump based on the carry or zero flag if the Permutation Buffer default state is correct;
- Otherwise reverse the corresponding bit in the permutation buffer with logical operations and mask bytes.

Each step above may require several instructions. The last three steps must be repeated for all 48 bits. Most microprocessors would spend 300 to 3,000 microseconds on each of the 16 iterations.

Notice, though, that this flow chart looks a lot like Figure 8. The Boolean Processor can permute bits by simply moving them from the source to the carry to the destination—a total of two instructions taking four bytes and three microseconds per bit. Assume the Shifted Key Buffer and Permutation Buffer both reside in bit-addressable RAM, with the bits of the former assigned symbolic names SKB\_1, SKB\_2, ... SKB\_56, and that the bytes of the latter are named PB\_1, ... PB\_8. Then working from Figure 9, the software for the permutation algorithm would be that of Example 1.a. The total routine length would be 192 bytes, requiring 144 microseconds.

The algorithm of Figure 10.b is just slightly more efficient in this time-critical application and illustrates the synergy of an integrated byte and bit processor. The bits needed for each byte of the Permutation Buffer are assimilated by loading each bit into the carry (1 usec.) and shifting it into the accumulator (1 usec.). Each byte is stored in RAM when completed. Forty-eight bits thus need a total of 112 instructions, some of which are listed in Example 1.b.



Figure 10.b. DES Key Permutation with Boolean Processor.

Worst-case execution time would be 112 microseconds, since each instruction takes a single cycle. Routine length would also decrease, to 168 bytes. (Actually, in the context' of the complete encryption algorithm, each permuted byte would be processed as soon as it is assimilated—saving memory and cutting execution time by another 8 usec.)

| Example 1. DES Key Permutation Software. |                          |  |  |  |  |
|------------------------------------------|--------------------------|--|--|--|--|
| a.) "Brute Force                         | e" technique.            |  |  |  |  |
| MOV                                      | C,SKB_1                  |  |  |  |  |
| MOV                                      | PB_1.1,C                 |  |  |  |  |
| MOV                                      | C,SKB_2                  |  |  |  |  |
| MOV                                      | PB_4.0,C                 |  |  |  |  |
| MOV                                      | C,SKB_3                  |  |  |  |  |
| MOV                                      | PB_2.5,C                 |  |  |  |  |
| MOV                                      | C,SKB_4                  |  |  |  |  |
| MOV                                      | PB_1.0,C                 |  |  |  |  |
| • • •                                    |                          |  |  |  |  |
|                                          |                          |  |  |  |  |
| MOV                                      | C,SKB_55                 |  |  |  |  |
| MOV                                      | PB_5.0,C                 |  |  |  |  |
| MOV                                      | C,SKB_56                 |  |  |  |  |
| MOV                                      | PB_7.2,C                 |  |  |  |  |
|                                          |                          |  |  |  |  |
| b.) Using Accur                          | mulator to Collect Bits. |  |  |  |  |
| CLR                                      | А                        |  |  |  |  |
| MOV                                      | C.SKB_14                 |  |  |  |  |
| RLC                                      | A                        |  |  |  |  |
| MOV                                      | C,SKB_17                 |  |  |  |  |
| RLC                                      | Α                        |  |  |  |  |
| MOV                                      | C,SKB_11                 |  |  |  |  |
| RLC                                      | Α                        |  |  |  |  |
| MOV                                      | C,SKB_24                 |  |  |  |  |
| RLC                                      | Α                        |  |  |  |  |
| MOV                                      | C,SKB_1                  |  |  |  |  |
| RLC                                      | Α                        |  |  |  |  |
| MOV                                      | C,SKB_5                  |  |  |  |  |
| RLC                                      | Α                        |  |  |  |  |
| MOV                                      | PB_1,A                   |  |  |  |  |
|                                          | • • • • •                |  |  |  |  |
| MOV                                      | C,SKB_29                 |  |  |  |  |
| RLC                                      | A                        |  |  |  |  |
| MOV                                      | C,SKB_32                 |  |  |  |  |
| RLC                                      | A                        |  |  |  |  |
| MOV                                      | PB_8,A                   |  |  |  |  |
|                                          |                          |  |  |  |  |
|                                          |                          |  |  |  |  |

To date, most banking terminals and other systems using the DES have needed special boards or peripheral controller chips just for the encryption decryption process, and still more hardware to form a serial bit stream for transmission (Figure 11.a). An 8051 solution could pack most of the entire system onto the one chip (Figure 11.b). The whole DES algorithm would require less than onefourth of the on-chip program memory, with the remaining bytes free for operating the banking terminal (or whatever) itself.

Moreover, since transmission and reception of data is performed through the on 4board UART, the unencrypted data (plaintext) never even exists outside the microcomputer! Naturally, this would afford a high degree of security from data interception.



Figure 11. Secure Banking Terminal Block Diagram.

#### Design Example #2 - Software Serial I/O

An exercise often imposed on beginning microcomputer students is to write a program simulating a UART. (See, for example, Application Notes AP24, AP29, and AP49.) Though doing this with the 8051 Family may appear to be a moot point (given that the hardware for a full UART is on-chip), it is still instructive to see how it would be done, and maintains a product line tradition.

As it turns out, the 8051 microcomputers can receive or transmit serial data via software very efficiently using the Boolean instruction set. Since any I/O pin may be a serial input or output, several serial links could be maintained at once.

Figures 12.a and 12.b show algorithms for receiving or transmitting a byte of data. (Another section of program would invoke this algorithm eight times, synchronizing it with a start bit, clock signal, software delay, or timer interrupt.) Data is received by testing an input pin, setting the carry to the same state, shifting the carry into a data buffer, and saving the partial frame in internal RAM. Data is transmitted by shifting an output buffer through the carry, and generating each bit on an output pin.



Figure 12. Serial I/O Algorithms.

A side-by-side comparison of the software for this common "bit-banging" application with three different microprocessor architectures is shown in Table 5.a and 5.b. The 8051 solution is more efficient than the others on every count!

|           |              | Table 5. Serial I/O Programs<br>for Various Microprocessors. | n an |
|-----------|--------------|--------------------------------------------------------------|------------------------------------------|
| a.) Input | Routine.     | · .                                                          |                                          |
| 80        | 85           | 8048                                                         | 8051                                     |
| IN        | SERPORT      |                                                              | MOV C,SERPIN                             |
| A         | NI MASK      | CLR C                                                        | 4 i                                      |
| JZ        | LO           | JNTO LO                                                      | 1                                        |
| -         | мс           | CPL C                                                        |                                          |
| LO: L     |              |                                                              |                                          |
|           | OV A,M       | MOV A.@R0                                                    | MOV A.SERBUF                             |
| R         |              | RRC A                                                        | RRC A                                    |
| М         | OV M,A       | MOV @R0.A                                                    | MOV SERBUF.A                             |
| RESUL     | TS:          |                                                              |                                          |
| 8         | INSTRUCTIONS | 7 INSTRUCTIONS                                               | 4 INSTRUCTIONS                           |
| 14        | BYTES        | 9 BYTES                                                      | 7 BYTES                                  |
| 56        | STATES       | 9 CYCLES                                                     | 4 CYCLES                                 |
| 19        | uSEC.        | 22.5 uSEC.                                                   | 4 uSEC.                                  |
| b.) Outp  | ut Routine.  | '                                                            |                                          |
| ,80       | 85           | 8048                                                         | 8051                                     |
| LX        | I HL.SERBUR  | MOV R0.#SERBUF                                               |                                          |
| М         | OV A,M       | MOV A,@R0                                                    | MOV A,SERBUF                             |
| R         |              | RRC A                                                        | RRC A                                    |
| М         | OV M,A       | MOV @R0,A                                                    | MOV SERBUF,A                             |
| IN        |              |                                                              |                                          |
| JC        |              | JC HI                                                        |                                          |
| LO: Al    |              | ANL SERPRT,#NOT MASK                                         | MOV SERPIN,C                             |
|           | 1P CNT       | JMP CNT                                                      | 1                                        |
| HI: O     |              | HI: ORL SERPRT,#MASK                                         |                                          |
| CNT: O    | UT SERPORT   | CNT:                                                         |                                          |
| RESUL     | TS:          |                                                              |                                          |
| 10        | INSTRUCTIONS | 8 INSTRUCTIONS                                               | 4 INSTRUCTIONS                           |
| 10        | BYTES        | 13 BYTES                                                     | 7 BYTES                                  |
|           | DITLO        |                                                              |                                          |
| 20        | STATES       | 11 CYCLES                                                    | 5 CYCLES                                 |

# Design Example #3 - Combinatorial Logic Equations

Next we'll look at some simple uses for bit-test instructions and logical operations. (This example is also presented in Application Note AP-69.)

Virtually all hardware designers have solved complex functions using combinatorial logic. While the hardware involved may vary from relay logic, vacuum tubes, or TTL or to more esoteric technologies like fluidics, in each case the goal is the same: to solve a problem represented by a logical function of several Boolean variables. Figure 13 shows TTL and relay logic diagrams for a function of the six variables U through Z. Each is a solution of the equation,

$$\mathbf{Q} = (\mathbf{U} \cdot (\mathbf{V} + \mathbf{W})) + (\mathbf{X} \cdot \overline{\mathbf{Y}}) + \overline{\mathbf{Z}}$$

Equations of this sort might be reduced using Karnaugh Maps or algebraic techniques, but that is not the purpose of this example. As the logic complexity increases, so does the difficulty of the reduction process. Even a minor change to the function equations as the design evolves would require tedious re-reduction from scratch.



Figure 13. Hardware Implementations of Boolean functions.



Other digital computers must solve equations of this type with standard word-wide logical instructions and conditional jumps. So for the first implementation, we won't use any generalized bit-addressing instructions. As we shall soon see, being constrained to such an instruction subset produces somewhat sloppy software solutions. MCS-51™ mnemonics are used in Example 2.a; other machines might further cloud the situation by requiring operation-specific mnemonics like INPUT, OUTPUT, LOAD, STORE, etc., instead of the MOV mnemonic used for all variable transfers in the 8051 instruction set.

The code which results is cumbersome and error prone. It would be difficult to prove whether the software worked for all input combinations in programs of this sort. Furthermore, execution time will vary widely with input data.

Thanks to the direct bit-test operations, a single instruction can replace each move/mask/conditional jump sequence in Example 2.a, but the algorithm would be equally convoluted (see Example 2.B). To lessen the confusion "a bit" each input variable is assigned a symbolic name.

A more elegant and efficient implementation (Example 2.c) strings together the Boolean ANL and ORL functions to generate the output function with straight-line code.



b.) Using Relay Logic:



Figure 14. Flow chart for tree-branching algorithm.

When finished, the carry flag contains the result, which is  $a_{1}$  simply copied out to the destination pin. No flow chart is needed—code can be written directly from the logic diagrams in Figure 14. The result is simplicity itself: fast, flexible, reliable, easy to design, and easy to debug.

An 8051 program can simulate an N-input AND or OR gate with at most N+1 lines of source program—one for each input and one line to store the results. To simulate NAND and NOR gates, complement the carry after computing the function. When some inputs to the gate have "inversion bubbles," perform the ANL or ORL operation on inverted operands. When the first input is inverted, either load the operand into the carry and then complement it, or use DeMorgan's Theorem to convert the gate to a different form.

Example 2. Software Solutions to Logic Function of Figure 13.

a.) Using only byte-wide logical instructions.

BFUNCISOLVE RANDOM LOGIC FUNCTION:OF 6 VARIABLES BY LOADING AND:MASKING THE APPROPRIATE BITS:IN THE ACCUMULATOR, THEN:EXECUTING CONDITIONAL JUMPS:BASED ON ZERO CONDITION.:(APPROACH USED BY BYTE-:ORIENTED ARCHITECTURES.):BYTE AND MASK VALUES:CORRESPOND TO RESPECTIVE BYTE:ADDRESS AND BIT POSITIONS.

OUTBUE DATA 22H :OUTPUT PIN STATE MAP

| •      |      |                       |
|--------|------|-----------------------|
| TESTV; | MOV  | A,P2                  |
|        | ANL  | A,#00000100B          |
|        | JNZ  | TESTU                 |
|        | MOV  | A.TCON                |
|        | ANL  | A,#00100000B          |
|        | JZ   | TESTX                 |
| TESTU: | MOV  | A.PI                  |
|        | ANL  | A,#00000010B          |
|        | JNZ  | SETQ                  |
| TESTX: | MOV  | A.TCON                |
|        | ANL  | A,#00001000B          |
|        | JZ   | TESTZ                 |
| ,      | MOV  | A.20H                 |
|        | ANL  | A,#0000001B           |
|        | JZ   | SETQ                  |
| TESTZ: | MOV  | A.21H                 |
|        | ANL  | A,#00000010B          |
| s16    | JZ ~ | SETQ CONTRACTOR OF ST |
|        |      |                       |

| CLRQ: | MOV | AOUTBUF      |
|-------|-----|--------------|
|       | ANL | A,#11110111B |
|       | JMP | OUTQ         |
| SETQ: | MOV | A.OUTBUF     |
|       | ORL | A,#00001000B |
| OUTQ: | MOV | OUTBUF,A     |
| ,     | MOV | P3,A         |

b.) Using only bit-test instructions.

| · -       | -                                             | -test instructions.             |  |  |  |
|-----------|-----------------------------------------------|---------------------------------|--|--|--|
| :BFUNC2   |                                               | E A RANDOM LOGIC FUNCTION       |  |  |  |
| :         |                                               | ARIABLES BY DIRECTLY            |  |  |  |
| :         |                                               | ING EACH BIT.                   |  |  |  |
| ;         | •                                             | OACH USING MCS-51 UNIQUE        |  |  |  |
| :         |                                               | EST INSTRUCTION CAPABILITY.)    |  |  |  |
| :         |                                               | OLS USED IN LOGIC DIAGRAM       |  |  |  |
| :         |                                               | NED TO CORRESPONDING 8x51       |  |  |  |
| :         | BIT AI                                        | DDRESSES.                       |  |  |  |
| :         |                                               | ł.                              |  |  |  |
| U         | BIT                                           | P1.1                            |  |  |  |
| V         | BIT "                                         | P2.2                            |  |  |  |
| W ,       | BIT                                           | TF0                             |  |  |  |
| X         | BIT                                           | IEI                             |  |  |  |
| Y         | BIT                                           | 20H.0                           |  |  |  |
| Z         | BIT                                           | 21H.I                           |  |  |  |
| Q         | BIT                                           | P3.3                            |  |  |  |
| :         |                                               | ••••• ·                         |  |  |  |
| TEST_V:   | JB                                            | V.TEST_U                        |  |  |  |
|           | JNB                                           | W,TEST_X                        |  |  |  |
| TEST_U:   |                                               | U.SET_Q                         |  |  |  |
| TEST_X:   |                                               | X.TEST_Z                        |  |  |  |
|           | JNB                                           | Y.SET_Q                         |  |  |  |
| TEST_Z:   |                                               | Z.SET_Q                         |  |  |  |
| CLR_Q:    |                                               | Q                               |  |  |  |
|           | JMP                                           | NXTTST                          |  |  |  |
| SET_Q:    | SETB                                          | Q                               |  |  |  |
| NXTTST:   |                                               | (CONTINUATION OF                |  |  |  |
|           |                                               | (PROGRAM)                       |  |  |  |
| c.) Using | logical o                                     | perations on Boolean variables. |  |  |  |
| :FUNC3    | -                                             | •                               |  |  |  |
| FUNCS     |                                               | E A RANDOM LOGIC FUNCTION       |  |  |  |
|           | OF 6 VARIABLES USING<br>STRAIGHT_LINE LOGICAL |                                 |  |  |  |
|           |                                               |                                 |  |  |  |
| :         |                                               | RUCTIONS ON MCS-51 BOOLEAN      |  |  |  |
| :         | VAKIA                                         | ABLES.                          |  |  |  |
| :         |                                               |                                 |  |  |  |
| , -       | <b>.V</b> 2 ,                                 | /                               |  |  |  |
| ORI. C    | .W :O                                         | UTPUT OF OR GATE                |  |  |  |

| OKL  | C.W          | OUTPUT OF OR GATE           |
|------|--------------|-----------------------------|
| ANL  | C.U          | OUPUT OF TOP AND GATE       |
| MOV  | F0,C         | :SAVE INTERMEDIATE STATE    |
| MOV  | C.X          | A A A                       |
| ANL  | <b>C</b> . Y | OUTPUT OF BOTTOM AND GATE   |
| ORI. | C.F0         | INCLUDE VALUE SAVED, ABOVE  |
| ORL  | C. Z         | INCLUDE LAST INPUT VARIABLE |
| MOV  | 0.0          | OUTPUT COMPUTED RESULT      |

An upper-limit can be placed on the complexity of software to simulate a large number of gates by summing the total number of inputs and outputs. The *actual* total should be somewhat shorter, since calculations can be "chained," as shown above. The output of one gate is often the first input to another, bypassing the intermediate variable to eliminate two lines of source.

#### Design Example #4 - Automotive Dashboard Functions

Now let's apply these techniques to designing the software for a complete controller system. This application is patterned after a familiar real-world application which isn't nearly as trivial as it might first appear: automobile turn signals.

Imagine the three position turn lever on the steering column as a single-pole, triple-throw toggle switch. In its central position all contacts are open. In the up or down positions contacts close causing corresponding lights in the rear of the car to blink. So far very simple.

Two more turn signals blink in the front of the car, and two others in the dashboard. All six bulbs flash when an emergency switch is closed. A thermo-mechanical relay (accessible under the dashboard in case it wears out) causes the blinking.

Applying the brake pedal turns the tail light filaments on constantly... unless a turn is in progress, in which case the blinking tail light is not affected. (Of course, the front turn signals and dashboard indicators are not affected by the brake pedal.) Table 6 summarizes these operating modes.

But we're not done vet. Each of the exterior turn signal (but not the dashboard) bulbs has a second, somewhat dimmer filament for the parking lights. Figure 15 shows TTL circuitry which could control all six bulbs. The signals labeled "High Freq." and "Low Freq." represent two square-wave inputs. Basically, when one of the turn switches is closed or the emergency switch is activated the low frequency signal (about 1 Hz) is gated through to the appropriate dashboard indicator(s) and turn signal(s). The rear signals are also activated when the brake pedal is depressed provided a turn is not being made in the same direction. When the parking light switch is closed the higher frequency oscillator is gated to each front and rear turn signal, sustaining a low-intensity background level. (This is to eliminate the need for additional parking light filaments.)



Figure 15. TTL logic implementation of automotive turn signals.

|                 | INI              | PUT SIGNA              | LS                      | OUTPUT SIGNALS          |                          |              |               |
|-----------------|------------------|------------------------|-------------------------|-------------------------|--------------------------|--------------|---------------|
| BRAKE<br>SWITCH | EMERG.<br>SWITCH | LEFT<br>TURN<br>SWITCH | RIGHT<br>TURN<br>SWITCH | LEFT<br>FRONT<br>& DASH | RIGHT<br>FRONT<br>& DASH | LEFT<br>REAR | RIGHT<br>REAR |
| 0               | 0                | 0                      | 0                       | OFF                     | OFF                      | OFF          | OFF           |
| 0               | 0                | 0                      | 1 1                     | OFF                     | BLINK                    | OFF          | BLINK         |
| 0               | 0                | 1                      | 0                       | BLINK                   | OFF                      | BLINK        | OFF           |
| 0               | 1                | 0 ·                    | 0                       | BLINK                   | BLINK                    | BLINK        | BLINK         |
| 0               | 1                | 0                      | 1                       | BLINK                   | BLINK                    | BLINK        | BI INK        |
| 0               | ×1               |                        | 0                       | BLINK                   | BLINK                    | BLINK        | BUINK         |
| 1               | 0                | 0                      | 0                       | OFF                     | OFF                      | ON           | ON            |
| 1               | 0                | 0                      | 1                       | OFF                     | BLINK                    | ON           | BLINK         |
| 1               | 0                | 1                      | 0                       | BLINK                   | OFF                      | BLINK        | ON            |
| ' I'            | 1                | 0                      | Ò                       | BLINK                   | BLINK                    | ON           | ON            |
| 1               | 1                | 0                      | 1                       | BUINK                   | BLINK                    | ON           | BLINK         |
| E -             | 1                |                        | 0                       | BLINK                   | BLINK                    | BLINK        | ON            |

#### Table 6. Truth table for turn-signal operation.

In most cars, the switching logic to generate these functions requires a number of multiple-throw contacts. As many as 18 conductors thread the steering column of some automobiles solely for turn-signal and emergency blinker functions. (The author discovered this recently to his astonishment and dismay when replacing the whole assembly because of one burned contact.)

A multiple-conductor wiring harness runs to each corner of the car, behind the dash, up the steering column, and down to the blinker relay below. Connectors at each termination for each filament lead to extra cost and labor during construction, lower reliability and safety, and more costly repairs. And considering the system's present complexity, increasing its reliability or detecting failures would be quite difficult.

There are two reasons for going into such painful detail describing this example. First, to show that the messiest part of many system designs is determining what the controller should do. Writing the software to solve these functions will be comparatively easy. Secondly, to show the many potential failure points in the system. Later we'll see how the peripheral functions and intelligence built into a microcomputer (with a little creativity) can greatly reduce external interconnections and mechanical part count.

## The Single-chip Solution

The circuit shown in Figure 16 indicates five input pins to the five input variables—left-turn select, right-turn select, brake pedal down, emergency switch on, and parking lights on. Six output pins turn on the front, rear, and dashboard indicators for each side. The microcomputer implements all logical functions through software, which periodically updates the output signals as time elapses and input conditions change.



#### Figure 16. Microcomputer Turn-signal Connections.

Design Example #3 demonstrated that symbolic addressing with user-defined bit names makes code and documentation easier to write and maintain. Accordingly, we'll assign these 1/O pins names for use throughout the program. (The format of this example will differ somewhat from the others. Segments of the overall program will be presented in sequence as each is described.)

| :                         | INDUT I    |                         |  |  |  |  |  |
|---------------------------|------------|-------------------------|--|--|--|--|--|
| : INPUT PIN DECLARATIONS: |            |                         |  |  |  |  |  |
| ; (ALL                    | INPUTS A   | RE POSITIVE-TRUE LOGIC) |  |  |  |  |  |
| :                         |            |                         |  |  |  |  |  |
| BRAKE                     | BIT P1.0   | ; BRAKE PEDAL DEPRESSED |  |  |  |  |  |
| EMERG                     | BIT P1.1   | ; EMERGENCY BLINKER     |  |  |  |  |  |
|                           |            | ACTIVATED               |  |  |  |  |  |
| PARK                      | BIT P1.2   | : PARKING LIGHTS ON     |  |  |  |  |  |
| L_TURN                    | BIT P1.3   | ; TURN LEVER DOWN       |  |  |  |  |  |
| R_TURN                    | BIT P1.4   | ; TURN LEVER UP         |  |  |  |  |  |
| :                         |            |                         |  |  |  |  |  |
|                           | OUTPUT     | PIN DECLARATIONS        |  |  |  |  |  |
|                           |            |                         |  |  |  |  |  |
| L_FRNT                    | BIT P1.5   | ; FRONT LEFT-TURN       |  |  |  |  |  |
|                           |            | INDICATOR *             |  |  |  |  |  |
| R_FRNT                    | BIT P1.6   | : FRONT RIGHT-TURN      |  |  |  |  |  |
|                           |            | INDICATOR               |  |  |  |  |  |
| L_DASH                    | BIT P1.7   | ; DASHBOARD LEFT-TURN   |  |  |  |  |  |
|                           |            | INDICATOR               |  |  |  |  |  |
| R_DASH                    | BIT P2.0   | : DASHBOARD RIGHT-TURN  |  |  |  |  |  |
|                           |            | INDICATOR               |  |  |  |  |  |
| <b>I</b> REAR             | BIT P2 1   | REAR LEFT-TURN          |  |  |  |  |  |
|                           |            | INDICATOR               |  |  |  |  |  |
| R RFAR                    | BIT P2 2   |                         |  |  |  |  |  |
| N_NL/M                    | 1911 1 2.2 | INDICATOR               |  |  |  |  |  |
|                           |            | INDICATOR               |  |  |  |  |  |
| •                         |            | •                       |  |  |  |  |  |

Another key advantage of symbolic addressing will appear further on in the design cycle. The locations of cable connectors, signal conditioning circuitry, voltage regulators, heat sinks, and the like all affect P.C. board layout. It's quite likely that the somewhat arbitrary pin assignment defined early in the software design cycle will prove to be less than optimum; rearranging the I/O pin assignment could well allow a more compact module, or eliminate costly jumpers on a single-sided board. (These considerations apply especially to automotive and other cost-sensitive applications needing single-chip controllers.) Since other architectures mask bytes or use "clever" algorithms to isolate bits by rotating them into the carry, re-routing an input signal (from bit 1 of port 1, for example, to bit 4 of port 3) could require extensive modifications throughout the software.

The Boolean Processor's direct bit addressing makes such changes absolutely trivial. The number of the port containing the pin is irrelevent, and masks and complex program structures are not needed. Only the initial Boolean varia-

... ; INTERRUPT RATE SUBDIVIDER SUB\_DIV DATA 20H ; HIGH-FREQUENCY OSCILLATOR BIT HI\_FREO BIT SUB\_DIV.0 ; LOW-FREQUENCY OSCILLATOR BIT LO\_FREQ BIT SUB\_DIV.7 : ORG 0000H JMP INIT ... ..... ORG 100H ; PUT TIMER 0 IN MODE I INIT: MOV TMOD,#0000001B ; INITIALIZE TIMER REGISTERS MOV TL0,#0 MOV TH0.#-16 : SUBDIVIDE INTERRUPT RATE BY 244 MOV SUB\_DIV.#244 ; ENABLE TIMER INTERRUPTS SETB ET0 ; GLOBALLY ENABLE ALL INTERRUPTS SETB EA : START TIMER SETB TR0 ; (CONTINUE WITH BACKGROUND PROGRAM) : PUT TIMER 0 IN MODE 1 : INITIALIZE TIMER REGISTERS ; SUBDIVIDE INTERRUPT RATE BY 244 : ENABLE TIMER INTERRUPTS

: GLOBALLY ENABLE ALL INTERRUPTS : START TIMER

ble declarations need to be changed; ASM51 automatically adjusts all addresses and symbolic references to the reassigned variables. The user is assured that no additional debugging or software verification will be required.

Timer 0 (one of the two on-chip timer/counters) replaces the thermo-mechanical blinker relay in the dashboard controller. During system initialization it is configured as a timer in mode 1 by setting the least significant bit of the timer mode register (TMOD). In this configuration the low-order byte (TL0) is incremented every machine cycle, overflowing and incrementing the high-order byte (TH0) every 256  $\mu$ Sec. Timer interrupt 0 is enabled so that a hardware interrupt will occur each time TH0 overflows. (For details of the numerous timer operating modes see the MCS-51<sup>TM</sup> User's Manual.)

An eight-bit variable in the bit-addressable RAM array will be needed to further subdivide the interrupts via software. The lowest-order bit of this counter toggles very fast to modulate the parking lights; bit 7 will be "tuned" to approximately 1 Hz for the turn- and emergency-indicator blinking rate.

Loading TH0 with -16 will cause an interrupt after 4.096 msec. The interrupt service routine reloads the high-order byte of timer 0 for the next interval, saves the CPU registers likely to be affected on the stack, and then decrements SUB\_DIV. Loading SUB\_DIV. with 244 initially and each time it decrements to zero will produce a 0.999 second period for the highest-order bit.

| ORG  | 000BH    | ; TIMER 0 SERVICE VECTOR |
|------|----------|--------------------------|
| MOV  | TH0.#-16 |                          |
| PUSH | PSW      |                          |
| PUSH | ACC      |                          |
| PUSH | В        |                          |
| DJNZ | SUB_DIV. | TOSERV                   |
| MOV  | SUB_DIV. | #244                     |

The code to sample inputs, perform calculations, and update outputs—the real "meat" of the signal controller algorithm—may be performed either as part of the interrupt service routine or as part of a background program loop. The only concern is that it must be executed at least several dozen times per second to prevent parking light flickering. We will assume the former case, and insert the code into the timer 0 service routine.

First, notice from the logic diagram (Figure 15) that the subterm (PARK  $\cdot$  H\_FREQ), asserted when the parking lights are to be on dimly, figures into four of the six output functions. Accordingly, we will first compute that term and save it in a temporary location named "DIM". The PSW contains two general purpose flags: F0. which corresponds to the 8048 flag of the same name, and PSW.1. Since The PSW has been saved and will be restored to its previous state after servicing the interrupt, we can use either bit for temporary storage.

|   | DIM | віт     | PSW.1 ; DECLARE TEMP.<br>STORAGE FLAG |
|---|-----|---------|---------------------------------------|
| : |     |         |                                       |
|   | MOV | C.PARK  | ; GATE PARKING                        |
|   |     |         | LIGHT SWITCH                          |
|   | ANL | HI_FREQ | ; WITH HIGH                           |
|   |     | -       | FREQUENCY                             |
|   |     |         | SIGNAL                                |
|   | моу | DIM.C   | : AND SAVE IN                         |
|   |     |         | TEMP. VARIABLE.                       |
|   |     |         |                                       |

This simple three-line section of code illustrates a remarkable point. The software indicates in very abstract terms exactly what function is being performed, independent of the hardware configuration. The fact that these three bits include an input pin, a bit within a program variable, and a software flag in the PSW is totally invisible to the programmer.

Now generate and output the dashboard left turn signal.

| : |               |                 |
|---|---------------|-----------------|
| • | MOV C.L_TURN  | ; SET CARRY IF  |
|   |               | TURN            |
|   | ORL C.EMERG   | ; OR EMERGENCY  |
|   |               | SELECTED.       |
|   | ANL C.LO_FREQ | : GATE IN 1 HZ  |
|   |               | SIGNAL          |
|   |               |                 |
|   | MOV L_DASH,C  | : AND OUTPUT ŤO |
|   |               | DASHBOARD.      |
|   |               |                 |

To generate the left front turn signal we only need to add the parking light function in F0. But notice that the function in the carry will also be needed for the rear signal. We can save effort later by saving its current state in F0.

| : SAVE FUNCTION  |
|------------------|
| SO FAR.          |
| : ADD IN PARKING |
| LIGHT FUNCTION   |
| : AND OUTPUT TO  |
| TURN SIGNAL.     |
|                  |

Finally, the rear left turn signal should also be on when the brake pedal is depressed, provided a left turn is not in progress.

| MOV C.BRAKE   | : GATE BRAKE    |
|---------------|-----------------|
| •             | PÈDAL SWITCH    |
| ANL C. L_TURN | ; WITH TURN     |
|               | LEVER.          |
| ORL C.F0      | ; INCLUDE TEMP. |
| ,             | VARIABLE FROM   |
| ·             | DASH            |
| ORL C.DIM     | : AND PARKING   |
|               | LIGHT FUNCTION  |
| MOV L_REAR,C  | : AND OUTPUT TO |
|               | TURN SIGNAL     |
|               |                 |

Now we have to go through a similar sequence for the right-hand equivalents to all the left-turn lights. This also gives us a chance to see how the code segments above look when combined.

| MOV C.R_TURN  | : SET CARRY IF<br>TURN                       |
|---------------|----------------------------------------------|
| ORL C.EMERG   | : OR EMERGENCY                               |
| ANL C.LO_FREQ | SELECTED.<br>: IF SO, GATE IN 1<br>HZ SIGNAL |

| MOV R_DASH,C  | ; AND OUTPUT TO<br>DASHBOARD             |
|---------------|------------------------------------------|
| MOV F0.C      | SAVE FUNCTION                            |
| ORL C.DIM     | ADD IN PARKING                           |
| MOV R_FRNT.C  | ; AND OUTPUT TO<br>TURN SIGNAL           |
| MOV C.BRAKE   | ; GATE BRAKE<br>PEDAL SWITCH             |
| ANL C, R_TURN | : WITH TURN<br>LEVER.                    |
| ORI. C.F0     | : INCLUDE TEMP.<br>VARIABLE FROM<br>DASH |
| ORL C,DIM     | : AND PARKING<br>LIGHT FUNCTION          |
| MOV R_REAR.C  | : AND OUTPUT TO<br>TURN SIGNAL.          |

(The perceptive reader may notice that simply rearranging the steps could eliminate one instruction from each sequence.)

Now that all six bulbs are in the proper states, we can return from the interrupt routine, and the program is finished. This code essentially needs to reverse the status saving steps at the beginning of the interrupt.

| <br> |        |               |
|------|--------|---------------|
| РОР  | В      | : RESTORE CPU |
|      |        | REGISTERS.    |
| POP  | ACC    |               |
| POP  | PSW    |               |
|      | 1.0.00 | ,             |
| RETI |        |               |
|      |        |               |

**Program Refinements.** The luminescence of an incandescent light bulb filament is generally non-linear; the 50% duty cycle of HL\_FREQ may not produce the desired intensity. If the application requires, duty cycles of 25%, 75%, etc. are easily achieved by ANDing and ORing in additional low-order bits of SUB\_DIV. For example, 30 Hz signals of seven different duty cycles could be produced by considering bits 2—0 as shown in Table 7. The only software change required would be to the code which sets-up variable DIM:

|      |             | -                              |
|------|-------------|--------------------------------|
| MOV  | C.SUB_DIV.1 | : START WITH 50<br>PERCENT     |
| ANL  | C.SUB_DIV.0 | ; MASK DOWN TO 25              |
| ORI. | C.SUB_DIV.2 | PERCENT<br>; AND BUILD BACK TO |
| MOV  | DIM,C       | 62 PERCENT<br>; DUTY CYCLÉ FOR |
| *    |             | PARKING LIGHTS.                |
|      |             |                                |

|   | SUB_DIV BITS |   |   |   |   |   |   |       | DUTY CYCLES |       |               |               |       |               |
|---|--------------|---|---|---|---|---|---|-------|-------------|-------|---------------|---------------|-------|---------------|
| 7 | 6            | 5 | 4 | 3 | 2 | 1 | 0 | 12.5% | 25.0%       | 37.5% | <b>50.0</b> % | <b>62.5</b> % | 75.0% | <b>87.5</b> % |
| X | X            | X | X | X | 0 | 0 | 0 | OFF   | OFF         | OFF   | OFF           | 011           | OFF   | OFF           |
| Х | Х            | Х | X | Х | 0 | 0 | 1 | OFF   | OFF         | OFF   | OFF           | OFF           | OFF   | ON            |
| Х | Х            | Х | X | Х | 0 | 1 | 0 | OFF   | OFF         | OFF   | OFF           | OFF           | ON    | ON            |
| х | Х            | Х | Х | Х | 0 | 1 | 1 | OFF   | OFF         | OFF   | OFF           | ON            | ON    | ON            |
| х | х            | х | Х | Х | 1 | 0 | 0 | OFF   | OFF         | OFF   | ON            | ON            | ON    | ON            |
| х | Х            | Х | Х | Х | 1 | 0 | 1 | OFF   | OFF         | ON    | ON            | ON            | ON    | ON            |
| х | х            | Х | Х | Х | 1 | 1 | 0 | OFF   | ON          | ON    | ON            | ON            | ON    | ON            |
| x | х            | х | х | Х | 1 | 1 | 1 | ON    | ON          | ON    | ON            | ON            | ON    | ON            |

Table 7. Non-trivial Duty Cycles.

Interconnections increase cost and decrease reliability. The simple buffered pin-per-function circuit in Figure 16 is insufficient when many outputs require higher-than-TTL drive levels. A lower-cost solution uses the 8051 serial port in the shift-register mode to augment 1/O. In mode 0, writing a byte to the serial port data buffer (SBUF) causes the data to be output sequentially through the "RXD" pin while a burst of eight clock pulses is generated on the "TXD" pin. A shift register connected to these pins (Figure 17) will load the data byte as it is shifted out. A number of special peripheral driver circuits combining shift-register inputs with high drive level outputs have been introduced recently.

Cascading multiple shift registers end-to-end will expand the number of outputs even further. The data rate in the 1/O expansion mode is one megabaud, or 8 usec. per byte. This is the mode which the serial port defaults to following a reset, so no initialization is required.

The software for this technique uses the B register as a "map" corresponding to the different output functions. The program manipulates these bits instead of the output pins. After all functions have been calculated the B register is shifted by the serial port to the shift-register driver. (While some outputs may glitch as data is shifted through them, at 1 Megabaud most people wouldn't notice. Some shift registers provide an "enable" bit to hold the output states while new data is being shifted in.)

This is where the earlier decision to address bits symbolically throughout the program is going to pay off. This major I 'O restructuring is nearly as simple to implement as rearranging the input pins. Again, only the bit declarations need to be changed.

| L_FRNT | BIT | <b>B</b> .0 | ; FRONT LEFT-TURN      |
|--------|-----|-------------|------------------------|
|        |     |             | INDICATOR              |
| R_FRNT | BIT | <b>B</b> .1 | ; FRONT RIGHT-TURN     |
|        |     |             | INDICATOR              |
| L_DASH | BIT | B.2         | ; DASHBOARD LEFT-TURN  |
|        | ,   |             | INDICATOR              |
| R_DASH | BIT | <b>B</b> .3 | : DASHBOARD RIGHT-TURN |
|        |     |             | INDICATOR              |



Figure 17. Output expansion using serial port.

| L_REAR | BIT | <b>B</b> .4 | ; REAR LEFT-TURN                                |
|--------|-----|-------------|-------------------------------------------------|
| R_REAR | BIT | B.5         | : INDICATOR<br>: REAR RIGHT-TURN<br>: INDICATOR |

The original program to compute the functions need not change. After computing the output variables, the control map is transmitted to the buffered shift register through the serial port:

#### MOV SBUF, B : LOAD BUFFER AND TRANSMIT

The Boolean Processor solution holds a number of advantages over older methods. Fewer switches are required. Each is simpler, requiring fewer poles and lower current contacts. The flasher relay is eliminated entirely. Only six filaments are driven, rather than 10. The wiring harness is therefore simpler and less expensive—one conductor for each of the six lamps and each of the five sensor switches. The fewer conductors use far fewer connectors. The whole system is more reliable.

And since the system is much simpler it would be feasible to implement redundancy and or fault detection on the four main turn indicators. Each could **still** be a standard double filament bulb, but with the filaments driven in parallel to tolerate single-element failures.

Even with redundancy, the lights will eventually fail. To handle this inescapable fact current or voltage sensing

circuits on each main drive wire can verify that each bulb and its high-current driver is functioning properly. Figure 18 shows one such circuit.



Figure 18.

Assume all of the lights are turned on except one; i.e., all but one of the collectors are grounded. For the bulb which is turned off, if there is continuity from +12 V through the bulb base and filament, the control wire, all connectors, and the P.C. board traces, and if the transistor is indeed not shorted to ground, then the collector will be pulled to +12 V. This turns on the base of Q8 through the corresponding resistor, and grounds the input pin, verifying that the bulb circuit is operational. The continuity of each circuit can be checked by software in this way.

Now turn *all* the bulbs on, grounding all the collectors. Q7 should be turned off, and the Test pin should be high. However, a control wire shorted to  $\pm 12$  V or an opencircuited drive transistor would leave one of the collectors at the higher voltage even now. This too would turn on Q7, indicating a different type of failure. Software could perform these checks once per second by executing the routine every time the software counter SUB\_DIV is reloaded by the interrupt routine.

| DJNZ SUB_DIV, TOSERV |                  |
|----------------------|------------------|
| MOV SUB_DIV,#244     | ; RELOAD COUNTER |
| ORL P1,#11100000B    | ; SET CONTROL    |
|                      | OUTPUTS HIGH     |
| ORL P2,#00000111B    |                  |
| CLR L_FRNT           | ; FLOAT DRIVE    |
|                      | COLLECTOR        |
| JB TO,FAULT          | ; TO SHOULD BE   |
|                      | PULLED LOW       |
| SETB L_FRNT          | ; PULL COLLECTOR |
|                      | BACK DOWN        |

| - CLR L_DAS         | Н                                  |
|---------------------|------------------------------------|
| JB T0,FAU           | LT -                               |
| SETB L_DAS          | Н                                  |
| CLR L_REA           | R                                  |
| JB T0,FAU           | LT                                 |
| SETB L_REA          | R                                  |
| CLR R_FRN           | Т                                  |
| JB T0.FAU           | LT                                 |
| SETB R_FRN          | Т                                  |
| CLR R_DAS           | н                                  |
| JB T0.FAU           | LT                                 |
| SETB R_DAS          | н                                  |
| CLR R_REA           | R                                  |
| JB T0,FAU           | LT                                 |
| SETB R_REA          | R                                  |
| :                   |                                    |
|                     | CTORS GROUNDED, TO                 |
| SHOULD BE HIGH      |                                    |
| ; IF SO, CONTINUE   | WITH INTERRUPT ROUTINE.            |
| JB T0,T0SERV        | ,                                  |
| FAULT:              | ; ELECTRICAL FAILURE               |
|                     | :PROCESSING ROUTINE                |
|                     | : (LEFT TO READER'S                |
|                     | : IMAGINATION)                     |
| T0SERV:             | : CONTINUE WITH                    |
|                     | INTERRUPT PROCESSING               |
|                     |                                    |
| :                   |                                    |
| The complete assemb | oled program listing is printed in |

The complete assembled program listing is printed in Appendix A. The resulting code consists of 67 program statements, not counting declarations and comments, which assemble into 150 bytes of object code. Each pass through the service routine requires (coincidently) 67 usec, plus 32 usec once per second for the electrical test. If executed every 4 msec as suggested this software would typically reduce the throughput of the background program by less than 2%.

Once a microcomputer has been designed into a system, new features suddenly become virtually free. Software could make the emergency blinkers flash alternately or at a rate faster than the turn signals. Turn signals could override the emergency blinkers. Adding more bulbs would allow multiple tail light sequencing and syncopation — true flash factor, so to speak.

# Design Example #5 - Complex Control Functions

Finally, we'll mix byte and bit operations to extend the use of 8051 into extremely complex applications.

Programmers can arbitrarily assign I/O pins to input and output functions only if the total does not exceed 32, which is insufficient for applications with a very large number of input variables. One way to expand the number of inputs is with a technique similar to multiplexedkeyboard scanning. Figure 19 shows a block diagram for a moderately complex programmable industrial controller with the following characteristics:

- 64 input variable sensors;
- 12 output signals;
- Combinational and sequential logic computations;
- Remote operation with communications to a host processor via a high-speed full-duplex serial link;
- Two prioritized external interrupts;
- Internal real-time and time-of-day clocks.

While many microprocessors could be programmed to provide these capabilities with assorted peripheral support chips, an 8051 microcomputer needs **no** other integrated circuits!

The 64 input sensors are logically arranged as an 8x8 matrix. The pins of Port 1 sequentially enable each column of the sensor matrix; as each is enabled Port 0 reads in the state of each sensor in that column. An eight-byte block in bit-addressable RAM remembers the data as it is read in so that after each complete scan cycle there is an internal map of the current state of all sensors. Logic functions can then directly address the elements of the bit map.

The computer's serial port is configured as a nine-bit UART, transferring data at 17,000 bytes-per-second. The ninth bit may distinguish between address and data bytes.



Figure 19. Block diagram of 64-input machine controller.

The 8051 serial port can be configured to detect bytes with the address bit set, automatically ignoring all others. Pins INT0 and INT1 are interrupts configured respectively as high-priority, falling-edge triggered and low-priority, lowlevel triggered. The remaining 121'O pins output TTLlevel control signals to 12 actuators.

There are several ways to implement the sensor matrix circuitry, all logically similar. Figure 20.a shows one possibility. Each of the 64 sensors consists of a pair of simple switch contacts in series with a diode to permit multiple contact closures throughout the matrix.

The scan lines from Port 1 provide eight un-encoded active-high scan signals for enabling columns of the matrix. The return lines on rows where a contact is closed are pulled high and read as logic ones. Open return lines are pulled to ground by one of the 40 kohm resistors and are read as zeroes. (The resistor values must be chosen to ensure all return lines are pulled above the 2.0 V logic threshold, even in the worst-case, where all contacts in an enabled column are closed.) Since P0 is provided opencollector outputs and high-impedance MOS inputs its input loading may be considered negligible.

The circuits in Figures 20.b—20.d are variations on this theme. When input signals must be electrically isolated from the computer circuitry as in noisy industrial environments, phototransistors can replace the switch diode pairs **and** provide optical isolation as in Figure 20.b. Additional opto-isolators could also be used on the control output and special signal lines.

The other circuits assume that input signals are already at TTL levels. Figure 20.c uses octal three-state buffers enabled by active-low scan signals to gate eight signals onto Port 0. Port 0 is available for memory expansion or peripheral chip interfacing between sensor matrix scans. Eight-to-one multiplexers in Figure 20.d select one of eight inputs for each return line as determined by encoded address bits output on three pins of Port 1. (Five more output pins are thus freed for more control functions.) Each output can drive at least one standard TTL or up to 10 low-power TTL loads without additional buffering.

Going back to the original matrix circuit, Figure 21 shows the method used to scan the sensor matrix. Two complete bit maps are maintained in the bit-addressable region of the RAM: one for the current state and one for the previous state read for each sensor. If the need arises, the program could then sense input transitions and 'or debounce contact closures by comparing each bit with its earlier value.



Figure 20. Sensor Matrix Implementation Methods.

Example 3.

The code in Example 3 implements the scanning algorithm for the circuits in Figure 20.a. Each column is enabled by setting a single bit in a field of zeroes. The bit maps are positive logic; ones represent contacts that are closed or isolators turned on.

| INPUT_SCAN: | ; SUBROUTINE TO READ |
|-------------|----------------------|
|             | CURRENT STATE        |
|             | ; OF 64 SENSORS AND  |
|             | SAVE IN RAM 20H-27H. |
| MOV R0,#20H | : INITIALIZE         |
| × .         | ; POINTERS           |
| MOV R1,#28H | : FOR BIT MAP        |
| · · · ·     | : BASES.             |

01489A-27

|       | MOV  | A.#80H     | : SET FIRST BIT IN<br>ACC. |
|-------|------|------------|----------------------------|
| SCAN: | моу  | DI A       | : OUTPUT TO SCAN           |
| ocan. |      | 11.4       | LINES.                     |
|       | RR   | А          | : SHIFT TO ENABLE          |
|       | N N  | 7          | NEXT COLUMN                |
|       |      |            | NEXT COLOMIN               |
|       | моу  | R2.A       | : REMEMBER CUR-            |
|       | 1101 | N2,/1      | RENT SCAN                  |
|       |      |            | POSITION.                  |
|       | моу  | A P0       | : READ RETURN              |
|       |      |            | LINES.                     |
|       | хсн  | A,@R0      | : SWITCH WITH              |
|       |      |            | PREVIOUS MAP               |
|       |      |            | BITS.                      |
|       | моу  | @R1.A      | : SAVE PREVIOUS            |
|       |      | <u>,</u>   | STATE AS WELL.             |
|       | INC  | RO         | : BUMP POINTERS.           |
|       | INC  | •          |                            |
|       | MOV  |            | : RELOAD SCAN LINE         |
|       | *    |            | MASK                       |
| •     | JNB  | ACC.7.SCAN | ; LOOP UNTIL ALL           |
|       |      |            | EIGHT COLUMNS              |
|       |      |            | READ.                      |
| ,     | RFT  |            | £ 1 F                      |







What happens after the sensors have been scanned depends on the individual application. Rather than inventing some artificial design problem, software corresponding to commonplace logic elements will be discussed.

Combinatorial Output Variables. An output variable which is a simple (or not so simple) combinational function of several input variables is computed in the spirit of Design Example 3. All 64 inputs are represented in the bit maps; in fact, the sensor numbers in Figure 20 correspond to the absolute bit addresses in RAM! The code in Example 4 activates an actuator connected to P2.2 when sensors 12, 23, and 34 are closed and sensors 45 and 56 are open.

#### Example 4.

Simple Combinatorial Output Variables.

: SET P2.2 = (12) (23) (34) (45) (56) MOV C 12

|            | ~      |
|------------|--------|
| <b>ĄNL</b> |        |
| ÁNI.       | Č.34   |
| <b>ĄNL</b> | C. 45  |
| ÁNL        | C. 56  |
| MOV        | P2.2,C |

Intermediate Variables. The examination of a typical relay-logic ladder diagram will show that many of the rungs control not outputs but rather relays whose contacts figure into the computation of other functions. In effect, these relays indicate the state of intermediate variables of a computation.

The MCS-51<sup>™</sup> solution can use any directly addressable bit for the storage of such intermediate variables. Even when all 128 bits of the RAM array are dedicated (to input bit maps in this example), the accumulator, PSW, and B register provide 18 additional flags for intermediate variables.

For example, suppose switches 0 through 3 control a safety interlock system. Closing any of them should deactivate certain outputs. Figure 22 is a ladder diagram for this situation. The interlock function could be recomputed for every output affected, or it may be computed once and saved (as implied by the diagram). As the program proceeds this bit can qualify each output.

Example 5. Incorporating Override signal into actuator outputs.

CALL INPUT\_SCAN MOV C.0 ORL C.1 ORL C.2 ORL C.3 MOV F0.C







Latching Relays. A latching relay can be forced into either the ON or OFF state by two corresponding input signals, where it will remain until forced onto the opposite state analogous to a TTL Set/Reset flip-flop. The relay is used as an intermediate variable for other calculations. In the previous example, the emergency condition could be remembered and remain active until an "emergency cleared" button is pressed.

Any flag or addressable bit may represent a latching relay with a few lines of code (see Example 6).

Example 6: Simulating a latching relay.

:L\_SET SET FLAG.0 IF C=1 L\_SET: ORL C.F0 MOV F0.C

:L\_RSET RESET FLAG 0 IF C=1 L\_RSET: CPS C ANL C.F0 MOV F0.C

Time Delay Relays. A time delay relay does not respond to an input signal until it has been present (or absent) for some predefined time. For example, a ballast or load resistor may be switched in series with a D.C. motor when it is first turned on, and shunted from the circuit after one second. This sort of time delay may be simulated by an interrupt routine driven by one of the two 8051 timer/ counters. The procedure followed by the routine depends heavily on the details of the exact function needed; timeouts or time delays with resettable or non-resettable inputs are possible. If the interrupt routine is executed every 10 milliseconds the code in Example 7 will clear an intermediate variable set by the background program after it has been active for two seconds.

Example 7. Code to clear USR FLG after a fixed time delay.

JNB USR\_FLG,NXTTST DJNZ DLAY\_COUNT,NXTTST CLR USR\_FLG MOV DLAY\_COUNT,#200

NXTTST: :.. .....

Serial Interface to Remote Processor. When it detects emergency conditions represented by certain input combinations (such as the earlier Emergency Override), the controller could shut down the machine immediately and/or alert the host processor via the serial port. Code bytes indicating the nature of the problem could be transmitted to a central computer. In fact, at 17,000 bytes-persecond, the entire contents of both bit maps could be sent to the host processor for further analysis in less than a millisecond! If the host decides that conditions warrant, it could alert other remote processors in the system that a problem exists and specify which shut-down sequence each should initiate. For more information on using the serial port, consult the MCS-51<sup>m</sup> User's Manual.

#### Response Timing.

One difference between relay and programmed industrial controllers (when each is considered as a "black box") is their respective reaction times to input changes. As reflected by a ladder diagram, relay systems contain a large number of "rungs" operating in parallel. A change in input conditions will begin propagating through the system immediately, possibly affecting the output state within milliseconds.

Software, on the other hand, operates sequentially. A change in input states will not be detected until the next time an input scan is performed, and will not affect the outputs until that section of the program is reached. For that reason the raw speed of computing the logical functions is of extreme importance.

Here the Boolean processor pays off. Every instruction mentioned in this Note completes in one or two microseconds—the minimum instruction execution time for many other microcontrollers! A ladder diagram containing a hundred rungs, with an average of four contacts per rung can be replaced by approximately five hundred lines of software. A complete pass through the entire matrix scanning routine and all computations would require about a millisecond; less than the time it takes for most relays to change state.

A programmed controller which simulates each Boolean function with a subroutine would be less efficient by at least an order of magnitude. Extra software is needed for the simulation routines, and each step takes longer to execute for three reasons: several byte-wide logical instructions are executed per user program step (rather than one Boolean operation); most of those instructions take longer to execute with microprocessors performing multiple off-chip accesses; and calling and returning from the various subroutines requires overhead for stack operations.

In fact, the speed of the Boolean Processor solution is likely to be much faster than the system requires. The CPU might use the time left over to compute feedback parameters, collect and analyze execution statistics, perform system diagnostics, and so forth.

## Additional functions and uses.

With the building-block basics mentioned above many more operations may be synthesized by short instruction sequences.

*Exclusive-OR*. There are no common mechanical devices or relays analogous to the Exclusive-OR operation, so this instruction was omitted from the Boolean Processor. However, the Exclusive-OR or Exclusive-NOR operation may be performed in two instructions by conditionally complementing the carry or a Boolean variable based on the state of any other testable bit.

: EXCLUSIVE-OR FUNCTION IMPOSED ON CARRY ; USING F0 IS INPUT VARIABLE. XOR\_F0: JNB F0.XORCNT ; ("JB" FOR X-NOR) CPL C

XORCNT: ....

*XCH*. The contents of the carry and some other bit may be exchanged (switched) by using the accumulator as temporary storage. Bits can be moved into and out of the accumulator simultaneously using the Rotate-through-carry instructions, though this would alter the accumulator data.

|         |     | RY WITH USRFLG |
|---------|-----|----------------|
| XCHBIT: | RLC | A              |
|         | MOV | C,USR_FLG      |
|         | RRC | A              |
|         | MOV | USR_FLG,C      |
|         | RLC | A              |

*Extended Bit Addressing.* The 8051 can directly address 144 general-purpose bits for all instructions in Figure 3.b. Similar operations may be extended to any bit anywhere on the chip with some loss of efficiency.

The logical operations AND, OR, and Exclusive-OR are performed on byte variables using six different addressing modes, one of which lets the source be an immediate mask, and the destination any directly addressable byte. Any bit may thus be set, cleared, or complemented with a three-byte, two-cycle instruction if the mask has all bits but one set or cleared.

Byte variables, registers, and indirectly addressed RAM may be moved to a bit addressable register (usually the accumulator) in one instruction. Once transferred, the bits may be tested with a conditional jump, allowing any bit to be polled in 3 microseconds—still much faster than most architectures—or used for logical calculations. (This technique can also simulate additional bit addressing modes with byte operations.)

Parity of bytes or bits. The parity of the current accumulator contents is always available in the PSW, from whence it may be moved to the carry and further processed. Error-correcting Hamming codes and similar applications require computing parity on groups of isolated bits. This can be done by conditionally complementing the carry flag based on those bits or by gathering the bits into the accumulator (as shown in the DES example) and then testing the parallel parity flag.

#### Multiple byte shift and CRC codes.

Though the 8051 serial port can accommodate eight- or nine-bit data transmissions, some protocols involve much

longer bit streams. The algorithms presented in Design Example 2 can be extended quite readily to 16 or more bits by using multi-byte input and output buffers.

Many mass data storage peripherals and serial communications protocols include Cyclic Redundancy (CRC) codes to verify data integrity. The function is generally computed serially by hardware using shift registers and Exclusive-OR gates, but it can be done with software. As each bit is received into the carry, appropriate bits in the multi-byte data buffer are conditionally complemented based on the incoming data bit. When finished, the CRC register contents may be checked for zero by ORing the two bytes in the accumulator.

#### 4. SUMMARY

A truly unique facet of the Intel MCS-51<sup>™</sup> microcomputer family design is the collection of features optimized for the one-bit operations so often desired in real-world, real-time control applications. Included are 17 special instructions, a Boolean accumulator, implicit and direct addressing modes, program and mass data storage, and many 1 O options. These are the world's first single-chip microcomputers able to efficiently manipulate, operate on, and transfer either bytes or individual bits as data. This Application Note has detailed the information needed by a microcomputer system designer to make full use of these capabilities. Five design examples were used to contrast the solutions allowed by the 8051 and those required by previous architectures. Depending on the individual application, the 8051 solution will be easier to design, more reliable to implement, debug, and verify, use less program memory, and run up to an order of magnitude faster than the same function implemented on previous digital computer architectures.

Combining byte- and bit-handling capabilities in a single microcomputer has a strong synergistic effect: the power of the result exceeds the power of byte- and bit-processors laboring individually. Virtually all user applications will benefit in some ways from this duality. Data intensive applications will use bit addressing for test pin monitoring or program control flags; control applications will use byte manipulation for parallel 1 O expansion or arithmetic calculations.

It is hoped that these design examples give the reader an appreciation of these unique features and suggest ways to exploit them in his or her own application.

#### ISIS-II MCS-51 MACRO ASSEMBLER V1.0 DBJECT MODULE PLACED IN FO AP70 HEX ASSEMBLER INVOKED BY: :f1:asm51 ap70 src date(328)

| JC DBJ       | LINE     | SOURCE   |         |                      |      |                                           |
|--------------|----------|----------|---------|----------------------|------|-------------------------------------------|
|              | 1        | \$XREF T |         | -70 APPEN            |      | () ~ ~ ~                                  |
|              | 2、       |          |         |                      |      | *********************                     |
|              | 3        | ;        |         | - 72                 |      | ×                                         |
|              | 4        | ;        | THE FO  | LLOWING P            | ROG  | RAM USES THE BOOLEAN INSTRUCTION SET      |
|              | 5        |          |         |                      |      | MICROCOMPUTER TO PERFORM A NUMBER OF      |
|              | 6        |          |         |                      |      | ARD CONTROL FUNCTIONS RELATING TO         |
|              | 7        |          |         |                      |      | DL, EMERGENCY BLINKERS, BRAKE LIGHT       |
|              | 8        |          |         |                      |      | ING LIGHT OPERATION.                      |
|              | 9        |          |         |                      |      | HARDWARE ARE DESCRIBED IN DESIGN          |
| · · ·        | . 10     |          |         |                      |      | L APPLICATION NOTE AP-70,                 |
|              | 11       | ,        |         |                      |      | THE INTEL MCS-51(TM)                      |
|              | 12       |          |         |                      |      | COCESSING CAPABILITIES"                   |
|              | 13       |          |         | DODECHI              | N CP | OCESSING CHENDICITIES                     |
|              | 13       | ,<br>    | ******  | ********             |      | *****                                     |
|              | 15       | ,        |         |                      |      |                                           |
| 4            | 16       | ,        | INPUT   | PIN DECLA            | 000  |                                           |
|              | 17       | ,        |         |                      |      | POSITIVE-TRUE LOGIC.                      |
|              | 18       |          |         |                      |      | IEN RESPECTIVE SWITCH CONTACT IS CLOSED ) |
|              | 18       | ,        | 110-013 | HAE HIGH             | 1 WP | TEN REPRESEIVE DWITCH CONTACT 13 CLUBED / |
| 0090         | 20       |          | BIT     | P1.0                 |      |                                           |
|              |          | BRAKE    |         |                      |      | BRAKE PEDAL DEPRESSED                     |
| 0091<br>0092 | 21<br>22 | EMERG    | BIT     | P1 1                 | ,    | EMERGENCY BLINKER ACTIVATED               |
|              |          | PARK     | BII     | P1. 2                | ;    | PARKING LIGHTS ON                         |
| 0093         | 23       |          |         |                      |      |                                           |
| 0094         | 24       | R_TURN   | BIT     | P1.4                 | ;    | TURN LEVER UP                             |
|              | 25       | i        |         |                      |      |                                           |
|              | 26       | ,        |         | PIN DECL             |      |                                           |
| -            | 27       | ,        |         |                      |      | OSITIVE TRUE LOGIC                        |
|              | 28       | ;        | BOLB I  | S TURNED             | ON   | WHEN OUTPUT PIN IS HIGH.)                 |
|              | 29       |          |         | ·                    |      |                                           |
| 0095         | 30       | L_FRNT   |         |                      |      | FRONT LEFT-TURN INDICATOR                 |
| 0096         | 31       | R_FRNT   |         |                      |      | FRONT RIGHT-TURN INDICATOR                |
| 0097         | 32       | L_DASH   | BIT     | P1 7                 |      | DASHBOARD LEFT-TURN INDICATOR             |
| 0000         | 33       | R_DASH   | BIT     | P1 /<br>P2 0<br>P2 1 |      | DASHBOARD RIGHT-TURN INDICATOR            |
| 00A1         | 34       | L_REAR   | BIT     | P2. 1                |      | REAR LEFT-TURN INDICATOR                  |
| 00A2         | 35       | R_REAR   | BIT     | P2 2                 | ;    | REAR RIGHT-TURN INDICATOR                 |
|              | - 36     | ;        |         |                      |      | ,<br>,                                    |
| 00A3         | 37       | S_FAIL   | BIT     | P2. 3                | ;    | ELECTRICAL SYSTEM FAULT INDICATOR         |
|              | . 38     | ;        |         |                      |      |                                           |
|              | 39       | ;        | INTERN  | AL VARIAE            | ILE  | DEFINITIONS                               |
|              | 40       | i        |         |                      |      | · *                                       |
| 0020         | 41       | SUB_DIV  |         | 20H                  |      | ; INTERRUPT RATE SUBDIVIDER               |
| 0000         | 42       | HI_FREQ  | BIT     | SUB_DIV              | 0 1  | , HIGH-FREQUENCY OSCILLATOR BIT           |
| 0007         | 43       | LO_FREQ  | BIT     | SUB_DIV              | 1.7  | ; LOW-FREQUENCY OSCILLATOR BIT            |
|              | 44       | · -      |         |                      |      |                                           |
| OOD1         | 45       | DIM      | BIT     | PSW 1                |      | ; PARKING LIGHTS ON FLAG                  |
|              | 46       | ;        |         |                      |      |                                           |
|              | - 47     | ; ====== |         |                      |      | - 法有法律者 网络拉拉 法法律 化乙烯 化乙烯 化乙烯 化乙烯 化乙烯      |
|              |          |          |         |                      |      |                                           |

د. معر ۲ Appendix A. Automobile Turm-indicator Controller Program Listing.

| LOC  | OBJ                                     | LINE     | SOURCE  |        |                   |                                                                                                                 |
|------|-----------------------------------------|----------|---------|--------|-------------------|-----------------------------------------------------------------------------------------------------------------|
|      |                                         | 49       |         | ORG    | 0000н             | RESET VECTOR                                                                                                    |
| 0000 | 020040                                  | 50       |         | LJMP   | INIT              |                                                                                                                 |
|      |                                         | 51       | , `     |        |                   |                                                                                                                 |
| OOOB |                                         | 52       |         | ORG    | ооовн             | ; TIMER O SERVICE VECTOR                                                                                        |
|      | 758CF0                                  | 53 .     |         | MOV    | THO, #-16         | , HIGH TIMER BYTE ADJUSTED TO CONTROL INT RATE                                                                  |
|      | CODO                                    | 54       |         |        | PSW               | ; EXECUTE CODE TO SAVE ANY REGISTERS USED BELOW                                                                 |
|      | 0154                                    | 55       |         | AJMP   | UPDATE            | (CONTINUE WITH REST OF ROUTINE)                                                                                 |
| 0010 | 0154                                    | 56       |         | HUIN   | 0. DATE           |                                                                                                                 |
| 0040 |                                         | 57       | ,       | ORG    | 0040H             |                                                                                                                 |
|      | 1.                                      | . 58     | T       | MOV    |                   | J ZERO LOADED INTO LOW-ORDER BYTE AND                                                                           |
|      | 758A00                                  |          | INIT    | MOV    |                   | , -16 IN HIGH-ORDER BYTE GIVES 4 MSEC PERIOD                                                                    |
|      | 758CF0                                  | 59       | -       |        | THO, #-16         |                                                                                                                 |
| 0046 | 758961                                  | 60       |         | MOV ·  | 1400° #01100001B. | , 8-BIT AUTO RELOAD COUNTER MODE FOR TIMER 1,                                                                   |
|      |                                         | 61       |         |        |                   | , 16-BIT TIMER MODE FOR TIMER O SELECTED                                                                        |
|      | 7520F4                                  | 62       |         | MOV    | SUB_DIV, #244     | ; SUBDIVIDE INTERRUPT RATE BY 244 FOR 1 HZ                                                                      |
|      | D2A9                                    | 63       |         | SETB   |                   | USE TIMER O OVERFLOWS TO INTERRUPT PROGRAM                                                                      |
| 004E | D2AF                                    | 64       |         | SETB   |                   | ; CONFIGURE IE TO GLOBALLY ENABLE INTERRUPTS                                                                    |
| 0050 | D28C                                    | 65       |         | SETB   | TRO               | ; KEEP INSTRUCTION CYCLE COUNT UNTIL OVERFLOW                                                                   |
| 0052 | BOFE                                    | 66       |         | SJMP   | \$                | , START BACKGROUND PROGRAM EXECUTION                                                                            |
|      |                                         | 67       | ,       | -      |                   | · ·                                                                                                             |
|      |                                         | 68       | , `     | -      |                   |                                                                                                                 |
| 0054 | D52038                                  | 69       | UPDATE  | DJNZ   | SUB DIV, TOSERV   | , EXECUTE SYSTEM TEST ONLY ONCE PER SECOND                                                                      |
|      | 7520F4                                  | 70       |         | MOV    | SUB DIV, #244     | ; GET VALUE FOR NEXT ONE SECOND DELAY AND                                                                       |
| 0007 | , , , , , , , , , , , , , , , , , , , , | 71       | ,       |        |                   | ; GO THROUGH ELECTRICAL SYSTEM TEST CODE.                                                                       |
| 0054 | 4390E0                                  | 72       | ,       | ORL    | P1, #11100000B    | SET CONTROL DUTPUTS HIGH                                                                                        |
|      | 43A007                                  | 73       |         | ORL    | P2, #00000111B    |                                                                                                                 |
|      | 43A007<br>C295                          | 74       |         | CLR    |                   | FLOAT DRIVE COLLECTOR                                                                                           |
|      |                                         | 75       |         | JB     | TO, FAULT         | ; TO SHOULD BE PULLED LOW                                                                                       |
|      | 208428                                  |          |         |        |                   | ; PULL COLLECTOR BACK DOWN                                                                                      |
|      | D295                                    | 76       |         | SETB   | L_FRNT            |                                                                                                                 |
|      | C297                                    | 77       |         | CLR    |                   | , REPEAT SEQUENCE FOR L_DASH,                                                                                   |
|      | 208421                                  | 78       |         | JB     | TO, FAULT         |                                                                                                                 |
|      | D297                                    | 79       |         | SETB   | L_DASH            |                                                                                                                 |
|      | C2A1                                    | 80 .     |         | CLR    | L_REAR            | , en La REAR, en la companya de      |
| 0070 | 20B41A                                  | 81       |         | JB     | TO, FAULT         |                                                                                                                 |
| 0073 | D2A1                                    | 82       |         | SETB   | L_REAR            | · ·                                                                                                             |
| 0075 | C296                                    | 83       |         | CLR    | R_FRNT            | R_FRNT,                                                                                                         |
| 0077 | 208413                                  | 84 ·     |         | JB     | TO, FAULT         |                                                                                                                 |
| 007A | D296                                    | 85       |         | SETB   | R_FRNT            |                                                                                                                 |
| 0070 | C2A0                                    | 86 .     | -       | CLR .  | R DASH            | R_DASH                                                                                                          |
|      | 20B40C                                  | 87       |         | JB     | TO FAULT          |                                                                                                                 |
|      | D2A0                                    | 88       |         | SETB   | R DASH            |                                                                                                                 |
|      | C2A2                                    | 89       |         | CLR    | RREAR             | AND R REAR                                                                                                      |
|      | 20B405                                  | 90       |         | JB     | TO, FAULT         |                                                                                                                 |
|      | D2A2                                    | 91       |         | SETB   | R_REAR            |                                                                                                                 |
| 0088 | VENE                                    | 71<br>92 |         |        | N_NERN            | A CALL AND A |
|      |                                         |          | i       |        |                   | UNDED, TO SHOULD BE HIGH                                                                                        |
|      |                                         | 93       | *       |        |                   |                                                                                                                 |
|      |                                         | 94       | ,       | 15 201 | CONTINUE WITH IN  | IERROFT ROUTINE.                                                                                                |
| /    |                                         | 95       | ;       | ·      |                   | N.                                                                                                              |
|      | 208402                                  | 96       |         | ับย    | TO, TOSERV        |                                                                                                                 |
| 0080 | B2A3                                    | 97       | FAULT.  | CPL    | S_FAIL            | ELECTRICAL FAILURE PROCESSING ROUTINE                                                                           |
|      | · · · ·                                 | 98       |         |        |                   | ; (TOGGLE INDICATOR ONCE PER SECOND)                                                                            |
|      | •                                       | 99 +1    | \$EJECT |        |                   |                                                                                                                 |

4. Y

. .

| LOC  | OBA          | LINE  | SOURCE         |         |                  |                                     |
|------|--------------|-------|----------------|---------|------------------|-------------------------------------|
|      |              | 100   | ;              | CONTINU | E WITH INTERRUPT | PROCESSING                          |
|      |              | 101   | j              |         |                  |                                     |
|      |              | 102   | , 1)           | COMPUTE | LOW BULB INTENS  | ITY WHEN PARKING LIGHTS ARE ON.     |
|      |              | 103   | ;              |         |                  |                                     |
| 008F | A201         | 104   | TOSERV:        | MOV     | C, SUB_DIV 1     | , START WITH 50 PERCENT,            |
| 0091 | 8200         | 105   |                | ANL     | C, SUB DIV O     | ; MASK DOWN TO 25 PERCENT,          |
| 0093 | 7202         | 106   |                | ORL     | C, SUB DIV 2     | , BUILD BACK TO 62.5 PERCENT,       |
| 0095 | 8292         | 107   |                | ANL     | C, PARK          | ; GATE WITH PARKING LIGHT SWITCH,   |
|      | 92D1         | 108   |                | MOV     | DIM, C           | , AND SAVE IN TEMP. VARIABLE.       |
|      |              | 109   | ;              |         |                  |                                     |
|      |              | 110   | ; 2)           | COMPUTE | AND OUTPUT LEFT  | -HAND DASHBOARD INDICATOR           |
|      |              | 111   | ;              |         |                  |                                     |
| 0000 | A293         | 112   | ,              | MOV     | C, L_TURN        | SET CARRY IF TURN                   |
|      | 7291         | 113   | *              | ORL     | C, EMERG         | OR EMERGENCY SELECTED.              |
|      |              |       |                |         |                  |                                     |
|      | 8207         | 114   |                | ANL     | C, LD_FREQ       | , IF SO, GATE IN 1 HZ SIGNAL        |
| 0045 | 9297         | 115   |                | MOV     | L_DASH, C        | ; AND OUTPUT TO DASHBOARD.          |
|      |              | 116   | ;              |         |                  |                                     |
|      |              | 117   | , 3)           | COMPUTE | AND OUTPUT LEFT  | -HAND FRONT TURN SIGNAL.            |
|      |              | 118   | , <sup>°</sup> |         |                  |                                     |
| 00A1 | 92D5         | 119   |                | MOV     | F0, C            | ; SAVE FUNCTION SO FAR.             |
| 00A3 | 72D1         | 120   |                | ORL     | C, DIM           | ; ADD IN PARKING LIGHT FUNCTION     |
| 00A5 | 9295         | 121   |                | MOV     | L. FRNT/C        | ; AND OUTPUT TO TURN SIGNAL.        |
|      |              | 122   | ,              |         | -                |                                     |
|      |              | 123   | ; 4)           | COMPUTE | AND OUTPUT LEFT  | -HAND REAR TURN SIGNAL.             |
|      |              | 124   | ;              |         |                  |                                     |
| 0047 | A270         | 125   |                | MOV     | C, BRAKE         | GATE BRAKE PEDAL SWITCH             |
|      | B093         | 126   |                | ANL     | C, /L_TURN       | WITH TURN LEVER                     |
|      | 7205         | 127   | 1              | ORL     | C, F0            | INCLUDE TEMP. VARIABLE FROM DASH    |
|      | 72D1         | 128   |                | ORL     | C, DIM           | AND PARKING LIGHT FUNCTION          |
|      | 92A1         | 129   | *              | MOV     |                  | AND OUTPUT TO TURN SIGNAL.          |
| UUAF | 72A1         |       |                | nuv     | L_REAR, C        | AND DUIFUT TO TURN STENAL.          |
|      |              | 130   |                |         |                  | DIAUT HAND COUNTERDADTO             |
|      |              | 131   | ; 5)           | REPEAL  | ALL OF ABOVE FOR | RIGHT-HAND COUNTERPARTS.            |
|      |              | 132   | ,              |         |                  |                                     |
|      | A294         | 133   |                | MOV     | C, R_TURN        | SET CARRY IF TURN                   |
|      | 7291         | 134   |                | ORL     | C, EMERG         | ; OR EMERGENCY SELECTED.            |
|      | 8207         | 135   |                | ANL     | C, LO_FREQ       | ; IF SO, GATE IN 1 HZ SIGNAL        |
| 0087 | 92A0         | 136   |                | MOV     | R_DASH, C        | , AND OUTPUT TO DASHBOARD.          |
| 0089 | 92D5         | 137   |                | MOV     | FO,C             | , SAVE FUNCTION SO FAR.             |
| OOBB | 72D1         | 138   |                | ORL     | C, DIM           | ; ADD IN PARKING LIGHT FUNCTION     |
| OOBD | 9296         | 139   |                | MOV     | R FRNT, C        | ; AND OUTPUT TO TURN SIGNAL.        |
| OOBF | A290         | 140   |                | MOV     | C, BRAKE         | GATE BRAKE PEDAL SWITCH             |
| 0001 | B094         | 141   |                | ANL     | C, /R_TURN       | ; WITH TURN LEVER.                  |
|      | 72D5         | 142   |                | ORL     | C, FO            | , INCLUDE TEMP. VARIABLE FROM DASH  |
|      | 72D1         | 143   |                | ORL     | C, DIM           | AND PARKING LIGHT FUNCTION          |
|      | 92A2         | 144   |                | MOV     | R REAR, C        | ; AND DUTPUT TO TURN SIGNAL.        |
| 0007 | r mut tillin | 145   | ,              |         |                  |                                     |
|      |              | 146   | ;              | PESTOPE | STATUS REGISTER  |                                     |
|      |              | 140   | ,              | REDIORE | STATUS REGISTER  |                                     |
| 0000 | DODO         |       | ,              | 800     | RCU              | DECTORE ROLL                        |
|      | DODO         | 148   |                | POP     | PSW              | RESTORE PSW                         |
| OOCB | 3e           | 149 . |                | RETI    |                  | ; AND RETURN FROM INTERRUPT ROUTINE |
|      |              | 150   | ;              |         |                  |                                     |
|      |              | 151   |                | END     |                  |                                     |

01489A-34

#### XREF SYMBOL TABLE LISTING

1

| NAME    | TYPE   | VALUE | AND REFERENCES                 |
|---------|--------|-------|--------------------------------|
| BRAKE . | N BSEG | 0090H | 20# 125 140                    |
| DIM .   | N BSEG | OOD1H | 45# 108 120 128 138 143        |
| EA.     | N BSEG | OOAFH | 64                             |
| EMERG   | N BSEG | 0091H | 21#`113_134                    |
| ETO     | N BSEG | 00A9H | 63                             |
| FO.     | N BSEG | 00D5H | 119 127 137 142                |
| FAULT . | L CSEG | 008DH | 75 78 81 84 87 90 97#          |
| HI_FREQ | N BSEG | 0000H | 42#                            |
|         | L CSEG |       | 50 58#                         |
|         | N BSEG |       | 32# 77 79 115                  |
| L_FRNT. | N BSEG |       | 30# 74 76 121                  |
| L_REAR. | N BSEG | 00A1H | 34# 80 82 129                  |
|         | N BSEG | 0093H | 23# 112 126                    |
|         |        |       | 43# 114 135                    |
|         | N DSEG | 0070H | 20 21 22 23 24 30 31 32 72     |
| P2      | N DSEG | OÓAOH | 33 34 35 37 73                 |
| PARK .  | N BSEG | 0092H | 22# 107                        |
|         | N DSEG |       | 45 54 148                      |
| R_DASH. | N BSEG | OOAOH | 33# 86 88 136                  |
| R_FRNT. | N BSEG | 0096H | 31# 83 85 139                  |
| R_REAR. | N BSEG | 00A2H | 35# 89 91 144                  |
|         | N BSEG |       | 24# 133 141                    |
| S_FAIL. | N BSEG | 00A3H | 37# 97                         |
| SUB_DIV |        |       | 41# 42 43 62 69 70 104 105 106 |
| TO      |        |       | 75 78 81 84 87 90 96           |
| TOSERV. | L CSEG |       | 69 96 104#                     |
| THO     |        |       | 53 59                          |
| TLO     |        |       | 58                             |
|         | N DSEG |       | 60                             |
|         | N BSEG |       |                                |
| UPDATE. | L CSEG | 0054H | 55 69#                         |

ASSEMBLY COMPLETE, NO ERRORS FOUND

APPLICATION NOTE

October 1984 and Based on troller unit as a second to the second HICTOORIONE ADDIDATORS

eintel corporation, 1984

ORDER NUMBER: 270032-001

## **1.0 INTRODUCTION**

This is the third application note that Intel has produced on CRT terminal controllers. The first Ap Note (ref. 1), written in 1977, used the 8080 as the CPU and required 41 packages including 11 LSI devices. In 1979, another application note (ref. 2) using the 8085 as the controller was produced and the chip count decreased to 20 with 11 LSI devices.

Advancing technology has integrated a complete system onto a single device that contains a CPU, program memory, data memory, serial communication, interrupt controller, and I/O. These "computer-on-a-chip" devices are known as microcontrollers. Intel's MCS®-51 microcontroller was chosen for this application because of its highly integrated functions. This CRT terminal design uses 12 packages with only 4 LSI devices.

This application note has been divided into five general sections:

- 1) CRT Terminal Basics
- 2) 8051 Description
- 3) 8276 Description
- 4) Design Background
- 5) System Description

## 2.0 CRT TERMINAL BASICS

A terminal provides a means for humans to communicate with a computer. Terminals may be as simple as a LED display and a couple of push buttons, or it may be an elaborate graphics system that contains a full function keyboard with user programmable keys, color CRT and several processors controlling its functions. This application note describes a basic low cost terminal containing a black and white CRT display, full function keyboard and a serial interface.

## 2.1 CRT Description

A raster scan CRT displays its images by generating a series of lines (raster) across the face of the tube. The electron beam usually starts at the top left hand corner moves left to right, back to the left of the screen, moves down one row and continues on to the right. This is repeated until the lower right hand of the screen is reached. Then the beam returns to the top left hand corner and refreshes the screen. The beam forms a zigzag pattern as shown in Figure 2.1.0.

Two independent operating circuits control this movement across the screen. The horizontal oscillator controls the left to right motion of the beam while the vertical controls the top to bottom movement. The vertical oscillator also tells the beam when to return to the upper left hand corner or "home" position.



Figure 2.1.0 Raster Scan

As the electron beam moves across the screen under the control of the horizontal oscillator, a third circuit controls the current entering the electron gun. By varying the current, the image may be made as bright or as dim as the user desires. This control is also used to turn the beam off or "blank the screen".

When the beam reaches the right hand side of the screen, the beam is blanked so it does not appear on the screen as it returns to the left side. This "retrace" of the beam is at a much faster rate than it traveled across the screen to generate the image.

The time it takes to scan the whole screen and return to the home position is referred to as a "frame". In the United States, commercial television broadcast uses a horizonal sweep frequency of 15,750Hz which calculates out to 63.5 microseconds per line. The frame time is equal to 16.67 milliseconds or 60Hz vertical sweep frequency.

Although this is the commercial standard, many CRT displays operate from 18KHz to 30KHz horizontal frequency. As the horizontal frequency increases, the number of lines per frame increases. This increase in lines or resolution is needed for graphic displays and on special text editors that display many more lines of text than the standard 24 or 25 character lines.

Since the United States operates on a 60Hz A.C. power line frequency, most CRT monitors use 60Hz as the vertical frequency. The use of 60Hz as the vertical frequency allows the magnetic and electrical variations that can modulate the electron beam to be synchronized with the display, thus they go unnoticed. If a frequency other than 60Hz is used, special shielding and power supply regulating is usually required. Very few CRTs operate on a vertical frequency other than 60Hz due to the increase in the overall system cost.

The CRT controller must generate the pulses that define the horizontal and vertical timings. On most raster scan CRTs the horizontal frequency may vary as much as 500Hz without any noticeable effect on the quality of the display. This variation can change the number of horizontal lines from 256 to 270 per frame.

The CRT controller must also shift out the information to be displayed serially to the circuit that controls the electron beam's intensity as it scans across the screen. The circuits that control the timing associated with the shifting of the information are known as the dot clock and the character clock. The character clock frequency is equal to the dot clock frequency divided by the number of dots it takes to form a character in the horizontal axis. The dot clock frequency is calculated by the following equation:

Dot Clcok (Hz) = 
$$(N+R)*D*L*F$$

where

- N is the number of displayed characters per row,
- R is the number of character times for the retrace,
- D is the number of dots per character in the horizontal axis,
- L is the number of horizontal lines per frame,

F is the frame rate in Hz.

In this design N = 80, R = 20, D = 7, L = 270, and F = 60Hz. Plugging in the numbers results in a dot clock frequency of 11.34MHz.

The retrace number may vary on each design because it is used to set the left and right hand margins on the CRT. The number of dots per character is chosen by the designer to meet the system needs. In this design, a  $5 \times 7$  dot matrix and 2 blank dots between each character (see Figure 2.1.1) makes D equal to 5+2=7.



Figure 2.1.1 5 × 7 Dot Matrix

The following equation can be used to figure the number of lines per frame:

$$L = (H*Z) + V$$

where

- H is the number of horizontal lines per character,
- Z is the number of character lines per frame,
- V is the number of horizontal line times during the vertical retrace

In this design H is equal to the 7 horizontal dots per character plus 3 blank dots between each row which adds up to 10. Also 25 lines of characters are displayed, so Z = 25. The vertical retrace time is variable to set the top and bottom margins on the CRT and in this design is equal to 20. Plugging in the numbers gives L = 270 lines per frame.

#### 2.2 Keyboard

A keyboard is the common way a human enters commands and data to a computer. A keyboard consists of a matrix of switches that are scanned every couple of milliseconds by a keyboard controller to determine if one of the keys has been pressed. Since the keyboard is made up of mechanical switches that tend to bounce or "make and break" contact everytime they are pressed, debouncing of the switches must also be a function of the keyboard controller. There are dedicated keyboard controllers available that do everything from scanning the keyboard, debouncing the keys, decoding the ASCII code for that key closure to flagging the CPU that a valid key has been depressed. The keyboard controller may present the information to the CPU in parallel form or in a serial data stream.

This Application Note integrates the function of the keyboard controller into the 8051 which is also the terminal controller. Provisions have been made to interface the 8051 to a keyboard that uses a dedicated keyboard controller. The 8051 can accept data from the keyboard controller in either parallel or serial format.

#### 2.3 Serial Communications

Communication between a host computer and the CRT terminal can be in either parallel or serial data format. Parallel data transmission is needed in high end graphic terminals where great amounts of information must be transferred.

One can rarely type faster than 120 words per minute, which corresponds to 12 characters per second or 1 character per 83 milliseconds. The utilization of a parallel port cannot justify the cost associated with the drivers and the amount of wire needed to perform this transmission. Full duplex serial data transmission requires 3 wires and two



Figure 3.0.0 8051 Block Diagram

drivers to implement the communication channel between the host computer and the terminal. The data rate can be as high as 19200 BAUD in the asynchronous serial format. BAUD rate is the number of bits per second received or transmitted. In the asynchronous serial format, 10 bits of information is required to transmit one character. One character per 500 microseconds or 1,920 characters per second would then be trasmitted using 19.2 KBAUD.

This application note uses the 8051 serial port configured for full duplex asynchronous serial data transmission. The software for the 8051 has been written to support variable BAUD rates from 150 BAUD up to 9.6 KBAUD.

#### 3.0 8051 DESCRIPTION

The 8051 is a single chip high-performance microcontroller. A block diagram is shown in figure 3.0.0. The 8051 combines CPU; Boolean processor;  $4K \times 8$  ROM: 128  $\times 8$  RAM; 32 I/O lines; two 16-bit timer/ event counters; a five-source, two-priority-level, nested interrupt structure; serial I/O port for either multiprocessor communications, I/O expansion, or full duplex UART; and on-chip oscillator and clock circuits.

## 3.1 CPU

Efficient use of program memory results from an instruction set consisting of 49 single-byte, 45 two-byte and 17 three-byte instructions. Most arithmetic, logical and branching operations can be performed using an instruction that appends either a short address or a long address. For example, branches may use either an offset that is relative to the program counter which takes two bytes or a direct 16-bit address which takes three bytes to perform. As a result, 64 instructions operate in one machine cycle, 45 in two machine cycles, and the multiply and divide instruction execute in 4 machine cycles.

The 8051 has five addressing modes for source operands: Register, Direct, Register-Indirect, Immediate, and Based-Register-plus Index-Register-Indirect Addressing.

The Boolean Processor can be thought of as a separate one-bit CPU. It has its own accumulator (the carry bit), instruction set for data moves, logic, and control transfer, and its own bit addressable RAM and I/O. The bitmanipulating instructions provide optimum code and speed efficiency for handling on chip peripherals. The Boolean processor also provides a straight forward means of converting logic equations directly into software. Complex combinational logic functions can be resolved without extensive data movement, byte masking, and test-andbranch trees.

## 3.2 On-Chip Ram

The CPU manipulates operands in four memory spaces. These are the 64K-byte Program Memory, 64K-byte External Data Memory, 128-byte Internal Data Memory, and 128-byte Special Function Registers (SFRs). Four Register Banks (each with 8 registers), 128 addressable bits, and the Stack reside in the internal Data RAM. The Stack size is limited only by the available Internal Data RAM and its location is determined by the 8-bit Stack Pointer. All registers except for the Program Counter and the four 8-Register Banks reside in the SFR address space. These memory mapped registers include arithmetic registers, pointers, I/O ports, and registers for the interrupt system, timers, and serial channel.

Registers in the four 8-Register Banks can be addressed by Register, Direct, or Register-Indirect Addressing modes. The 128 bytes of internal Data Memory can be addressed by Direct or Register-Indirect modes while the SFRs are only addressed directly.

#### 3.3 I/O Ports

The 8051 has instructions that can treat the 32 I/O lines as 32 individually addressable bits or as 4 parallel 8-bit ports addressable as Ports 0, 1, 2, and 3.

Resetting the 8051 writes a logical 1 to each pin on port 0 which places the output drivers into a high-impedance mode. Writing a logical 0 to a pin forces the pin to ground and sinks current. Re-writing the pin high will place the pin in either an open drain output or high-impedance input mode.

Ports 1, 2, and 3 are known as quasi-bidirectional I/O pins. Resetting the device writes a logical one to each pin. Writing a logical 0 to the pin will force the pin to ground and sink current. Re-writing the pin high will place the pin in an output mode with a weak depletion pullup FET or in the input mode. The weak pullup FET is easily overcome by a TTL output.

Ports 0 and 2 can also be used for off-chip peripheral expansion. Port 0 provides a multiplexed low-order address and data bus while Port 2 contains the high-order address when using external Program Memory or more than 256 byte external Data Memory.

Port 3 pins can also be used to provide external interrupt request inputs, event counter inputs, the serial port TXD and RXD pins and to generate control signals used for writing and reading external peripherals.

#### 3.4 Interrupt System

External events and the real-time-driven on-chip peripherals require service by the CPU asynchronous to the execution of any particular section of code. A five-source, two-level, nested interrupt system ties the real time events to the normal program execution.

The 8051 has two external interrupt sources, one interrupt from each of the two timer/counters, and an interrupt from the serial port. Each interrupt vectors the program execution to its own unique memory location for servicing the interrupt. In addition, each of the five sources can be individually enabled or disabled as well as assigned to one of the two interrupt priority levels available on the 8051.

Up to two additional external interrupts can be created by configuring a timer/counter to the event counter mode. In this mode the timer/counter increments on command by either the T0 or T1.pin. An interrupt is generated when the timer/counter overflows. Thus if the timer/counter is loaded with the maximum count, the next high-to-low transition of the event counter input will cause an interrupt to be generated.

## 3.5 Serial Port

The 8051's serial port is useful for linking peripheral devices as well as multiple 8051s through standard asynchronous protocols with full duplex operation. The serial port also has a synchronous mode for expansion of I/O lines using shift registers. This hardware serial port saves ROM code and permits a much higher transmission rate than could be achieved through software. The processor merely needs to read or write the serial buffer in response to an interrupt. The receiver is double buffered to eliminate the possibility of overrun if the processor failed to read the buffer before the beginning of the next frame.

The full duplex asynchronous serial port provides the means of communication with standard UART devices such as CRT terminals and printers.

The reader should refer to the microcontroller handbook for a complete discussion of the 8051 and its various modes of operation.

#### 4.0 8276 DESCRIPTION

The 8276's block diagram and pin configuration are shown in Figure 4.0.0. The following sections describe the general capabilities of the 8276.



Figure 4.0.0 8276 Block Diagram

#### 4.1 CRT Display Refreshing

The 8276, having been programmed by the system designer for a specific screen format, generates a series of Buffer Ready signals. A row of characters is then transferred by the system controller from the display memory to the 8276's row buffers. The row buffers are filled by deselecting the 8276  $\overline{CS}$  and asserting the BS and WR signals. The 8276 presents the character codes to an external character generator ROM by using outputs CC0-CC6. The parallel data from the outputs of the character generator is converted to serial information that is clocked by external dot timing logic into the video input of the CRT.

The character rows are displayed on the CRT one line at a time. Line count outputs LCO-LC3 select the current line information from the character generator ROM. The display process is illustrated in Figure 4.1.0. This process is repeated for each display character row. At the beginning of the last display row the 8276 generates an interrupt request by raising its INT output line. The interrupt request is used by the 8051 system controller to reinitialize its load buffer pointers for the next display refresh cycle.

Proper CRT refreshing requires that certain 8276 parameters be programmed at system initialization time. The 8276 has two types of internal registers; the write only Command (CREG) and Parameter (PREG) Registers, and the read only Status Register (SREG). The 8276 expects to receive a command followed by 0 to 4 parameter bytes depending on the command. A summary of the 8276's instruction set is shown in Figure 4.1.1. To access the registers,  $\overline{CS}$  must be asserted along with  $\overline{WR}$  or  $\overline{RD}$ . The status of the C/P pin determines whether the command or parameter registers are selected.

The 8276 allows the designer flexibility in the display format. The display may be from 1 to 80 characters per row, 1 to 64 rows per screen, and 1 to 16 horizontal lines per character row. In addition, four curser formats are available; blinking, non-blinking, underline, and reverse video. The curser position is programmable to anywhere on the screen via the Load Curser command. AP-223



Figure 4.1.0 8276 Row Display

## 4.2 CRT Timing

The 8276 provides two timing outputs for controlling the CRT. The Horizontal Retrace Timing and Control (HRTC) and Vertical Retrace Timing and Control (VRTC) signals are used for synchronizing the CRT horizontal and vertical oscillators. A third output, VSP (Video Suppress), provides a signal to the dot timing logic to blank the video signal during the horizontal and vertical retraces. LTEN (Light Enable) is used to provide the ability to force the

video output high regardless of the state of the VSP signal. This feature is used to place the cursor on the screen and to control attribute functions.

RVV (Reverse Video) output, if enabled, will cause the system to invert its video output. The fifth timing signal output, HLGT (highlight) allows the flexibility to increase the CRT beam intensity to a greater than normal level.

| COMMAND              | NO. OF<br>PARAMETER<br>BYTES | NOTES                                              |
|----------------------|------------------------------|----------------------------------------------------|
| RESET                | 4                            | Display format<br>parameters required              |
| START<br>DISPLAY     | 0                            | DMA operation<br>parameters included in<br>command |
| STOP<br>DISPLAY      | 0                            | — ,<br>. , .                                       |
| red light<br>Pen     | 2                            | <b>—</b> .                                         |
| LOAD<br>CURSOR       | 2                            | Cursor X, Y position<br>parameters required        |
| ENABLE<br>INTERRUPT  | 0                            | -                                                  |
| DISABLE<br>INTERRUPT | 0                            | _                                                  |
| PRESET<br>COUNTERS   | 0                            | Clears all internal<br>counters                    |

Figure 4.1.1 8276 Instruction Set

#### 4.3 Special Functions

#### 4.3.1 Special Codes

The 8276 recognizes four special codes that may be used to reduce memory, software, or system controller overhead. These characters are placed within the display memory by the system controller. The 8276 performs certain tasks when these codes are received in its row buffer memory.

- 1) End of Row Code Activates VSP. VSP remains active until the end of the line is reached. While VSP is active the screen is blanked.
- End Of Row-Stop Buffer Loading Code Causes the Buffer Ready control logic to stop requesting buffer transfers for the rest of the row. It affects the display the same as End of Row Code.
- 3) End Of Screen Code Activates VSP. VSP remains active until the end of the frame is reached.

4) End Of Screen-Stop Buffer Loading Code — Causes the Buffer Ready control logic to stop requesting buffer transfers until the end of the frame is reached. It affects the display the same way as the End of Screen code:

## 4.3.4 Programmable Buffer Loading Control

The 8276 can be programmed to request 1, 2, 4, or 8 characters per Buffer load. The interval between loads is also programmable. This allows the designer the flexibility to tailor the buffer transfer overhead to fit the system needs.

Each scan line requires 63.5 microseconds. A character line consists of 10 scan lines and takes 635 microseconds to form. The 8276 row buffer must be filled within the 635 microseconds or an under run condition will occur within the 8276 causing the screen to be blanked until the next vertical retrace. This blanking will be seen as a flicker in the display.

## 5.0 DESIGN BACKGROUND

A fully functional, microcontroller-based CRT terminal was designed and constructed using the 8051 and the 8276. The terminal has many of the functions that are found in commercially available low cost terminals. Sophisticated features such as programmable keys can be added easily with modest amounts of software.

The 8051's functions in this application note include: up to 9.6K BAUD full duplex serial transmission; decoding special messages sent from the host computer; scanning, debouncing, and decoding a full function keyboard; writing to the 8276 row buffer from the display RAM without the need for a DMA controller; and scrolling the display.

The 8276 CRT controller's functions include: presenting the data to the character generator; providing the timing signals needed for horizontal and vertical retrace; and providing blanking and video information.

#### 5.1 Design Philosophy

Since the device count relates to costs, size, and reliability of a system, arriving at a minimum device count without degrading the performance was a driving force for this application note. LSI devices were used where possible to maintain a low chip count and to make the design cycle as short as possible.

PL/M-51 was chosen to generate the majority of the software for this application because it models the human thought process more closely than assembly language. Consequently it is easier and faster to write programs using PL/M-51 and the code is more likely to be correct because less chance exists to introduce errors. PL/M-51 programs are easier to read and follow than assembly language programs, and thus are easier to modify and customize to the end user's application. PL/M-51 also offers lower development and maintenance costs than assembly language programming.

PL/M-51 does have a few drawbacks. It is not as efficient in code generation relative to assembly language and thus may also run slower.

This application note uses the 8051's interrupts to control the servicing of the various peripherals. The speed of the main program is less critical if interrupts are used. In the last two application notes on terminal controllers, a criterion of the system was the time required for receiving an incoming serial byte, decoding it, performing the function requested, scanning the keyboard, debouncing the keys, and transmitting the decoded ASCII code must be less than the vertical refresh time. Using the 8051 and its interrupts makes this time constraint irrelevant.

#### 5.2 System Target Specifications

The design specifications for the CRT terminal design is as follows:

#### Display Format

- 80 characters/display row
- 25 display lines

#### **Character Format**

- 5  $\times$  7 character contained within a 7  $\times$  10 frame
- First and seventh columns blanked
- Ninth line curser position
- Programmable delay blinking underline curser

#### **Control Characters Recognized**

- Backspace
- Linefeed
- Carriage Return
- Form Feed

#### **Escape Sequences Recognized**

- ESC A, Curser up
- ESC B, Curser down
- ESC C, Curser right
- ESC D, Curser left
- ESC E, Clear screen
- ESC F, Move addressable curser
- ESC H, Home curser
- ESC J, Erase from curser to the end the screen
- ESC K, Erase the current line

#### Characters Displayed

96 ASCH Alphanumeric Characters

#### **Characters Transmitted**

- 96 ASCII Alphanumeric Characters
- ASCII Control Character Set
- ASCII Escape Sequence Set
- Auto Repeat

#### **Display Memory**

•  $2K \times 8$  static RAM

#### Data Rate

Variable rate from 150 to 9600 BAUD

#### **CRT Monitor**

• Ball Bros TV-12, 12MHZ Black and White

#### Keyboard

- Any standard undecoded keyboard (2 key lock-out)
- Any standard decoded keyboard with output enable pin
- Any standard decoded serial keyboard up to 150 BAUD

#### Scrolling Capability

#### **Compatible With Wordstar**

#### 6.0 SYSTEM DESCRIPTION

A block diagram of the CRT terminal is shown in figure 6.0.0. The diagram shows only the essential system features. A detailed schematic of the CRT terminal is contained in the Appendix 7.1.

The "brains" of the CRT terminal is the 8051 microcontroller. The 8276 is the CRT controller in the system, and a 2716 EPROM is used as the character generator. To handle the high speed portion of the CRT, the 8276 is surrounded by a handful of TTL devices. A  $2K \times 8$  static RAM was used as the display memory.

Following the system reset, the 8276 is initialized for curser type, number of characters per line, number of lines, and character size. The display RAM is initialized to all "spaces" (ASCII 20H). The 8051 then writes the "start display" command to the 8276. The local/line input is sampled to determine the terminal mode. If the terminal is on-line, the BAUD rate switches are read and the serial port is set up for full duplex UART mode. The processor then is put into a loop waiting to service the serial port fifo or the 8276.

The serial port is programmed to have the highest priority interrupt. If the serial port generates an interrupt, the processor reads the buffer, puts the character in a generated fifo that resides in the 8051's internal RAM, increments the fifo pointer, sets the serial interrupt flag and returns.

**AP-223** 



Figure 6.0.0 CRT Terminal Controller Block Diagram

The main program determines if it is a displayable character, a Control word or an ESC sequence and either puts the character in the display buffer or executes the appropriate command sent from the host computer.

If the 8276 needs servicing, the 8051 fills the row buffer for the CRT display's next line. If the 8276 generates a vertical retrace interrupt, the buffer pointers are reloaded with the display memory location that corresponds to the first character of the first display line on the CRT. The vertical retrace also signals the processor to read the keyboard for a key closure.

## 6.1 Hardware Description

The following section describes the unique characteristics of this design.

#### 6.1.1 Peripheral Address Map

The display RAM, 8276 registers, and the 8276 row buffers are memory mapped into the external data RAM address area. The addresses are as follows:

Read and Write External<br/>Display RAM —Address 1000H to 17CFHWrite to 8276 row buffers<br/>from Display RAM —Address 1800H to 17CFHWrite to 8276 Command<br/>Register (CREG) —Address 0001HWrite to 8276 Parameter<br/>Register (PREG) —Address 0000HRead from 8276 Status<br/>Register (SREG) —Address 0001H

Three general cases can be explored; reading and writing the display RAM, writing to the 8276 row buffers, and reading and writing the 8276's control registers.

As mentioned previously the 8051 fills the 8276 row buffer without the need of a DMA controller. This is accomplished by using a Quad 2-input multiplexor (Figure 6.1.0) as the transfer logic shown in the block diagram. The address line, P2.3, is used to select either of the two inputs. When the address line is low the  $\overline{RD}$  and  $\overline{WR}$  lines perform their normal functions, that is read and write the



Figure 6.1.0 Simplified Version Of The Transfer Logic

8276 or the external display RAM depending on the states of their respective chip selects. If the address line is high, the 8051  $\overline{RD}$  line is transformed into  $\overline{BS}$  and  $\overline{WR}$  signals for the 8276. While holding the address line high, the 8051 executes an external data move (MOVX) from the display RAM to the accumulator which causes the display RAM to output the addressed byte onto the data bus. Since the multiplexor turns the same 8051  $\overline{RD}$  pulses into  $\overline{BS}$ and  $\overline{WR}$  pulses to the 8276, the data bus is thus read into the 8276 as a Buffer transfer. This scheme allows 80 characters to be transferred from the display RAM into the 8276 within the required character line time of 635 microseconds. The 8051 easily meets this requirement by accomplishing the task within 350 microseconds.

## 6.1.2 Scanning The Keyboard

Throughout this project, provision have been made to make the overall system flexible. The software has been written for various keyboards and the user simply needs to link different program modules together to suit their needs.

## 6.1.2.1 Undecoded Keyboard

Incorporating an undecoded keyboard controller into the other functions of the 8051 shows the flexibility and over all CPU power that is available. The keyboard in this case is a full function, non-buffered  $8 \times 8$  matrix of switches for a total of 64 possible keys. The 8 send lines are connected to a 3-to-8 open-collector decoder as shown in Figure 6.1.1. Three high order address lines from the 8051 are the decoder inputs. The enabling of the decoder is accomplished through the use of the <u>PSEN</u> signal from the 8051 which makes the architecture of the separate address space for the program memory and the external data RAM work for us to eliminate the need to decode addresses externally. The move code (MOVC) instruction allows each scan line of the keyboard to be read with one instruction.

The keyboard is read by bringing one of the eight scan lines low sequentially while reading the return lines which are pulled high by an external resistor. If a switch is



Figure 6.1.1 Keyboard

closed, the data bus line is connected through the switch to the low output of the decoder and one of the data bus lines will be read as a 0. By knowing which scan line detected a key closure and which data bus line was low, the ASCII code for that key can easily be looked up in a matrix of constants. PL/M-51 has the ability to handle arrays and structured arrays, which makes the decoding of the keyboard a trivial task.

Since the Shift, Cap Lock, and Control keys may change the ASCII code for a particular key closure, it is essential to know the status of these pins while decoding the keyboard. The Shift, Cap Lock, and Control keys are therefore not scanned but are connected to the 8051 port pins where they can be tested for closure directly.

The 8 receive lines are connected to the data bus through germanium diodes which chosen for their low forward voltage drop. The diodes keep the keyboard from interfering with the data bus during the times the keyboard is not being read. The circuit consisting of the 3-to-8 decoder and the diodes also offers some protection to the 8051 from possible Electrostatic Discharge (ESD) damage that could be transmitted through the keyboard.

#### 6.1.2.2 Decoded Keyboard

A decoded keyboard can easily be connected to the system as shown in Figure 6.1.2. Reading the keyboard can be evoked either by interrupts or by software polling.

The software to periodically read a decoded keyboard was not written for this application note but can be accomplished with one or two PL/M-51 statements in the READER routine.

A much more interesting approach would be to have the servicing of the keyboard be interrupt driven. An additional external interrupt is created by configuring timer/ counter 0 into an event counter. The event counter is

initialized with the maximum count. The keyboard controller would inform the 8051 that a valid key has been depressed by pulling the input pin TO low. This would overflow the event counter, thus causing an interrupt. The interrupt routine would simply use a MOVC (PSEN is connected to the output enable pin of the keyboard controller) to read the contents of the keyboard controller onto the data bus, reinitialize the counter to the maximum count and return from the interrupt.

#### 6.1.2.3 Serial Decoded Keyboard

The use of detachable keyboards has become popular among the manufacturers of keyboards and personal computers. This terminal has provisions to use such a keyboard.

The keyboard controller would scan the keyboard, debounce the key and send back the ASCII code for that key closure. The message would be in an asynchronous serial format.

The flowchart for a software serial port is shown in Figure 6.1.3. An additional external interrupt is created as discussed for the decoded keyboard but the use in this case would be to detect a start bit. Once the beginning of the start bit has been detected, the timer/counter 0 is configured to become a timer. The timer is initialized to cause an interrupt one-half bit time after the beginning of the start bit. This is to validate the start bit. Once the start bit is validated, the timer is initialized with a value to cause an interrupt one bit time later to read the first data bit. This process of interrupting to read a data bit is repeated until all eight data bits have been received. After all 8 data bits are read, the software serial port is read once more to detect if a stop bit is present. If the stop bit is not present, an error flag is set, all pointers and flags are reset to their initial values, and the timer/counter is reconfigured to an event counter to detect the next start bit. If the stop bit is present, a valid flag is set and the flags and counter are reset as previously discussed.



Figure 6.1.2 Using A Decoded Keyboard



Figure 6.1.3 Flowchart for the Software Serial Port

#### 6.1.4 System Timings

The requirements for the BALL BROTHERS. TV-12 monitor's operation is shown in table 6.1.0. From the monitor's parameters, the 8276 specifications and the system target specifications the system timing is easily calculated.

The 8276 allows the vertical retrace to be only an integer multiple of the horizontal character lines. Twenty-five display lines and a character frame of  $7 \times 10$  are required from the target specification which will require 250 horizontal lines. If the horizontal frequency is to be within

500 Hz of 15,750 Hz, we must choose either one or two character line times for horizontal retrace. To allow for a little more margin at the top and bottom of the screen, two character line times was chosen for the vertical retrace. This choice yields 250 + 20 = 270 total character lines per frame. Assuming 60 Hz vertical retrace frequency:

60 Hz \* 270 = 16,200 Hz horizontal frequency and

1/16,200 Hz \* 20 horizontal sync times = 1.2345 milliseconds

| PARAMETER                          | RANGE                                                    |
|------------------------------------|----------------------------------------------------------|
| Vertical Blanking Time<br>(VRTC)   | 800 $\mu$ sec nominal                                    |
| Vertical Drive Pulsewidth          | $300 \ \mu \text{sec} \le \text{PW} \le 1.4 \ \text{ms}$ |
| Horizontal Blanking Time<br>(HRTC) | 11 $\mu$ sec nominal                                     |
| Horizontal Drive Pulsewidth        | 25 $\mu$ sec $\leq$ PW $\leq$ 30 $\mu$ sec               |
| Horizontal Repetition Rate         | 15,750 ± 500 pps                                         |

| Table 6.1.0 CRT Monitor's | <b>Operational Requirements</b> |
|---------------------------|---------------------------------|
|---------------------------|---------------------------------|

The 1.2345 milliseconds of retrace time meets the nominal VRTC and vertical drive pulse width time of .3mSec to 1.4mSec for the Ball monitor.

The next parameter to find is the horizontal retrace time which is wholly dependent on the monitor used. Usually it lies between 15 and 30 percent of the total horizontal line time.

Since most designs display a fixed number of characters per line it is useful to express the horizontal retrace time as a given number of character times. In this design, 80 characters are displayed, and it was experimentally found that 20 character times for the horizontal retrace gave the best results. It should be noted if too much time was given for retrace, there would be less time to display the characters and the display would not fill out the screen. Conversely, if not enough time is given for retrace, the characters would seem to run off the screen.

One hundred character times per complete horizontal line means that each character needs:

(1/16,200 Hz)/100 character times = 617.3 nanoseconds

If we multiply the 20 character times needed to retrace by 617.3 nanoseconds needed for each character, we find 12.345 microseconds are allocated for retrace. This value falls short of the 25 to 30 microseconds required by the horizontal drive of the Ball monitor. To correct for this, a 74LS123 one-shot was used to extend the horizontal drive pulse width.

The dot clock frequency is easy to calculate now that we know the horizontal frequency. Since each character is formed by seven dots in the horizontal axis, the dot clock period would be the character clock (617.3 nanoseconds) divided by the 7 which is equal to 11.34 MHz. The basic dot timing and CRT timing are shown in the Appendix.

## 6.2 Software Description

#### 6.2.1 Software Overview

The software for this application was written in a "foreground-background" format. The background programs are all interrupt driven and are written in assembly language due to time constraints. The foreground programs are for the most part written in PL/M-51 to ease the programming effort. A number of subroutines are written in assembly language due to time constraints during execution. Subroutines such as clearing display lines, clearing the screen, and scanning the keyboard require a great deal of 16 bit adds and compares and would execute much slower and would require more code space if written in PL/M-51. The background and foreground programs talk to each other through a set of flags. For example, the PL/M-51 foreground program tests "SERIAL\$INT" to determine if a serial port interrupt had occurred and a character is waiting to be processed.

#### 6.2.2 The Background Program

Two interrupt driven routines, VERT and BUFFER, (see Fig. 6.2.0) request service every 16.67 milliseconds and 617 microseconds respectively. VERT's request comes during the last character row of the display screen. This routine resets the buffer pointers to the first CRT display line in the display memory. VERT is also used as a time base for the foreground program. VERT sets the flag, SCAN, to tell the foreground program (PL/M-51) that it is time to scan the Keyboard. VERT also increments a counter used for the delay between transmitting characters in the AUTO\$REPEAT routine.

The BUFFER routine is executed once per character row. BUFFER uses the multiplexor discussed earlier to fill the 8276's row buffer by executing 80 external data moves and incrementing the Data Pointer between each move.



Figure 6.2.0 Flowcharts For VERT and BUFFER Routine

The MOVX reads the display RAM and writes the character into the row buffer during the same instruction.

SERBUF is an interrupt driven routine that is executed each time a character is received or transmitted through the on-chip serial port. The routine first checks if the interrupt was caused by the transmit side of the serial port, signaling that the transmitter is ready to accept another character. If the transmitter caused the interrupt, the flag "TRANSMIT\$INT" is set which is checked by the foreground program before putting a character in the buffer for transmission.

If the receiver caused the interrupt, the input buffer on the serial port is read and fed into the fifo that has been manufactured in the internal RAM and increments the fifo pointer "FIFO." The flag "SERIAL\$INT" is then set, telling the foreground program that there is a character in the fifo to be processed. If the read character is an ESC character, the flag "ESCSEQ" is set to tell the foreground program that an escape sequence is in the process of being received.

## 6.2.3 The Foreground Program

The foreground program is documented in the Appendix. The foreground program starts off by initializing the 8276 as discussed earlier. After all variables and flags are initialized, the processor is put into a loop waiting for either VERT to set SCAN so the program can scan the keyboard, or for the serial port to set SERIAL\$INT so the program can process the incoming character.

The vertical retrace is used to time the delay between keyboard scans. When VERT gets set, the assembly language routine READER is called. READER scans the keyboard, writing each scan into RAM to be processed later. READER controls two flags, KEY0 and SAME. KEY0 is set when all 8 scans determine that no key is pressed. SAME is set when the same key that was pressed last time the keyboard was read is still pressed.

After READER returns execution to the main program, the flags are tested. If the KEYO flag is set the main program goes back to the loop waiting for the vertical retrace or a serial port interrupt to occur. If the SAME flag is set the main program knows that the closed key has been debounced and decoded so it sends the already known ASCII code to the AUTO\$REPEAT routine which determines if that character should be transmitted or not.

If KEY0 and SAME are not set, signifying that a key is pressed but it is not the same key as before, the foreground program determines if the results from the scan are valid. First all eight scans are checked to see if only one key was closed. If only one key is closed, the ASCII code is determined, modified if necessary by the Shift, Cap Lock, or Control keys. The NEW\$KEY and VALID flags are then set. The next time READER is called, if the same key is still pressed, the SAME flag will be set, causing the AUTO\$REPEAT subroutine to be called as just discussed. Since the keyboard is read during the vertical retrace, 16.67 milliseconds has elapsed between the detection of the pressed key and reverifying that the key is still pressed before transmitting it, thus effectively debouncing the key.

The AUTO\$REPEAT routine is written to transmit any key that the NEW\$KEY flag is set for. The counter that is incremented each time the vertical refresh interrupt is serviced causes a programmable delay between the first transmission and subsequent auto repeat transmission. Once the NEW\$KEY character is sent, the counter is initialized. Each time the AUTO\$REPEAT routine is called, the counter is checked. Only when the counter overflows will the next character be transmitted. After the initial delay, a character will be transmitted every other time the routine is called as long as the key remains pressed.

## 6.2.3.1 Handling Incoming Serial Data

One of the criteria for this application note was to make the software less time dependent. By creating a fifo to store incoming characters until the 8051 has time to process them, software timing becomes less critical. This application note uses up to 8 levels of the fifo at 9.2KBAUD, and 1 level at 4.8KBAUD and lower. As discussed earlier, the interrupt service routine for the serial port uses the fifo to store incoming data, increments the fifo pointer, "FIFO", and sets SERIAL\$INT to tell the main program that the fifo needs servicing. Once the main program detects that SERIAL\$INT is set the routine DECIPHER is executed.

DECIPHER has three separate blocks; a block for decoding displayable characters, a block for processing Escape sequences, and a block for processing Control codes. Each block works on the fifo independently. Before exiting a block, the contents of the fifo are shifted up by the amount of characters that were processed in that particular block. The shifting of the characters insures that the beginning of the fifo contains the next character to be processed. FIFO is then decremented by the number of characters processed.

Let's look at this process more closely. Figure 6.2.1-A shows a representation of a fifo containing 5 characters. The first three characters in the fifo contain displayable characters, A, B, and C respectively with the last two characters being an ESC sequence for moving the curser up one line (ESC A) and FIFO points to the next available location to be filled by the serial port interrupt routine, in this case, 5.



FIGURE 6.2.1 FIFO

When DECIPHER is executed, the first block begins looking at the first character of the fifo for a displayable character. If the character is displayable, it is placed into the display RAM and the software pointer "TOP" that points to the character that is being processed is incremented to the next character. The character is then looked at to see if it too is displayable and if it is, it's placed in the display RAM. The process of checking for displayable characters is continued until either the fifo is empty or a non-displayable character is detected. In our example, three characters are placed into the display RAM before a nondisplayable character is detected. At this point the fifo looks like figure 6.2.1-B.

Before entering the next block, the remaining contents of the fifo between TOP, that is now pointing to 1BH and (FIFO-1) are moved up in the fifo by the amount of characters processed, in this example three. TOP is reset to 0 and FIFO is decremented by 3. The serial port interrupt is inhibited during the time the contents of the fifo and the pointers are being manipulated. The fifo now looks like figure 6.2.1-C.

The execution is now passed to the next block that processes ESC sequences. The first location of the fifo is examined to see if it is an ESC character (1BH). If not, the execution is passed to the next block of DECIPHER that processes Control codes. In this case the fifo does contain an ESC code. The flag ESC\$SEQ is checked to see if the 8051 is in the process of receiving an ESC sequence thus signifying that the next byte of the sequence has not been received yet. If the ESC\$SEQ is not set, the next character in the fifo is checked for a valid escape code and the proper subroutine is then called. The fifo contents are then shifted as discussed for the previous block. Due to the length of time that is needed to execute an ESC code sequence or a Control code, only one ESC code and/or Control code can be processed each time DECIPHER is executed.

If at the end of the DECIPHER routine, FIFO contains a 0, the flag SER\$INT is reset. If SER\$INT remains set, DECIPHER will be executed immediately after returning to the main program if SCAN had not been set during the execution of the DECIPHER routine, otherwise DECI-PHER will be called after the keyboard is read.

#### 6.2.4 Memory Pointers and Scrolling

The curser always points to the next location in display memory to be filled. Each time a character is placed in the display memory, the curser position needs to be tested to determine if the curser should be incremented to the beginning of the next line of the display or simply moved to the next position on the current display line. The curser position pointers are then updated in both the 8276 and the internal registers in the 8051. When the 2000th character is entered into the display memory, a full display page has been reached signaling the need for the display to scroll. The memory pointer that points to the display memory that contains the first character of the first display line, LINE0, prior to scrolling contains 1800H which is the starting address of the display memory. Each scrolling operation adds 80 (50H) to LINE0 which will now point to the following row in memory as shown in figure 6.2.2-B. LINE0 is used during the vertical

refresh routine to re-initialize the pointers associated with filling the 8276 row buffers.

The display memory locations that were the first line of the CRT display now becomes the last line of the CRT display. Incoming characters are now entered into the display memory starting with 1800H, which is now the first character of the last line of the display screen.



Figure 6.2.2 Pointer Manipulation During Scrolling

#### 6.2.5 Software Timing

The use of interrupts to tie the operation of the foreground program to the real-time events of the background program has made the software timing non-critical for this system.

## 6.3 System Operation

Following the system reset, the 8051 initializes all onchip peripherals along with the 8276 and display ram. After initialization, the processor waits until the fifo has a character to process or is flagged that it is time to scan the keyboard. This foreground program is interrupted once every 617 microseconds to service the 8276 row buffers. The 8051 is also interrupted each 16.67 milliseconds to re-initialize LINE0 and to flag the foreground program to read the keyboard. As discussed earlier, a special technique of rapidly moving the contents of the display RAM to the 8276 row buffers without the need of a DMA device was employed. The characters are then synchronously transferred to the character generator via CC0-CC6 and LC0-LC2 which are used to display one line at a time. Following the transfer of the first line to the dot timing logic, the line count is incremented and the second line is selected. This process continues until the last line of the character is transferred.

The dot timing logic latches the ouput of the character ROM in a parallel in, serial out synchronous shift register. The shift register's output constitutes the video information to the CRT.

| AF | P  | Ē | N | D | IX | A | • | • | • | • | • | • | • |   | • | • | 1 | 9 |
|----|----|---|---|---|----|---|---|---|---|---|---|---|---|---|---|---|---|---|
| AF | PP | E | N | D | IX | В |   |   |   | • |   | • |   | • |   |   | 7 | 7 |

AP-223

1







10-85











•

1

|      | CON<br>CHARA |          |     |     | DISPLA<br>CHAR/ |     |     |     | ESCAPE<br>SEQUENCE |     |            |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |
|------|--------------|----------|-----|-----|-----------------|-----|-----|-----|--------------------|-----|------------|-----|-----|-----|--|--|--|--|--|--|--|--|--|--|--|--|
| BIT  | 000          | 001      | 010 | 011 | 100             | 101 | 110 | 111 | 010                | 011 | 100        | 101 | 110 | 111 |  |  |  |  |  |  |  |  |  |  |  |  |
| 0000 | ® NUL        | P<br>DLE | SP  | ø   | @               | . P |     | P   |                    | 1.  |            |     |     | ,   |  |  |  |  |  |  |  |  |  |  |  |  |
| 0001 | A<br>Soh     | DC1 Q    | 1   |     | A               | ٩   | A   | a   |                    |     | <b>A</b>   |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |
| 0010 | B<br>STX     | R<br>DC2 | "   | 2   | Ŗ               | R   | B   | R   |                    |     | ₿          |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |
| 0011 | C<br>ETX     | S<br>DC3 | =   | 3   | с               | s   | с   | s   |                    |     | > c        |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |
| 0100 | D<br>EOT     | T<br>DC4 | \$  | 4   | D               | т   | D   | т   |                    |     | <b>←</b> ₀ |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |
| 0101 | E<br>ENQ     | U<br>NAK | %   | 5   | E               | U   | E   | U   |                    |     | CLR E      |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |
| 0110 | F<br>ACK     | V<br>SYN | å   | 6   | F               | v   | F   | v   |                    |     | 5          |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |
| 0111 | G<br>Bel     | W<br>ETB | ,   | 7   | G               | w   | G   | w   |                    |     |            |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |
| 1000 | <b>85</b> H  | CAN X    | (   | 8   | н               | x   | ,H  | x   |                    |     | HOME H     |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |
| 1001 | нт           | Y<br>EM  | )   | 9   | ı               | Y   | I   | ιŶ. |                    |     |            |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |
| 1010 | J<br>LF      | Z<br>SUB | •   | :   | J               | z   | J   | Z a |                    | c.  | EOS I      |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |
| 1011 | VT K         | ESC I    | +   | ;   | к               | ĩ   | ĸ   |     |                    |     | EL J       |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |
| 1100 | FF           | FS       | ,   |     | L               |     | L   |     |                    |     |            |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |
| 1101 | CR W         | GS       | -   | =   | м               | 1   | M   |     |                    |     |            |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |
| 1110 | N<br>SO      | RS '     |     |     | N               | ^   | N   |     |                    |     |            |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |
| 1111 | °<br>S1      | US -     | ,   | ?   | o               | -   | o   |     |                    |     |            |     |     |     |  |  |  |  |  |  |  |  |  |  |  |  |

## Appendix 7.4 Escape/Control/Display Character Summary

NOTE:

Shaded blocks -- functions terminal will react to. Others can be generated but are ignored upon receipt.

#### Appendix 7.5 Character Generator

As previously mentioned, the character generator used in this terminal is a 2716 EPROM. A 1K by 8 device would have been sufficient since a 128 character 5 by 7 dot matrix only requires 8K of memory. A custom character set could have been stored in the second 1K bytes of the 2716. Any of the free I/0 pins on the 8051 could have been used to switch between the character sets.

The three low-order line count outputs (LCO-LC2) from the 8276 are connected to the three low-order address lines of the character generator. The CCO-CC6 output lines are connected to the A3-A9 lines of the character generator. The output of the character generator is loaded into the shift register. The serial output of the shift register is the video output to the CRT.

Let's assume that the letter "E" is to be displayed. The ASCII code for "E" (45H) is presented to the address lines A2–A9 of the character generator. The scan lines (LC0–LC2) will now count from 0 to seven to form the character as shown in Figure 7.5.0. The same procedure is used to form all 128 possible characters. For reference Appendix 7.6 contains the HEX dump of the character generator used in this terminal.



Figure 7.5.0 Character Generator

~

# Appendix 7.6 Hex Dump of the Character Generator

• \*

| :1077300301070017070707707707707070707070                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | F         |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| : 10331 03300 3000000 000000000000000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 3         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 11)<br>(7 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ñ.        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ä         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 3         |
| : 10/28/22/22/20/28/20/28/20/28/27/20/28/20/28/20/28/20/28/27/20/28/27/20/28/27/28/20/28/27/28/27/28/27/28/27/2<br>: 10/28/22/28/29/29/28/27/28/27/28/27/28/27/28/27/28/27/28/27/28/27/28/27/28/27/28/27/28/27/28/27/28/27/28/27/2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Ø         |
| 1093A022220000000000000000000000000000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | C a       |
| 110000000000000000000000000000000000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | .?<br>A   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ă         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 3         |
| 100000000000000000000000000000000000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Ø.        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 5         |
| = :1001100014141400000000000014143E143E1414000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ٦.        |
| : 1001200033C0A1C281E030006261008043230005                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ĕ         |
| : 1001 300000 30000 300 300 300 300 300 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 3         |
| : 1971 407373 34 02 72 02 74 08 740 81 02 02 72 70 108 73 72<br>: 1071 572778 24 10 73 10 75 75 75 75 75 75 75 75 75 75 75 75 75                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1         |
| : 1001500000271C051C2A05.0000.0508 3E0808.00099                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | S.        |
| • = !!!!= !!!!!!!!!!!!!!!!!!!!!!!!!!!!!                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |           |
| : [0,1]502.1[[]77577675771[[0,000,000,000,000,000,000,000,000,000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |           |
| : 100190000022201C02023E003E20101920221C028                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |           |
| :1001A00010181412351010003502152020221C03C<br>:1001B0003814492152221C00352010082404000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 7         |
| :100180003804021E22221C003E20100804040404<br>:1001C0001C22221C22221C001C22223C20140E447                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 1         |
| : 1031C0301C22221C22221C001C22223C20109E447<br>: 1031D000003030300003033700303030803003387934F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 9         |
| - :1001600010050402049819000037778033603360336033                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 5         |
| : 10/11/0203409102010/8440910222010/84830005                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | i         |
| : 10/02/03/021C222A3A1A323C/03/01422223E22220/1<br>: 10/021/03/1E24241C24241E3/1C223/20/202221C977<br>: 10/022/03/1E2424242424241E0/73-3/20/20E0/2023E4344<br>: 10/023/03/3E/0202020/20/20/20/20/20/2023E4344<br>: 10/023/03/3E/0202020/20/20/20/20/20/20/20/20/20/20/2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 2         |
| 103210371E24241C24241E371C223282222371<br>103210371E24241C24241E371C22320202221C9977<br>103220391E2424242424241E3757292726222236344                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 4         |
| 1002201031224242424242416032532020206020236734<br>1002200316326202020203353202023A222235036<br>100240302222223222223202120333803983310034<br>1002533732020202322220322103221204053A1222398<br>10026030302302020202020202352424222222013<br>100273332225243222222240122222222216339<br>10028330162222163322222220122222222216339<br>1002833016222216342222222003202022222222222216339<br>100283301622221634222222200320202222222222222230<br>10029030316222216341222035020202222222216339<br>10029030316222216341222035020202222222216339<br>1002903031622221634122203502020222222216332<br>1002903031622221634122203502020222222222005<br>1002903031622221634122203502020222222222222005<br>100290303162222163412222035020202222222222005<br>10029030316222216320202020202020202020202020202020202020 | 2         |
| :10024000222223522222301C033809988331C044                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |           |
| : 10325/37772020202727221C03221204053A122247E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1         |
| : 10325/337320202020202020202020200000000000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | วี        |
| :10/27/3/322262A32222222401C2222222222222222<br>:10/328/3/3/1E22221E3202020/01C22222222221C3/39<br>:10/328/3/3/1E22221E3202020/01C22222222A122209F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Ż         |
| :10028/00/1E22221E02020/01C2222222A122C00F<br>:100290001E22221E0A1222003C02021C2222A122C00F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 2         |
| : 107290701 E 22221 E 7A 1222073572721 C 27201 E 3AE<br>: 1072A073E 9308 18 18 18 33 34 122222222222222222222222222222222                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 5         |
| : 10/02A0/0703E 0308.18 08 0303 0012222222222222222222222222222222                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 3         |
| * 10 <i>02</i> -0002222140314222270322227140483238                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 7         |
| 14320402020114/1020330/00/00/00/00/00/00/00/00/00/00/00/00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Ś         |
| :10030000,05901100000000000000000000000000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 5         |
| :19/320/32/2020322222223C0/0/0/0/382/4-Ca/40/0/                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | í.        |
| :10/330/03824040E040404030403000030000000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ŝ         |
| : 10/34/0002021214252222220008/30/938/07 1993/04<br>: 10/3500020202020202024241802022212041622002<br>: 10/35000200402020202020202020202020202000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 3         |
| : 11/2353/17/20/00/20/2/20/A424180/20/22212741622073<br>: 10/250/0385080803789739770000362A2A222220077                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 3         |
| 10/03/50/08/50/80/50/50/50/50/50/50/20/20/20/20/20/20/20/20/20/20/20/20/20                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 2         |
| :1003803020031E22221E020207071C22223C2720                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ś         |
| : 10/039/00/03/01 A 250/20/20/20/03/03/83418201C0/94<br>: 10/03A00/00/3781C0 30/8/99/03/03/0222222324C0/94<br>: 10/03B0/03/00/222222140/310/03/0222222324C0/94<br>: 10/03D0/02/02/22140/314220/03/00/222222322/3830<br>: 10/03D0/02/02/22140/314220/03/00/222222322/3830                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ĩ         |
| : 10//3A//J0//3J81C0 3//8J9J/JJJJ/JJ/2222222222222222<br>: 10//3B//0/JJ/0/222222140 3/JJJ/J/0/222222A 3E 1407F<br>: 10//3C//J0/J2/14/J314220/JJJ0/222222322J383J                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 5         |
| 1073500777777777777777777777777777777777                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |           |
| • 10//30//00/00/00/37/37.10//M/44 4E(4/188880/329990104/33)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |           |
| :1073E070/08/08/378/378/378/378759/91219791007.5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | i i       |
| : 1003F 703393095233091903030730037003700399                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 5         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |           |

# Appendix 7.7 Composite Video

In this design it was assumed that the CRT monitor required a separate horizontal drive, vertical drive, and video input. Many monitors require a composite video signal. The schematic shown in Figure 7.7.0 illustrate how to generate a composite video from the output of the 8276. The dual one-shots are used to provide a small delay and the proper horizontal and vertical pulse to the composite video monitor. The delay introduced in the horizontal and vertical timing is used to center the display. The 7486 is used to mix the vertical and horizontal retrace. Q1 mix the video and retrace signals along with providing the proper D.C. levels.



Figure 7.7.0 Composite Video

# Appendix 7.8 Software Documentation

|             | **************                          |                |
|-------------|-----------------------------------------|----------------|
| **********  | *************************************** | ************** |
| *****       |                                         | ******         |
| *****       | SOFTWARE DOCUMENTATION FOR THE 8051     | ******         |
| ******      | TERMINAL CONTROLLER APPLICATION NOTE    | ******         |
| ******      | · · · · · · · · · · · · · · · · · · ·   | ******         |
| **********  | *************************************** | ***********    |
| *********** | ******************                      | *************  |

MEMORY MAP ASSOCIATED WITH PERIPHERAL DEVICES (USING MOVX):

| 8051 WR AND READ DISPLAY RAM-    | ADDRESS | 1000H TO 17CFH |
|----------------------------------|---------|----------------|
| 8051 WR DISPLAY RAM TO THE 8276- | ADDRESS | 1800H TO 1FCFH |
| 8276 COMMAND ADDRESS-            | ADDRESS | 0001H          |
| 8276 PARAMETER ADDRESS-          |         | ADDRESS 0000H  |
| 8276 STATUS REGISTER-            |         | ADDRESS 0001H  |

MEMORY MAP FOR READING THE KEYBOARD (USING MOVC):

KEYBOARD ADDRESS-

ADDRESS 10FFH TO 17FFH

/\* BEGIN BY PUTTING THE ASCII CODE FOR BLANK IN THE DISPLAY RAM\*/

INIT: {FILL 2000 LOCATIONS IN THE DISPLAY RAM WITH SPACES (ASCII 20H)}

/\*

INITIALIZE POINTERS, RAM BITS, ETC. \*/

{INITIALIZE POINTERS AND FLAGS} INITIALIZE TOP OF THE CRT DISPLAY "LINEO"=1800H} INITIALIZE 8276 BUFFER POINTER "RASTER" =1800H} INITIALIZE DISPLAY \$RAM\$POINTER=0000H}

/\* INITIALIZE THE 8276 \*/

{ RESET THE 8276} INITIALIZE 8276 TO 80 CHARACTER/ROW } INITIALIZE 8276 TO 25 ROWS PER FRAME INITIALIZE 8276 TO 10 LINES PER ROW INITIALIZE 8276 TO 10 LINES PER ROW INITIALIZE 8276 TO NON-BLINKING UNDERLINE CURSER INITIALIZE CURSER TO HOME POSITION (00,00) (UPPER LEFT HAND CORNER) START DISPLAY ENABLE 8276 INTERRUPT

/\* SET UP 8051 INTERRUPTS AND PRIORITIES \*/

{SERIAL FORT HAS HIGHEST INTERRUPT PRIORITY } EXTEINAL INTERRUPTS ARE EDGE SENSITIVE } ENABLE EXTEINAL INTERRUPTS }

/\*PROCEDURE SCANNER: THIS PROCEDURE SCANS THE KEYBOARD AND DETERMINES IF A SINGLE VALID KEY HAS BEEN PUSHED. IF TRUE THEN THE ASCII EQUIVALENT WILL BE TRANSMITTED TO THE HOST COMPUTER.\*/ SCANNER: ENABLE 8051 GLOBAL INTERRUPT BIT /\* PROGRAMMABLE DELAY FOR THE CURSER BLINK \*/ IF {30 VERTICAL RETRACE INTERRUPTS HAVE OCCURRED (CURSER\$COUNT=1FH)} THEN DO: COMPLEMENT CURSERSON {CLEAR CURSER\$COUNT} IF (CURSER IS TO BE OFF (CURSERSON=0) THEN (MOVE CURSER OFF THE SCREEN) CALL LOADSCURSER: END; IF {THE LOCALSLINE SWITCH HAS CHANGED STATE} THEN DO; IF {IN LOCAL MODE} THEN {DISABLE SERIAL PORT INTERRUPT} ELSE CALL CHECK \$BAUD\$RATE: END: DO WHILE {INBETWEEN VERTICAL REFRESHES} IF {THE FIFO HAS A CHARACTER TO PROCESS (SERIAL\$INT=1)} THEN CALL DECIPHER; END: CALL READER: IF THE PRESENT PRESSED KEY IS EQUAL TO THE LAST KEY PRESSED AND VALID=1 THEN CALL AUTOSREPEAT; ELSE DO; IF {A KEY IS PRESSED BUT NOT THE SAME ONE AS THE LAST KEYBOARD SCAN} THEN DO; IF {ONLY ONE KEY IS PRESSED} THEN GET THE ASCII CODE FOR IT SET NEWŞKEY AND VALID FLAGS ELSE {RESET VALID AND NEWSKEY FLAGS} END: ELSE {THE KEYBOARD MUST NOT HAVE A KEY PRESSED SO RESET VALIDSKEY AND NEWSKEY FLAGS} END: GOTO SCANNER; END; PROCEDURE AUTO\$REPEAT: THIS PROCEDURE WILL PERFORM AN AUTO REPEAT FUNCTION /\* BY TRANSMITTING A CHARACTER EVERY OTHER TIME THIS ROUTINE IS CALLED. THE AUTO REPEAT FUNCTION IS ACTIVATED AFTER A FIXED DELAY PERIOD AFTER THE FIRST CHARACTER IS SENT\*/ AUTOSREPEAT : IF {THE KEY PRESSED IS NEW (NEW\$KEY=1} THEN DO; CLEAR THE DIVIDE BY TWO COUNTER "TRANSMIT STOGGLE" INITIALIZE THE DELAY COUNTER "TRANSMITSCOUNT" TO ODOH CALL TRANSMIT; /\* FIRST CHARACTER \*/

{CLEAR NEW\$KEY } END;

ELSE DO; IF {TRANSMIT\$COUNT IS NOT EQUAL TO 0} THEN DO; {INCREMENT TRANSMIT\$COUNT} IF TRANSMITSCOUNT=OFFH THEN /\*DELAY BETWEEN FIRST CHARACTER AND THE SECOND \*/ DO: CALL TRANSMIT: /\*SECOND CHARACTER \*/ CLEAR TRANSMITSCOUNT END: END: ELSE DO; TURN THE CURSER ON DURING THE AUTO REPEAT FUNCTION IF TRANSMITSTOGGLE = 1 THEN /\* 2 VERT FRAMES BETWEEN 3RD TO NTH CHARACTER \*/ /\* 3RD THROUGH NTH CHARACTER \*/ CALL TRANSMIT; COMPLEMENT TRANSMITSTOGGLE END; END: END AUTOSREPEAT: /\* PROCEDURE TRANSMIT- ONCE THE HOST COMPUTER SIGNALS THE 8051H BY BRINGING THE CLEAR-TO-SEND LINE LOW, THE ASCII CHARACTER IS PUT INTO THE SERIAL PORT.\*/ TRANSMIT: PROCEDURE; IF THE TERMINAL IS ON-LINE THEN DO; (WAIT UNTIL THE CLEARSTOSSEND LINE IS LOW AND UNTIL THE 8051 SERIAL PORT TX IS NOT BUSY (TRANSMIT\$INT=1) TRANSMIT THE ASCII CODE CLEAR THE FLAG "TRANSMIT\$INT". THE SERIAL PORT SERVICE ROUTINE WILL SET THE FLAG WHEN THE SERIAL PORT IS FINISHED TRANSMITTING END; ELSE {THE TERMINAL IS IN THE LOCAL MODE} DO; PUT THE ASCII CODE IN THE FIFO} INCREMENT THE FIFO POINTER SET SERIALSINT END; END TRANSMIT'S

PROCEDURE DECIPHER: THIS PROCEDURE DECODES THE HOST COMPUTER'S MESSAGES AND DETERMINES /\* WHETHER IT IS A DISPLAYABLE CHARACTER, CONTROL SEQUENCE, OR AN ESCAPE SEQUENCE THE PROCEDURE THEN ACTS ACCORDINGLY \*/ DECIPHER: START\$DECIPHER: VALID\$RECEPTION=0; DO WHILE {THE FIFO IS NOT EMPTY AND THE CHARACTER IS DISPLAYABLE} RECEIVE={ASCII CODE} CALL DISPLAY; NEXT CHARACTER END: IF {CHARACTERS WERE DISPLAYED} THEN DISABLE SERIAL PORT INTERRUPT MOVE THE REMAINING CONTENTS OF THE FIFO UP TO THE BEGINNING OF THE FIFO ENABLE SERIAL PORT INTERRUPT SET THE VALIDSRECEPTION FLAG IF {THE FIFO IS EMPTY} THEN {CLEAR THE "SERIAL\$INT FLAG AND RETURN} IF {THE NEXT CHARACTER IS AN "ESC" CODE } THEN DO: {LOOK AT THE CHARACTER IN THE FIFO AFTER THE ESC CODE AND CALL THE CORRECT SUBROUTINE} CALL UP\$CURSER; /\* ESC A \*/ CALL DOWNSCURSER; /\* ESC B \*/ CALL RIGHT\$CURSER; /\* ESC C \*/ CALL LEFT\$CURSER; /\* ESC D \*/ /\* ESC E \*/ CALL CLEAR\$SCREEN; CALL MOV\$CURSER; /\* ESC F \*/ CALL HOME; /\* ESC H \*/ /\* ESC J \*/ CALL ERASE\$FROM\$CURSER\$TO\$END\$OF\$SCREEN; CALL BLINE; /\* ESC K \*/ DISABLE THE SERIAL PORT INTERRUPT MOVE THE REMAINING CONTENTS OF THE FIFO UP TO THE BEGINNING OF THE FIFO ENABLE THE SERIAL PORT INTERRUPT SET THE "VALID\$RECEPTION" FLAG}

IF {THE FIFO IS EMPTY} THEN {CLEAR THE SERIAL\$INT FLAG AND RETURN} END;

IF {THE NEXT CHARACTER IS A CONTROL CODE} THEN ...

[CALL THE RIGHT SUBROUTINE]

| CALL LEFTSCURSER;                                  | /* CTL H */                |
|----------------------------------------------------|----------------------------|
| CALL LINESFEED;                                    | /* CTL J */                |
| ;<br>CALL CLEAR\$SCREEN;<br>CALL CARRIAGE\$RETURN; | /* CTL L */<br>/* CTL M */ |

[DISABLE THE SERIAL PORT INTERRUPT] MOVE THE REMAINING CONTENTS OF THE FIFO UP TO THE BEGINNING OF THE FIFO] ENABLE THE SERIAL PORT INTERRUPT] (SET THE "VALIDSRECEPTION" FLAG]

END;

IF {NO VALID CODE WAS RECEIVED ("VALID\$RECEPTION" IS 0)} THEN {THROW THE CHARACTER OUT AND MOVE THE REMAINING CONTENTS OF THE FIF0} {UP TO THE BEGINNING}

IF {THE FIFO IS EMPTY} THEN {CLEAR THE SERIALSINT FLAG AND RETURN}

END DECIPHER;

/\*

PROCEDURE DISPLAY: THIS PROCEDURE WILL TAKE THE BYTE IN RAM LABELED RECEIVE AND PUT IT INTO THE DISPLAY RAM. \*/

#### DISPLAY:

{PUT INTO THE DISPLAY RAM LOCATION POINTED TO BY "DISPLAY\$RAM\$POINTER THE CONTENTS OF RECEIVE}

IF {THE END OF THE DISPLAY MEMORY HAS BEEN REACHED} THEN {RESET "DISPLAY \$RAM\$POINTER" TO THE BEGINNING OF THE RAM} ELSE

{INCREMENT "DISPLAY \$RAM\$POINTER"}

IF {THE CURSER IS IN THE LAST COLUMN OF THE CRT DISPLAY} THEN DO;

(MOVE THE CURSER BACK TO THE BEGINNING OF THE LINE)

IF {THE NEW DISPLAY RAM LOCATION HAS A END-OF-LINE CHARACTER IN IT} THEN CALL FILL;

IF {THE CURSER IS ON THE LAST LINE OF THE CRT DISPLAY} THEN CALL SCROLL;

ELSE

{MOVE THE CURSER TO THE NEXT LINE}

END; ELSE

[INCREMENT THE CURSER TO THE NEXT LOCATION]

{TURN THE CURSER ON } CALL LOADCURSER; END DISPLAY; /\* PROCEDURE LINE\$FEED \*/

LINE\$FEED:

```
IF {THE CURSER IS IN THE LAST LINE OF THE CRT DISPLAY} THEN
CALL SCROLL;
ELSE
DO;
{
MOVE THE CURSER TO THE NEXT LINE}
{TURN THE CURSER ON}
CALL LOAD$CURSER;
END;
END;
IF {THE DISPLAY$RAM$POINTER IS ON THE LAST LINE IN THE DISPLAY RAM} THEN
{MOVE THE DISPLAY$RAM$POINTER TO THE LAST LINE IN THE DISPLAY RAM}
ELSE
{MOVE THE DISPLAY$RAM$POINTER TO THE NEXT LINE IN THE DISPLAY RAM}
IF {THE FIRST CHARACTER IN THE NEW LINE CONTAINS AN END-OF-LINE CHARACTER } THEN
CALL FILL;
END LINE$FEED;
```

/\* PROCEDURE SCROLL

SCROLL:

CALL BLANK; {DISABLE VERTICAL RETRACE INTERRUPT}

IF {THE FIRST LINE OF THE CRT CONTAINS THE LAST LINE OF THE DISPLAY MEMORY} THEN { MOVE THE POINTER "LINEO" TO THE BEGINNING OF THE DISPLAY MEMORY} ELSE

\*/

{MOVE "LINEO" TO THE NEXT LINE IN THE DISPLAY MEMORY }

{ENABLE VERTICAL RETRACE INTERRUPT}

.

END SCROLL;

/\* PROCEDURE CLEAR SCREEN \*/

CLEAR\$SCREEN:

CALL HOME;

CALL ERASE\$FROM\$CURSER\$TO\$END\$OF\$SCREEN;

END CLEAR\$SCREEN;

/\* PROCEDURE HOME: THIS PROCEDURE MOVES THE CURSER TO THE 0,0 POSITION \*/

HOME:

{MOVE THE CURSER POSITION TO THE UPPER LEFT HAND CORNER OF THE CRT} {TURN THE CURSER ON} CALL LOAD\$CURSER;

MOVE THE DISPLAY SRAMSPOINTER TO THE CORRECT LOCATION IN THE DISPLAY RAM

END HOME;

/\* PROCEDURE ERASE FROM CURSER TO END OF SCREEN: \*/

ERASESFROMSCURSERSTOSENDSOFSSCREEN:

CALL BLINE;

/\* ERASE CURRENT LINE \*/

IF {THE CURSER IS NOT ON THE LAST LINE OF THE CRT DISPLAY} THEN STARTING WITH THE NEXT LINE, FUT AN END-OF-LINE CHARACTER (0F1H) IN THE DISPLAY RAM LOCATIONS THAT CORRESPOND TO THE BEGINNING OF THE CRT DISPLAY LINES UNTIL THE BOITOM OF THE CRT SCREEN HAS BEEN REACHED} END:

END ERASE\$FROM\$CURSER\$TO\$END\$OF\$SCREEN;

/\*PROCEDURE MOV\$CURSER: THIS PROCEDURE IS USED IN CONJUNCTION WITH WORDSTAR IF A ESC F IS RECEIVED FROM THE HOST COMPUTER, THE TERMINAL CONTROLLER WILL READ THE NEXT TWO BYTE TO DETERMINE WHERE TO MOVE THE CURSER. THE FIRST BYTE IS THE ROW INFORMATION FOLLOWED BY THE COLUMN INFORMATION \*/

MOV\$CURSER:

WAIT UNTIL THE FIFO HAS RECEIVED THE NEXT TWO CHARACTERS MOVE THE CURSER TO THE LOCATION SPECIFIED IN THE ESCAPE SEQUENCE MOVE THE DISPLAY \$RAM\$POINTER TO THE CORRECT LOCATION

IF THE FIRST CHARACTER IN THE NEW LINE HAS AN END-OF-LINE CHARACTER} THEN CALL FILL;

END;

{DISABLE THE SERIAL FORT INTERRUPT} MOVE THE REMAIN CONTENTS OF THE FIFO UP TWO LOCATIONS IN MEMORY} DECREMENT THE FIFO BY TWO [ENABLE THE SERIAL FORT INTERRUPT]

END MOV\$CURSER;

/\* PROCEDURE LEFT CURSER: THIS PROCEDURE MOVES THE CURSER LEFT ONE COLUMN BY SUBTRACTING 1 OF THE CURSER COLUMN RAM LOCATION THEN CALL LOAD CURSER \*/

LEFT\$CURSER:

IF {THE CURSER IS NOT IN THE FIRST LOCATION OF A LINE} THEN DO; {MOVE THE CURSER LEFT BY ONE LOCATION} {TUEN THE CURSER ON} CALL LOADSCURSER; {DECREMENT THE DISPLAY\$RAM\$POINTER BY ONE} END:

END LEFT\$CURSER;

/\* PROCEDURE RIGHT CURSER: THIS PROCEDURE MOVES THE CURSER RIGHT ONE COLUMN BY ADDING 1 TO THE CURSER COLUMN RAM LOCATION THEN CALL LOAD CURSER \*/

RIGHT\$CURSER:

IF {THE CURSER IS NOT IN THE LAST POSITION OF THE CRT LINE} THEN

DO;

MOVE THE CURSER RIGHT BY ONE LOCATION

TURN THE CURSER ON

CALL LOADSCURSER;

{INCREMENT THE DISPLAY \$RAM\$POINTER BY ONE}

END;

END RIGHT\$CURSER;

/\* PROCEDURE UP CURSER: THIS PROCEDURE MOVES THE CURSER UP ONE ROW BY SUBTRACTING 1 TO THE CURSER ROW RAM LOCATION THEN CALL LOAD CURSER \*/

UP\$CURSER:

IF {THE CURSER IS NOT ON THE FIRST LINE OF THE CRT DISPLAY} THEN DO;

{MOVE THE CURSER UP ONE LINE} {TURN ON THE CURSER} CALL LOAD\$CURSER;

IF {THE DISPLAY \$RAM\$POINTER IS IN THE FIRST LINE OF DISPLAY MEMORY} THEN {MOVE THE DISPLAY \$RAM\$POINTER TO THE LAST LINE OF DISPLAY MEMORY}

{MOVE THE DISPLAY \$RAM\$POINTER UP ONE LINE IN DISPLAY MEMORY}

IF {THE FIRST LOCATION OF THE NEW LINE CONTAINS AN END-OF-LINE CHARACTER} THEN CALL FILL;

END;

END UP\$CURSER;

/\* PROCEDURE DOWN CURSER: THIS PROCEDURE MOVES THE CURSER DOWN ONE ROW BY ADDING 1 TO THE CURSER ROW RAM LOCATION THEN CALL LOAD CURSER \*/

DOWNSCURSER:

IF {THE CURSER IS NOT ON THE LAST LINE OF THE CRT DISPLAY} THEN DO;

{TURN THE CURSER ON} {MOVE THE CURSER TO THE NEXT LINE} CALL LOAD\$CURSER;

IF {THE DISPLAY \$RAM\$POINTER IS NOT ON THE LAST LINE OF THE DISPLAY MEMORY} THEN {MOVE THE DISPLAY \$RAM\$POINTER TO THE NEXT LINE IN THE DISPLAY MEMORY} ELSE

MOVE THE DISPLAY \$RAM\$POINTER TO THE FIRST LINE IN THE DISPLAY MEMORY }

IF {THE FIRST CHARACTER IN THE NEW LINE IS AN END-OF-LINE CHARACTER} THEN CALL FILL;

END;

#### END DOWN\$CURSER;

# /\* PROCEDURE CARRIAGE\$RETURN

CARRIAGE\$REFURN:

{MOVE THE DISPLAY \$RAM\$POINTER TO THE BEGINNING OF THE CURRENT LINE IN THE DISPLAY MEMORY} MOVE THE CURSER TO THE BEGINNING OF THE CURRENT LINE OF THE CRT DISPLAY} (TURN THE CURSER ON) (TURN THE CURSER ON)

\*/

END CARRIAGE\$RETURN:

/\* PROCEDURE LOAD CURSER: LOAD CURSER TAKES THE VALUE HELD IN RAM AND LOADS IT INTO THE 8276 CURSER REGISTER. \*/

LOAD\$CURSER: PROCEDURE; IF {THE CURSER IS ON} THEN {MOVE THE CURSER BACK ONTO THE CRT DISPLAY} {DISABLE BUFFER INTERNIET} {WRITE TO THE 8276 CURSER REGISTERS THE X,Y LOCATIONS} [ENABLE BUFFER INTERNIET]

#### END LOAD\$CURSER;

/\*

PROCEDURE CHECK BAUD RATE: THIS PROCEDURE READS THE THREE FORT PINS ON P1 AND SETS UP THE SERIAL PORT FOR THE SPECIFIED BAUD RATE \*/

1128

11.1.4.0

96-

CHECK \$BAUD\$RATE :

SET TIMER 1 TO MODE 1 AND AUTO RELOAD [TURN TIMER ON] [ENABLE SERIAL FORT INTERRUPT] [READ BADD RATE SWITCHES AND SET UP RELOAD VALUE]

TH1=040H; TH1=0A0H; TH1=0D0H; TH1=0E8H; TH1=0E4H; TH1=0F4H; TH1=0FAH; TH1=0FDH; /\* 00 IS NOT ALLOWED \*/ /\* 150 BAUD \*/ /\* 300 BAUD \*/ /\* 600 BAUD \*/ /\* 1200 BAUD \*/ /\* 2400 BAUD \*/ /\* 4800 BAUD \*/

END CHECK \$BAUD\$RATE;

/\* PROCEDURE READER: THIS PROCEDURE IS WRITTEN IS ASSEMBLY LANGUAGE. THE EXTERNAL PROCEDURE SCANS THE 8 LINES OF THE KEYBOARD AND READS THE RETURN LINES. THE STATUS OF THE 8 RETURN LINES ARE THEN STORED IN INTERNAL MEMORY ARRAY CALLED CURRENT\$KEY \*/

READER: {INITIALIZE FLAGS "KEY0"=0, "SAME"=1, 0 COUNTER=0} DO UNTIL {ALL 8 KEYBOARD SCAN LINES ARE READ} {READ KEYBOARD SCAN} IF {NO KEY WAS PRESSED} THEN INCREMENT 0 COUNTER ELSE IF THE KEY PRESSED WAS NOT THE SAME KEY THAT WAS PRESSED THE LAST TIME THE KEYBOARD WAS READ THEN {CLEAR "SAME" AND WRITE NEW SCAN RESULT TO CURRENTSKEY RAM ARRAY} END: IF {ALL 8 SCANS DIDN'T HAVE A KEY PRESSED (0 COUNTER=8)} THEN SET KEYO, AND CLEAR SAME END READER: PROCEDURE BLANK: THIS EXTERNAL PROCEDURE FILLS LINEO WITH SPACES (20H ASCII) DURING THE SCROLL ROUTINES.\*/ BLANK : DO I = {BEGINNING OF THE CRT DISPLAY (LINEO)} TO {LINEO + 50H} {DISPLAY RAM POINTED TO BY "I" = SPACE (ASCII 20H)} NEXT I FND: ..... END BLANK: /\* PROCEDURE BLINE: THIS EXTERNAL PROCEDURE BLANKS FROM THE CURSER TO THE END OF THE DISPLAY LINE \*/ BLINE: DO I = {CURRENT CURSER POSITION ON CRT DISPLAY} TO {END OF ROW} {DISPLAY RAM POINTED TO BY "I" = SPACE (ASCII 20H)} NEXT I END; END BLINE; PROCEDURE FILL: THIS EXTERNAL PROCEDURE FILLS A DISPLAY LINE WITH SPACES\*/ 14 FILL: DO I = {BEGINNING OF THE LINE THAT THE CURSER IS ON} TO {END OF THE ROW} {DISPLAY RAM POINTED TO BY "I" = SPACE (ASCII 20H)} NEXT I

END;

END FILL;

# Appendix 7.9 Software Listings

PL/M-51 COMPILER

ISIS-II PL/M-51 V1.1 COMPILER INVOKED BY: PLM51 :F1:CRTPLM.SRC

> \$OPTIMIZE (1) \$NOINTVECTOR \$ROM (LARGE)

| ********<br>NAL |
|-----------------|
| NAT *******     |
|                 |
| ******          |
| ******          |
| ******          |
| *               |

MEMORY MAP ASSOCIATED WITH PERIPHERAL DEVICES (USING MOVX);

| 8051 WR AND READ DISPLAY RAM-    | ADDRESS 1000H TO 17CFH |
|----------------------------------|------------------------|
| 8051 WR DISPLAY RAM TO THE 8276- | ADDRESS 1800H TO 1FCFH |
| 8276 COMMAND ADDRESS-            | ADDRESS 0001H          |
| 8276 PARAMETER ADDRESS-          | ADDRESS 0000H          |
| 8276 STATUS REGISTER-            | ADDRESS 0001H          |

MEMORY MAP FOR READING THE KEYBOARD (USING MOVC):

KEYBOARD ADDRESS-

ADDRESS 10FFH TO 17FFH

THE FOLLOWING SOFTWARE SWITCHES MUST BE SET ACCORDING TO THE TYPE OF KEYBOARD THAT IS GOING TO BE USED.

SW1- SET WHEN USING AN UNDECODED KEYBOARD IS TO BE USED SW2- SET WHEN USING A DECODED OR A SERIAL TYPE OF KEYBOARD

PROGRAMS TO LINK TOGETHER FOR WORKING SYSTEMS:

UNDECODED KEYBOARD- CRTPIM.OBJ, CRTASM.OBJ, KEYBO.OBJ, PIM51.LIB DECODED KEYBOARD-CRTPIM.OBJ, CRTASM.OBJ, DECODE.OBJ, PIM51.LIB DETACHED KEYBOARD-CRTPIM.OBJ, CRTASM.OBJ, DETACH.OBJ, PIM51.LIB

\*/ \$SET (SW1) \$RESET (SW2)

# PL/M-51 COMPILER

.

**SEJECT** 

| 1        | 1           | CRT\$CONTROLLER:<br>DO;                                                                                                                                                |
|----------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |             | /************************* DECLARE LITERALS ***********************************/                                                                                       |
| 2        | 1           | DECLARE LLC LITERALLY 'LOCAL\$LINE\$CHANGE';                                                                                                                           |
| 3        | 1           | DECLARE REG LITERALLY 'REGISTER';                                                                                                                                      |
| 4        | 1           | DECLARE CURRENT\$KEY LITERALLY 'CURKEY';                                                                                                                               |
| 5        | 1           | DECLARE SERIALSSERVICE LITERALLY 'SERBUF';                                                                                                                             |
| 6        | 1           | DECLARE DISPLAY \$RAM\$POINTER LITERALLY 'POINT';                                                                                                                      |
| 7        | 1           | DECLARE SERIALSINT LITERALLY 'SERINT';                                                                                                                                 |
| 8        | 1           | DECLARE TRANSMITSINT LITERALLY 'TRNINT';                                                                                                                               |
| 9        | 1           | DECLARE CURSERSCOLUMN LITERALLY 'CURSER';                                                                                                                              |
| 10       | 1           |                                                                                                                                                                        |
| 11       | ī           |                                                                                                                                                                        |
| 12       | 1           | DECLARE SCANSINT LITERALLY 'SCAN';                                                                                                                                     |
| 10<br>11 | 1<br>1<br>1 | DECLARE CURSER\$COLUMN LITERALLY 'CURSER';<br>DECLARE LAST\$KEY LITERALLY 'LSTKEY';<br>DECLARE CURSER\$COUNT LITERALLY 'COUNT';<br>DECLARE SCAN\$INT LITERALLY 'SCAN'; |

/\*\*\*\*\*\*\*\*\* REGISTER DECLARATIONS FOR THE 8051 \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*/

.

.

/\*\*\*\*\*\*\*\*\* BYTE REGISTERS \*\*\*\*\*\*\*/

### 13 1

| DECLARE |      |           |      |
|---------|------|-----------|------|
| PO      | BYTE | AT (80H)  | REG, |
| Pl      | BYTE | AT (90H)  | REG, |
| P2      | BYTE | AT (OAOH) | REG, |
| P3      | BYTE | AT (OBOH) | REG, |
| PSW     | BYTE | AT (0D0H) | REG, |
| ACC     | BYTE | AT (OEOH) | REG, |
| в       | BYTE | AT (OFOH) | REG, |
| SP      | BYTE | AT (81H)  | REG, |
| DPL     | BYTE | AT (82H)  | REG, |
| DPH     | BYTE | AT (83H)  | REG, |
| PCON    | BYTE | AT (87H)  | REG, |
| TCON    | BYTE | AT (88H)  | REG, |
| TMOD    | BYTE | AT (89H)  | REG, |
| TLO     | BYTE | AT (8AH)  | REG, |
| TLL     | BYTE | AT (8BH)  | REG, |
| тно     | BYTE | AT (8CH)  | REG, |
| THL     | BYTE | AT (8DH)  | REG, |
| IE      | BYTE | AT (OA8H) | REG, |
| IP      | BYTE | AT (0B8H) | REG, |
| SCON    | BYTE | AT (98H)  | REG, |
| SBUF    | BYTE | AT (99H)  | REG; |
|         |      |           |      |

|    |   | \$EJECT |      |           |             |
|----|---|---------|------|-----------|-------------|
|    |   | /****** | * BI | T REGISTE | RS *******/ |
|    |   | /*****  | ***  | PSW BITS  | ; *******/  |
| 14 | 1 | DECLARE |      |           |             |
|    |   |         | BIT  | AT (0D7H) | REG,        |
|    |   |         |      | AT (OD6H) | REG         |
|    |   |         |      | AT (OD5H) | REG,        |
|    |   | RS1 B   |      | AT (OD4H) | REG         |
|    |   | RSO B   |      | AT (OD3H) | REG,        |
| -  |   | OV B    | BIT  | AT (OD2H) | REG,        |
|    |   | PB      | BIT  | AT (ODOH) | REG,        |
|    |   | /*****  | ***  |           | ; *******/  |
|    |   | ,       |      |           |             |
|    |   |         |      | AT (8FH)  | REG,        |
|    |   |         |      | AT (8EH)  | REG,        |
|    |   |         |      | AT (8DH)  | REG,        |
|    |   |         |      | AT (8CH)  | REG,        |
|    |   |         |      | AT (8BH)  | REG,        |
|    |   |         |      | AT (8AH)  | REG,        |
|    |   | -       |      | AT (89H)  | REG,        |
|    |   | ITO E   | SIT  | AT (88H)  | REG,        |
|    |   | /*****  | ***  | IE BITS   | ; *******/  |
|    |   |         |      | AT (OAFH) | REG,        |
|    | , |         |      | AT (OACH) | REG,        |
|    |   |         |      | AT (OABH) | REG,        |
|    |   |         |      | AT (OAAH) | REG,        |
|    |   |         |      | AT (OA9H) | REG,        |
|    |   | EXO E   | BIT  | AT (OA8H) | REG,        |
|    |   | /*****  | ***  | IP BITS   | ; *******/  |
|    |   | PS E    | BIT  | AT (OBCH) | REG,        |
|    |   | PT1 B   | BIT  | AT (OBBH) | REG,        |
|    |   | PX1 E   | BIT  | AT (OBAH) | REG,        |
|    |   | PTO E   | BIT  | AT (OB9H) | REG,        |
|    |   | PXO E   | BIT  | AT (OB8H) | REG,        |
|    |   | /*****  | ***  | P3 BITS   | 5 *******/  |
|    |   | RD E    | BIT  | AT (0B7H) |             |
|    |   | WR E    | BIT  | AT (OB6H) | REG,        |
|    |   | TÌ E    | BTT  | AT (OB5H) | REG,        |
|    |   | то е    | BIT  | AT (OB4H) | REG,        |
|    |   | INT1 E  | BIT  | AT (OB3H) | REG,        |
|    |   | INTO E  | BIT  | AT (OB2H) | REG,        |
|    |   | TXD E   | BIT  | AT (OB1H) | REG,        |
|    |   | RXD B   | BIT  | AT (OBOH) | REG,        |
|    |   | /*****  | ***  | SOON BIT  | 5 *******/  |
|    | - | /       | BIT  | AT (9FH)  | REG.        |
|    |   |         |      | AT (9EH)  | REG,        |
|    |   |         | BIT  | AT (9DH)  | REG,        |
|    |   |         | BIT  | AT (9CH)  | REG,        |
|    |   |         | BIT  | AT (9BH)  | REG,        |
|    |   |         | BIT  | AT (9AH)  | REG,        |
|    |   |         | BIT  | AT (99H)  | REG,        |
|    |   | RI E    | 3IT  | AT (98H)  | REG;        |
|    |   | •       |      |           |             |

```
$EJECT
            SIF SW1
                15 1
            DECLARE LOW$SCAN (16) STRUCTURE
                (KEY (8) BYTE) CONSTANT
                ('890-', 5CH, 5EH, 08H, 00H,
            /* SCAN 0, SHIFT KEY =0; 8,9,0,-,\,^, BACK SPACE */
                'uiop',5BH,'@',0AH,7FH,
            /* SCAN 1, SHIFT =0; u,i,o,p,[,@, LINE FEED, DELETE */
                'jkl;:',00H,0DH,'7',
            /* SCAN 2, SHIFT =0; j,k,1,;,:, RETURN, 7 */
                'm',2CH,'.',00H,'/',00H,00H,00H,
            /* SCAN 3, SHIFT =0; m, COMMA, ., / */
            00H,'azxcvbn',
/* SCAN 4, SHIFT =0; a,z,x,c,v,b,n */
                'y',00H,00H,' dfgh',
            /* SCAN 5, SHIFT =0; y, SPACE, d,f,g,h */
                09H,'qwsert',00H,
            /* SCAN 6, SHIFT =0; TAB,q,w,s,e,r,t */
                1BH, '123456',00H,
            /* SCAN 7, SHIFT =0;ESC,1,2,3,4,5,6 */
                28H, 29H, 00H, '=', 7CH, 7EH, 08H, 00H,
            /* SCAN 0, SHIFT =1; (,),=, ,~, BACK SPACE */
                'UIOP',00H,00H,0AH,7FH,
            /* SCAN 1, SHIFT =1; U,I,O,P, LINE FEED, DELETE */
                'JKL+*',00H,0DH,27H,
            /* SCAN 2, SHIFT =1; J,K,L,+,*, RETURN, ' */
                'M<>',00H,3FH,00H,00H,00H,
            /* SCAN 3, SHIFT =1; M,<,>,? */
                OOH, 'AZXCVEN',
            /* SCAN 4, SHIFT =1; A,Z,X,,C,V,B,N */
            'Y',00H,00H,' DFGH',
/* SCAN 5, SHIFT =1; Y, SPACE, D,F,G,H */
                09H,'QWSERT',00H,
            /* SCAN 6, SHIFT =1; TAB, Q,W,S,E,R,T */
                1BH,'!"#$%&',00H);
            /* SCAN 7, SHIFT =1;ESC,!,",#,$,&,& */
            SENDIF
```

| ILER CRICONTROLLER                                                                                                                                                                                                                                                            |                                                              |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|
| \$EJECT<br>/******************DECLARE VARIABLES**********************/                                                                                                                                                                                                        | `                                                            |
| DECLARE                                                                                                                                                                                                                                                                       |                                                              |
| \$IF SW2                                                                                                                                                                                                                                                                      |                                                              |
| BIT AT (0B4H) REG,<br>\$ENDIF<br>\$IF SW1<br>CAP\$LOCK BIT AT (095H) REG,<br>SHIFT\$KEY BIT AT (096H) REG,<br>CONTROL\$KEY BIT AT (097H) REG,<br>\$ENDIF<br>LOCAL\$LINE BIT AT (0B5H) REG,<br>CLEAR\$TO\$SEND BIT AT (094H) REG;<br>DATA\$TERMINAL\$READ\$ BIT AT (094H) REG; |                                                              |
| DECLARE (                                                                                                                                                                                                                                                                     |                                                              |
| <pre>\$IF SW1<br/>SAME,<br/>VALID\$KEY,<br/>KEY0,<br/>LAST\$SHIFT\$KEY,<br/>LAST\$CONTROL\$KEY,<br/>LAST\$CAP\$LOCK,<br/>\$ENDIF</pre>                                                                                                                                        |                                                              |
| \$IF SW2<br>RCVFLG,<br>SYNC,<br>BYFIN,<br>KEDINT,<br>ERROR,<br>\$ENDIF                                                                                                                                                                                                        |                                                              |
| NEWSKEY,<br>TRANSMITSTOGGLE,<br>CURSERSON,<br>SERIALSINT,<br>SCANSINT,<br>TRANSMITSINT,<br>ESCSEQ,<br>VALIDSRECEPTION,<br>LLC,<br>ENSP) BIT FUBLIC;                                                                                                                           | ,                                                            |
|                                                                                                                                                                                                                                                                               | <pre>\$EJECT<br/>/************************************</pre> |

**ŞEJECT** 

18 1 DECLARE (

I, J, K, ASCII\$KEY, TRANSMIT\$COUNT, TEMP, SHIFT, CURSER\$COL, CURSE

\$IF SW1 19 1 DECLARE LAST\$KEY (8) BYTE PUBLIC; \$ENDIF

> \$IF SW2 DECLARE LAST\$KEY(2) BYTE PUBLIC; \$ENDIF

- 20 1 DECLARE SERIAL (16) BYTE FUBLIC;
- 21 1 DECLARE DISPLAY \$RAM (7CFH) BYTE AT (1000H) AUXILIARY;
- 22 1 DECLARE

| PARAMETERŞADDRESS | BYTE | AT (0000H) | AUXILIARY, |
|-------------------|------|------------|------------|
| COMMAND\$ADDRESS  | BYTE | AT (0001H) | AUXILIARY; |

23 1 DECLARE (

DISPLAY \$RAM\$POINTER, RASTER, LINEO, L) WORD PUBLIC;

**\$EJECT** 

- /\* PROCEDURE READER: THIS PROCEDURE IS WRITTEN IS ASSEMBLY LANGUAGE. THE EXTERNAL PROCEDURE SCANS THE 8 LINES OF THE KEYBOARD AND READS THE RETURN LINES. THE STATUS OF THE 8 RETURN LINES ARE THEN STORED IN INTERNAL MEMORY ARRAY CALLED CURRENT\$KEY. THE PROCEEDURE CONTROLS 2 STATUS FLAGS; KEYO AND SAME. KEYO IS SET IF ALL 8 SCANS READ NO KEY WAS PRESSED. IF ALL 8 SCANS ARE THE SAME AS THE LAST READING OF THE KEYBOARD, THEN SAME IS SET. \*/
- 24 2 READER: PROCEDURE EXTERNAL; 25 1 END READER:
  - /\* PROCEDURE BLANK: THIS EXTERNAL PROCEDURE FILLS LINEO SCAN WITH SPACES (20H ASCII) DURING THE SCROLL ROUTINES.\*/
- 262BLANK: PROCEDURE EXTERNAL;271END BLANK;
  - /\* PROCEDURE BLINE: THIS EXTERNAL PROCEDURE BLANKS FROM THE CURSER TO THE END OF THE DISPLAY LINE \*/
- 282BLINE: PROCEDURE EXTERNAL;291END BLINE;
  - /\* PROCEDURE FILL: THIS EXTERNAL PROCEDURE FILLS THE CURSER LINE WITH SPACES\*/
- 30 1 FILL:
- PROCEDURE EXTERNAL;
- 31 1 END FILL;

\$EJECT

/\* PROCEDURE CHECK BAUD RATE: THIS PROCEDURE READS THE THREE FORT PINS ON P1 AND SETS UP THE SERIAL FORT FOR THE SPECIFIED BAUD RATE \*/

| 32  | 1      | CHECK \$BAUD\$RATE :   |                                  |
|-----|--------|------------------------|----------------------------------|
|     |        | PROCEDURE;             |                                  |
| 33  | 2      | SCON=70H;              | /* MODE 1                        |
|     | -      | book / hily            | ENABLE RECEPTION*/               |
| ~ • | ~      |                        |                                  |
| 34  | 2      | TMOD=TMOD OR 20H;      | /* TIMER 1 AUTO RELOAD */        |
| 35  | 2      | TRl=l;                 | /* TIMER 1 ON */                 |
| 36  | 2      | ES=1;                  | /* ENABLE SERIAL INTERRUPT*/     |
| 37  | 2      | ENSP=1;                | /* SERIAL INTERRUPT MASK FLAG */ |
| 38  | 3      | DO CASE (P1 AND 07H);  | ,                                |
| 39  | 3      | ,                      | /* 00 IS NOT ALLOWED */          |
| 40  | 3<br>3 | TH1=040H;              | /* 150 BAUD */                   |
| 41  | 3      | TH1=QAOH;              | /* 300 BAUD */                   |
| 42  | 3      | TH1=0D0H;              | /* 600 BAUD */                   |
| 43  | 3      | TH1=0E8H;              | /* 1200 BAUD */                  |
| 44  | 3      | TH1=OF4H;              | /* 2400 BAUD */                  |
| 45  | 3      | TH1=OFAH:              | /* 4800 BAUD */                  |
|     | 2      |                        |                                  |
| 46  | 3      | TH1=OFDH;              | /* 9600 BAUD */                  |
| 47  | 3      | END;                   |                                  |
| 48  | 1      | END CHECK\$BAUD\$RATE; |                                  |
|     |        |                        |                                  |

.

/\* PROCEDURE LOAD CURSER: LOAD CURSER TAKES THE VALUE HELD IN RAM AND LOADS IT INTO THE 8276 CURSER REGISTERS. \*/

| 49 | 1 | LOAD\$CURSER:                 |                                       |
|----|---|-------------------------------|---------------------------------------|
|    |   | PROCEDURE;                    | · · ·                                 |
| 50 | 2 | IF CURSERSON=1 THEN           |                                       |
| 51 | 2 | CURSERSCOL=CURSERSCOLUMN;     |                                       |
| 52 | 2 | EX1=0;                        | /* DISABLE BUFFER INTERRUPT */        |
| 53 | 2 | COMMANDSADDRESS=80H;          | /* INITIALIZE CURSER COMMAND */       |
| 54 | 2 | PARAMETERSADDRESS=CURSERSCOL; |                                       |
| 55 | 2 | PARAMETERSADDRESS=CURSERSROW: | ×                                     |
| 56 | 2 | EX1=1;                        | /* ENABLE BUFFER INTERRUPT */         |
| 57 | 1 | END LOAD\$CURSER;             | · · · · · · · · · · · · · · · · · · · |

#### /\* PROCEDURE CARRIAGE\$RETURN \*/

|    |   | ,                                                             |
|----|---|---------------------------------------------------------------|
| 58 | 1 | CARRIAGE\$RETURN:                                             |
|    |   | PROCEDURE;                                                    |
| 59 | 2 | DISPLAY \$RAM\$POINTER=DISPLAY \$RAM\$POINTER-CURSER\$COLUMN; |
| 60 | 2 | CURSER\$COLUMN=0;                                             |
| 61 | 2 | CURSER\$ON=1;                                                 |
| 62 | 2 | CALL LOADSCURSER;                                             |
| 63 | 1 | END CARRIAGE\$RETURN;                                         |

# \$EJECT

/\* PROCEDURE DOWN CURSER: THIS PROCEDURE MOVES THE CURSER DOWN ONE ROW BY ADDING 1 TO THE CURSER ROW RAM LOCATION THEN CALL LOAD CURSER \*/

| 64 | 1 | DOWN\$CURSER:                                         |                       |
|----|---|-------------------------------------------------------|-----------------------|
|    |   | PROCEDURE;                                            | 4                     |
| 65 | 2 | IF CURSER\$ROW < 18H THEN                             | 1                     |
| 66 | 3 | DO;                                                   |                       |
| 67 | 3 | CURSER\$ON=1;                                         |                       |
| 68 | 3 | CURSER\$ROW=CURSER\$ROW + 1;                          |                       |
| 69 | 3 | CALL LOADSCURSER;                                     |                       |
| 70 | 3 | IF DISPLAY SRAMSPOINTER < 780H THEN                   |                       |
| 71 | 3 | DISPLAY \$RAM\$POINTER=DISPLAY \$RAM\$POINTER + 50H;  |                       |
| 72 | 3 | ELSE                                                  |                       |
|    |   | DISPLAY \$RAM\$POINTER=(DISPLAY \$RAM\$POINTER-780H); |                       |
| 73 | 3 | L=DISPLAY \$RAM\$POINTER-CURSER\$COLUMN;              |                       |
| 74 | 3 | IF DISPLAY \$RAM(L)=0F1H THEN                         | /* LOOK FOR END OF*/  |
| 75 | 4 | DO;                                                   | /* LINE CHARACTER *   |
| 76 | 4 | CALL FILL;                                            | /*IF TRUE FILL LINE*/ |
| 77 | 4 | DISPLAY \$RAM(L)=20H;                                 | /*WITH SPACES */      |
| 78 | 4 | END:                                                  |                       |
| 79 | 3 | END;                                                  |                       |
| 80 | ĩ | END DOWNSCURSER;                                      |                       |
|    |   |                                                       |                       |

/\* PROCEDURE UP CURSER: THIS PROCEDURE MOVES THE CURSER UP ONE ROW BY SUBTRACTING 1 TO THE CURSER ROW RAM LOCATION THEN CALL LOAD CURSER \*/

| 81 | 1 | UP\$CURSER:                                            |
|----|---|--------------------------------------------------------|
|    |   | PROCEDURE;                                             |
| 82 | 2 | IF CURSER\$ROW >0 THEN                                 |
| 83 | 3 | DO;                                                    |
| 84 | 3 | CURSER\$ROW=CURSER\$ROW - 1;                           |
| 85 | 3 | CURSER\$ON=1;                                          |
| 86 | 3 | CALL LOADSCURSER;                                      |
| 87 | 3 | IF DISPLAY \$RAM\$POINTER<50H THEN                     |
| 88 | 3 | DISPLAY \$RAM\$POINTER=DISPLAY \$RAM\$POINTER+780H;    |
| 89 | 3 | ELSE                                                   |
|    |   | DISPLAY \$RAM\$POINTER=DISPLAY \$RAM\$POINTER - 50H;   |
| 90 | 3 | L=DI SPLAY \$RAM\$POINTER-CURSER\$COLUMN;              |
| 91 | 3 | IF DISPLAY\$RAM(L)=0F1H THEN /* LOOK FOR END OF LINE*/ |
| 92 | 4 | DO; /* CHARACTER */                                    |
| 93 | 4 | CALL FILL; /* IF TRUE FILL WITH */                     |
| 94 | 4 | DISPLAY \$RAM(L)=20H; /* SPACES */                     |
| 95 | 4 | END;                                                   |
| 96 | 3 | END;                                                   |
| 97 | 1 | END UP\$CURSER;                                        |

### **\$EJECT**

/\* PROCEDURE RIGHT CURSER: THIS PROCEDURE MOVES THE CURSER RIGHT ONE COLUMN BY ADDING 1 TO THE CURSER COLUMN RAM LOCATION THEN CALL LOAD CURSER \*/

| 98  | 1 | RIGHT\$CURSER:                                    |
|-----|---|---------------------------------------------------|
| 99  | 2 | PROCEDURE;                                        |
|     | 4 | IF CURSER\$COLUMN < 4FH THEN                      |
| 100 | 3 | DO;                                               |
| 101 | 3 | CURSER\$COLUMN=CURSER\$COLUMN + 1;                |
| 102 | 3 | CURSER\$ON=1;                                     |
| 103 | 3 | CALL LOAD\$CURSER;                                |
| 104 | 3 | DISPLAY \$RAM\$POINTER=DISPLAY \$RAM\$POINTER +1; |
| 105 | 3 | END;                                              |
| 106 | 1 | END RIGHTSCURSER;                                 |

/\* PROCEDURE LEFT CURSER: THIS PROCEDURE MOVES THE CURSER LEFT ONE COLUMN BY SUBTRACTING 1 TO THE CURSER COLUMN RAM LOCATION THEN CALL LOAD CURSER \*/

| 107 | 1 | LEFT\$CURSER:                                     |
|-----|---|---------------------------------------------------|
|     |   | PROCEDURE;                                        |
| 108 | 2 | IF CURSERSCOLUMN >0 THEN                          |
| 109 | 3 | DOT                                               |
| 110 | 3 | CURSERSCOLUMN=CURSERSCOLUMN - 1;                  |
| 111 | 3 | CURSERSON=1;                                      |
| 112 | 3 | CALL LOADSCURSER;                                 |
| 113 | 3 | DISPLAY \$RAM\$POINTER=DISPLAY \$RAM\$POINTER -1; |
| 114 | 3 | END;                                              |
| 115 | ī | END LEFTSCURSER;                                  |

DT M-51 COMDITIED

CONCOMPOST 7

----

| PL/M-5 | 51 COMP | ILER CRICONTROLLER                                                                                                                                                                                                                                                                                           |
|--------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |         | SEJECT                                                                                                                                                                                                                                                                                                       |
|        |         | ŞEJECT.                                                                                                                                                                                                                                                                                                      |
|        |         | /* PROCEDURE MOV\$CURSER: THIS PROCEDURE IS USED IN CONJUNCTION WITH WORDSTAR<br>IF A ESC F IS RECEIVED FROM THE HOST COMPUTER, THE TERMINAL CONTROLLER WILL<br>READ THE NEXT TWO BYTE TO DETERMINE WHERE TO MOVE THE CURSER. THE FIRST BYTE<br>IS THE ROW INFORMATION FOLLOWED BY THE COLUMN INFORMATION */ |
| 116    | 1       | MOV\$CURSER:                                                                                                                                                                                                                                                                                                 |
| 117    | 2       | PROCEDURE;                                                                                                                                                                                                                                                                                                   |
| 117    | 3<br>3  | DO WHILE FIFO<4; /* WAIT UNTILL THE MOV\$CURSER PARAMETERS*/<br>END; /* ARE RECEIVED INTO THE FIFO */                                                                                                                                                                                                        |
| 110    | 2       | ,                                                                                                                                                                                                                                                                                                            |
| 120    | 2       | TEMP=CURSER\$ROW;                                                                                                                                                                                                                                                                                            |
| 120    | 2       | CURSER\$ROW=SERIAL(2);                                                                                                                                                                                                                                                                                       |
| 121    | -       | IF CURSERSROW>TEMP THEN                                                                                                                                                                                                                                                                                      |
| 122    | 3<br>3  |                                                                                                                                                                                                                                                                                                              |
| 123    | 3       | L=DISPLAY\$RAM\$POINTER+((CURSER\$ROW-TEMP)*50H);                                                                                                                                                                                                                                                            |
| 124    | 3       | IF L>7CFH THEN /* IF OUT OF RAM RANGE */                                                                                                                                                                                                                                                                     |
| 125    | 3       | DISPLAY \$RAM\$POINTER=L-7DOH; /* RAP AROUND TO BEGINNING */<br>ELSE /* OF RAM */                                                                                                                                                                                                                            |
| 120    | 2       | DISPLAY \$RAM\$POINTER=L;                                                                                                                                                                                                                                                                                    |
| 127    | 3       | END;                                                                                                                                                                                                                                                                                                         |
| 127    | 2       | EISE                                                                                                                                                                                                                                                                                                         |
| 120    | 2       | DO:                                                                                                                                                                                                                                                                                                          |
| 129    | 3       | IF CURSER\$ROW <temp td="" then<=""></temp>                                                                                                                                                                                                                                                                  |
| 130    | 4       | DO;                                                                                                                                                                                                                                                                                                          |
| 131    | 4       | L=(TEMP-CURSER\$ROW) * 50H;                                                                                                                                                                                                                                                                                  |
| 132    | 4       | IF DISPLAY \$RAM\$POINTER <l *="" <="" if="" of="" out="" ram="" range*="" td="" then=""></l>                                                                                                                                                                                                                |
| 133    | 4       | DISPLAY \$RAM\$POINTER= (7D0H- (L-DISPLAY \$RAM\$POINTER));/* RAP AROUND TO END OF RAM*/                                                                                                                                                                                                                     |
| 134    | 4       | ELSE                                                                                                                                                                                                                                                                                                         |
|        | •       | DISPLAY \$RAM\$POINTER=DISPLAY \$RAM\$POINTER-L;                                                                                                                                                                                                                                                             |
| 135    | 4       | END:                                                                                                                                                                                                                                                                                                         |
| 136    | 3       | END;                                                                                                                                                                                                                                                                                                         |
| 137    | 2       | TEMP=CURSER\$COLUMN;                                                                                                                                                                                                                                                                                         |
| 138    | 2       | CURSER\$COLUMN=SERIAL(3);                                                                                                                                                                                                                                                                                    |
| 139    | 2       | IF CURSERSCOLUMN>TEMP THEN                                                                                                                                                                                                                                                                                   |
| 140    | 2       | DISPLAY \$RAM\$POINTER=DISPLAY \$RAM\$POINTER+ (CURSER\$COLUMN-TEMP);                                                                                                                                                                                                                                        |
| 141    | 2       | ELSE                                                                                                                                                                                                                                                                                                         |
|        |         | DISPLAY \$RAM\$POINTER=DISPLAY \$RAM\$POINTER- (TFMP-CURSER\$COLUMN);                                                                                                                                                                                                                                        |
| 142    | 2       | CURSER\$ON=1;                                                                                                                                                                                                                                                                                                |
| 143    | 2       | CALL LOAD\$CURSER;                                                                                                                                                                                                                                                                                           |
| 144    | 2       | L=DISPLAY\$RAM\$POINTER-CURSER\$COLUMN;                                                                                                                                                                                                                                                                      |
| 145    | 2       | IF DISPLAY \$RAM(L)=0F1H THEN /* LOOK FOR END FO LINE CHARACTER*/                                                                                                                                                                                                                                            |
| 146    | 3       | DO;                                                                                                                                                                                                                                                                                                          |
| 147    | 3       | CALL FILL; /* IF TRUE FILL WITH SPACES */                                                                                                                                                                                                                                                                    |
| 148    | 3       | DISPLAY \$RAM(L)=20H;                                                                                                                                                                                                                                                                                        |
| 149    | 3       | END;                                                                                                                                                                                                                                                                                                         |
| 150    | 2       | ES=0;                                                                                                                                                                                                                                                                                                        |
| 151    | 3       | DO I=2 TO FIFO-2;                                                                                                                                                                                                                                                                                            |
| 152    | 3       | SERIAL (I)=SERIAL (I+2);                                                                                                                                                                                                                                                                                     |
| 153    | 3       | END;                                                                                                                                                                                                                                                                                                         |
| 154    | 2       | FIFO=FIFO-2;                                                                                                                                                                                                                                                                                                 |
| 155    | 2       | ESE ENSP;                                                                                                                                                                                                                                                                                                    |
| 156    | 1       | END MOV\$CURSER;                                                                                                                                                                                                                                                                                             |

SEJECT

/\* PROCEDURE ERASE FROM CURSER TO END OF SCREEN: \*/

| 157 | 1 | ERASE\$FROM\$CURSER\$TO\$END\$OF\$SCREEN:<br>PROCEDURE;          |
|-----|---|------------------------------------------------------------------|
| 158 | 2 | CALL BLINE; /* ERASE CURRENT LINE */                             |
| 159 | 2 | IF CURSERSPOW < 18H THEN                                         |
| 160 | 3 | DO;                                                              |
| 161 | 3 | L=DISPLAY \$RAM\$POINTER-CURSER\$COLUMN+50H; /* GET NEXT LINE */ |
| 162 | 4 | DO WHILE (L < 7D0H) AND (L <> (LINEO AND 7FFH));                 |
| 163 | 4 | DISPLAY \$RAM(L)=0F1H; /* ERASE UNTIL LINEO OR */                |
| 164 | 4 | L=L+50H; /* END OF DISPLAY RAM*/                                 |
| 165 | 4 | END;                                                             |
| 166 | 3 | L=0;                                                             |
| 167 | 4 | DO WHILE L <> (LINEO AND 7FFH); /* ERASE UNTIL LINEO */          |
| 168 | 4 | DISPLAY \$RAM (L) = 0F 1H;                                       |
| 169 | 4 | L=L+50H;                                                         |
| 170 | 4 | END;                                                             |
| 171 | 3 | END;                                                             |
| 172 | 1 | END ERASESFROMSCURSERSTOSENDSOFSSCREEN:                          |

/\* PROCEDURE HOME: THIS PROCEDURE MOVES THE CURSER TO THE 0,0 POSITION \*/

173 l HOME: PROCEDURE; 174 175 176 2 2 2 2 2 CURSER\$ROW=00; CURSERSCOLUMN=00; CURSER\$ON=1; CALL LOAD\$CURSER; 177 178 2 DISPLAY \$RAM\$POINTER=(LINE0 AND 7FFH); 179 1 END HOME;

\$EJECT

/\* PROCEDURE CLEAR SCREEN \*/

| 180 | 1 | CLEAR\$SCREEN:                                 |
|-----|---|------------------------------------------------|
|     |   | PROCEDURE;                                     |
| 181 | 2 | CALL HOME;                                     |
| 182 | 2 | CALL ERASE\$FROM\$CURSER\$TO\$END\$OF\$SCREEN; |
| 183 | 1 | END CLEAR\$SCREEN;                             |

/\* PROCEDURE SCROLL \*/

| 184 | 1 | SCROLL:              |                                          |
|-----|---|----------------------|------------------------------------------|
|     |   | PROCEDURE;           |                                          |
| 185 | 2 | CALL BLANK;          |                                          |
| 186 | 2 | EX0=0;               | /* DISABLE VERTICAL REFRESH INTERRUPT */ |
| 187 | 2 | IF LINEO= 1F80H THEN |                                          |
| 188 | 2 | LINE0= 1800H;        |                                          |
| 189 | 2 | ELSE                 |                                          |
|     |   | LINEO= LINEO+50H;    |                                          |
| 190 | 2 | EX0=1;               | /* ENABLE VERTICAL REFRESH INTERRUPT */  |
| 191 | 1 | END SCROLL;          |                                          |
|     |   |                      |                                          |

# /\* PROCEDURE LINE\$FEED \*/

| 192 | 1 | LINE\$FEED:                                         |                                     |
|-----|---|-----------------------------------------------------|-------------------------------------|
|     |   | PROCEDURE;                                          |                                     |
| 193 | 2 | IF CURSER\$ROW=18H THEN                             |                                     |
| 194 | 2 | CALL SCROLL;                                        |                                     |
| 195 | 2 | ELSE                                                |                                     |
|     |   | DO;                                                 |                                     |
| 196 | 3 | CURSER\$ROW= CURSER\$ROW+1;                         |                                     |
| 197 | 3 | CURSER\$ON=1;                                       |                                     |
| 198 | 3 | CALL LOAD\$CURSER;                                  |                                     |
| 199 | 3 | END;                                                |                                     |
| 200 | 2 | IF DISPLAY \$RAM\$POINTER >77FH THEN                |                                     |
| 201 | 2 | DISPLAY \$RAM\$POINTER=DISPLAY \$RAM\$POINTER-780H; |                                     |
| 202 | 2 | ELSE                                                |                                     |
|     |   | DISPLAY \$RAM\$POINTER=DISPLAY \$RAM\$POINTER+50H;  |                                     |
| 203 | 2 | L=DISPLAY \$RAM\$POINTER-CURSER\$COLUMN;            |                                     |
| 204 | 2 | IF DISPLAY\$RAM(L)=0F1H THEN                        | /* LOOK FOR END OF LINE CHARACTER*/ |
| 205 | 3 | DO;                                                 |                                     |
| 206 | 3 | CALL FILL;                                          | /* IF TRUE FILL WITH SPACES */      |
| 207 | 3 | DISPLAY \$RAM(L)=20H;                               |                                     |
| 208 | 3 | END;                                                |                                     |
| 209 | 1 | END LINE\$FEED;                                     |                                     |

,

PL/M-51 COMPILER CRICONTROLLER

\$EJECT

/\* PROCEDURE DISPLAY: THIS PROCEDURE WILL TAKE THE BYTE IN RAM LABELED RECEIVE AND FUT IT INTO THE DISPLAY RAM. \*/

| 210 | 1 | DISPLAY:                                                |    |
|-----|---|---------------------------------------------------------|----|
|     |   | PROCEDURE;                                              |    |
| 211 | 2 | DISPLAY \$RAM (DISPLAY \$RAM\$POINTER) = RECEIVE;       |    |
| 212 | 2 | IF DISPLAY \$RAM\$POINTER=7CFH THEN /* IF END OF RAM */ | 1  |
| 213 | 2 | DISPLAY \$RAM\$POINTER=000H; /* RAP AROUND TO BEGINNING | */ |
| 214 | 2 | FLSE                                                    |    |
|     | - | DISPLAY \$RAM\$POINTER=DISPLAY \$RAM\$POINTER+1;        |    |
| 215 | 2 | IF CURSERSCOLUMN=4FH THEN                               |    |
| 216 |   | DO;                                                     |    |
| 217 | 3 | CURSERSCOLLIMN=00H:                                     |    |
| 218 |   | L=DISPLAY \$RAM\$POINTER;                               |    |
| 219 | 3 | IF DISPLAY \$RAM(L)=OF1H THEN                           |    |
| 220 | 4 | DO;                                                     |    |
| 221 | 4 | CALL FILL;                                              |    |
| 222 | 4 |                                                         |    |
|     | - | DISPLAY \$RAM(L)=20H;                                   |    |
| 223 | 4 | END;                                                    |    |
| 224 | 3 | IF CURSER\$ROW=18H THEN                                 |    |
| 225 | 3 | CALL SCROLL;                                            |    |
| 226 | 3 | ELSE                                                    |    |
|     |   | CURSER\$ROW=CURSER\$ROW+1;                              |    |
| 227 | 3 | END;                                                    |    |
| 228 | 2 | ELSE                                                    |    |
|     |   | CURSER\$COLUMN=CURSER\$COLUMN+1;                        |    |
| 229 | 2 | CURSER\$ON=1;                                           |    |
| 230 | 2 | CALL LOADCURSER;                                        |    |
| 231 | 1 | END DISPLAY;                                            |    |
|     |   | •                                                       |    |

# SEJECT

/\* PROCEDURE DECIPHER: THIS PROCEDURE DECODES THE HOST COMPUTER'S MESSAGES AND DETERMINES WHETHER IT IS A DISPLAYABLE CHARACTER, CONTROL SEQUENCE, OR AN ESCAPE SEQUENCE THE PROCEDURE THEN ACTS ACCORDINGLY \*/

| 232 | 1 | DECIPHER:<br>PROCEDURE:                                                      |
|-----|---|------------------------------------------------------------------------------|
| 233 | 2 | STARTSDECIPHER:                                                              |
| 233 | 2 | VALIDSRECEPTION=0;                                                           |
| 234 | 2 | I=0;                                                                         |
| 235 | 3 |                                                                              |
| 236 | - | DO WHILE (I <fifo) (serial(i)="" and="">1FH) AND (SERIAL(I)&lt;7FH);</fifo)> |
|     | 3 | RECEIVE=SERIAL(I);                                                           |
| 237 | 3 | CALL DISPLAY;                                                                |
| 238 | 3 | I=I+1;                                                                       |
| 239 | 3 | END;                                                                         |
| 240 | 2 | IF I>0 THEN                                                                  |
| 241 | 3 | DO;                                                                          |
| 242 | 3 | ES=0; /* DISABLE SERIAL INTERRUPT WHILE MOVING FIFO */                       |
| 243 | 3 | K=FIFO-I;                                                                    |
| 244 | 4 | DO J=0 TO K; /* MOVE FIFO */                                                 |
| 245 | 4 | SERIAL $(J)$ = SERIAL $(I)$ ;                                                |
| 246 | 4 | I=I+1;                                                                       |
| 247 | 4 | END;                                                                         |
| 248 | 3 | FIFO=K;                                                                      |
| 249 | 3 | ES=ENSP; /* ENABLE SERIAL INTERRUPT */                                       |
| 250 | 3 | VALID\$RECEPTION=1;                                                          |
| 251 | 3 | END;                                                                         |
| 252 | 2 | IF FIFO=0 THEN                                                               |
| 253 | 3 | DO;                                                                          |
| 254 | 3 | SERIAL\$INT=0;                                                               |
| 255 | ž | GOTO END\$DECIPHER;                                                          |
| 256 | 3 | END;                                                                         |
| 257 | 2 | IF (SERIAL(0)=1BH) THEN                                                      |
| 258 | 3 | DO;                                                                          |
| 259 | 3 | IF (ESC\$SEO=1) AND (FIFO<2) THEN                                            |
| 260 | 3 | GOTO ENDÉDECIPHER:                                                           |
| 261 | 3 | · ·                                                                          |
| 261 | 3 | K = (SERIAL(1) AND SFH) - 40H;                                               |
|     | - | IF (K >00H) AND (K<0CH) THEN                                                 |
| 263 | 4 | DO;                                                                          |
| 264 | 5 | DO CASE K;                                                                   |
| 265 | 5 | 1                                                                            |
| 266 | 5 | CALL UP\$CURSER; /* ESC A */                                                 |
| 267 | 5 | CALL DOWN\$CURSER; /* ESC B */                                               |
| 268 | 5 | CALL RIGHT\$CURSER; /* ESC C */                                              |
| 269 | 5 | CALL LEFT\$CURSER; /* ESC D */                                               |
| 270 | 5 | CALL CLEAR\$SCREEN; /* ESC E */                                              |
| 271 | 5 | CALL MOV\$CURSER; /* ESC F */                                                |
| 272 | 5 | ;                                                                            |
| 273 | 5 | CALL HOME; /* ESC H */                                                       |
| 274 | 5 | ;                                                                            |
| 275 | 5 | CALL ERASE\$FROM\$CURSER\$TO\$END\$OF\$SCREEN; /* ESC J */                   |
| 276 | 5 | CALL BLINE; /* ESC K */                                                      |
| 277 | 5 | END;                                                                         |
| 278 | 4 | END;                                                                         |
| 279 | 3 | ES=0; /* DISABLE SERIAL INTERRUPTS WHILE MOVING FIFO */                      |
|     | - | · · · · · · · · · · · · · · · · · · ·                                        |

```
280
      4
                DO I=0 TO (FIFO-2);
281
      4
                    SERIAL(I)=SERIAL(I+2);
                                                /* MOVE FIFO */
                 END;
282
      .4
283
      3
                 FIFO=FIFO-2:
284
      ž
                 ES=ENSP;
                                                /* ENABLE SERIAL INTERRUPTS */
                 VALIDSRECEPTION=1;
285
      3
286
      3
                 IF FIFO=0 THEN
287
                DO;
      4
288
      4
                    SERIAL$INT=0;
289
                    GOTO ENDSDECIPHER;
      4
                END;
290
      4
291
      3
             END:
292
             IF (SERIAL(0)> 07H) AND (SERIAL(0)<0EH) THEN
      23
293
             DO;
294
      4
                DO CASE (SERIAL(0) -08H);
                    CALL LEFTSCURSER;
295
      4
                                                         /* CTL H */
296
      4
297
                    CALL LINESFEED;
                                                         /* CTL J */
      4
298
      4
                    CALL CLEARSSCREEN;
299
                                                         /* CTL L */
      4
300
                    CALL CARRIAGESRETURN;
                                                         /* CTL M */
      4
301
                 END;
      4
302
                                                         /* DISABLE SERIAL INTERRUPTS WHILE MOVING FIFO */
      3
                 ES=0;
303
                 DO I=0 TO (FIFO-1);
      4
304
                    SERIAL(I)=SERIAL(I+1);
                                                         /* MOVE FIFO */
      4
305
                 END;
      4
306
                FIFO=FIFO-1;
      3
307
      3
                 ES=ENSP;
                                                         /* ENABLE SERIAL INTERRUPTS */
308
      3
                 VALID$RECEPTION=1;
309
      3
             END;
310
      23
             IF VALID$RECEPTION=0 THEN
311
             DO;
312
      3
                ES=0;
                DO I=0 TO (FIFO-1);
SERIAL(I)=SERIAL(I+1);
                                                    /* IF CHARACTER IS UNRECOGNIZED THEN */
313
      4
                                                     /* TRASH IT */
314
      4
315
      4
                 END:
316
      3
                FIFO=FIFO-1;
317
      3
                ES=ENSP;
318
      3
             END;
319
      2
             IF FIFO=0 THEN
320
      2
                SERIALSINT=0:
321
      2
             END$DECIPHER:
             END DECIPHER;
```

# **\$EJECT**

/\* PROCEDURE TRANSMIT- THIS PROCEDURE LOOKS AT THE CLEAR TO SEND PIN FOR AN ACTIVE LOW SIGNAL. ONCE THE MAIN COMPUTER SIGNALS THE 8051 THE ASCII CHARACTER IS FUT INTO THE SERIAL PORT.\*/

| 1 | TRANSMIT:                                                     |
|---|---------------------------------------------------------------|
|   | PROCEDURE;                                                    |
| 2 | IF LOCAL\$LINE =1 THEN                                        |
| 3 | DO;                                                           |
| 4 | DO WHILE (CLEAR\$TO\$SEND=1) OR (TRANSMIT\$INT=0);            |
| 4 | END;                                                          |
| 3 | SBUF=ASCII\$KEY;                                              |
| 3 | TRANSMIT\$ INT=0;                                             |
| 3 | END;                                                          |
| 2 | ELSE                                                          |
|   | DO;                                                           |
| 3 | SERIAL (FIFO) =ASCIISKEY ;                                    |
| 3 | FIFO=FIFO+1;                                                  |
| 3 | SERIAL\$INT=1;                                                |
| 3 | END;                                                          |
| 1 | END TRANSMIT;                                                 |
|   | 3<br>4<br>4<br>3<br>3<br>3<br>2<br>3<br>3<br>3<br>3<br>3<br>3 |

/\* PROCEDURE AUTO\$REPEAT: THIS PROCEDURE WILL PERFORM AN AUTO REPEAT FUNCTION AFTER A FIXED DELAY PERIOD \*/

| 336 | 1          | AUTOSREPEAT:                                                                   |
|-----|------------|--------------------------------------------------------------------------------|
| 220 | -          | PROCEDURE:                                                                     |
| 337 | 2          | IF NEWSKEY=1 THEN                                                              |
| 338 | 3          |                                                                                |
| 339 | 3          |                                                                                |
| 340 | 3          | TRANSMIT\$TOGELE=0;<br>TRANSMIT\$COUNT=000H;                                   |
| 341 | 3          | CALL TRANSMIT; /* FIRST CHARACTER */                                           |
| 342 | 3          | NEWSKEY=0;                                                                     |
| 343 | 3          |                                                                                |
| 344 | 2          | BND;                                                                           |
| 344 | 2          | ELSE                                                                           |
| ~   | •          |                                                                                |
| 345 | 3          | IF TRANSMIT\$COUNT <> 00H THEN                                                 |
| 346 | 4          | D0;                                                                            |
| 347 | 4          | TRANSMIT\$COUNT=TRANSMIT\$COUNT+1;                                             |
| 348 | 4          | IF TRANSMIT\$COUNT=OFFH THEN /*DELAY BETWEEN FIRST CHARACTER AND THE SECOND */ |
| 349 | 5          | DO;                                                                            |
| 350 | 5          | CALL TRANSMIT; /*SECOND CHARACTER */                                           |
| 351 | 5          | TRANSMIT\$COUNT=00;                                                            |
| 352 | 5          | END;                                                                           |
|     | * <b>4</b> | END;                                                                           |
| 354 | 3          | ELSE                                                                           |
|     |            | DO;                                                                            |
| 355 | 4          | CURSER\$ON=1;                                                                  |
| 356 | 4          | CURSER\$COUNT=0;                                                               |
| 357 | 4          | IF TRANSMIT\$TOGGLE = 1 THEN /* 2 VERT FRAMES BETWEEN 3RD TO NTH CHARACTER */  |
| 358 | 4          | CALL TRANSMIT; /* 3RD THROUGH NTH CHARACTER */                                 |
| 359 | 4          | TRANSMIT\$TOGGLE= NOT TRANSMIT\$TOGGLE;                                        |
| 360 | 4          | END;                                                                           |
| 361 | 3          | END;                                                                           |
| 362 | 1          | END AUTO\$ REPEAT;                                                             |
|     |            |                                                                                |

,

# \$EJECT

\*/

- 363 1 INIT: DO L=0 TO 7CFH;
   364 2 DISPLAY \$RAM(L)=20H;
   365 2 END;
  - /\* INITIALIZE POINTERS, RAM BITS, ETC.
- 366 1 ESC\$SEQ=0; 367 1 SCAN\$INT=0; 368 1 SERIALSINT=0; 369 1 FIFO=0; 370 1 CURSER\$COUNT=0; 371 1 LLC=0; DATA\$TERMINAL\$READY=1; 372 1 373 1 TCON=05H; 374 1 LINE0=1800H; 375 RASTER=1800H; 1 DISPLAY \$RAM\$POINTER=0000H; 376 377 TRANSMIT\$INT=1;

\$IF SW1

- 378
   2
   DO I=0 TO 7;

   379
   2
   LAST\$KEY(I)=00H;

   380
   2
   END;
- 381
   1
   VALID\$KEY=0;

   382
   1
   LAST\$\$SHIFT\$KEY=1;

   383
   1
   LAST\$\$CONTROL\$KEY=1;
- 384 1 LAST\$CAP\$LOCK=1; \$ENDIF

\$IF SW2 RCVFLG=0; SYNC=0; BYFIN=0; KBDINT=0; ERROR=0; \$ENDIF

### /\* INITIALIZE THE 8276 \*/

| 385<br>386 | 1<br>1 | COMMAND\$ADDRESS=00H;<br>PARAMETER\$ADDRESS=4FH; | /* RESET THE 8276 */<br>/* NORMAL ROWS, 80 CHARACTER/ROW */  |
|------------|--------|--------------------------------------------------|--------------------------------------------------------------|
| 387        | 1      | PARAMETER\$ADDRESS=58H;                          | /* 2 ROW COUNTS PER VERTICAL RETRACE<br>25 ROWS PER FRAME */ |
| 388        | 1      | PARAMETER\$ADDRESS=89H;                          | /* LINE 9 IS THE UNDERLINE POSITION<br>10 LINES PER ROW */   |
| 389        | 1      | PARAMETER\$ADDRESS=0F9H;                         | /* OFFSET LINE COUNTER, NON-TRANSPARENT FIELD ATTRIBUTE      |

÷

NON-BLINKING UNDERLINE CURSER, 20 CHARACTER COUNTS PER HORIZONTAL RETRACE \*/

| 390                             | 1                | TEMP=COMMAND\$ADDRESS;                                                                                      | ,                                              |
|---------------------------------|------------------|-------------------------------------------------------------------------------------------------------------|------------------------------------------------|
| 391<br>392<br>393<br>394<br>395 | 1<br>1<br>1<br>1 | CURSER\$COLUMN=00H;<br>CURSER\$ROW=00H;<br>CURSER\$COL=00H;<br>CALL LOAD\$CURSER;<br>TEMP=COMMAND\$ADDRESS; |                                                |
| 396<br>397                      | 1<br>1           | COMMAND\$ADDRESS=0E0H;<br>TEMP=COMMAND\$ADDRESS;                                                            | /* PRESET 8276 COUNTERS */                     |
| 398<br>399<br>400               | 1<br>1<br>1      | COMMAND\$ADDRESS=23H;<br>COMMAND\$ADDRESS=0A0H;<br>TEMP=COMMAND\$ADDRESS;                                   | /* START DISPLAY */<br>/* ENABLE INTERRUPTS */ |

/\* SET UP INTERRUPTS AND PRIORITIES \*/

| 401<br>402 | 1<br>1 | \$IF SW1<br>IP=10H;<br>IE=85H;<br>\$ENDIF                                                     | /* SERIAL PORT HAS HIGHEST PRIORITY */<br>/* ENABLE 8051 EXTERNAL INTERRUPTS */                                                            |
|------------|--------|-----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
|            |        | \$IF SW2<br>IP=10H;<br>IE=87H;<br>IMOD=05H;<br>ITLO=0FFH;<br>ITHO=0FFH;<br>ITRO=1;<br>\$ENDIF | /* SERIAL PORT HAS HIGHEST PRIORITY */<br>/* ENABLE TIMERO INTERRUPT*/<br>/* TIMER 0 =EVENT COUNTER */<br>/* INITIALIZE COUNTER TO FFFFH*/ |

/\* PROCEDURE SCANNER: THIS PROCEDURE SCANS THE KEYBOARD AND DETERMINES IF A SINGLE VALID KEY HAS BEEN FUSHED. IF TRUE THEN THE ASCII EQUIVALENT WILL BE TRANSMITTED TO THE HOST COMPUTER.\*/

| 403 | 1 | SCANNER:                 |                                          |
|-----|---|--------------------------|------------------------------------------|
|     |   | EA=1;                    |                                          |
| 404 | 1 | DATASTERMINALSREADY =0;  |                                          |
| 405 | 1 | IF CURSERSCOUNT=1FH THEN | /* PROGRAMMABLE CURSER BLINK */          |
| 406 | 2 | DO;                      |                                          |
| 407 | 2 | CURSERSON=NOT CURSERSON; |                                          |
| 408 | 2 | CURSER\$COUNT=00;        |                                          |
| 409 | 2 | IF CURSERSON=0 THEN      |                                          |
| 410 | 2 | CURSERSCOL=7FH;          |                                          |
| 411 | 2 | CALL LOADSCURSER;        | , i                                      |
| 412 | 2 | END;                     |                                          |
| 413 | 1 | IF LLC<>LOCAL\$LINE THEN | /* IF LOCAL/LINE HAS CHANGED STATUS */   |
| 414 | 2 | DO;                      |                                          |
| 415 | 2 | IF LOCAL\$LINE=0 THEN    | с. — — — — — — — — — — — — — — — — — — — |
| 416 | 3 | DO;                      |                                          |
| 417 | 3 | ENSP=0;                  |                                          |
| 418 | 3 | ES=0;                    |                                          |
| 419 | 3 | END;                     |                                          |
| 420 | 2 | ELSE                     |                                          |
|     |   | CALL CHECK \$BAUD\$RATE; |                                          |
| 421 | 2 | LLC=LOCAL\$LINE;         |                                          |
| 422 | 2 | END;                     |                                          |
|     |   | ŞIF SW1                  |                                          |
| 423 | 2 | DO WHILE SCAN\$INT=0;    | /* WAIT UNITL VERTICAL RETRACE BEFORE */ |
| 424 | 2 | IF SERIALSINT=1 THEN     | /* SCANNING THE KEYBOARD*/               |
| 425 | 2 | CALL DECIPHER;           |                                          |
| 426 | 2 | END;                     | ,                                        |
|     |   |                          |                                          |

.

.

PL/M-51 COMPILER CRICONTROLLER

\$EJECT

| 427 | 1 | CALL READER;                                                           |
|-----|---|------------------------------------------------------------------------|
| 428 | ĩ | IF VALID\$KEY =1 AND SAME=1 AND (LAST\$SHIFT\$KEY=SHIFT\$KEY) AND      |
| 120 | - | (LAST\$CAP\$LOCK=CAP\$LOCK) AND (LAST\$CONTROL\$KEY=CONTROL\$KEY) THEN |
| 429 | 1 |                                                                        |
|     |   | CALL AUTOSREPEAT;                                                      |
| 430 | 1 | ELSE                                                                   |
|     |   | DO;                                                                    |
| 431 | 2 | IF KEY0=0 AND SAME=0 THEN                                              |
| 432 | 3 | DO;                                                                    |
| 433 | 3 | TEMP = 0;                                                              |
| 434 | 3 | K=0;                                                                   |
| 435 | 4 | DO WHILE LAST\$KEY (K)=0;                                              |
| 436 | 4 | K=K+1;                                                                 |
|     |   |                                                                        |
| 437 | 4 | END;                                                                   |
| 438 | 3 | TEMP=LAST\$KEY(K);                                                     |
| 439 | 4 | DO $I = (K+1)$ TO 7;                                                   |
| 440 | 4 | TEMP=TEMP+LAST\$KEY (I);                                               |
| 441 | 4 | END;                                                                   |
| 442 | 3 | IF TEMP=LAST\$KEY (K) THEN                                             |
| 443 | 4 | DO;                                                                    |
| 444 | 4 | J=0;                                                                   |
| 445 | 5 | DO WHILE (TEMP AND $0lh$ )=0;                                          |
| 446 | 5 |                                                                        |
|     | - | TEMP=SHR (TEMP,1);                                                     |
| 447 | 5 | J=J+1;                                                                 |
| 448 | 5 | END;                                                                   |
| 449 | 4 | IF TEMP >1 THEN                                                        |
| 450 | 5 | DO;                                                                    |
| 451 | 5 | VALID\$KEY=0;                                                          |
| 452 | 5 | NEWSKEY=0;                                                             |
| 453 | 5 | END;                                                                   |
| 454 | 4 | ELSE                                                                   |
| 434 | * |                                                                        |
|     | - | DO;                                                                    |
| 455 | 5 | IF CONTROL\$KEY=0 THEN                                                 |
| 456 | 5 | ASCII\$KEY = (LOW\$SCAN (K).KEY (J)) AND 1FH;                          |
| 457 | 5 | ELSE                                                                   |
| 1   |   | DO;                                                                    |
| 458 | 6 | IF SHIFT\$KEY=0 THEN                                                   |
| 459 | 6 | ASCII \$KEY = LOW\$SCAN (K+08H) . KEY (J);                             |
| 460 | 6 | ELSE                                                                   |
| 400 | U |                                                                        |
| 463 | - |                                                                        |
| 461 | 7 | ASCIIŞKEY=LOWŞSCAN(K).KEY(J);                                          |
| 462 | 7 | IF (CAP\$LOCK=0) AND (ASCII\$KEY>60H) AND (ASCII\$KEY<7BH) THEN        |
| 463 | 7 | ASCII\$KEY=ASCII\$KEY-20H;                                             |
| 464 | 7 | IF LLC=0 THEN                                                          |
| 465 | 8 | DO;                                                                    |
| 466 | 8 | IF ASCIISKEY=1BH THEN                                                  |
| 467 | 8 | ESC\$SEQ=1;                                                            |
| 468 | 8 | ELSE                                                                   |
|     | U | ESC\$SEQ=0;                                                            |
| 469 | 8 |                                                                        |
|     |   | END;                                                                   |
| 470 | 7 | END;                                                                   |
| 471 | 6 | END;                                                                   |
| 472 | 5 | last\$shift\$key=shift\$key;                                           |
| 473 | 5 | LAST\$CAP\$LOCK=CAP\$LOCK;                                             |
| 474 | 5 | LAST\$CONTROL\$KEY =CONTROL\$KEY ;                                     |
| 475 | 5 | VALID\$KEY=1;                                                          |
| 476 | 5 | NEWSKEY=1;                                                             |
| 477 | 5 |                                                                        |
| 478 | 4 | END;                                                                   |
|     | - | END;                                                                   |
| 479 | 3 | ELSE                                                                   |
|     |   | DO;                                                                    |
| 480 | 4 | VALID\$KEY=0;                                                          |
| 481 | 4 | NEW\$KEY=0;                                                            |
| 482 | 4 | END;                                                                   |
| 483 | 3 | END;                                                                   |
| 484 | 2 | END;                                                                   |
|     | - |                                                                        |
|     |   | SENDTR                                                                 |

•

(STATIC+OVERLAYABLE)

2DH+00H

00H+00H

10H+00H

00H+00H

2278D

128D

45D+ 0D

0D+ 0D

16D+ 0D

0D+ 0D

0D

12D

= 08E6H

= 0.080H

= 0000H

= 000CH

0

=

=

-

# PL/M-51 COMPILER CRICONTROLLER

**\$EJECT** 

\$IF SW2 IF SERIAL\$INT=1 THEN CALL DECIPHER; IF KBDINT =1 THEN DO; IF ERROR =0 THEN DO; ASCII\$KEY=LST\$KEY(1); NEW\$KEY=1; CALL AUTOSREPEAT; KBDINT=0; END; ERROR=0; KBDINT=0; END; SENDIF

| 485 | 1 | GOIO | SCANNER; |
|-----|---|------|----------|
| 486 | 1 | END; |          |

| MODULE INFORMATION:     |
|-------------------------|
| CODE SIZE               |
| CONSTANT SIZE           |
| DIRECT VARIABLE SIZE    |
| INDIRECT VARIABLE SIZE  |
| BIT SIZE                |
| BIT-ADDRESSABLE SIZE    |
| AUXILIARY VARIABLE SIZE |
| MAXIMUM STACK SIZE      |
| REGISTER-BANK (S) USED: |
| 1056 LINES READ         |
| 0 PROGRAM ERROR (S)     |

END OF PL/M-51 COMPILATION

MCS-51 MALRU ASSEMBLEN CHTASM

```
ISIS-II MCS-SI MALRU ASSEMBLER V2.1
Object mounle placed in "F1:Crtasm.ubj
Assembler Invuked by: Asm51 "F1:Cr[Asm.src
```

| LUC     | UBJ            | ι | INE      | SOURLE  |              |                             |                                         |
|---------|----------------|---|----------|---------|--------------|-----------------------------|-----------------------------------------|
|         |                |   | 1        |         |              |                             |                                         |
|         |                |   | è        |         |              |                             |                                         |
|         |                |   | د        |         |              |                             |                                         |
|         |                |   | 4        | ;       |              |                             |                                         |
|         |                |   | 5        | ;       |              |                             |                                         |
|         |                |   | 7        |         | PUBLIC       | BLANK                       |                                         |
|         |                |   | 8        |         | PUBLIC       |                             |                                         |
|         |                |   | 9        |         | PUBLIC       |                             |                                         |
|         |                |   | 1 V      |         |              |                             | PUINT, SERIAL, FIFO, CURSER, COUNT, L)  |
|         |                |   | 11       |         | EXTRIN 0     | SIT (SERINT, ESUSEQ,        | , TRNINT, SCANJ                         |
|         |                |   | 12       |         |              |                             |                                         |
|         |                |   | 15<br>14 |         | CSEG A       | (u3H)                       |                                         |
| 0005    | 8050           |   | 15       |         | SJMP         |                             | RESET RASTER TO LINEO AND SCAN KEYBUARD |
|         |                |   | 16       |         | -            |                             | • • • • • • • • • •                     |
|         |                |   | 17       |         |              | CCUE (UETACH)               |                                         |
|         |                |   | 16       | 1       | CSEG A       |                             |                                         |
|         |                |   | 19<br>20 | ;       | LJMP         | DETACH                      | INEEDED IF DECUDED KEYBOARD IS USED     |
|         |                |   | 21       |         | CSEG A       | T (013H)                    |                                         |
| 0013    | 802A           |   | 22       |         | SJMP         | BUFFER                      | JFILL 8276 RUW BUFFER                   |
|         |                |   | 25       |         |              |                             |                                         |
|         |                |   | 24       |         |              | T(U23H)                     |                                         |
| 0023    | 80≤D           |   | 25       |         | SJMP         | SEKBUF                      | STICK SERIAL INFORMATION INTO THE FIFU  |
|         |                |   | 51       |         | CSEG         |                             |                                         |
|         |                |   | 28       |         | 6966         |                             |                                         |
| 0025    | C000           |   | 29       | VERTI   | PUSH         | PSN                         | PUSH REG USED BY PLM51                  |
|         | COLO           |   | 30       |         | PUSH         | ACC                         | · ··· ··· ··· ··· · · · · · · · · · ·   |
|         | C000           |   | 31       |         | PUSH         | 00H                         |                                         |
|         | 850000         | F | 35       |         | MOV          | HASTER, LINEO               | REINITIALIZE RASTER TO LINEO            |
|         | 850000<br>78v1 | F | 35<br>34 |         | MOV<br>MOV   | RASTER+1,LINE0+1<br>R0,#01H | CLR 8276 INTERRUPT FLAG                 |
| 0035    |                |   | 35       |         | MOVX         | A, dRU                      | JCEN BERG INTERNOLI FENG                |
|         | v5v0           | F | 36       |         | INC          | COUNT                       | INCK CURSER COUNT REGISTER              |
|         | 0020           | F | 37       |         | SETB         | SCAN                        | FOR DEBOUNCE HOUTINE                    |
|         | 0000           |   | 38       |         | POP          | 00H                         | ;POP REGISTERS                          |
|         | 0000<br>0000   |   | 39       |         | POP<br>POP   | ACL<br>PSn                  |                                         |
| 0036    |                |   | 40<br>41 |         | RELL         | FUN                         |                                         |
|         |                | r | 42       |         |              |                             |                                         |
|         |                |   | 43       |         |              |                             | , ,                                     |
|         | CODO           |   | 44       | BUFFER: |              | PSN                         | ;PUSH ALL REG USED BY PLM51 CODE        |
|         | COLO           |   | 45       |         | PUSH         | ACL                         |                                         |
|         | C083           |   | 46<br>47 |         | PUSH<br>Push | UPL<br>UPn                  | · · · · · · · · · · · · · · · · · · ·   |
|         | 1164           |   | 48       |         | ACALL        | UNA                         | JFILL 8276 RUW BUFFER                   |
|         | L083           | ~ | 49       |         | POP          | UPn                         | POP REGISTENS                           |
|         | N085           |   | 50       |         | POP          | UPL                         |                                         |
| 0 u 4 u | LOE0           |   | 51       |         | POP          | ACL                         |                                         |
|         | 000            |   | S2       |         | POP          | 2SA                         |                                         |
| 0051    | 32 (           |   | 55       |         | REII         |                             |                                         |
|         |                |   | 54       |         | · · •        |                             |                                         |
|         |                | v | 55       | +1 æEJE |              |                             |                                         |

,

S

| MUS-51 MALR      | U ASSEMBLEN              | CHTASM        |
|------------------|--------------------------|---------------|
| SYMBOL IABL      | t LISTING                |               |
| NAFE             | TYPE VA                  | LUE ATTRIBUTE |
| ACC              | D AUCH OVE               | UH A          |
| BLANK            | C AUCH 008               | SH A PUB      |
| BLINE            | C AUDK OUA               | SH A PUB      |
| BUFFER           | C AUDK 003               |               |
| CHECK            | C AUDH 01A               |               |
| CUN11            | C AUDA OUB               |               |
| CUNT2            | C AUCH OUE               |               |
| CUUNT            | D AUDH                   | - EXT         |
| CURSER           | D AUDH                   |               |
| DUONE            | C AUDH OUF               |               |
| DMA<br>DMADNE    | C AUDH OUF               |               |
|                  | C AUDH 018<br>C AUDH 018 |               |
| 0.014            | D AUCK OUE               |               |
| OPL              | D ADDK OUE               |               |
| EIGHTY .         | C AUDH 01A               |               |
| ESCSEu .         | B ADDK                   | -             |
| F1F0             | D AUCH                   |               |
| FIFTY            | C AUDH 016               |               |
| FILL             | C AUCH OUD               |               |
| FURTY            | C AUDK 015               |               |
| GUBACK           | C AUCH OUS               | 4H A          |
| L                | D AUDH                   | - EXT         |
| LINEC            | D AUDH                   | - EXT         |
| NUTYET           | C AUDK 009               | 7H A          |
| OVEH             | C AUCH 005               | 9H A          |
| OVER1            | C AUDR 007               | A HB          |
| PUINT            | D AUDK -++               |               |
| PSW              | D AUDH OUD               |               |
| RASIEN           | D AUCH +                 | - wat         |
| SHUF             | D AUCH 009               |               |
| SCAN             | B AUDK                   | - EXT         |
| SERBUF           | C AUDH 005               | <b>T</b> 11   |
| SERIAL           | D AUDK                   | - EXT         |
| SERINI<br>Sevnty | B ADDH                   |               |
|                  | C AUDR 018<br>C AUDR 017 |               |
|                  | C AUDR 017               |               |
| THINTY           | C AUDK 013               |               |
| TRNINI           | B AUDK +                 |               |
| THENTY .         | C AUDH 012               |               |
| VERI             | C AUDK 002               |               |
|                  |                          | -             |

# REGISTER BANK(S) USED: 0

ASSEMBLY COMPLETE, NC ENRURS FOUND

,

MCS-51 MALRU ASSEMBLEN CHTASM

| LUC    | UBJ            |   | LINE     | SOURCE        |             |              |                                                                             |
|--------|----------------|---|----------|---------------|-------------|--------------|-----------------------------------------------------------------------------|
|        |                |   | _        |               |             |              |                                                                             |
|        | 3000.0         |   | 56       |               |             |              |                                                                             |
|        | 309904<br>C299 |   | 57       | SERBUFI       |             | USSP USSP    | TRANSMIT BIT NUT SET THEN CHECK RECEIVE<br>ICLR THANSMISSION INTERRUPT FLAG |
|        | U200           | F | 50<br>54 |               | CLR<br>Setb | IRAINT       |                                                                             |
|        | 204858         | F | 57       | UVER:         | J8          |              | ;SETE TRANS INT FON PLM51 STATUS CHECK<br>HI NOT SET GUBACK                 |
|        | L001           |   | 61       | PUSI          |             | V1           | KI NUI JEI GUDALK                                                           |
|        | A999           |   | 4.5      | FUSI          | MOV         | K1,80UF      | IRLAU SBUF                                                                  |
|        | C298           |   | . 63     |               | CLN         | 0988         | CLEAR RI BIT                                                                |
|        | 6640           |   | 64       |               | PUSH        | PSN          | JUERN REGISTERS USED BY PLM51                                               |
|        | COLO           |   | 65       |               | PUSH        | ACC          | thogy wegigiews ngen by hewar                                               |
|        | C000           |   | 65       |               | PUSH        | 00h          |                                                                             |
|        | L200           | F | 67       |               | CLK         | LSCSLG       | JCLR ESC SEQUENCE FLAG                                                      |
|        | 7400           | F | 68       |               | MOV         | A,#SERIAL    | JGET SERIAL FIFO RAM START LUCATION                                         |
| - 006C |                | F | 69       |               | ADU         | A, HIFC      | JAND FIND HOW FAN INTO THE FIFU WE ARE                                      |
| 006E   |                | · | 70       |               | ŇOV         | HO,A         | PUT IT INTO RO                                                              |
| 006F   |                |   | 71       |               | MOV         | A.N1         | Jidi II ANIO NA                                                             |
|        | CZET           |   | 72       |               | LLR         | UE7H         | CLR BIT 7 OF ACC                                                            |
| 0072   |                |   | 73       |               | MOV         | dRU, A       | PUT DATA IN FIFU                                                            |
|        | 6418V2         |   | 74       |               |             | A,#10H,OVER1 | FIF DATA IS NOT A ESC KEY THEN GO UVER                                      |
|        | 0200           | F | 75       |               | SETB        | ESCSEQ       | ISET ESC SEQUENCE FLAG                                                      |
|        | 0500           | F | 76       | OVER1:        | INC         | FIFC         | MOV FIFE TO NEXT LOCATION                                                   |
|        | 0200           | F |          |               | SETB        | SENINT       | SET SERIAL INT DIT FOR PLMS1 STATUS CHECK                                   |
|        | 0000           |   | 78       |               | POP         | OOH          | POP REGISTENS                                                               |
|        | DOF0           |   | 79       |               | POP         | ACC          |                                                                             |
|        | 0000           |   | 80       |               | POP         | PSN          |                                                                             |
| 0082   | 0001           |   | 81       |               | POP         | 01h          |                                                                             |
| 0084   | 32             |   | 82       | GOBACKI       | RETI        |              | i                                                                           |
| ••••   |                |   | 83       |               |             | ,            |                                                                             |
| 0085   | C000           |   | 84       | <b>BLANK:</b> | PUSH        | Pan          | PUSH REG USED BY PLNS1                                                      |
| 0087   | COLO           |   | 85       |               | PUSH        | ACC          |                                                                             |
| 0089   | C085           |   | -8 0     |               | PUSH        | OPL          |                                                                             |
| 0086   | C093           |   | 87       |               | PUSH        | 0PH          |                                                                             |
| UBU.Ó  | C000           |   | 88       |               | PUSH        | 00h .        |                                                                             |
| OUBF   | 850082         | F | 89       |               | MOV         | UPL,LINE0+1  | JGET LINEO INFU                                                             |
|        | 850063         | F | 90       |               | MOV         | UPH,LINEO    | JAND PUT IT INTO DPTR                                                       |
|        | 7850           |   | 91       |               | MOV         | R0,#50H      | INUMBER OF CHARACTERS IN A LINE                                             |
|        | 1420           |   | 92       | NOTYETS       |             | A,#20H       | JASCII SPACE CHAHACTER                                                      |
| 0099   |                |   | 93       |               | MOVX        |              | JMOV TO DISPLAY KAM                                                         |
| 0U9A   |                |   | 94       |               | INC         | UPTR         | JINCH TO NEXT UISPLAY HAM LOCATION                                          |
| 0095   | U8FA           |   | 95       |               | ÚJNZ        | RO, NUTYET   | ; IF ALL SOH LOCATIONS ARE NOT FILLED                                       |
|        |                |   | 96       |               |             |              | JGU DO MORE                                                                 |
|        | 0000           |   | 97       |               | POP         | VON          | POP REGISTERS                                                               |
|        | D083           |   | 98       |               | POP         | lph          |                                                                             |
|        | 085            |   | 99       |               | POP         | OPL          |                                                                             |
|        | DOFO           |   | 100      |               | POP         | ACC          |                                                                             |
|        | 0000           |   | 101      |               | POP         | P 8 N        |                                                                             |
| 0047   | 55             |   | 102      |               | RET         |              |                                                                             |
|        |                |   | 103      | +1 SEJE       | CT          |              |                                                                             |

| MCS-    | 51 MAURI | A | SJErB      | LEN    | CKTASM |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------|----------|---|------------|--------|--------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LUC     | UBJ      |   | LINE       | SOURLE |        |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|         |          |   | 104        |        |        |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6 A U O |          |   |            | BLINE: |        | PSN           | PUSH REGISTERS USED BY PLM51                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|         |          |   |            |        |        |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| OUAC    | 4095     |   | 107        |        | PUSP   | LPL           | ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|         | C083     |   | 108        | 2      | PUSP   | UPh .         | <ul> <li>A second sec<br/>second second sec</li></ul> |
| OUBU    | C000     |   | 109        |        | PUSH   | VOH           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|         | 850083   |   |            |        | MOV    | UPH, FCINI    | JGET CURRENT DISPLAY RAM LUCATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|         | 620085   | F | 111        |        | MOV    | ·UPL, PCINT+1 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|         | 438310   |   | 116        |        | URLS   | UPH,#10H      | ;SET BIT 15 FOR RAM ADURESS DECOUING                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0088    | A800     | F | 113        |        | MOV    | RO, CURSER    | JGET CURSER COLUMN INFO TO TELL HON                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| A       | 1420     |   | 114        | CONTIS |        | A.#20H        | FAR INTO THE KOW YOU ARE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| OUBD    |          |   | 115        | CONTI  | MOUV   | GDPTK.A       | JAGUII SPACE CHARACTER<br>JMOV TO UISPLAY RAM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| OUCU    |          |   | 117        |        | INC    | UPIR          | JINCH TO NEXT DISPLAY HAM LOCATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 00001   |          |   | 118        |        | INC    | RO            | FINCE TO REAL DISPLAT RAM LUCATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|         | 6820F8   |   | 119        |        |        |               | JIF NOT AT THE END OF THE LINE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|         | 003010   |   | 150        |        | GUNE   |               | CONTINUE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0005    | 0000     |   | 121        |        | POP    | NOH           | PUP REGISTERS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| OUC7    | J083     | , | 122        |        | POP    | UPh           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0009    | 0095     |   | 123        |        | POP    | UPL           | ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| OUCH    | LOE0     |   | 124        |        | POP    | ACC           | · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 00CU    | 0000     |   | 125        |        | POP    | PSh           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| OUCF    | 55       |   | 120        |        | RET    | 8             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|         |          |   | 157        |        |        |               | `                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| OUDU    | C000     |   | 128        | FILLI  | PUSH   | PSN           | PUSH REGISTERS USED BY PLM51                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|         | LOLO     |   | 159        |        | PUSH   | ACC           | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|         | C085     |   | 130        |        | PUSH   |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|         | C083     |   | 131        |        | PUSH   | DPH           | · .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|         | C000     |   | - 132      |        | PUSH   | 00h -         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|         | C 3      |   | 135        |        | CLR    | C             | i                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|         | 650083   |   |            |        | MOV    | UPH,L         | JGET BEGINNING OF LINE RAM LUCATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|         | 820085   | F |            |        | MOV    | UPL,L+1       | ICALLULATED BY PLM51                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|         | 438310   |   | 136        |        | URL    | UPH,#10H      | SET BIT 15 FOR UISPLAY RAM ADURESS DECODE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|         | 184F     |   | 137        |        | MOV    | K0,#4FH       | SET UP COUNTER FOR SOH LOCATIONS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|         | A3       |   | 138        |        | INC    | UPTR          | IGO PAST THE OFIN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|         | 1420     |   |            | CONTES |        | A,#20H        | JASCII SPACE CHARACTER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 00E9    |          |   | 140        |        |        |               | MOVE TO DISPLAY RAM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| OUEA    |          |   | 141        |        | INL    | UPTR          | INCH TO NEXT UISPLAY HAM LOCATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| OVER    | UBFA     |   | 142<br>145 |        | DJNZ   | K0,CUNT2      | FIF ALL 79 LUCATIONS HAVE NOT BEEN FILLED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0.1E1   | 0000     |   | 144        |        | POP    | 40n           | PUP REGISTERS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|         | 0000     |   | 144        |        | POP    | ÚPh           | ILAL UPOIDIEND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|         | 0083     |   | 145        |        | P0P    | UPL           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|         | L0E0     |   | 147        |        | POP    | ACL           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|         | 0000     |   | 148        |        | POP    | PSN           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| OUF5    |          |   | 149        |        | REI    | r 0 M         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|         |          |   | 150        |        |        |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|         |          |   | 151        |        |        |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|         |          |   |            |        |        |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

151 152 +1 &EJELT

10-126

MUS-51 MAURU ASSEMBLEN CHTASM

| LUC       | uPJ    |   | LINE       | SOURLE  |        |                  |            |           |                                       |
|-----------|--------|---|------------|---------|--------|------------------|------------|-----------|---------------------------------------|
|           |        |   | د 15       |         |        |                  |            |           |                                       |
|           |        |   | 154        |         |        |                  |            |           | *************                         |
|           |        |   | 155        |         |        | MCVES DISPLAT RA |            |           |                                       |
|           |        |   | 150        | ;+++++  | ++++++ | ************     | *********  | ********  | ************                          |
|           |        |   | 157        |         |        |                  |            |           |                                       |
| 0 u F 8   | 2108   |   | 150<br>159 | UDUNE:  | AJMP   | UNADINE          |            | ,         | Υ · · ·                               |
| OUFA      | 850083 | F | 164        | UMA:    | MOV    | UPH, NASTER      | ;LUAU XFER | PUTNTER   | HIGH HYTE                             |
| OUFD      | 050082 | F | 161        |         | MOV    | UPL, HASTER+1    | ILUAD XFER |           |                                       |
| 0100      | E0     |   | 164        |         | MOVX   | AreDrTh          |            |           |                                       |
| 0101      | A3     |   | 165        |         | INC    | LPTR             |            |           |                                       |
| 0102      | 200313 |   | 164        |         | JB     | UB3F, DUONE      | TE INTE H  | IGH. THEN | UMA IS OVER                           |
| 0105      |        |   | 165        |         | MOVX   | Arebrin          |            |           |                                       |
| 0106      | A3     |   | 166        |         | INC    | UPIR             |            |           |                                       |
| 0107      | E0     |   | 167        |         | MOVX   | A. CPTH          |            |           |                                       |
| 0108      |        |   | 160        |         | INC    | UPIRS            |            |           |                                       |
| 0109      |        |   | 169        |         | MOVX   | A. CPTK          |            |           |                                       |
| 010A      |        |   | 170        |         | INC    | UP1R             |            |           |                                       |
| 0108      |        |   | 171        |         | MOVX   | ALGOPTH          |            |           |                                       |
| 0100      |        |   | 172        |         | INC    | UPIR             |            |           |                                       |
| 0100      | E0     |   | 173        |         | MOVX   | AFGDPTK          |            |           |                                       |
| 0106      |        |   | 174        |         | INC    | UPTR             |            |           |                                       |
| 0101      |        |   | 175        |         | MOVX   | ALGENTH          |            |           | 3                                     |
| 0110      |        |   | 176        |         | INC    | DPTR             |            |           |                                       |
| 0111      |        |   | 177        |         | MOVX   | AJOPTH           |            |           |                                       |
| 0112      | -      |   | 178        |         | INC    | UPTR             |            |           |                                       |
| 0115      |        |   | 179        |         | MOVX   | ALGOPTH          |            |           |                                       |
| 0114      |        |   | 180        |         | INC    | UPIR .           |            |           | <i>i</i> .                            |
| 0115      |        |   | 181        | TENI    | MOVX   | A.GDPTN          |            |           |                                       |
| 0116      |        |   | 182        | 12      | INC    | UPIR .           |            |           | 1                                     |
| 0117      |        |   | 183        |         | MOVX   | A. GDPTK         |            |           | 5                                     |
| 0118      |        |   | 184        |         | INC    | UP TR            |            |           | 1                                     |
| 0119      |        |   | 185        |         | MOVX   | AJODPTH          |            |           |                                       |
| 0114      |        |   | 186        |         | INC    | UPIR             |            |           | · · · · · · · · · · · · · · · · · · · |
| 0115      |        |   | 187        |         | MOVX   | ArcOPTH          |            |           | \$                                    |
| 0116      |        |   | 185        | ``      | INL    | UPIR             |            | ,         |                                       |
| 0110      |        |   | 189        |         | MOVX   | ALADPTH          |            |           |                                       |
| 0116      |        |   | 190        |         | INC    | DEIR             |            |           |                                       |
| 011F      |        |   | 191        |         | MOVX   | A. COPTH         |            |           |                                       |
| 0120      |        |   | 192        |         | INC    | UP (R            |            |           | ,                                     |
| 0121      |        |   | 193        |         | MOVX   | A. COPTH         |            |           |                                       |
| 0122      |        |   | 194        |         | INC    | LPIR             |            |           |                                       |
| 0123      |        |   | 195        |         | MOVX   | AraDPTH          |            |           |                                       |
| 0124      |        |   | 196        |         | INC    | UFIR             |            |           |                                       |
| 0125      |        |   | 197        |         | MOVX   | AreDrTK          |            |           |                                       |
| 0126      |        |   | 198        |         | INC    | upir             |            |           |                                       |
| 0127      |        |   | 199        |         | MOVX   | A, aDPTH         |            |           |                                       |
| 0128      |        |   | 200        |         | INC    | UPIR .           |            |           |                                       |
| 0129      |        |   | 200        | [WEN1Y: |        | A, GDPTH         |            | •         |                                       |
| 0124      |        |   | 202        |         | INC    | LPIR             |            |           |                                       |
| 0128      |        |   | 202        |         | MOVX   | A. OPTR          |            |           |                                       |
| 0126      |        |   | 203        |         | INC    | UPTR             |            | ير ٢      | N                                     |
| 0120      |        |   | 205        |         | MOVX   | A,aDPTN          |            |           | e î                                   |
| 0125      |        |   | 205        |         | INC    | UPIR             |            | ,         |                                       |
| 1210      |        |   | 207        |         | MOVX   | A, CFTH          |            |           | × * ×                                 |
| v • • • r |        |   |            |         | HUTA   | S WOF IN         |            |           | , · · ·                               |

,

| PLS-51 MALRU       | ASSEMBLEN (                           | RIASH       |             |                  |
|--------------------|---------------------------------------|-------------|-------------|------------------|
| LUC UBJ            | Line                                  | SOURCE      |             | ,                |
| 0130 A3            | 605                                   |             | INC         | UPTR             |
| 0131 ED            | < C 9                                 | - A 1       | MOVX        | A, a D M T H     |
| 0132 A3            | c10                                   |             | TNC 3       | UPIR             |
| 0135 20            | <b>411</b> *                          | ч.          | MOVX        | A, GDPTH '       |
| 0134 A3            | é1e                                   |             | INC         | UPIR             |
| 0135 E0<br>0136 A3 | e13                                   |             | MOVX        | A, aCrTn         |
| 0136 A3<br>013/ E0 | 214<br>615                            |             | IVC<br>MOAX | 0019<br>A.gCPTK  |
| 0136 A3            | e15<br>/ c16                          |             | INC         | UPIR             |
| 0139 20            | ¢1/                                   |             | MOVX        | A, aCPTH         |
| 013A A3            | <10<br><                              |             | INC         | UPIR             |
| 0130 E0            | · · · · · · · · · · · · · · · · · · · | , t.,       | MOVX        | A, GCPTH         |
| 013C A3            | 220                                   |             | INC         | UPIR             |
| 013U E0            | c21                                   | THIRIY:     | MOVX        | A, aDFTK         |
| 0136 A3            | 225                                   |             | INC         | UPTR             |
| 013F E0            | 625                                   |             | MOVX        | A, a DPTK        |
| 0140 A3            | <24                                   |             | INC         | UPTR             |
| 0141 E0            | <52<br>2                              |             | MOVX        | ALCPTK           |
| 0142 A3<br>0145 e0 | 226<br>227                            |             | INC         | UPTR             |
| 0145 E0<br>0144 A3 | 20                                    |             | MOVX        | A, GDPTH<br>UPTR |
| 0145 60            | <29<br><29                            |             | MOVX        | ALGUPTK          |
| 0146 A3            | 230                                   |             | INC         | UPIR             |
| 0147 E0            | 631                                   |             | MOVX        | ALGOPTH          |
| 0148 A3            | 232                                   |             | INC         | UPTR             |
| 0149 EO            | 233                                   |             | MOVX        | A, aDPTH         |
| 014A A3            | ∠34                                   |             | INC         | " UP IR          |
| 0146 EO            | 235                                   |             | MOVX        | AyeDPTH          |
| 014C A3            | £36                                   |             | INC         | UPTR             |
| 0140 E0            | 237                                   |             | MOVX        | A, dDPTH         |
| 014Ë A3<br>014F e0 | 238<br>239                            |             | INC<br>MOVX | UPIR<br>Ajd0ptk  |
| 0150 A3            | 240                                   |             | INC         | UPIR             |
| 0151 60            | 241                                   | FORTYS      | MOVX        | AreDPTH          |
| 0152 A3            | 242                                   |             | INC         | LPIR             |
| 0153 EO            | 243                                   |             | MOVX        | ALGOPTH          |
| 0154 A3            | 244                                   |             | INC         | UPTR             |
| 0155 E0            | c45                                   |             | MOVX        | A, aDPTH         |
| 0156 A3            | c 46                                  |             | INC         | UPIR             |
| 0157 EO            | £47                                   |             | MOVX        | A, GDPTH         |
| 0158 A3            | 648                                   |             | INC         | UPTR             |
| 0159 E0            | 249                                   |             | MOVX        | A, aDFTK         |
| 015A A3<br>0150 E0 | c50                                   |             | INC         | UPTR             |
| 0150 EU<br>0151 A3 | 251                                   |             | MOVX<br>INC | AjeDPTH<br>UPTR/ |
| 0150 E0            | 255                                   |             | MOVX        | ALGORTH          |
| 015E A3            | 254                                   |             | INC         | UPIR             |
| 015F E0            | 255                                   |             | MCVX        | ALCOPTH          |
| 0160 A3            | 256                                   |             | INC         | UPIR             |
| 0161 EO            | 257                                   |             | MOVX        | A, aDPTN         |
| 0162 A3            | د58                                   |             | INC         | UPIR             |
| 0163 ±0            | 259                                   |             | MOVX        | A, GCPTK         |
| 0164 A3            | 260                                   |             | INC         | UPTR             |
| 0165 EO            | 261                                   | + I + T Y : | MOVX        | A, & DPTK        |
| 0160 A3            | c62                                   |             | INC         | UPIR             |

MUS-51 MAURU ASSEMBLEN CRTASH

10-128

r

MUS-51 MAURU ASSEMPLEN CHTASM

| LuC          | UB ]     | LINE       | SOURLE  |             |                  |
|--------------|----------|------------|---------|-------------|------------------|
| 0167         | E0       | دفغ        |         | MOVX        | AreDrin          |
| 0168         | A3       | 264        |         | INL         | UFIR             |
| 0164         | E0       | 265        |         | MCVX        | ALGEPTH          |
| 0164         | A3       | 260        |         | INL         | UPIR             |
| 0160         | LO       | 267        |         | MOVX        | ALGOPTN          |
| 0160         | A3       | c60        |         | INC         | UPIR             |
| 0160         | F0       | 269.       |         | MOVX        | A, GDFTH         |
| 016E         | A3       | c7V        |         | INC         | UPIR             |
| 016+         | £0       | c71        |         | MOVX        | A, CPTH          |
| 0170         | A 3      | ê7e        |         | INC         | UPI9             |
| 0171         | E0       | د72        |         | MOVX        | A. CPTN          |
| 017c         | A3       | e74        | · e     | INC         | UPTR             |
| 0175         | E0       | 275        |         | MOVX        | A, GCMTH         |
| 0174         | A3       | e76        |         | INC         | UPIR             |
| 0175<br>0176 | L0<br>A3 | ≤71<br>278 |         | MOVX        | A, aDPTN         |
| 0177         | EO       | 279        |         | INC<br>MOVX | UPTR             |
| 0178         | A3       | 280        |         | INC         | A, GDPTN<br>UPTR |
| 0179         | EQ       | 281        | SIXTYS  | MOVX        | ALGOPTK -        |
| 0174         | A3       | 282        | 214111  | INC         | DPIR             |
| 0175         | ÊÓ       | 283        |         | MOVX        | AJEDPTN          |
| 0176         | A3       | 284        |         | INC         | DPTR             |
| 0170         | LO ·     | 285        |         | MOVX        | ALGOPTH          |
| 0175         | A3       | 280        |         | INL         | UPTR             |
| 017F         | EO       | 287        |         | MOVX        | ALGOPTH          |
| 0180         | A 3      | 288        |         | INC         | UPTR             |
| 0181         | F0       | 289        |         | MOVX        | A, COPTH         |
| 0182         |          | 290        |         | INC         | UPIR             |
| 0183         | F0       | 291        |         | MOVX        | A, GDPTN         |
| 0184         |          | 292        |         | INC         | UPIR             |
| 0185         | E0       | 293        |         | MOVX        | A, GDPTK         |
| 0186         | A3       | 294        |         | INC         | DPTR             |
| 0187         | FO       | 295        |         | MOVX        | A, GOPTH         |
| 0188         | A3       | 296        |         | INC         | UPIR             |
| 0189         | E0       | 291        |         | MOVX        | A, GDPTK         |
| 018A<br>0185 | A3<br>10 | 298<br>299 |         | INC<br>MOVX | UPTR             |
| 0180         | A3       | 300        |         | INC         | A, GDPTH<br>DPTR |
| 0180         | ±0       | 301        | SEVNTY  | MOVX        | A. CPTR          |
| 0185         | A3       | 201        | SEVALIT | INC         | UPIR             |
| 018F         | EQ       | 305        |         | MOVX        | A, GDPTH         |
| 0190         | A3       | 304        |         | INC         | UPIR             |
| 0191         | EO       | 105        |         | MOVX        | ALGOPTH          |
| 0192         | A3       | 106        |         | INC         | UPTR             |
| 0195         | E0       | 301        |         | MOVX        | ALGUTH           |
| 0194         | A'3      | 308        |         | INC         | UPIR             |
| 0195         | E0       | 509        |         | MOVX        | A, CDFTH         |
| 0196         | A3       | 310        |         | INC         | UPTR             |
| 0197         | E0       | 111        |         | MOVX        | A, aCPTN         |
| 0198         | A3       | 516        |         | INC         | UPIR             |
| 0199         | E0       | 315        |         | MOVX        | A, aCFTK         |
| 019A         | A3       | 514        |         | INC         | UPIR             |
| 0196         | E0       | 315        |         | MGVX        | A, GCPTN         |
| 0190         | A3       | 316        |         | INC         | UPIR             |
| 0190         | E0       | 317        |         | MOVX        | A, GCPTH         |
|              |          |            |         |             |                  |

| MLS-5 | 51 MALRU | ASSEM | BLEK | CHTASM  |         |               |         |                      |
|-------|----------|-------|------|---------|---------|---------------|---------|----------------------|
| LUC   | UBJ      |       | LINE | SOURCE  |         |               |         |                      |
| 0196  | A3       |       | 518  |         | INC     | UF)R          |         |                      |
| 019F  | F0       |       | 519  |         | 110 V X | A,GCrTN       |         |                      |
| 01AU  | A3       |       | 150  |         | INC     | UP IR         |         |                      |
| 01A1  | L0       |       | 155  | EIGHTY: | MOVX    | AFECHTH       |         |                      |
| 0142  | A3       |       | 526  |         | INL     | WPIR          |         |                      |
|       |          |       | 525  |         |         |               |         |                      |
| 01A5  | £583     |       | 524  | LHECKI  | MOV     | A,UPH         |         |                      |
| 01A5  | 641FUC   |       | 525  |         | CJNE    | A,#1FH,DUNE   |         |                      |
| 0146  | £582     |       | 350  |         | MOV     | AFUPL         |         |                      |
| 0144  | 840007   |       | 327  |         | CJNE    | A,#OUOH,DONE  | `       |                      |
| 01AU  | /50018   | F     | 956  |         | MOV     | HASTER,#18n   |         |                      |
| 0180  | 750000   | F     | 329  |         | MOV     | RASTER+1,#UOH |         |                      |
| 0183  | 55       |       | 330  |         | RET     | х.            |         |                      |
|       |          |       | 331  |         |         |               |         |                      |
| 01B4  | 553300   | F     | 532  | DONES   | MOV     | KASTER,DPH    |         |                      |
|       | 858200   | F     | 333  |         | MOV     | RASTER+1,DPL  |         |                      |
| 018A  | 55       |       | 334  |         | KET     |               |         |                      |
|       |          |       | 335  |         |         |               |         |                      |
| 0186  | 63       |       | 336  | UMADNE: | CLR     | C             |         |                      |
| 018C  | F295     |       | 337  |         | MOV     | A, UPL        |         |                      |
| 01BE  | 244F     |       | 538  |         | ADU     | A,#79D        | 3ADU 79 | TU BUFFER PUINTER    |
| 01Cu  | F582     |       | 339  |         | MOV     | UPL,A         |         | TU NEXT DISPLAY LINE |
| 0102  |          |       | 340  |         | JNC     | LPECK         | JIN THE | DISPLAY MEMURY       |
| 01C4  |          |       | 341  |         | INC .   | up H          |         |                      |
| 0106  | SOUB     |       | 342  |         | SJMP    | CHECK         |         |                      |
|       |          |       | 345  |         |         |               |         |                      |
|       |          |       | 344  |         |         |               |         |                      |
|       |          |       | 345  | ENU     | 4       |               |         |                      |

MC8-51 MAURU ASSEMPLEN KEYED

ISIS-II MUS-51-MAURU ASSEMBLEH V2.1 CBJECI MODULE PLACEL IN 141:KEYBD.OBJ ASSEMBLER INVUKED B1: ASP51 141:KEYBD.SRU

| LuC | uBJ | LINE  | SOURLE                                                          |
|-----|-----|-------|-----------------------------------------------------------------|
|     |     | 1 `   |                                                                 |
|     |     | 2     |                                                                 |
|     |     | \$    |                                                                 |
|     |     | 4     | ***************************************                         |
|     |     | 5     | *********************                                           |
|     |     | 6     | 5 m m m m m m m m m m m m m m m m m m m                         |
|     |     | 1     | J#### SGFTNAKE FUR READING AN UNDECODED ####                    |
|     |     | 6     | 3**** KEYdOARU ****                                             |
|     |     | 9     | 3 manha                                                         |
|     |     | 10    | ***************************************                         |
|     |     | 11    | **********************                                          |
|     |     | 14    | 3                                                               |
|     |     | 15    | 3                                                               |
|     |     | 14    | <b>3</b>                                                        |
|     |     | 15    | 3                                                               |
|     |     | 16    | THIS CUNTAINS THE SOFTWARE NEEDED TO SCAN AN UNDECUDED KEYBOARD |
|     |     | 1/    | THIS PROGRAM MUST BE LINKED TO THE MAIN PROGRAMS TO FUNCTION    |
|     |     | 16    | <b>)</b>                                                        |
|     |     | 19    | <b>3</b>                                                        |
|     |     | 20    | 3 MEMURY MAP FOR READING KEY BOARD (USING MOVC)                 |
|     |     | 21    | <b>;</b>                                                        |
|     |     | 22    | ; ADDRESS FCH NEY BOARD 10FFH TO 17FFH                          |
|     |     | 23    | 3                                                               |
|     |     | 24    | 3                                                               |
|     |     | 25    | 3                                                               |
|     |     | 56    | ; · · · · · · · · · · · · · · · · · · ·                         |
|     |     | 27    | PUBLIC REAVER                                                   |
|     |     | 20    | EXTRN UATA (LSTKEY)                                             |
|     |     | 29    | EXTRN dit (Keyu, Same)                                          |
|     |     | 30    | 3                                                               |
|     |     | 31    | ***************************************                         |
|     |     | 32    | S A S S S S S S S S S S S S S S S S S S                         |
|     |     | 35    | s* ."RÉADER"KOUTINE" *                                          |
|     |     | 34    | 5+ ×                                                            |
|     |     | 35    | ***************************************                         |
|     |     | 36 +1 | a E J E C T                                                     |

•

| MLS-    | 51 MALRU         | ASSEPE     | ILEN K  | EYD0         |                      |                                                    |
|---------|------------------|------------|---------|--------------|----------------------|----------------------------------------------------|
| LUC     | 68J              | LINE       | SOURLE  |              |                      | · · · · ·                                          |
|         |                  | 3/         |         |              |                      |                                                    |
|         |                  | 30         | UNDELOU | EU_KEY       | BUARD SEGMENT        | CUDE                                               |
|         |                  | 34         |         |              | D_KEYBCARD           |                                                    |
|         |                  | 40         |         |              |                      |                                                    |
|         |                  | 41         |         |              |                      |                                                    |
| 000     | C0U0             | 42         | READERS | ынен         |                      | BURN OF HELD BY DIMES                              |
|         | L000             | 4 S<br>4 4 | READERS | PUSH         | rsn<br>Acl           | ;PUSH REG USED BY PLM51                            |
|         | C082             | 45         |         | PUSH         | UFL                  |                                                    |
|         | C083             | 40         | e       | PUSH         | UPH                  |                                                    |
| 0000    | C000             | 41         |         | PUSH         | von                  |                                                    |
| OUOA    |                  | 48         |         | PUSH         | Ulh                  | <i>i</i>                                           |
|         | COUS             | 49         |         | PUSH         | , U2H                |                                                    |
|         | COU3<br>9010FF   | 50<br>51   |         | PUSH<br>Mov  | 03H<br>Uptr,#10ffh   | JINITIALIZE UPTR TU KEYBUARD                       |
| .0010   | 901066           | 52         |         | MUV          | DETRYNIOPPH          | JADDKESS                                           |
| 0013    | 1900             | 53         |         | MOV          | H1,#00H              | CLR ZERG COUNTER                                   |
|         | 7800 F           | 54         |         | MOV          | HO, ALSIKEY          | JGET KEYBOARD KAM POINTEN                          |
| 0017    |                  | 55         |         | MOV          | K3,#08H              | JINITIALIZE LOUP CUUNTER                           |
|         | L200 F           | 56         |         | CLR          | KEYO                 | JINITIALIZE PLM51 STATUS BITS                      |
|         | 0200 F           | 57         |         | SETB         | SAME                 |                                                    |
| 0010    | 6602<br>F4       | 58<br>59   | MORE:   | MOV<br>CLR · | 02h,dR0<br>A         | IMUV LAST KEYBUARD SCAN IO OZH                     |
| 0020    |                  | 57<br>6û   |         | MOVC         | A A+DPTH             | ISCAN KEYBUARD                                     |
| 0021    |                  | 61         |         | CPL          | A                    | INVERT                                             |
| 0022    | 6005             | 62         |         | JZ           | ZEHO                 | JIF SCAN WAS ZERU GO INCREMENT ZERU COUNTER        |
| 0024    | 620224           | 63         | 1       | CJNE         | A, U2H, NTSAME       | COMPARE WITH LAST SCAN IF NOT THE SAME             |
|         |                  | 64         |         |              |                      | THEN CLR SAME BIT AND WRITE NEW INFURMATION        |
| 0027    | 8005             | 65<br>66   |         | SJMP         | EQUAL                | JTU RAM<br>JIF EQUAL JMP UVER INCR OF ZERU COUNTER |
|         | 0501             | 67         | ZENO:   | INC          | 01H                  | JIF EGUAL JAF OVER INCK OF ZERD COUNTER            |
|         | 85021D           | 68         | 221101  | CJNE         | A, U2H, NTSAME       |                                                    |
| 002L    | 08               | 69         | EQUAL:  | INC          | kQ                   | STEP TO NEXT SCAN RAM LUCATION                     |
|         | <b>v5v3</b>      | 70         |         | INC          | UPH.                 | INEXT KEYBOARD ADDRESS                             |
|         | UREA             | 71         |         | DJNZ         | H3, FURE             | IF LOOP COUNTER NUT O, SCAN AGAIN                  |
|         | 590804<br>D200 F | 72<br>73   | ,       | CJNE<br>Setb | K1,#08H,DACK<br>KEYO | CHECK TO SEE 1F ALL 8 SCANS WHERE 0                |
|         | C200 F           | 74         |         | CLK.         | SAME                 | JIF YES SET KEYO BIT                               |
| .003A   |                  | 75         | BACK:   | POP          | USH                  |                                                    |
|         | 5000             | 76         |         | POP          | UZH.                 | POP REGISTERS                                      |
| 003E    |                  | 77         |         | POP          | 01H                  | × .                                                |
|         | 0000             | 76         |         | POP          | 00h                  |                                                    |
|         | 0083             | 79         |         | P0P          | UPH                  |                                                    |
| 0044    | D062             | 8 U<br>8 1 |         | P0P<br>P0P   | OPL · ·              |                                                    |
| 0048    |                  | 82         |         | POP          | 78N                  |                                                    |
| 0 U 4 A |                  | 8.5        |         | RET          |                      |                                                    |
|         |                  | 84         |         |              |                      |                                                    |
| 0048    | F 6              | 85         | NTSAME: | MOV          | aRU,A                | IF SCAN WAS NUT THE SAME THEN PUT NEW              |
|         |                  | 80         |         | <b>.</b>     |                      | SCAN INFC INTU NAM                                 |
|         | C200 F           | 87         |         | CLR          | SAME                 | JCLR SAME BIT                                      |
| VU46    | BOUE             | 8d<br>89   |         | SJMP         | EGUAL                | ;GU DO MURE                                        |
|         |                  | 90         |         |              |                      |                                                    |
|         |                  | 91         | LNU     |              |                      |                                                    |
|         |                  |            |         |              |                      |                                                    |

~ .

MUS-51 MALRU ASSENBLEN KEYDD

SYMBOL TABLE LISTING -----NAME TYPE VALUE ATTRIBUTES ALC. . . . . . . . D AUCH OUEUH A OUJAH R SEG=LNDECUDED\_KEYBOARD BACK . . . . . . . C AUCH OUBSH DPH. . . . . . . . D AUDH ۸ DPL. . . . . . . . D AUCH 0082H A EWUAL. . . . . . . R . . SEG=UNDECUDED\_KEYDOARL C ALCH OUZEH KEYU . . . . . . . EXT E AUDK ..... LSTREY . . . . . . D AUCH .... EXT MURE . . . . . . . R SEG=UNDECUDED\_KEYBOARU Seg=Undecuded\_keyboaru 0010H C AUDH NISAME . . . . . . R C AUCH 0046H P5H. . . . . . . . C AUCH OUDUH 4 REAUER . . . . . . OUDUH R PUB SEG=UNDECUDED\_KEYBOARD C AUCK SAME . . . . . . . E AUCK .... EXT UNDECUDED\_KEYBOARD C SEG 0050H -RELEUNII ZERU . . . . . . . C AUDK 0029H R SEG=UNDECUDED\_KEYBOARD

REGISTER BANK(S) USEC: U

ASSEMBLY COMPLETE, NC ERRURS FOUND

MCS-51 MACRU ASSEMBLER DECUDE

ISIS-II MCS-51 MACRU ASSEMBLER V2.1 Object module placed in :f1:Decude.ubj Assembler Invuked by: ASM51 :f1:Decude.skc

LUC UBJ LINE SOURLE 1 ć ک 4 \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* \*\*\*\*\*\*\*\*\*\*\*\*\* 5 ;\*\*\*\* 6 \*\*\*\* ī \*\*\*\* SOFTWARE FUR DECUDED KEYBOARD \*\*\* đ \*\*\*\* \*\*\*\* 9 10 11 : 12 ; 15 ; 14 3 15 PUBLIC DETACH EXTRN DATA (LETKEY) EXTRN DIT (NEDINT) 16 17 18 19 20 3 51 3 \* \* .................. 22 ;\* 25 "DECUDE" INTERKUPT RUUTINE FUR DECODED KEYBOARUS ;\* • 24 1\* 22 SEJECT 26 +1

MUS-51 MACRU ASSEMBLEN DECUDE

| LUC  | uBJ    |   | LINE | SOURCE  |         |                |                                   |
|------|--------|---|------|---------|---------|----------------|-----------------------------------|
|      |        |   | 21   |         |         |                |                                   |
|      |        |   | 26   | DELODED | KEYBUAH | C SEGMENT CUDE |                                   |
|      |        |   | 24   | KSEG DE |         |                |                                   |
|      |        |   | 30   |         |         |                |                                   |
| 0000 | 000    |   | 31   | UETALH: | PUSH    | PSN            | PUSH REGISTERS                    |
|      | C095   |   | 34   |         | FUSH    | UPL            | JUSED BY PLM51                    |
|      | L083   |   | 33   |         | PUSH    | UFn            |                                   |
|      | COLO   |   | 34   |         | PUSH    | ACU            |                                   |
|      | 9080FF |   | 35   |         | MCV     | UFTR, ABOFFH   | JAUDKESS FUR KEYBOARU             |
| 0006 |        |   | 30   |         | CLK     | A              |                                   |
| 0000 |        |   | 37   |         | MOVC    | A A+DPTK       | FETCH ASCII BYTE                  |
|      | FSVO   | F | 38   |         | MOV     | LSIKEY+1.A     | HUV TO VEMORY TO BE READ BY PLM51 |
|      | 00020  | F | 39   |         | SETB    | KBUINT         | JLET PLM51 KNOW THERE IS A BYTE   |
|      | 758CFF | • | 40   |         | MOV     | THU,#OrFH      | SET COUNTER TO FFFFH SO INTERNUPT |
|      | 150AFF |   | 41   |         | MOV     | TLV, #OFFH     | JON THE NEXT FALLING EUGE OF TO   |
|      | UOLO   |   | 42   |         | POP     | ACC            |                                   |
|      | U0d3   |   | 43   |         | POP     | DPH            | PUP REGISTENS                     |
|      | 0002   |   | 44   |         | POP     | UPL            | JI OF ALGICIENC                   |
|      | 0000   |   | 45   |         | POP     | PSN            |                                   |
| 001F |        |   | 46   |         | RETI    | 1 GA           |                                   |
|      | 26     |   | 47   |         |         |                |                                   |
|      |        |   | 48   |         |         |                |                                   |
|      |        |   | 49   |         |         |                |                                   |
|      |        |   | 50   |         |         |                |                                   |
|      |        |   | 51   | END     |         | •              |                                   |
|      |        |   | 28   |         |         |                |                                   |

.

MCS-51 MALRU ASSEMPLEN DECUDE

SYMBOL TABLE LISTING

NAME

ATTRIBUTES -

ACC. . . . . D ALCH OVEUH A . ٠ DECUDED\_KEYBOARU C SEG C AUDK OUZUH DETACH . . . . . OVOUH R PUB DPH. . . . . . . D AUDH 0083H A D AUDH 0082H A EXT 8 ALDK .... LATKEY . . . . . D ALON ----EXT Paw. . . . . . . D ALDH OUDUH A D ALDK 0U8LH A D ALDH OU8AH A

TYPE

VALUE

REL=UNII SEG=DECUDED\_KEYBOARU

REGISTER BANK(S) USED: 0

ASSEMBLY COMPLETE, NO ERRURS FOUND

MLS-51 HALRU ASSEMBLEN DETACH

```
ISIS-1I MUS-51 MAURU ASSEMBLER V2.1
Objeci mouule placed in :F1:Detach.urj
Assembler Invuked B1: Asm51 :F1:Detach.skc
```

| LUC | uBJ | LINE  | SOURLE                                                               |
|-----|-----|-------|----------------------------------------------------------------------|
|     |     | 1     |                                                                      |
|     |     | 2     |                                                                      |
|     |     | ک     |                                                                      |
|     |     | 4     | ;                                                                    |
|     |     | 5     | ;**************************************                              |
|     |     | 6     | 2 data data data data data data data dat                             |
|     |     | 1     | J+### SCHTWARE FUR A SERIAL OR DETACHABLE ####                       |
|     |     | 6     | ;**** KEYBUARD ****                                                  |
|     |     | 9     | 3 ****                                                               |
|     |     | 10    | ; * * * * * * * * * * * * * * * * * * *                              |
|     |     | 11    | ;**************************************                              |
|     |     | 14    |                                                                      |
|     |     | 15    | 3                                                                    |
|     |     | 14    |                                                                      |
|     |     | 15    | ; THIS CUNIAINS THE SOFTWARE NEEDED TO PERFORM A SUFTWARE SERIAL     |
|     |     |       | FORT FUR SERIAL NEYBUARDS AND DETACHABLE KEYBOARD, THIS PRUGHAM MUST |
|     |     | 17    | ; BE LINKED TO THE MAIN PROGRAMS FUR USE.                            |
|     |     | 18    | Σ · · · · · · · · · · · · · · · · · · ·                              |
|     |     | 19 +1 | SEJECT                                                               |

| MCS-51 MALRU | ASSEMPLEN   | DETACH                                  | ، ۴,                                 | -              | *     |
|--------------|-------------|-----------------------------------------|--------------------------------------|----------------|-------|
| LUC UBJ      | LINE        | SOURLE                                  | ,<br>,                               | ,              | ,     |
|              | 20          | ;                                       |                                      |                |       |
|              | 51          | ;                                       |                                      |                |       |
|              | 54          |                                         |                                      |                |       |
| 0084         | 53          | INPUI EGU TV                            |                                      |                | · · · |
|              | 24<br>25    | •                                       |                                      |                |       |
|              | 50          | PUBLIC DETACH                           |                                      |                |       |
|              | 27          | EXTRN UATA (LS                          |                                      | - *            |       |
|              | 20          |                                         | FLG, SYNC, BYFINJ                    |                |       |
|              | 24          | EXTRN BIT (KBE                          | INI, ERNOR)                          |                |       |
|              | 30          |                                         |                                      | 1              |       |
| 1 x          | 31          | 2 - 2 - 2 - 2 - 2 - 2 - 2 - 2 - 2 - 2 - |                                      |                |       |
|              | 32          | 3                                       |                                      |                |       |
|              | 33          | 3                                       |                                      |                |       |
| `            | 34          |                                         |                                      |                |       |
|              | · 35.<br>36 |                                         | ALUES FOR DIFFER<br>Chable Keyboards |                |       |
|              | 37          | J USED WITH DET                         | CHADLE NETBUARD                      | 5              |       |
|              | 38          | 2                                       |                                      |                |       |
|              | 3.9         |                                         | ,                                    | '              |       |
| ÷ ,          | 40          | BAUD START BI                           | DETECT                               | MESSAGE DETECT |       |
|              | 41          | 110 UEFA2                               |                                      | ODF 45H        |       |
|              | 42          | ; 150 OF400                             | (                                    | OEBOUH         |       |
|              | 43          | 3                                       |                                      | · .            |       |
|              | 44          | 1                                       |                                      |                |       |
|              | 45          | 1                                       |                                      |                |       |
| 0000         | 46<br>47    | J<br>STARTO                             | EQU VOUH                             | ILUW BYTE FOR  | 150   |
| 0000<br>00F4 | 40          | STARIU<br>STARII                        | LOU UF4H                             | HIGH BYTE FUR  |       |
| 0000         | 49          | MESSAGEO                                | ÉQU VOUH                             | JLOW BYTE FOR  |       |
| OVES         | 50          | MESSAGE1                                | EQU DESH                             | HIGH BYTE FO   |       |
|              | 51 +1       | SEJECT                                  |                                      |                |       |

| LUC   | UBJ          |   | LINE     | SOURLE      |               |                       |                                                      |
|-------|--------------|---|----------|-------------|---------------|-----------------------|------------------------------------------------------|
|       |              |   | 52       |             |               |                       |                                                      |
|       |              |   | 51       | ;           |               |                       |                                                      |
|       |              |   | 54       | ;******     | ******        | ******                | ***********************************                  |
|       |              |   | 55       | ;*          |               |                       | *                                                    |
|       |              |   | 56       | ;*          |               | "CETACH," INTERNUPT R | UUTINE FUR DETACHADLE KEYBUANDS *                    |
|       |              |   | 57       | 3 *         |               |                       | *                                                    |
|       |              |   | 58       | ;*****      | ******        | ******                | ***************************************              |
|       |              |   | 59       |             |               |                       |                                                      |
|       |              |   | 60       |             |               |                       |                                                      |
|       |              |   | 61       |             |               |                       |                                                      |
|       |              |   | 62       |             |               | BOARD SEGMENT CODE    |                                                      |
|       |              |   | 63       | KSEG DE     | TACHABL       | E_KEYBUARD            |                                                      |
|       |              |   | 64       |             |               |                       |                                                      |
|       | 000          |   | 65       | UEIALH:     |               | FSN                   | ;PUSH REGISTERS USED BY PLM51                        |
|       | L0L0         | ~ | 66       |             | PUSH          | ACL                   |                                                      |
|       | 200013       | F | 67       |             | JB            | RCVFLG, VALID         | JIF RECEIVE FLAG SET GET NEXT WIT                    |
|       | 20844A       | _ | 68       |             | JB            | INPLI, KS1            | JIF TO IS A 1 THEN NUT A START BIT                   |
|       | DSNO         | F | 69       |             | SETB          | HCVFLG                | FTO IS UTHEN II A START BIT                          |
|       | 758CF4       |   | 70       |             | MOV           | 1+0,#STANT1           | SET TIMER TO INTERRUPT IN THE MIDDLE OF START BIT    |
|       | 758AUO       |   | 71       |             | MOV           | TLO,#STARTO           |                                                      |
|       | £589         |   | 72       |             | MOV           | A, THUC               |                                                      |
|       | C2F5         |   | 73       |             | CLK           | UEZH                  | ;SET TIMER COUNTER TO VIMER MODE                     |
|       | F589         |   | 7.4      |             | MOV           | TNUD, A               |                                                      |
| 0010  | 802 <b>8</b> |   | 75       | _           | SJMP          | FINI                  | JGU BACK TU PRUGRAM                                  |
| A 4 A | 200010       | F | 76<br>77 | J<br>VALIU: | JB            |                       | - OURDM BR NAS TH STADT HET NAG DECH OF PH           |
|       | 200010       | r | 78       | AVE TO :    |               | SYNC, NATUI           | SCHECK IF VALIU START BIT HAS BEEN SEEN              |
|       | D500434      | F | 79       |             | JB<br>Setb    | INPLI, HSI<br>Sync    | JIF NOT CHECK IF VALID START BIT<br>JIF YES SET SYNC |
|       | 750080       | F | 80       |             | MOV           | LSTKLY,#BOH           | INIT LSTREY                                          |
|       | 750CE8       | r | 81       |             | MOV           | THU, #MÉSSAGE1        | J INII LOIKET                                        |
|       | 758AU0       |   | 84       |             | MOV           | TLO, #MESSAGEO        | SET TIMER FUR 1 BIT TIME                             |
|       | 8018         |   | 85       |             | SJMP          | FINI                  | JAND GO BACK TU MAIN PROGRAM                         |
|       | 0010         |   | 84       | ;           | <b>U</b> UPHP | 1 1 1 1               | JAND GO DAGA TO MAIN PROSKAM                         |
| 0020  | /50CE8       |   | 85       | NXTBIT:     | MOV           | (HO,#MESSAGE1         |                                                      |
|       | 758AU0       |   | 86       |             | MOV           | TLO, #MESSAGEU        | SET TIMER FOR 1 BIT TIME                             |
|       | 200014       | F | 87       |             | JB            | BYFIN, STUP           | CHECK TO SEE IF ALL & BITS HAVE BEEN RECEIVED        |
|       | ESU0         | F | 86       | *           | MOV           | A,LSTKLY              | JGET WURKING REGISTER                                |
|       | A284         | • | 89       |             | MOV           | C, INPUI              | GET NEXT BIT FRUM TI                                 |
| 0U3A  |              |   | . 90     |             | RRC           | A                     |                                                      |
|       | F500         | F | 91       |             | MOV           | LSIKEY,A              |                                                      |
|       | 5006         |   | 92       |             | JNC           | FINI                  | IF NO CARKY THEN NOT DONE                            |
|       | 0200         | F | 93       |             | SETB          | BYFIN                 |                                                      |
|       | C217         |   | 94       |             | CLK           | UE7h                  | CLR BIT 7                                            |
|       | F500         | F | 95       |             | MOV           | LSIKEY+1,A            | MOV FINAL CUDE 10 LSTKY+1                            |
|       | UOLO         |   | 96       | FINI:       | POP           | ACC                   | · · · · · · · · · · · · · · · ·                      |
| 0047  | 0000         |   | 97       |             | POP           | PSN                   |                                                      |
| 0049  |              |   | 98       |             | KETI          |                       |                                                      |

,

| LUC     | UPJ    |   | LINE | SOURCE |             |            |                                     |
|---------|--------|---|------|--------|-------------|------------|-------------------------------------|
|         | 4      |   | 99   | ;      |             |            |                                     |
| 0 u 4 A | 300405 |   | 100  | STUPI  | JNь         | INFLI,ERK  | FIF NOT 1 THEN NUT A VALID STOP BIT |
| 0040    | 9050   | F | 101  |        | SETB        | KBUINT     | TELL PLM A BYTE IS READY            |
| 0u4F    | 020000 | F | 105  |        | JMP         | KST        | JAND GO BACK TU MAIN PROGRAM        |
|         |        |   | 105  | ;      |             |            |                                     |
| 0052    | 0200   | F | 104  | ERK I  | SETB        | ERNCN      |                                     |
|         | C200   | F | 105  | KS1:   | CLR         | KCVFLG     | ICLEAR FLAGS                        |
|         | C200   | F | 106  |        | CLN         | SYNC       |                                     |
|         | 0123   | F | 10/  |        | <b>UL</b> R | BYFIN      | `                                   |
|         | £589   |   | 108  |        | MOV         | A, THUD    |                                     |
|         | U252   |   | 109  |        | SEIB        | VE2H       | SET TIMER O TU LOUNIER MODE         |
|         | +509   |   | 110  |        | MOV         | INCO, A    |                                     |
|         | 758CFF |   | 111  |        | MOV         | (FU, #0+FH | ISET COUNTER TO FFFFH SO INTERRUPT  |
|         | 7584FF |   | 11c  |        | MOV         | ILV,#OFFH  | JON NEXT FALLING EDGE OF TU         |
|         | 8000   |   | 113  |        | SJMP        | FINI       | Jou WERT INFEITUR FRAF AL IN        |
|         | 0000   |   | 114  |        | ••••        |            |                                     |
|         |        |   | 115  |        |             |            | ·                                   |
|         |        |   | 116  |        |             |            |                                     |
|         |        |   | 117  |        |             |            |                                     |
|         |        |   | 110  | ENU    |             |            |                                     |
|         |        |   | 110  | ENU    |             |            |                                     |

10-140

AP-223

MLS-51 MALRU ASSEMBLEN DETACH

SYMDOL TABLE LISTING

| NAME                | ITPE VALU      | E     | AIIRIBUTES                            |
|---------------------|----------------|-------|---------------------------------------|
| ACC                 | L ACUR VOLOH   | A     |                                       |
| BYFIN               | B ADUR         | EX (  |                                       |
| DETACH              | C ADUR UQUOH   | H PUU | SEG=DETACHABLE_KEYBOARD               |
| DETACHADLE_KEYBUAND | L SEG U068H    |       | HELSUNIT                              |
| EKR                 | LADUR 0052H    | ĸ     | SEGEDETACHABLE_KEYBOARD               |
| EKRUR               | HADUR          |       | •                                     |
| FIN1                | C ACUR 0045H   | R     | SEG=UEIACHABLE_KEYBOARD               |
| INPUT               | BACUR VOBON.4  | • ·   | · · · · · · · · · · · · · · · · · · · |
| KUDINT.             | E ADUR         |       |                                       |
| LSTREY.             | U ACUR         | EXT   |                                       |
| MESSAGEU.           | NLMB UOUDH     | A     |                                       |
| MESSAGE1.           | NLMB UDEBH     | Â     |                                       |
|                     | C ADUR 002DH   | ĥ     | SEG=DETACHABLE_KEYBOARD               |
|                     | U ADUR UOUOH   | Ä     | SEGADE INCOMPLE_REIDONND              |
|                     |                | ^ EXT |                                       |
| RCVFLG              |                |       |                                       |
| RST                 | C ADUR 0054H   | R     | SEG=DETACHABLE_KEYBOARD               |
| STARTO              | NLMB 0000H     | A     |                                       |
| START1              | NUPB 00F4H     | A     |                                       |
| STOP                | C ADUR 004AH   | R     | SEG=DETACHABLE_KEYBOARD               |
| SYNC                | H ADUR         | EXT   |                                       |
| Τυ                  | BÁCDR 00BOH.4  | •     |                                       |
| TH0                 | U ACUR 008CH   | A     |                                       |
| TLO                 | U ACUR - OOBAH | A     |                                       |
| TMOU                | D ADUR 0089H   | Α     |                                       |
| VALID               | C ADDR 001AH   | R     | SEG#DETACHABLE_KEYBOARD               |

REGISTER BANK(S) USED: 0

ASSEMBLY COMPLETE, NO ENRORS FOUND

## APPENDIX B REFERENCES

1. John Murray and George Alexy, *CRT Terminal Design Using The Intel 8275 and 8279*, Intel Application Note AP-32, Nov., 1977.

2. John Katausky, A Low Cost CRT Terminal Using The 8275, Intel Application Note AP-62, Nov., 1979.

# MCS<sup>®</sup>-51 Article Reprint

11



ing in the second se Second 
Extensive I/O subsystems and a tailored instruction set allow a 16-bit microcontroller to set its sights on a widening range of industrial and computer (and telecomm and consumer) applications.

## Controller chip takes on many industrial, computer uses

With industrial and computer control applications increasing all the time—and telecommunications and consumer applications emerging—designers increasingly need microcontrollers whose performance extends beyond that of the conventional 8-bit architectures. Normally, control system designers must depend on expensive and complex multiple-chip microprocessors to achieve high performance. But now, a 16-bit single-chip controller offers a much better solution. Not only does the 8096 offer perhaps the most extensive input/output "services" of any microcontroller, it also provides an instruction set and addressing modes tuned for both fast control operations and high-speed arithmetic.

In industrial applications, the 8096 can be used for process control, robotics, numerical and motor control, and instrumentation. Figure 1 shows the chip in a typical closed-loop servo system of the type used in industrial applications. In computer applications performance is the key feature, and here the 8096 provides greater throughput in systems in which simple data structures—a single I/O bit—and relatively small memories are required. Typical applications are computer peripherals such as printers, plotters, Winchesters, and other hard-disk systems.

In the consumer end, moreover, the 8096 is ideally suited for automotive engine and other controls (see "Stopping a Car") and sophisticated video games. Both applications need the speed, calculating power, and addressability of a 16-bit microcomputer. For telecommunications, the controller is intended for high-speed modems, PABXs, and central office switching systems.

In addition to the full 16-bit CPU, the 8096's basic

Steve Wiseman, Product Marketing Manager Steve Burton, Senior Engineer John Katausky, Technical Marketing Manager Intel Corp. 5000 W Williams Field Rd, Chandler, Ariz. 85224 architecture includes an 8-kbyte ROM and a 232-byte RAM, which serves as a register file. To meet the wide needs of controller environments, the chip contains an eight-channel, 10-bit analog-to-digital converter, a full-duplex UART (universal asynchronous receiver-transmitter), two 16-bit timers, and a programmable pulse-width-modulated output.

Since a microcontroller must be able to interface with various types of transducers and sensors, the 8096 features built-in, extensive I/O facilities. These include an eight-level priority interrupt structure, full-duplex serial I/O, parallel I/O, a watchdog timer, analog inputs for the a-d converter, a pulsewidth modulated output and a high-resolution pulse output. Each of these facilities is integrated not only physically but logically into the chip's structure by being tightly coupled to the CPU.

The inherently high performance of a CPU suffers if the controller spends too much time administering complex real-time I/O operations. The 8096's onboard I/O facilities solve this problem by permitting the CPU to devote more time to executing mathematics and control algorithms and less on I/O.

|           | lines (                         |
|-----------|---------------------------------|
| 0000-0017 | On-chip I/O                     |
| 00180019  | Data register/stack pointer     |
| 001A-00FF | Data registers (230 bytes)      |
| 0100-1FFD | Off-chip expansion RAM/ROM/I/O  |
| 1FFE-1FFF | On-chip I/O                     |
| 2000200F  | Internal ROM interrupt vectors  |
| 2010207F  | Reserved                        |
| 2080-3FFF | Internal ROM user program space |
| 4000-FFFF | Off-chip expansion RAM/ROM/I/O  |

## Table 1. Memory allocations of the 8096

The instruction set handles signed and unsigned 16-bit multiplications and divisions. Both 8-bit bytes and 16-bit double words are supported, and even 32bit double words are supported for a subset of the main instruction set. A full 64 kbytes of memory address space is usable.

#### A flexible register structure

The 8096 instruction set directly supports 256 bytes of registers, which can be referenced as 128word registers or as 64 double-word registers. These registers also appear—for memory reference instructions—as the first 256 bytes of the 64-kbyte RAM address space. This permits, for example, the use of a portion of the register space as the subroutine stack on smaller systems that do not have external expansion memory (Table 1).

The first 24 bytes of this register space are reserved for on-chip I/O addresses. I/O locations are memory-mapped and can be referenced directly as registers. The word register located at address 18H serves as the stack pointer. Such a large register space allows a programmer to keep his most frequently referenced scalar variables in registers.

| Table 2. Address modes of the 8096 |                        |            |        |         |                                                                  |
|------------------------------------|------------------------|------------|--------|---------|------------------------------------------------------------------|
| Name                               | Time (µs) <sup>1</sup> | Time (µs)? | Writte | en form | Action taken                                                     |
| Direct                             | 0                      | N.A.       | ADD    | B,A     | $(B) \le (B) + (A)$                                              |
| Immediate                          | 0.2 (word)             | NA.        | ADDB   | B,#A    | (B) <= (B) + A                                                   |
| Immediate                          | 0 (byte)               | N.A.       | ADD    | B,#A    | `(B) <= (B) + A                                                  |
| Indirect                           | 0.4                    | 1.4        | ADD    | B,(A)   | $(B) \le (B) + (A)$                                              |
| Autoincrement                      | 0.6                    | 16         | ADD    | B,(A)+  | (B) <= (B) + ((A)); (A) <= (A)<br>+ <length a="" of=""></length> |
| Short indexed                      | 0.4                    | 1.4        | ADD    | B,C[A]  | (B) <= (B) + ((A) + C); where<br>-128 <c<127< td=""></c<127<>    |
| Short indexed                      | 0.6                    | 1.8        | ST     | C[A],B  | ((A) + C) <= (B) ST, Pop only                                    |
| Long indexed                       | 0.6                    | 1.6        | ADD    | B[A],C  | $(B) \le (B) + ((A) + C)$                                        |
| Long indexed                       | 0.8                    | 1.8        | ST     | [A]C,B  | ((A) + C) = (B) ST, Pop only                                     |

1 Addressed operand located in register space

Addressed operand located in ROM space or external memory-expansion space

Note ST and Pop are the only instructions with an address-moded destination





Since the number of instructions required is reduced, fewer external memory references are needed. As a result, program execution is accelerated.

The 8096 uses separate internal instruction and data buses. With this architecture, ROM and external memory references are slightly slower than register references. Instructions cannot be executed out of the internal RAM register space, but externalexpansion RAM instructions can be executed.

Both memory space and register space are fully byte-addressable. A 16-bit word begins on an even byte address, and the odd byte is the most significant byte of the word. A 32-bit double word begins on an even-word address—both bit 0 and bit 1 of the address are zeros. Double words are produced by Multiply Words, Shift, and Normalize instructions and are used by Divide Words, Shift, and Normalize instructions. Double words are added and subtracted using Add with Carry and Subtract with Borrow instructions.

In most computers, the most commonly used instruction is Move. Because of the many registers in the 8096, a programmer can get away with fewer Move instructions—it is not necessary to switch

The 8096 can be very useful in an automotive antiskid braking system that allows a driver to decelerate his vehicle safely when one or more wheels start slipping. Slip conditions can be detected either by excessive wheel-speed differential or by excessive apparent deceleration, or both. For example, if one wheel hits an ice patch during heavy braking, the rotation of that wheel will slow down significantly, indicating a skid. On the other hand, normal tires begin to slip at or below 1 g of acceleration. If the apparent deceleration as measured by wheel speed is less than 1 g, the wheel is assumed to be skidding. Both skid-detection techniques depend on measuring a wheel's rotational speed.

Wheels are monitored by reluctance (magnetic) pickups, which generate pulse trains whose frequencies are proportional to wheel speed. Usually, a simple numerical relationship relates frequency to speed-13.3 Hz per miles per hour is a typical value. Four pickup outputs are easily handled by the 8096's high-speed input unit. At each transition of any of the pickups, the current value of timer 0 is saved in the input FIFO. The programmable edge detector in the high-speed input unit provides a convenient device for handling the wide dynamic range of the period measurement. At slow

## Stopping a car

speeds, the edge detector can be programmed to respond to both edges of the input signal; at medium speeds, to recognize only positive-going edges; and at high speeds, to respond to just one of eight positive-going edges. This technique not only extends the dynamic range of the measurement, but also reduces the intenrupt overhead at high speeds.

Three successive time samples  $-T_s$ ,  $T_s$ , and  $T_s$ -allow the speed and acceleration of a wheel to be determined from the following equations:

| Vxy | $= C/(T_y - T_y)$                        | (1) |
|-----|------------------------------------------|-----|
| Vyz | $= C/(T_y - T_y)$ $= C/(T_z - T_y)$      | (2) |
| Azx | $= (\mathbf{V}_{zy} - \mathbf{V}_{xy})/$ | +   |
|     | $(\mathbf{T}_{z} - \mathbf{T}_{z})$      | (3) |

where C is the reciprocal of the proportionality constant (e.g., C = 1/13.3),  $V_{xy}$ ,  $V_{yp}$  and  $V_{zy}$  are velocities, and  $A_{zx}$  is acceleration.

The period of the incoming frequency is in units of 1.6  $\mu$ s since timer 0 is incremented at this rate. If I<sub>x</sub> represents the value in the timer at time x and I<sub>y</sub> the value at time y, then Eq. 1 and 2 are written as

In practice, the constants in Eq. 4 and 5 should be multiplied by a scaling factor to allow calculations to be performed in integer arithmetic. A factor of 100, for example, gives speed measured in units of 1/100 of a mile per hour. Then the value 46992.48 becomes 4699248; which can easily be represented within 32 bits, and a 32-by-16-division instruction is used to perform the division.

Each wheel requires two such divisions-one for speed, one for acceleration-during each loop of the calculation. A typical loop takes about 10 ms. A typical 8-bit microprocessor takes 500 to 750 µs per division, which means eight such divisions would require 4 to 6 ms. But the 8096 does all eight divisions in about 50 µs. This speed improvement translates into a higher-performance module in response time or adaptability. The watchdog timer of the 8096 helps enhance the reliability of the braking module. At a 15-MHz clock rate, the timer is incremented every 200 ns. During operation, the system software executes diagnostics periodically to ensure that the overall systemincluding hardware and software -is operating properly. If the operation is correct, the software will issue commands to reset the watchdog. But if a system failure prevents a diagnostic from running within a prescribed period. the watchdog timer will reset the entire system. The software cannot reset properly on an erroneous operation, such as a counter overflow, except by writing to the watchdog timer twice within its counting cycle.

#### **16-bit microcontroller**

operands in and out of memory locations. In addition, the chip's powerful three-operand instructions— Add, Subtract, Multiply and Logical And—often eliminate them. Since programmer productivity (measured in lines of code written per day) is reasonably constant, writing fewer Move instructions can lead to reduced development expense. Register Load and Store instructions, with a full set of addressing modes, handle moves that cannot be eliminated.

#### Keeping addressing simple

Because a study of the ways in which addressing is used on the 8086 microprocessor indicates that programmers use complex addressing modes less than 0.7% of the time, the 8096's instruction set bypasses those in favor of the more commonly used addressing modes. But should complex addressing be needed, programmers can build such modes through macros. Addressing modes in the 8096 include direct, register-indirect, immediate, autoincrement, and both short (8-bit) and long (16-bit) indexed-address. Table 2 lists the address modes and the operations that occur when each is activated.

Indexed-address modes, by adding an 8- or 16-bit displacement to the contents of any 16-bit register to form the effective address of an operand, allow fast access to arrays stored anywhere in memory. Indexed modes are also useful for referencing elements of based structures, as in the PL/M language. However, preliminary calculations are needed to reference a based array.

The stack pointer is fully addressable, as are all other 16-bit registers. As a result, it can be the base register for moded references. Stack-relative addressing, which is easy to program, is often used for recursive-subroutine parameter passing and dynamically allocated variables. While this technique does not make the best use of a large register space, it adds flexibility to the system. The stack need not be confined to internal RAM, but can fill any available RAM space in the system. The stack can flow across the boundary into register space at will, allowing recursion to very great subroutine depths.

Of the instruction set's 71 instructions, 25 take on both word and byte form, which increases the total to 96 instructions. The set includes 16 varieties of conditional jump, allowing for both signed and unsigned comparisons. All of the 2048 bits in register space can be tested individually by a Jump on Bit/Not Bit instruction. A Decrement and Jump on Not Zero instruction provides for loop control.



 Centered around the CPU and memory, the 8096's extensive I/O subsystems include an analog-to-digital converter, a universal asynchronous receiver-transmitter (UART), high-speed input and output circuitry, and a pulse-width modulation output circuit. Such Intelligent I/O allows the CPU to concentrate not on real-time housekeeping but on high-speed arithmetic and control operations.

Most of the instructions execute in about  $0.8 \ \mu$ s; the longest, to normalize a zero, takes  $8 \ \mu$ s. All datareference instructions except Pop, Push, and Normalize are available in byte form, and all such instructions except Jump on Bit and Normalize are available in word form. Table 3 lists some typical 8096 instructions and their run times.

A survey of code frequency usage shows that although most multiplications and divisions are unsigned, a signed form is still necessary. When unsigned multiplication and division instructions are preceded by a 0.8- $\mu$ s SIGND prefix, they are converted into full two's-complement signed multiplication and division. Either type of operation executes in less than 6  $\mu$ s. Word multiplications result in a double-word product, and byte multiplications produce a word product. With an instruction called Word Divide, a double-word dividend is divided by a word divisor to produce a word quotient and remainders.

Because jumps and calls are PC-relative, code is easy to relocate. Both Jump and Call instructions are available in a short 2-byte form with an 11-bit displacement. Jump on Bit is a 3-byte instruction with an 8-bit displacement. An indirect jump for the "do-case" is also provided.

In addition to the usual sign-extending (EXT) instructions for byte-to-word and word-to-doubleword conversions, the set includes instructions LDBSA and LDBZE, which move a byte into a word with sign or zero extension. Most one- and twooperand forms execute in 1  $\mu$ s. Conditional jumps run in less than 1.8  $\mu$ s, and in about 0.8  $\mu$ s when the jump is not taken.

Shifts, whether by a specific number of bit positions or by a computed number, are provided for all three operand lengths (byte, word, and double word). In a floating-point software package, the mantissas must be aligned before they are added or subtracted, and the results normalized afterwards. Both functions require a software shift loop.

The Normalize instruction and the computer form of the Shift Double Word instruction allow fast software implementations of floating-point arithmetic with up to a 32-bit mantissa. Multibit shift instructions are very useful for scaling operations in scaled-integer arithmetic. Scaled-integer operations are usually faster than floating-point arithmetic in control applications.

In addition to an overflow flag, which is set by each arithmetic instruction, there is an overflowtrap flag. It can be checked at the end of a sequence of instructions to determine whether an overflow has occurred anywhere in the sequence.

The instruction set is complemented by a variety of I/O subsystems for handling virtually any com-

| Table 3. Typical instruction times |               |                                 |                                      |
|------------------------------------|---------------|---------------------------------|--------------------------------------|
| Microsoc-                          | Oper-<br>ands | <b>Minementes</b>               |                                      |
| 0.8                                | 0             | CLRC,SETC,DI,EI,<br>CLRVT,SIGND | Flag manipu-<br>lations              |
| 0.8                                | 1             | INC,DEC,CLR,<br>NOT,NEG,SEX     | One-operand<br>instructions          |
| 0.8                                | 2*            | XOR,ADDC,SUB,<br>AND,ADD,SUBC   | Two-operand<br>arithmetics           |
| 08                                 | 2*            | OR,CMP                          | Two-op<br>arithmetics                |
| 0.8                                | 2*            | LD,LDBSE,LDBZE,<br>ST           | Load and store<br>registers          |
| 0.8 (not<br>taken)                 | 1             | JC,JNC,ETC.                     | Conditional jumps                    |
| 1.0                                | 3*            | AND,SUB,ADD                     | Thr <del>ee-</del> op<br>arithmetics |
| 1.0 (not<br>taken)                 | 2             | JBS,JBC                         | Jump on bit/<br>jump on not bit      |
| 1.6 (taken)                        | 1             | JC, JNC, ETC.                   | Conditional jumps                    |
| 1.6                                | 1             | SJMP,IJMP,<br>LJMP              | Unconditional<br>jumps               |
| 1.6 (stack<br>register)            | 0             | PUSHF                           | Push PSW                             |
| 1.6 (stack register)               | 1*            | PUSH                            | Stack push                           |
| 1.8 (taken)                        | 2             | JBS,JBC,DJNZ                    | Jump on bit/<br>decrement and jump   |
| 1.6 +<br>0.2/shift                 | 2             | SHL,SHR,SHRA                    | Shift instruc-<br>tions              |
| 1.8                                | 0             | POPF                            | Pop PSW                              |
| 2.2 +<br>0.2/shift                 | 2             | NORML                           | Normalize                            |
| 2.4                                | 1*            | POP                             | Stack pop                            |
| 2.4 (stack register)               | 1             | LCALL,SCALL,<br>RET             | Subroutines                          |
| 2.4 (stack<br>external)            | 0             | PUSHF                           | Push PSW                             |
| 2.4 (stack<br>external)            | 1*            | PUSH                            | Stack push                           |
| 2.6 (stack<br>external)            | 0             | POPF                            | Pop PSW                              |
| 2.8 (stack<br>external)            | 1*            | POP                             | Stack pop                            |
| 3.0 (stack<br>external)            | 1             | SCALL,CALL                      | Subroutines                          |
| 3.2 (stack<br>external)            | 0             | RET                             | Subroutine                           |
| 3.4                                | 2*            | MULB                            | Byte multi-<br>plication             |
| 3.6                                | 2*            | DIVB                            | Byte division                        |
| 3.6                                | 3*            | MULB                            | Byte multi-<br>plication             |
| 5.2                                | 2*            | MUL                             | Word multi-<br>plication             |
| 5.2                                | 2*            | DIV                             | Word division                        |
| 5.4                                | 3*            | MUL                             | Word multi-<br>plication             |

\*One of these operands may have full address modes

puter peripheral or industrial application (Fig. 2). They include an a-d converter, a UART, timercounters, and a programmable pulse-width-modulated output.

#### I/O resources include a-d

The controller contains a complete eight-channel, 10-bit a-d converter. Using successive approximation to achieve high speed—33.6  $\mu$ s at a 15-MHz clock rate —it handles analog input voltages in the range of 0 to 5 V. An external reference is required and must be connected between the reference voltage and analog ground terminals. The converter generates a vectored interrupt when it completes a conversion cycle, allowing the CPU to have rapid access to the a-d input handler when operating in a multitask environment.

Conversion is initiated by writing to an 8-bit a-d command register. The results of a conversion are read from two 8-bit output data registers. One 8-bit register contains the eight most significant bits, and the other holds the two least significant bits, a 3-bit channel indicator, two unused bits, and a status bit. The status bit, which indicates whether the a-d conversion is still in progress, is typically used in a noninterrupt-driven environment.

Just four bits of the a-d command register are used. Three of the bits specify the channel to be converted, and the fourth specifies the method of initiating an a-d conversion cycle. For example, if the fourth bit is a 1, the cycle begins immediately after writing to the command register. If it is a 0,



3. One half of the 8096's high-speed I/O subsystem is an input unit, which contains a user-programmable change detector that defines input transitions for the high-speed inputs. Each of the four inputs ( $HSI_0 - HSI_3$ ) can be programmed to respond to a different input transition.

the high-speed output logic subsystem initiates the conversion. The reason for the option is that many data acquisition algorithms require that conversions occur at specific intervals. This requirement is often difficult to manage through software because of interrupt latency and other conditions. Thus, the high-speed output subsystem provides the proper timing for periodic a-d conversions.

The 8096's UART is virtually a carbon copy of the one on the 8051 microcontroller. One of its 8-bit registers receives data, another transmits data, and another indicates the UART status plus bits to configure it for a specific operating mode. By setting the appropriate bits in the third, or control-status, register, a user can select one of four modes:

• Mode 0 (shift register) is a simple, synchronous mode in which the 8096 provides a clock to synchronize incoming or outgoing data. Mode 0 can also be used to expand the I/O.

• Mode 1 is an 8-bit UART mode in which the eighth bit is used for parity when it is enabled.

• Mode 2 is a 9-bit UART mode in which the ninth bit is used for parity when it is enabled.

• Mode 3 is a 9-bit data/address mode in which the UART transmits and receives nine bits of data. This is useful for implementing a simple multiprocessor intercommunications link in which the ninth bit distinguishes address from data.

The remaining six bits of the control-status register are used for six operations: enabling the receiver section of the UART, enabling parity for both transmission and reception (even parity); storing the ninth bit when in the 9-bit transmitting mode; storing the ninth bit when in the 9-bit receiving mode, indicating that the receiver is ready, and indicating that the transmitter is ready. Also on board are a dedicated 15-bit baud-rate generator and a baud-rate clock that can be driven by either the 8096's crystal oscillator or an input at pin T2CLK. This gives maximum flexibility in setting baud rates.

The pulse-width modulated output can produce a pulse train of variable duty cycle, which can be integrated and clamped to provide an accurate digital-to-analog output function. The PWM circuit operates as follows: The 8096 crystal frequency is divided by three and clocks an 8-bit free-running counter. The counter output connects to one side of an 8-bit comparator; the other side of the comparator is tied to a user-addressable register. When the freerunning counter value is the same as the one stored in the addressable register, an R-S flip-flop is set. The flip-flop is also reset when the counter rolls over from a count of 255 to 0. This produces a simple yet accurate variable duty-cycle oscillator, which can be programmed for a variable duty cycle from 0 to 255 in increments of X/256.

#### 16-bit microcontroller

The watchdog timer offers a simple way to recover from a software or hardware error. Essentially a 16bit free-running counter that is clocked by the CPU clock generator circuitry, the timer is reset by writing a  $01E_{\rm H}$  followed by a  $0E1_{\rm H}$  to byte location 000AH. If a resetting does not occur at least once every 13.107 ms, the timer will overflow, causing the 8096 to be reset—resetting reinitializes the 8096. This feature makes it virtually impossible for the 8096 to become lost in a program for too long. For development purposes, the reset terminal can be connected to  $V_{\rm CC}$  to disable the watchdog timer.

#### More I/O-and faster

Correlating events in real time is one of the most important considerations in computer-based control system design. Another common requirement is generating pulses and pulse trains to drive actuators. Most single-chip microcontrollers support such operations by having one or more timer/event counters under software control. The 8096, on the other hand, offers a complete integrated subsystem to perform these functions. Called the high-speed I/O unit, it is intended to be an integrated subsystem, but it can be viewed as separate units for input and output.

Figure 3 shows the block diagram of the high-speed input unit. Its major components are a 16-bit timer, a programmable change detector and a first-in, firstout (FIFO) memory. Also included are several registers used by the software to control the high-speed input unit.

The read-only timer is cleared by the system reset and incremented once every eight CPU cycles (every 1.6  $\mu$ s with a 15-MHz crystal). When the timer overflows—rolls over from FFFF<sub>H</sub> to 0000<sub>H</sub>—a status bit is set and an interrupt is generated. The change detector monitors four pins on the 8096 and looks for predefined changes. Change definitions are controlled by the high-speed input unit's mode register, which is set by the software. This register contains a 2-bit field for each of the four high-speed inputs. Using the fields, a programmer can select the type of change for each input. Fields are encoded in one of four ways:

- 00 defines positive transitions divided by 8.
- 01 defines positive transitions.
- 10 defines negative transitions.
- 11 defines positive and negative transitions.

Each high-speed input can be disabled through a second control register. When this is done, inputs of the high-speed input unit become available as digital input pins or, if required, two of the pins can be connected to the high-speed output unit.

As the block diagram in Fig. 4 shows, the highspeed output unit uses the same timer as the input unit and also has a 16-bit event counter. The readonly event counter is similar to the timer in that it can be read at any time, generates an overflowinterrupt or status indication, and cannot be written into. It differs from the timer, in that its reset and clock sources, instead of being fixed by hardware, can be selected under software control.

Two of the 8096's pins are dedicated to the event counter. A positive-going pulse on ECRST (Event Counter Reset) clears the counter, and either edge of a pulse applied to ECCLK (Event Counter Clock) increments the counter. A programmer has the option of using  $HSI_0$  instead of ECRST or  $HSI_1$ instead of ECCLK. These options are available by setting the appropriate bits in the I/O control register. The event counter can also be cleared under software control either directly, by setting a bit in the I/O control register, or indirectly, using the high-



4. The other half of the high-speed I/O subsystem is the output unit. Using a content-addressable memory to store socalled time-field data, the unit's logic matches this information with timer or event-counter operations.



 In the content-addressable memory of the high-speed output unit, 23-bit words are broken down into a 16-bit time field and a 7-bit command field. Command-field encoding defines the output unit's operating mode.

speed output unit itself.

The FIFO register of the high-speed input unit is replaced by a content-addressable memory in the output unit. The memory contains a file of eight 23bit registers. The 23 bits are divided into a 16-bit time field and a 7-bit command field. Control logic continually scans each location in the memory to determine whether its time field matches either the timer or the event counter as selected by one of the seven bits in the command field. When a match is found, the remaining six bits in the command field are executed.

#### What the bits do

The encoding of the command field bits and their functions are shown in Fig. 5. Four-bit channel code selects the output unit's operation. For example, the event counter can be reset or an a-d conversion can be initiated. If one of the high-speed output pins is to be changed, bit 5 of the command field will determine its state. For all of the high-speed output unit's operations, bit 4 determines whether an interrupt is generated upon execution of a command.

The high-speed output unit uses two interrupt vectors, one for the software timers and one for all other functions. When a software timer interrupt occurs, the interrupt service routine can interrogate an I/O status register to determine which of the four timers caused the interrupt. The ability of the command field to trigger an a-d conversion allows measurements to be made at precise moments, an absolute necessity in digital signal processing. Also, the ability to reset a count when it reaches a preset limit allows the simple implementation of a modulo-N counter. This is useful, for example, in a crankshaft position-sensor application that generates 214 pulses per revolution.

The eight locations in the content-addressable memory's file are scanned at the rate of one CPU cycle per location. At a 15-MHz clock rate, all eight locations will be scanned within 1.6  $\mu$ s. A high-speed output unit's command is executed as soon as it finds a time match. As each command is executed, it is removed from the content-addressable memory to make room for a new command, which is sent in from the input holding register.

Because of the extensive functions built into the 8096, a standard 40-lead DIP is far too small; the 8096 is housed in a 68-pin JEDEC package. Alternatively, it is supplied in a 48-pin DIP. $\Box$ 

## The Single Component MCS<sup>®</sup>-48 System

12

## **12.0 INTRODUCTION**

Sections 12.1 through 12.4 describe in detail the functional characteristics of the 8748H and 8749H EPROM, 8048AH/8049AH/8050AH ROM, and 8035AHL/ 8039AHL/8040-AHL CPU only single component microcomputers. Unless otherwise noted, details within these sections apply to all versions. This chapter is limited to those functions useful in single-chip implementations of the MCS®-48. Chapter 14 discusses functions which allow expansion of program memory, data memory, and input output capability.

## **12.1 ARCHITECTURE**

The following sections break the MCS-48 Family into functional blocks and describe each in detail. The following description will use the 8048AH as the representative product for the family. See Figure 14.1.

## 12.1.1 Arithmetic Section

The arithmetic section of the processor contains the basic data manipulation functions of the 8048AH and can be divided into the following blocks:

- Arithmetic Logic Unit (ALU)
- Accumulator
- Carry Flag
- Instruction Decoder

In a typical operation data stored in the accumulator is combined in the ALU with data from another source on the internal bus (such as a register or I/o port) and the result is stored in the accumulator or another register.

The following is more detailed description of the function of each block.

## INSTRUCTION DECODER

The operation code (op code) portion of each program instruction is stored in the Instruction Decoder and converted to outputs which control the function of each of the blocks of the Arithmetic Section. These lines control the source of data and the destination register as well as the function performed in the ALU.

## **ARITHMETIC LOGIC UNIT**

The ALU accepts 8-bit data words from one or two sources and generates an 8-bit result under control of the Instruction Decoder. The ALU can perform the following functions:

- Add With or Without Carry
- AND, OR, Exclusive OR
- Increment/Decrement
- Bit Complement
- Rotate Left, Right
- Swap Nibbles
- BCD Decimal Adjust

If the operation performed by the ALU results in a value represented by more than 8 bits (overflow of most significant bit), a Carry Flag is set in the Program Status Word.

## ACCUMULATOR

The accumulator is the single most important data register in the processor, being one of the sources of input to the ALU and often the destination of the result of operations performed in the ALU. Data to and from I/O ports and memory also normally passes through the accumulator.

## 12.1.2 Program Memory

Resident program memory consists of 1024, 2048, or 4096 words eight bits wide which are addressed by the program counter. In the 8748H and the 8749H this memory is user programmable and erasable EPROM; in the 8048AH/ 8049AH/8050AH the memory is ROM which is mask programmable at the factory. The 8035AHL/8039AHL/ 8040AHL has no internal program memory and is used with external memory devices. Program code is completely interchangeable among the various versions. To access the upper 2K of program memory in the 8050AH, and other MCS-48 devices, a select memory bank and a JUMP or CALL instruction must be executed to cross the 2K boundary.

There are three locations in Program Memory of special importance as shown in Figure 12 2.

#### LOCATION 0

Activating the Reset line of the processor causes the first instruction to be fetched from location 0.

#### LOCATION 3

Activating the Interrupt input line of the processor (if interrupt is enabled) causes a jump to subroutine at location 3.

#### LOCATION 7

A timer/counter interrupt resulting from timer counter overflow (if enabled) causes a jump to subroutine at location 7.

Therefore, the first instruction to be executed after initialization is stored in location 0, the first word of an external interrupt service subroutine is stored in location 3, and the first word of a timer/counter service routines





12-2

SINGLE COMPONENT MCS®-48 SYSTEM

is stored in location 7. Program memory can be used to store constants as well as program instructions. Instructions such as MOVP and MOVP3 allow easy access to data "lookup" tables.



Figure 12-2. Program Memory Map

#### 12.1.3 Data Memory

Resident data memory is organized as 64, 128, or 256 by 8-bits wide in the 8048AH, 8049AH and 8050AH. All locations are indirectly addressable through either of two RAM Pointer Registers which reside at address 0 and 1 of the register array. In addition, as shown in Figure 12-3, the first 8 locations (0-7) of the array are designated as working registers and are directly addressable by several instructions. Since these registers are more easily addressed, they are usually used to store frequently accessed intermediate results. The DJNZ instruction makes very efficient use of the working registers as program loop counters by allowing the programmer to decrement and test the register in a single instruction.

By executing a Register Bank Switch instruction (SEL RB) RAM locations 24–31 are designated as the working

registers in place of locations 0-7 and are then directly addressable. This second bank of working registers may be used as an extension of the first bank or reserved for use during interrupt service subroutines allowing the registers of Bank 0 used in the main program to be instantly "saved" by a Bank Switch. Note that if this second bank is not used, locations 24-31 are still addressable as general purpose RAM. Since the two RAM pointer Registers R0 and R1 are a part of the working register array, bank switching effectively creates two more pointer registers (R0/and R1/) which can be used with R0 and R1 to easily access up to four separate working areas in RAM at one time. RAM locations (8-23) also serve a dual role in that they contain the program counter stack as explained in Section 12.1.6. These locations are addressed by the Stack Pointer during subroutine calls as well as by RAM Pointer Registers R0 and R1. If the level of subroutine nesting is less than 8, all stack registers are not required and can be used as general purpose RAM locations. Each level of subroutine nesting not used provides the user with two additional RAM locations.





1



Figure 12-4. "Quasi-bidirectional" Port Structure

## 12.1.4 Input/Output

The 8048AH has 27 lines which can be used for input or output functions. These lines are grouped as 3 ports of 8 lines each which serve as either inputs, outputs or bidirectional ports and 3 "test" inputs which can alter program sequences when tested by conditional jump instructions.

## PORTS 1 AND 2

Ports 1 and 2 are each 8 bits wide and have identical characteristics. Data written to these ports is statically latched and remains unchanged until rewritten. As input ports these lines are non-latching, i.e., inputs must be present until read by an input instruction. Inputs are fully TTL compatible and outputs will drive one standard TTL load.

The lines of ports 1 and 2 are called quasi-bidirectional because of a special output circuit structure which allows each line to serve as an input, and output, or both even though outputs are statically latched. Figure 12-4 shows the circuit configuration in detail. Each line is continuously pulled up to  $V_{CC}$  through a resistive device of relatively high impedance.

This pullup is sufficient to provide the source current for a TTL high level yet can be pulled low by a standard TTL gate thus allowing the same pin to be used for both input and output. To provide fast switching times in a "0" to "1" transition a relatively low impedance device is switched in momentarily ( $\approx 1/5$  of a machine cycle) whenever a "1" is written to the line. When a "0" is written to the line a low impedance device overcomes the light pullup and provides TTL current sinking capability. Since the pulldown transistor is a low impedance device a "1" must first be written to any line which is to be used as an input. Reset initializes all lines to the high impedance "1" state.

It is important to note that the ORL and the ANL are read/ write operations. When executed, the  $\mu$ C "reads" the port, modifies the data according to the instruction, then "writes" the data back to the port. The "writing" (essentially an OUTL instruction) enables the low impedance pull-up momentarily again even if the data was unchanged from a "1." This specifically applies to configurations that have inputs and outputs mixed together on the same port. See also section 13.7.

#### BUS

Bus is also an 8-bit port which is a true bidirectional port with associated input and output strobes. If the bidirectional feature is not needed, Bus can serve as either a statically latched output port or non-latching input port. Input and output lines on this port cannot be mixed however.

As a static port, data is written and latched using the OUTL instruction and inputted using the INS instruction. The INS and OUTL instructions generate pulses on the corresponding  $\overline{RD}$  and  $\overline{WR}$  output strobe lines; however, in the static port mode they are generally not used. As a bidirectional port the MOVX instructions are used to read and write the port. A write to the port generates a pulse on the  $\overline{WR}$  output line and output data is valid at the trailing edge of  $\overline{WR}$ . A read of the port generates a pulse on the  $\overline{RD}$  output line and input data must be valid at the trailing edge of  $\overline{RD}$ . When not being written or read, the BUS lines are in a high impedance state. See also sections 13.6 and 13.7.

## 12.1.5 Test and INT Inputs

Three pins serve as inputs and are testable with the conditional jump instruction. These are T0, T1, and  $\overline{INT}$ . These pins allow inputs to cause program branches without the necessity to load an input port into the accumulator. The T0, T1, and  $\overline{INT}$  pins have other possible functions as well. See the pin description in Section 12.2.

## 12.1.6 Program Counter and Stack

The Program Counter is an independent counter while the Program Counter Stack is implemented suing pairs of registers in the Data Memory Array. Only 10, 11, or 12 bits of the Program Counter are used to address the 1024, 2048, or 4096 words of on-board program memory of the 8048AH, 8049AH, or 8050AH, while the most significant bits can be used for external Program Memory fetches. See Figure 12.5. The Program Counter is initialized to zero by activating the Reset line.



Figure 12-5. Program Counter

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 as shown in Figure 12-6. The pair to be used is determined by a 3-bit Stack Pointer which is part of the Program Status Word (PSW).



Figure 12-6. Program Counter Stack

Data RAM locations 8-23 are available as stack registers and are used to store the Program Counter and 4 bits of PSW as shown in Figure 12-6. The Stack Pointer when initialized to 000 points to RAM locations 8 and 9. The first subroutine jump or interrupt results in the program counter contents being transferred to locations 8 and 9 of the RAM array. The stack pointer is then incremented by one to point to locations 10 and 11 in anticipation of another CALL. Nesting of subroutines within subroutines can continue up to 8 times 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 111 to 000. It also underflows from 000 to 111.

The end of a subroutine, which is signalled by a return instruction (RET or RETR), causes the Stack Pointer to be decremented and the contents of the resulting register pair to be transferred to the Program Counter.

### 12.1.7 Program Status Word

An 8-bit status word which can be loaded to and from the accumulator exists called the Program Status Word (PSW). Figure 12-7 shows the information available in

the word. The Program Status Word is actually a collection of flip-flops throughout the machine which can be read or written as a whole. The ability to write to PSW allows for easy restoration of machine status after a power down sequence.



Figure 12-7. Program Status Word (PSW)

The upper four bits of PSW are stored in the Program Counter Stack with every call to subroutine or interrupt vector and are optionally restored upon return with the RETR instruction. The RET return instruction does not update PSW.

The PSW bit definitions are as follows:

- Bits 0–2: Stack Pointer bits  $(S_0, S_1, S_2)$
- Bit 3: Not used ('1' level when read)
- Bit 4: Working Register Bank Switch Bit (BS) 0 = Bank 0 1 = Bank 1
- Bit 5: Flag 0 bit (F0) user controlled flag which can be complemented or cleared, and tested with the conditional jump instruction JF0.
- Bit 6: Auxiliary Carry (AC) carry bit generated by an ADD instruction and used by the decimal adjust instruction DA A.
- Bit 7: Carry (CY) carry flag which indicates that the previous operation has resulted in overflow of the accumulator.

### 12.1.8 Conditonal Branch Logic

The conditional branch logic within the processor enables several conditions internal and external to the processor to be tested by the users program. By using the conditional jump instruction the conditions that are listed in Table 12-1 can effect a change in the sequence of the program execution.

| Table | 12-1 |
|-------|------|
|-------|------|

| Device Testable       | Jump Conditions<br>(Jump On) |         |  |
|-----------------------|------------------------------|---------|--|
|                       |                              | not all |  |
| Accumulator           | All zeros                    | zeros   |  |
| Accumulator Bit       |                              | 1       |  |
| Carry Flag            | -0                           | 1       |  |
| User Flags (F0, F1)   | -                            | 1       |  |
| Timer Overflow Flag   |                              | 1       |  |
| Test Inputs (T0, T1)  | 0                            | 1       |  |
| Interrupt Input (INT) | 0                            |         |  |

## 12.1.9 Interrupt

An interrupt sequence is initiated by applying a low "0" level input to the INT pin. Interrupt is level triggered and active low to allow "WIRE ORing" of several interrupt sources at the input pin. Figure 12-8 shows the interrupt logic of the 8048AH. The Interrupt line is sampled every instruction cycle and when detected causes a "call to subroutine" at location 3 in program memory as soon as all cycles of the current instruction are complete. On 2cycle instructions the interrupt line is sampled on the 2nd cycle only. INT must be held low for at least 3 machine cycles to ensure proper interrupt operations. As in any CALL to subroutine, the Program Counter and Program Status word are saved in the stack. For a description of this operation see the previous section, Program Counter and Stack. Program Memory location 3 usually contains an unconditional jump to an interrupt service subroutine elsewhere in program memory. The end of an interrupt service subroutine is signalled by the execution of a Return and Restore Status instruction RETR. The interrupt system is single level in that once an interrupt is detected all further interrupt requests are ignored until execution of an RETR reenables the interrupt input logic. This occurs at the beginning of the second cycle of the RETR instruction. This sequence holds true also for an internal interrupt generated by timer overflow. If an internal timer/counter generated interrupt and an external interrupt are detected at the same time, the external source will be recognized. See the following Timer/Counter section for a description of timer interrupt. If needed, a second external interrupt can be created by enabling the timer/counter interrupt, loading FFH in the Counter (ones less than terminal count), and enabling the event counter mode. A "1" to "0" transition on the T1 input will then cause an interrupt vector to location 7.

#### INTERRUPT TIMING

The interrupt input may be enabled or disabled under Program Control using the EN I and DIS I instructions. Interrupts are disabled by Reset and remain so until enabled by the users program. An interrupt request must be removed before the RETR instruction is executed upon return from the service routine otherwise the processor will re-enter the service routine immediately. Many peripheral devices prevent this situation by resetting their interrupt request line whenever the processor accesses (Reads or Writes) the peripherals data buffer register. If the interrupting device does not require access by the processor, one output line of the 8048AH may be designated as an "interrupt acknowledge" which is activated by the service subroutine to reset the interrupt request. The INT pin may also be tested using the conditional jump instruction JNI. This instruction may be used to detect the presence of a pending interrupt before interrupts are enabled. If interrupt is left disabled, INT may be used as another test input like T0 and T1.

#### 12.1.10 Time/Counter

The 8048AH contains a counter to aid the user in counting external events and generating accurate time delays without placing a burden on the processor for these functions. In both modes the counter operation is the same, the only difference being the source of the input to the counter. The timer/event counter is shown in Figure 12-9.

#### COUNTER

The 8-bit binary counter is presettable and readable with two MOV instructions which transfer the contents of the accumulator to the counter and vice versa. The counter content may be affected by Reset and should be initialized by software. The counter is stopped by a Reset or STOP TCNT instruction and remains stopped until started as a timer by a START T instruction or as an event counter by a START CNT instruction. Once started the counter will increment to this maximum count (FF) 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 the setting of an overflow flag flip-flop and in the generation of 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 Reset. The interrupt request is stored in a latch and then ORed with the external interrupt input INT. The timer interrupt may be enabled or disabled independently of external interrupt by the EN TCNT1 and DIS TCNT1 instructions. If enabled, the counter overflow will cause a subroutine call to location 7 where the timer or counter service routine may be stored.

If timer and external interrupts occur simultaneously, the external source will be recognized and the Call will be to 7





1

12-8



Figure 12-9. Timer/Event Counter

location 3. Since the timer interrupt is latched it will remain pending until the external device is serviced and immediately be recognized upon return from the service routine. The pending timer interrupt is reset by the Call to location 7 or may be removed by executing a DIS TCNT1 instruction.

#### AS AN EVENT COUNTER

Execution of a START CNT instruction connects the T1 input pin to the counter input and enables the counter. The T1 input is sampled at the beginning of state 3 or in later MCS-48 devices in state time 4. Subsequent high to low transitions on T1 will cause the counter to increment. T1 must be held low for at least 1 machine cycle to insure it won't be missed. The maximum rate at which the counter may be incremented is once per three instruction cycles (every 5.7  $\mu$ sec when using an 8 MHz crystal)—there is no minimum frequency. T1 input must remain high for at least 1/5 machine cycle after each transition.

#### AS A TIMER

Eexcution of a START T instruction connects an internal clock to the counter input and enables the counter. The internal clock is derived bypassing the basic machine cycle clock through a  $\div$  32 prescaler. The prescaler is reset during the START T instruction. The resulting clock increments the counter every 32 machine cycles. Various delays from 1 to 256 counts can be obtained by presetting the counter and detecting overflow. Times longer than 256 counts may be achieved by accumulating multiple overflows in a register under software control. For time results

olution less than 1 count an external clock can be applied to the T1 input and the counter operated in the event counter mode. ALE divided by 3 or more can serve as this external clock. Very small delays or "fine tuning" of larger delays can be easily accomplished by software delay loops.

Often a serial link is desirable in an MCS-48 family member. Table 12-2 lists the timer counts and cycles needed for a specific baud rate given a crystal frequency.

#### 12.1.11 Clock and Timing Circuits

Timing generation for the 8048AH is completely selfcontained with the exeception of a frequency reference which can be XTAL, ceramic resonator, or external clock source. The Clock and Timing circuitry can be divided into the following functional blocks.

#### OSCILLATOR

The on-board oscillator is a high gain parallel resonant circuit with a frequency range of 1 to 11 MHz. The X1 external pin is the input to the amplifier stage while X2 is the output. A crystal or ceramic resonator connected between X1 and X2 provides the feedback and phase shift required for oscillation. If an accurate frequency reference is not required, ceramic resonator may be used in place of the crystal.

For accurate clocking, a crystal should be used. An externally generated clock may also be applied to X1-X2as the frequency source. See the data sheet for more information.

|              | Frequency<br>(MHz)                       | т <sub>су</sub>                          | T0 Prr(1/5 T <sub>Cy</sub> )             | Timer Prescaler<br>(32 T <sub>CV</sub> )  |
|--------------|------------------------------------------|------------------------------------------|------------------------------------------|-------------------------------------------|
| 1            | 4                                        | 3.75μs                                   | 750ns                                    | 120μs                                     |
|              | 6                                        | 2.50μs                                   | 500ns                                    | 80μs                                      |
|              | 8                                        | 1.88μs                                   | 375ns                                    | 60.2μs                                    |
|              | 11                                       | 1.36μs                                   | 275ns                                    | 43.5μs                                    |
| Baud<br>Rate | 4 MHz<br>Timer Counts +<br>Instr. Cycles | 6 MHz<br>Timer Counts +<br>Instr. Cycles | 8 MHz<br>Timer Counts +<br>Instr. Cycles | 11 MHz<br>Timer Counts +<br>Įnstr. Cycles |
| 110          | 75 + 24 Cycles                           | 113 + 20 Cycles                          | 151 + 3 Cycles                           | 208 + 28 Cycles                           |
|              | .01% Error                               | .01% Error                               | .01% Error                               | .01% Error                                |
| 300          | 27 + 24 Cycles                           | 41 + 21 Cycles                           | 55 + 13 Cycles                           | 76 + 18 Cycles                            |
|              | .1% Error                                | .03% Error                               | .01% Error                               | .04% Error                                |
| 1200         | 6 + 30 Cycles                            | 10 + 13 Cycles                           | 12 + 27 Cycles                           | 19 + 4 Cycles                             |
|              | .1% Error                                | .1% Error                                | .06% Error                               | .12% Error                                |
| 1800         | 4 + 20 Cycles                            | 6 + 30 Cycles                            | 9 + 7 Cycles                             | 12 + 24 Cycles                            |
|              | .1% Error                                | .1% Error                                | .17% Error                               | .12% Error                                |
| 2400         | 3 + 15 Cycles                            | 5 + 6 Cycles                             | 6 + 24 Cycles                            | 9 + 18 Cycles                             |
|              | .1% Error                                | .4% Error                                | .29% Error                               | .12% Error                                |
| 4800         | 1 + 23 Cycles                            | 2 + 19 Cycles                            | 3 + 14 Cycles                            | 4 + 25 Cycles                             |
|              | 1.0% Error                               | .4% Error                                | .74% Error                               | .12% Error                                |

#### Table 12-2. Baud Rate Generation

#### STATE COUNTER

The output of the oscillator is divided by 3 in the State Counter to create a clock which defines the state times of the machine (CLK). CLK can be made available on the external pin T0 by executing an ENTO CLK instruction. The output of CLK on T0 is disabled by Reset of the processor.

#### **CYCLE COUNTER**

CLK is then divided by 5 in the Cycle Counter to provide a clock which defines a machine cycle consisting of 5 machine states as shown in Figure 12-10. Figure 12-11 shows the different internal operations as divided into the machine states. This clock is called Address Latch Enable (ALE) because of its function in MCS-48 systems with external memory. It is provided continuously on the ALE output pin.

#### 12.1.12 Reset

The reset input provides a means for initialization for the processor. This Schmitt-trigger input has an internal pullup device which in combination with an external 1  $\mu$  fd capacitor provides an internal reset pulse of sufficient length to guarantee all circuitry is reset, as shown in Figure 12-12. If the reset pulse is generated externally the RESET pin must be held low for at least 10 milliseconds after the power supply is within tolerance. Only 5 machine cycles (6.8  $\mu$ s @ 11 MHz) are required if power is already on and the oscillator has stabilized. ALE and PSEN (if EA = 1) are active while in Reset.

Reset performs the following functions:

- 1) Sets program counter to zero.
- 2) Sets stack pointer to zero.
- 3) Selects register bank 0.
- 4) Selects memory bank 0.
- 5) Sets BUS to high impedance state (except when EA = 5V).
- 6) Sets Ports 1 and 2 to input mode.
- 7) Disables interrupts (timer and external).
- 8) Stops timer.
- 9) Clears timer flag.
- 10) Clears F0 and F1.
- 11) Disables clock output from T0.



Figure 12-10. MCS®-48 Timing Generation and Cycle Timing

#### 12.1.13 Single-Step

This feature, as pictured in Figure 12-13, provides the user with a debug capability in that the processor can be stepped through the program one instruction at a time. While stopped, the address of the next instruction to be fetched is available concurrently on BUS and the lower

half of Port 2. The user can therefore follow the program through each of the instruction steps. A timing diagram, showing the interaction between output ALE and input  $\overline{SS}$ , is shown. The BUS buffer contents are lost during single step; however, a latch may be added to reestablish the lost I/O capability if needed. Data is valid at the leading edge of ALE.

|                        |                      | CYCLE 2                      |                          |                        |                            |                                                                                                               |                  |                              |                    |            |
|------------------------|----------------------|------------------------------|--------------------------|------------------------|----------------------------|---------------------------------------------------------------------------------------------------------------|------------------|------------------------------|--------------------|------------|
| INSTRUCTION            | S1                   | \$2                          | <b>S</b> 3               | S4                     | <b>S</b> 5                 | S1                                                                                                            | S2               | \$3                          | S4                 | <b>S</b> 5 |
| IN A,P                 | FETCH<br>INSTRUCTION | INCREMENT<br>PROGRAM COUNTER | -                        | *INCREMENT<br>TIMER    | -                          | -                                                                                                             | READ<br>PORT     | -                            | *                  | -          |
| OUTL P,A               | FETCH<br>INSTRUCTION | INCREMENT<br>PROGRAM COUNTER | -                        | *INCREMENT<br>TIMER    | OUTPUT<br>TO PORT          | -                                                                                                             |                  | -                            | * _                | -          |
| ANL P, = DATA          | FETCH<br>INSTRUCTION | INCREMENT<br>PROGRAM COUNTER | -                        | *INCREMENT<br>TIMER    | READ PORT                  | FETCH<br>IMMEDIATE DATA                                                                                       | -                | INCREMENT<br>PROGRAM COUNTER | *OUTPUT<br>TO PORT | -          |
| ORL P, = DATA          | FETCH<br>INSTRUCTION | INCREMENT<br>PROGRAM COUNTER | -                        | *INCREMENT<br>TIMER    | READ PORT                  | FETCH<br>IMMEDIATE DATA                                                                                       | -                | INCREMENT<br>PROGRAM COUNTER | *OUTPUT<br>TO PORT | -          |
| INS A, BUS             | FETCH<br>INSTRUCTION | INCREMENT<br>PROGRAM COUNTER | _                        | INCREMENT<br>TIMER     | -                          |                                                                                                               | READ<br>PORT     | -                            | * –                |            |
| OUTL BUS, A            | FETCH<br>INSTRUCTION | INCREMENT<br>PROGRAM COUNTER | -                        | INCREMENT<br>TIMER     | OUTPUT<br>TO PORT          | -                                                                                                             | -                | -                            | *                  | -          |
| ANL BUS, = DATA        | FETCH<br>INSTRUCTION | INCREMENT<br>PROGRAM COUNTER | -                        | *INCREMENT<br>TIMER    | READ PORT                  | FETCH<br>IMMEDIATE DATA                                                                                       | -                | INCREMENT<br>PROGRAM COUNTER | *OUTPUT<br>TO PORT | -          |
| ORL BUS, = DATA        | FETCH<br>INSTRUCTION | INCREMENT<br>PROGRAM COUNTER | -                        | *INCREMENT<br>TIMER    | READ PORT                  | FETCH<br>IMMEDIATE DATA                                                                                       | -                | INCREMENT<br>PROGRAM COUNTER | *OUTPUT<br>TO PORT | -          |
| MOVX @'R,A             | FETCH<br>INSTRUCTION | INCREMENT<br>PROGRAM COUNTER | OUTPUT RAM<br>ADDRESS    | INCREMENT<br>TIMER     | OUTPUT<br>DATA TO RAM      | -                                                                                                             | -                | -                            | • _                | -          |
| MOVX A,@R              | FETCH<br>INSTRUCTION | INCREMENT<br>PROGRAM COUNTER | OUTPUT RAM<br>ADDRESS    | INCREMENT<br>TIMER     | -                          | -                                                                                                             | READ<br>DATA     | -                            | • _                | -          |
| MOVD A,Pj              | FETCH<br>INSTRUCTION | INCREMENT<br>PROGRAM COUNTER | OUTPUT<br>OPCODE/ADDRESS | INCREMENT<br>TIMER     | -                          | -                                                                                                             | READ P2<br>LOWER | -                            | • _                | _          |
| MOVD P <sub>i</sub> ,A | FETCH<br>INSTRUCTION | INCREMENT<br>PROGRAM COUNTER | OUTPUT<br>OPCODE/ADDRESS | INCREMENT<br>TIMER     | OUTPUT DATA<br>TO P2 LOWER | -                                                                                                             | -                | -                            | • _                | -          |
| ANLD P,A               | FETCH<br>INSTRUCTION | INCREMENT<br>PROGRAM COUNTER | OUTPUT<br>OPCODE/ADDRESS | INCREMENT<br>TIMER     | OUTPUT<br>DATA             | -                                                                                                             | _                | -                            | • _                | -          |
| ORLD P,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>SAMPLE   | -                          | FETCH<br>IMMEDIATE DATA                                                                                       | -                | UPDATE<br>PROGRAM COUNTER    | •                  | _          |
| STRT T<br>STRT CNT     | FETCH<br>INSTRUCTION | INCREMENT<br>PROGRAM COUNTER | -                        | *                      | START<br>COUNTER           |                                                                                                               |                  |                              |                    |            |
| STOP TONT              | FETCH<br>INSTRUCTION | INCREMENT<br>PROGRAM COUNTER | · _                      | • _                    | STOP<br>COUNTER            |                                                                                                               |                  |                              |                    |            |
| ENI                    | FETCH<br>INSTRUCTION | INCREMENT<br>PROGRAM COUNTER | _                        | * ENABLE<br>INTERRUPT  | -                          |                                                                                                               |                  | N ADDRESSES AR               |                    |            |
| DIS I                  | FETCH<br>INSTRUCTION | INCREMENT<br>PROGRAM COUNTER | _                        | * DISABLE<br>INTERRUPT | - `                        | AT THIS TIME IF EXTERNAL PROGRAM MEMOR<br>BEING ACCESSED.<br>(1) IN LATER MCS-48 DEVICES T1 IS SAMPLED IN S4. |                  |                              | Y 15               |            |
| ENTO CLK               | FETCH<br>INSTRUCTION | INCREMENT<br>PROGRAM COUNTER |                          | * ENABLE<br>CLOCK      | -                          |                                                                                                               |                  |                              |                    |            |

x

12-12

•

SINGLE COMPONENT MCS®-48 SYSTEM



Figure 12-12

#### TIMING

The 8048AH operates in a single-step mode as follows:

- 1) The processor is requested to stop by applying a low level on  $\overline{SS}$ .
- 2) The processor responds by stopping during the address 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 ALE high. In this state (which can be maintained indefinitely) the address of the next instruction to be fetched is present on BUS and the lower half of port 2.
- 4) 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 ALE low.
- 5) To stop the processor at the next instruction  $\overline{SS}$  must be brought low again soon after ALE goes low. If  $\overline{SS}$ is left high the processor remains in a "Run" mode.

A diagram for implementing the single-step function of the 8748H is shown in Figure 12-13. D-type flip-flop with preset and clear is used to generate  $\overline{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 ALE to bring  $\overline{SS}$  low via the clear input. ALE should be buffered since the clear input of an SN7474 is the equivalent of 3 TTL loads. The processor is now in the stopped state. The next instruction is initiated by clocking a "1" into the flip-flop. This "1" will not appear on  $\overline{SS}$  unless ALE is high removing clear from the flip-flop. In response to  $\overline{SS}$  going high the processor begins an instruction fetch which brings ALE low resetting  $\overline{SS}$  through the clear input and causing the processor to again enter the stopped state.

#### 12.1.14 Power Down Mode (8048AH, 8049AH, 8050AH, 8039AHL, 8035AHL, 8040AHL)

Extra circuitry has been added to the 8048AH/8049AH/ 8050AH ROM version to allow power to be removed from all but the data RAM array for low power standby operation. In the power down mode the contents of data RAM can be maintained while drawing typically 10% to 15% of normal operating power requirements.

 $V_{CC}$  serves as the 5V supply pin for the bulk of circuitry while the  $V_{DD}$  pin supplies only the RAM array. In normal operation both pins are a 5V while in standby,  $V_{CC}$  is at ground and  $V_{DD}$  is maintained at its standby value. Applying Reset to the processor through the RESET pin inhibits any access to the RAM by the processor and guarantees that RAM cannot be inadvertently altered as power is removed from  $V_{CC}$ .

A typical power down sequence (Figure 12-14) occurs as follows:

- 1) Imminent power supply failure is detected by user defined circuitry. Signal must be early enough to allow 8048AH to save all necessary data before  $V_{CC}$  falls below normal operating limits.
- 2) Power fail signal is used to interrupt processor and vector it to a power fail service routine.
- 3) Power fail routine saves all important data and machine status in the internal data RAM array. Routine may also initiate transfer of backup supply to the  $V_{DD}$  pin and indicate to external circuitry that power fail routine is complete.
- 4) Reset is applied to guarantee data will not be altered as the power supply falls out of limits. Reset must be held low until  $V_{CC}$  is at ground level.

Recovery from the Power Down mode can occur as any other power-on sequence with an external capacitor on the Reset input providing the necessary delay. See the previous section on Reset.



#### Figure 12-13. Single Step Operation



Figure 12-14. Power Down Sequence

#### 12.1.15 External Access Mode

Normally the first 1K (8048AH), 2K (8049AH), or 4K (8050AH) words of program memory are automatically fetched from internal ROM or EPROM. The EA input pin however allows the user to effectively disable internal program memory by forcing all program memory fetches to reference external memory. The following chapter explains how access to external program memory is accomplished.

The External Access mode is very useful in system test and debug because it allows the user to disable his internal applications program and substitute an external program of his choice — a diagnostic routine for instance. In addition, section 12.4 explains how internal program memory can be read externally, independent of the processor. A "1" level on EA initiates the external accesss mode. For proper operation, Reset should be applied while the EA input is changed.

#### 12.1.16 Sync Mode

The 8048AH, 8049AH, 8050AH has incorporated a new SYNC mode. The Sync mode is provided to ease the design of multiple controller circuits by allowing the designer to force the device into known phase and state time. The SYNC mode may also be utilized by automatic test equipment (ATE) for quick, easy, and efficient synchronizing between the tester and the DUT (device under test).

SYNC mode is enabled when SS' pin is raised to high voltage level of +12 volts. To begin synchronization, T0 is raised to 5 volts at least four clocks cycles after SS'. T0 must be high for at least four X1 clock cycles to fully

reset the prescaler and time state generators. T0 may then be brought down with the rising edge of X1. Two clock cycles later, with the rising edge of X1, the device enters into Time State 1, Phase 1, SS' is then brought down to 5 volts 4 clocks later after T0. RESET' is allowed to go high 5 tCY (75 clocks) later for normal execution of code. See Figure 12-15.

#### 12.1.17 idle Mode

Along with the standard power down, the 80C438, 80C49, 80C50 has added an IDLE mode instruction (01H) to give even further flexibility and power management. In the IDLE mode, the CPU is frozen while the oscillator, RAM, timer, and the interrupt circuitry remains fully active.

When the IDL instruction (01H) is decoded, the clock to the CPU is stopped. CPU status is preserved in its entirety: the Stack Pointer, Program Counter, Program Status Word, Accumulator, RAM, and all the registers maintain their data throughout idle.

Externally, the following occurs during idle:

- 1) The ports remain in the logical state they were in when idle was executed.
- 2) The bus remains in the logical state it was in when idle was executed if the bus was latched.

If the bus was in a high Z condition or if external program memory is used the bus will remain in the float state.

- 3) ALE remains in the inactive state (low).
- 4) RD', WR', PROG', and PSEN' remains in the inactive state (high).
- 5) T0 outputs clock if enabled.

There are three ways of exiting idle. Activating any enabled interrupt (external or timer) will cause the CPU to vector to the appropriate interrupt routine. Following a RETR instruction, program execution will resume at the instruction following the address that contained the IDL instruction.

The F0 and F1 flags may be used to give an indication if the interrupt occurred during normal program execution or during idle. This is done by setting or clearing the flags before going into idle. The interrupt service routine can examine the flags and act accordingly when idle is terminated by an interrupt.

Resetting the device can also terminate idle. Since the oscillator is already running, five machine cycles are all that is required to insure proper machine operation.







Figure 12-16. 8048AH and 8049AH Logic Symbol

#### **12.2 PIN DESCRIPTION**

The MCS-48 processors are packaged in 40 pin Dual In-Line Packages (DIP's). Table 12-3 is a summary of the functions of each pin. Figure 12-16 is the logic symbol for the 8048AH product family. Where it exists, the second paragraph describes each pin's function in an expanded MCS-48 system. Unless otherwise specified, each input is TTL compatible and each output will drive one standard TTL load.

| Table | 12-3. | Pin | Description |  |
|-------|-------|-----|-------------|--|
|       |       |     | · •         |  |

| Designation         | Pin<br>Number* | Function                                                                                                                                                                                                                                                                                                                                            |
|---------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| V <sub>SS</sub>     | 20             | Circuit GND potential                                                                                                                                                                                                                                                                                                                               |
| V <sub>DD</sub>     | 26             | Programming power supply; 21V during program for the 8748H/8749H; +5V during operation for both ROM and EPROM. Low power standby pin in 8048AH and 8049AH/8050AH ROM versions.                                                                                                                                                                      |
| V <sub>CC</sub>     | 40             | Main power supply; +5V during operation and during 8748H and 8749H pro-<br>gramming.                                                                                                                                                                                                                                                                |
| PROG                | 25             | Program pulse; +18V input pin during 8748H/8749H programming. Output strobe for 8243 I/O expander.                                                                                                                                                                                                                                                  |
| P10-P17<br>(Port 1) | 27-34          | 8-bit quasi-bidirectional port. (Internal Pullup $\approx$ 50K (I)                                                                                                                                                                                                                                                                                  |
| P20-P27<br>(Port 2) | 21-24<br>35-38 | 8-bit quasi-bidirectional port. (Internal Pullup $\approx 50 \mathrm{K} \Omega$ )                                                                                                                                                                                                                                                                   |
| (Pon 2)             | 33-38          | P20–P23 contain the four high order program counter bits during an external program memory fetch and serve as a 4-bit $I/O$ expander bus for 8243.                                                                                                                                                                                                  |
| D0-D7<br>(BUS)      | 12-19          | True bidirectional port which can be written or read synchronously using the $\overline{RD}$ , $\overline{WR}$ strobes. The port can also be statically latched.                                                                                                                                                                                    |
|                     |                | Contains the 8 low order program counter bits during an external program mem-<br>ory fetch, and receives the addressed instruction under the control of $\overrightarrow{PSEN}$ . Also<br>contains the address and data during an external RAM data store instruction,<br>under control of ALE, $\overrightarrow{RD}$ , and $\overrightarrow{WR}$ . |
| ,Γ0                 | 1              | Input pin testable using the conditional transfer instructions JT0 and JNT0. T0 can be designated as a clock output using ENTO CLK instruction. T0 is also used during programming and sync mode.                                                                                                                                                   |
| <b>Γ</b> Ι          | 39             | Input pin testable using the JT1, and JNT1 instructions. Can be designated the event counter input using the STRT CNT instruction. (See Section 2.1.10)                                                                                                                                                                                             |
| ĪNT                 | 6              | Interrupt input. Initiates an interrupt if interrupt is enabled. Interrupt is disabled after a reset. (Active low)                                                                                                                                                                                                                                  |
|                     |                | Interrupt must remain low for at least 3 machine cycles to ensure proper operation.                                                                                                                                                                                                                                                                 |
| RD                  | 8              | Output strobe activated during a BUS read. Can be used to enable data onto the BUS from an external device. (Active low)                                                                                                                                                                                                                            |
|                     |                | Used as a Read Strobe to External Data Memory.                                                                                                                                                                                                                                                                                                      |
| RESET               | 4              | Input which is used to initialize the processor. Also used during EPROM programming and verification. (Active low) (Internal pullup $\approx 80 \text{ K} \Omega$ )                                                                                                                                                                                 |
| WR                  | 10             | Output strobe during a BUS write. (Active low) Used as write strobe to external data memory.                                                                                                                                                                                                                                                        |
| ALE                 | 11             | Address Latch Enable. This signal occurs once during each cycle and is useful as a clock output.                                                                                                                                                                                                                                                    |
|                     |                | The negative edge of ALE strobes address into external data and program memory.                                                                                                                                                                                                                                                                     |

| Pin<br>Number* | Function                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9              | Program Store Enable. This output occurs only during a fetch to external program memory. (Active low)                                                                                                                                                                                                                                                                                   |
| 5              | Single step input can be used in conjunction with ALE to "single step" the processor through each instruction. (Active low) (Internal pullup $\approx 300 \text{K}\Omega$ ) +12V for sync modes (See 2.1.16)                                                                                                                                                                            |
| 7              | External Access input which forces all program memory fetches to reference external memory. Useful for emulation and debug, and essential for testing and program verification. (Active high) +12V for 8048AH/8049AH/8050AH program verification and +18V for 8748H/8749H program verification (Internal pullup $\approx$ 10M $\Omega$ on 8048AH/8049AH/8035AHL/8039AHL/8050AH/8040AHL) |
| 2              | One side of crystal input for internal oscillator. Also input for external source.                                                                                                                                                                                                                                                                                                      |
| 3              | Other side of crystal/external source input.                                                                                                                                                                                                                                                                                                                                            |
|                | Number*           9           5           7           2                                                                                                                                                                                                                                                                                                                                 |

Table 12-3. Pin Description (Continued)

\*Unless otherwise stated, inputs do not have internal pullup resistors. 8048AH, 8748H, 8049AH, 8050AH, 8040AHL

#### 12.3 PROGRAMMING, VERIFYING AND ERASING EPROM

The internal Program Memory of the 8748H and the 8749H may be erased and reprogrammed by the user as explained in the following sections. See also the 8748H and 8749H data sheets.

### 12.3.1 Programming/Verification

In brief, the programming process consists of: activating the program mode, applying an address, latching the address, applying data, and applying a programming pulse. This programming algorithm applies to both the 8748H and 8749H. Each word is programmed completely before moving on to the next and is followed by a verification step. The following is a list of the pins used for programming and a description of their functions:

| Pin             | Function                            |
|-----------------|-------------------------------------|
| XTAL 1          | Clock Input (3 to 4 MHz)            |
| Reset           | Initialization and Address Latching |
| Test 0          | Selection of Program (0V) or Verify |
|                 | (5V) Mode                           |
| EA              | Activation of Program/Verify Modes  |
| BUS             | Address and Data Input Data Output  |
|                 | During Verify                       |
| P20-1           | Address Input for 8748H             |
| P20-2           | Address Input for 8749H             |
| V <sub>DD</sub> | Programming Power Supply            |
| PROG            | Program Pulse Input                 |
| P10P11          | Tied to ground (8749H only)         |

#### 8748H AND 8749H ERASURE CHARACTERISTICS

The erasure characteristics of the 8748H and 8749H are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms (A). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the 3000–4000A range. Data show that constant exposure to room level fluorescent lighting could erase the typical 8748H and 8749H in approximately 3 years while it would take approximately 1 week to cause erasure when exposed to direct sunlight. If the 8748H or 8749H is to be exposed to these types of lighting conditions for extended periods of time, opaque labels should be placed over the 8748H window to prevent unintentional erasure.

When erased, bits of the 8748H and 8749H Program Memory are in the logic ''0'' state.

The recommended erasure procedure for the 8748H and 8749H is exposure to shortwave ultraviolet light which has a wavelength of 2537 Angstroms (A). The integrated dose (i.e., UV intensity X exposure time) for erasure should be a minimum of 15W-sec/cm<sup>2</sup>. The erasure time with this dosage is approximately 15 to 20 minutes using an ultraviolet lamp with a  $12000\mu$ W/cm<sup>2</sup> power rating. The 8748H and 8749H should be placed within one inch from the lamp tubes during erasure. Some lamps have a filter in their tubes and this filter should be removed before erasure.





12-19

. .

# Expanded MCS®-48 System

,

e Merene en la construcción de la c

# CHAPTER 13 EXPANDED MCS®-48 SYSTEM

#### **13.0 INTRODUCTION**

If the capabilities resident on the single-chip 8048AH/ 8748H/8035AHL/8049AH/8749H/8039AHL are not sufficient for your system requirements, special on-board circuitry allows the addition of a wide variety of external memory, I/O, or special peripherals you may require. The processors can be directly and simply expanded in the following areas:

- Program Memory to 4K words
- Data Memory to 320 words (384 words with 8049AH)
- I/O by unlimited amount
- Special Functions using 8080/8085AH peripherals

By using bank switching techniques, maximum capability is essentially unlimited. Bank switching is discussed later in the chapter. Expansion is accomplished in two ways:

- Expander I/O A special I/O Expander circuit, the 8243, provides for the addition of four 4-bit Input/ Output ports with the sacrifice of only the lower half (4-bits) of port 2 for inter-device communication. Multiple 8243's may be added to this 4-bit bus by generating the required "chip select" lines.
- 2) Standard 8085 Bus One port of the 8048AH/ 8049AH is like the 8-bit bidirectional data bus of the 8085 microcomputer system allowing interface to the numerous standard memories and peripherals of the MCS<sup>®</sup>-80/85 microcomputer family.

MCS-48 systems can be configured using either or both of these expansion features to optimize system capabilities to the application.

Both expander devices and standard memories and peripherals can be added in virtually any number and combination required.

#### 13.1 EXPANSION OF PROGRAM MEMORY

Program Memory is expanded beyond the resident 1K or 2K words by using the 8085 BUS feature of the MCS<sup>®</sup>-48. All program memory fetches from the addresses less than 1024 on the 8048AH and less than 2048 on the 8049AH occur internally with no external signals being generated (except ALE which is always present). At address 1024 on the 8048AH, the processor automatically initiates external program memory fetches.

#### 13.1.1 Instruction Fetch Cycle (External)

As shown in Figure 13-1, for all instruction fetches from addresses of 1024 (2048) or greater, the following will occur:

- 1) The contents of the 12-bit program counter will be output on BUS and the lower half of port 2.
- 2) Address Latch Enable (ALE) will indicate the time at which address is valid. The trailing edge of ALE is used to latch the address externally.
- Program Store Enable (PSEN) indicates that an external instruction fetch is in progress and serves to enable the external memory device.
- 4) BUS reverts to input (floating) mode and the processor accepts its 8-bit contents as an instruction word.



#### Figure 13-1. Instruction Fetch from External Program Memory

All instruction fetches, including internal addresses, can be forced to be external by activating the EA pin of the 8048AH/ 8049AH/8050AH. The 8035AHL/8039AHL/8040AHL processors without program memory always operate in the external program memory mode (EA = 5V).

#### 13.1.2 Extended Program Memory Addressing (Beyond 2K)

For programs of 2K words or less, the 8048AH/8049AH addresses program memory in the conventional manner. Addresses beyond 2047 can be reached by executing a program memory bank switch instruction (SEL MB0, SEL MB1) followed by a branch instruction (JMP or CALL). The bank switch feature extends the range of branch instructions beyond their normal 2K range and at the same time prevents the user from inadvertently crossing the 2K boundary.

#### **PROGRAM MEMORY BANK SWITCH**

The switching of 2K program memory banks is accomplished by directly setting or resetting the most significant bit of the program counter (bit 11); see Figure 13-2. Bit 11 is not altered by normal incrementing of the program counter but is loaded with the contents of a special flipflop each time a JMP or CALL instruction is executed. This special flip-flop is set by executing an SEL MB1 instruction and reset by SEL MB0. Therefore, the SEL MB instruction may be executed at any time prior to the actual bank switch which occurs during the next branch instruction encountered. Since all twelve bits of the program counter, including bit 11, are stored in the stack, when a Call is executed, the user may jump to subroutines across the 2K boundary and the proper bank will be restored upon return. However, the bank switch flip-flop will not be altered on return.



Figure 13-2. Program Counter

#### INTERRUPT ROUTINES

Interrupts always vector the program counter to location 3 or 7 in the first 2K bank, and bit 11 of the program

counter is held at "0" during the interrupt service routine. The end of the service routine is signalled by the execution of an RETR instruction. Interrupt service routines should therefore be contained entirely in the lower 2K words of program memory. The execution of a SEL MB0 or SEL MB1 instruction within an interrupt routine is not recommended since it will not alter PC11 while in the routine, but will change the internal flip-flop.

#### 13.1.3 Restoring I/O Port Information

Although the lower half of Port 2 is used to output the four most significant bits of address during an external program memory fetch, the I/O information is still outputed during certain portions of each machine cycle. I/O information is always present on Port 2's lower 4 bits at the rising edge of ALE and can be sampled or latched at this time.

#### **13.1.4 Expansion Examples**

Shown in Figure 13-3 is the addition of 2K words of program memory using an 2716A 2K x 8 ROM to give a total of 3K words of program memory. In this case no chip select decoding is required and PSEN enables the memory directly through the chip select input. If the system requires only 2K of program memory, the same configuration can be used with an 8035AHL substituted for the 8048AH. The 8049AH would provide 4K of program memory with the same configuration.



Figure 13-3. Expanding MCS®-48 Program Memory Using Standard Memory Products



Figure 13-4. External Program Memory Interface

Figure 13-4 shows how the 8755/8355 EPROM/ROM with I/O interfaces directly to the 8048AH without the need for an address latch. The 8755/8355 contains an internal 8-bit address latch eliminating the need for an 8212 latch. In addition to a 2K x 8 program memory, the 8755/8355 also contains 16 I/O lines addressable as two 8-bit ports. These ports are addressed as external RAM; therefore the  $\overline{RD}$  and  $\overline{WR}$  outputs of the 8048AH are required. See the following section on data memory expansion for more detail. The subsequent section on I/O expansion explains the operation of the 16 I/O lines.

#### **13.2 EXPANSION OF DATA MEMORY**

Data Memory is expanded beyond the resident 64 words by using the 8085AH type bus feature of the MCS<sup>®</sup>-48.

#### 13.2.1 Read/Write Cycle

All address and data is transferred over the 8 lines of BUS. As shown in Figure 13-5, a read or write cycle occurs as follows:



Figure 13-5. External Data Memory Timings

- 1) The contents of register R0 or R1 is outputed on BUS.
- 2) Address Latch Enable (ALE) indicates addresss is valid. The trailing edge of ALE is used to latch the address externally.
- 3) A read (RD) or write (WR) pulse on the corresponding output pins of the 8048AH indicates the type of data memory access in progress. Output data is valid at the trailing edge of WR and input data must be valid at the trailing edge of RD.
- 4) Dat (8 bits) is transferred in or out over BUS.

#### 13.2.2 Addressing External Data Memory

External Data Memory is accessed with its own two-cycle move instructions. MOVXA, @R and MOVX@R, A, which transfer 8 bits of data between the accumulator and the external memory location addressed by the contents of one of the RAM Pointer Registers R0 and R1. This allows 256 locations to be addressed in addition to the resident locations. Additional pages may be added by "bank switching" with extra output lines of the 8048AH.

#### 13.2.3 Examples of Data Memory Expansion

Figure 13-6 shows how the 8048AH can be expanded using the 8155 memory and I/O expanding device. Since the 8155 has an internal 8-bit address latch, it can interface directly to the 8048AH without the use of an external latch. The 8155 provides an additional 256 words of static data memory and also includes 22 I/O lines and a 14-bit timer. See the following section on I/O expansion and the 8155 data sheet for more details on these additional features.

#### 13.3 EXPANSION OF INPUT/OUTPUT

There are four possible modes of I/O expansion with the 8048AH: one using a special low-cost expander, the 8243; another using standard MCS-80/85 I/O devices; and a third using the combination memory I/O expander devices the 8155, 8355, and 8755. It is also possible to expand using standard TTL devices as shown in Chapter 5.

#### 13.3.1 I/O Expander Device

The most efficient means of I/O expansion for small systems is the 8243 I/O Expander Device which requires only 4 pot lines (lower half of Port 2) for communication with the 8048AH. The 8243 contains four 4-bit I/O ports which serve as an extension of the on-chip I/O and are addressed as ports #4-7 (see Figure 13-7). The following operations may be performed on these ports:

- Transfer Accumulator to Port
- Transfer Port to Accumulator
- AND Accumulator to Port
- OR Accumulator to Port

A 4-bit transfer from a port to the lower half of the Accumulator sets the most significant four bits to zero. All communication between the 8048AH and the 8243 occurs over Port 2 lower (P20–P23) with timing provided by an output pulse on the PROG pin of the processor. Each transfer consists of two 4-bit nibbles: The first containing the "op code" and port address, and the second containing the actual 4 bits of data.



Figure 13-6. 8048AH Interface to 256 x 8 Standard Memories

13-4



Figure 13-7. 8243 Expander I/O Interface



A high to low transition of the PROG line indicates that address is present, while allow to high transition indicates the presence of data. Additional 8243's may be added to the four-bit bus and chip selected using additional output lines from the 8048AH/8748H.

#### **I/O PORT CHARACTERISTICS**

Each of the four 4-bit ports of the 8243 can serve as either input or output and can provide high drive capability in both the high and low state.

#### 13.3.2 I/O Expansion with Standard Peripherals

Standard MCS-80/85 type I/O devices may be added to the MCS<sup>®</sup>-48 using the same bus and timing used for Data Memory expansion. Figure 13-8 shows an example of how an 8048AH can be connected to an MCS-85 peripheral. I/O devices reside on the Data Memory bus and in the data memory address space and are accessed with the same MOVX instructions. (See the previous section on data memory expansion for a description of timing.) The following are a few of the Standard MCS-80 devices which are very useful in MCS<sup>®</sup>-48 systems:

- 8214 Priority Interrupt Encoder
- 8251 Serial Communications Interface
- 8255 General Purpose Programmable I/O
- 8279 Keyboard/Display Interface
- 8253 Interval Timer

#### 13.3.3 Combination Memory and I/O Expanders

As mentioned in the sections on program and data memory expansion, the 8355/8755 and 8155 expanders also contain I/O capability.



Figure 13-8. Keyboard/Display Interface

**8355/8755:** These two parts of ROM and EPROM equivalents and therefore contain the same I/O structure. I/O consists of two 8-bit ports which normally reside in the external data memory address space and are accessed with MOVX instructions. Associated with each port is an 8-bit Data Direction Register which defines each bit in the port as either an input or an output. The data direction registers are directly addressable, thereby allowing the user to define under software control each individual bit of the ports as either input or output. All outputs are statically latched and double buffered. Inputs are not latched.

**8155/8156:** I/O on the 8155/8156 is configured as two 8-bit programmable I/O ports and one 6-bit programmable

port. These three registers and a Control/Status register are accessible as external data memory with the MOVX instructions. The contents of the control register determines the mode of the three ports. The ports can be programmed as input or output with or without associated handshake communication lines. In the handshake mode, lines of the six-bit port become input and output strobes for the two 8-bit ports. Also included in the 8155 is a 14-bit programmable timer. The clock input to the timer and the timer overflow output are available on external pins. The timer can be programmed to stop on terminal count or to continuously reload itself. A square wave or pulse output on terminal count can also be specified.



Figure 13-9. Low Cost I/O Expansion

#### **I/O EXPANSION EXAMPLES**

Figure 13-9 shows the expansion of I/O using multiple 8243's. The only difference from a single 8243 system is the addition of chip selects provided by additional 8048AH output lines. Two output liens and a decoder could also be used to address the four chips. Large numbers of 8243's would require a chip select decoder chip such as the 8205 to save I/O pins.

Figure 13-10 shows the 8048AH interface to a standard MCS<sup>®</sup>-80 peripheral; in this case, the 8255 Programmable Peripheral Interface, a 40-pin part which provides three 8-bit programmable I/O ports. The 8255 bus interface is typical of programmable MCS<sup>®</sup>-80 peripherals with an 8-bit bidirectional data bus, a RD and WR input for Read/Write control, a CS (chip select) input used to enable the Read/Write control logic and the address inputs used to select various internal registers.



Figure 13-10. Interface to MCS®-80 Peripherals

Interconnection to the 8048AH is very straightforward with BUS,  $\overline{RD}$ , and  $\overline{WR}$  connecting directly to the corresponding pins on the 8255. The only design consideration is the way in which the internal registers of the 8255 are to be addressed. If the registers are to be addressed as external data memory using the MOVX instructions, the appropriate number of address bits (in this case, 2) must be latched on BUS using ALE as described in the section on external data memories. If only a single device is connected to BUS, the 8255 may be continuously selected by grounding  $\overline{CS}$ . If multiple 8255's are used, additional address bits can be latched and used as chip selects.

A second addressing method eliminates external latches and chip select decoders by using output port lines as address and chip select lines directly. This method, of course, requires the setting of an output port with address information prior to executing a MOVX instruction.

#### 13.4 MULTI-CHIP MCS®-48 SYSTEMS

Figure 13-11 shows the addition of two memory expanders to the 8048AH, one 8355/8755 ROM and one 8156 RAM. The main consideration in designing such a system is the addressing of the various memories and I/O ports. Note that in this configuration address lines  $A_{10}$  and  $A_{11}$  have been O Red to chip select the 8355. This ensures that the chip is active for all external program memory fetches in the 1K to 3K range and is disabled for all other addresses. This gating has been added to allow the I/O port of the 8355 to be used. If the chip was left selected all the time, there would be conflict between these ports and the RAM and I/O of the 8156. The NOR gate could be eliminated and  $A_{11}$  connected directly to the CE (instead of CE) input of the 8355; however, this would create a 1K word "hole" in the program memory by causing the 8355 to be active in the 2K and 4K range instead of the normal 1K to 3K range.

In this system the various locations are addressed as follows:

- Data RAM Addresses 0 to 255 when Port 2 Bit 0 has been previously set = 1 and Bit 1 set = 0
- RAM I/O Addresses 0 to 3 when Port 2 Bit 0 = 1 and Bit 1 = 1
- ROM I/O Addresses 0 to 3 when Port 2 Bit 2 or Bit 3 = 1

See the memory map in Figure 13-12.



Figure 13-11. The Three-Component MCS®-48 System

#### 13.5 MEMORY BANK SWITCHING

Certain systems may require more than the 4K words of program memory which are directly addressable by the program counter or more than the 256 data memory and I/O locations directly addressable by the pointer registers R0 and R1. These systems can be achieved using "bank switching" techniques. Bank switching is merely the selection of various blocks of "banks" of memory using dedicated output port lines from the processor. In the case of the 8048AH, program memory is selected in blocks of 4K words at a time, while data memory and I/O are enabled 256 words at a time.

The most important consideration in implementing two or more banks is the software required to cross the bank boundaries. Each crossing of the boundary requires that the processor first write a control bit to an output port before accessing memory or I/O in the new bank. If program memory is being switched, programs should be organized to keep boundary crossings to a minimum. Jumping to subroutines across the boundary should be avoided when possible since the programmer must keep track of which bank to return to after completion of the subroutine. If these subroutines are to be nested and accessed from either bank, a software "stack" should be implemented to save the bank switch bit just as if it were another bit of the program counter.

From a hardware standpoint bank switching is very straightforward and involves only the connection of an I/O line or lines as bank enable signals. These enables are ANDed with normal memory and I/O chip select signals to activate the proper bank.

#### **13.6 CONTROL SIGNAL SUMMARY**

Table 13 summarizes the instructions which activate the various control outputs of the MCS®-48 processors. During all other instructions these outputs are driven to the active state.

| Control<br>Signal | When Active                                                                  |  |  |  |
|-------------------|------------------------------------------------------------------------------|--|--|--|
| RD                | During MOVX, A, @R or INS Bus                                                |  |  |  |
| WR                | During MOVX @R, A or OUTL Bus                                                |  |  |  |
| ALE               | Every Machine Cycle                                                          |  |  |  |
| PSEN              | During Fetch of external program mem-<br>ory (instruction or immediate data) |  |  |  |
| PROG              | During MOVD, A,P ANLD P,A MOVD<br>P,A ORLD P,A                               |  |  |  |

#### Table 13-1. MCS®-48 Control Signals

#### 13.7 PORT CHARACTERISTICS

#### 13.7 BUS Port Operations

The BUS port can operate in three different modes: as a latched I/O port, as a bidirectional bus port, or as a program memory address output when external memory is used. The BUS port lines are either active high, active low, or high impedance (floating). The latched mode (INS, OUTL) is intended for use in the single-chip configuration where BUS is not begin used as an expander port. OUTL and MOVX instructions can be mixed if necessary. However, a previously latched output will be destroyed by executing a MOVX instruction and BUS will be left in the high impedance state. INS does not put the BUS in a high impedance state. Therefore, the use of MOVX after OUTL to put the BUS in a high impedance state is necessary before an INS instruction intended to read an external word (as opposed to the previously latched value).

OUTL should never be used in a system with external program memory, since latching BUS can cause the nc instruction, if external, to be fetched improperly.

#### 13.7.2 Port 2 Operations

The lower half of Port 2 can be used in three different ways: as a quasi-bidirectional static port, as an 8243 expander port, and to adddress external program memory.



Figure 13-12. Memory Map for Three-Component MCS®-48 Family

In all cases outputs are driven low by an active device and driven high momentarily by a low impedance device and held high by a high impedance device to VCC.

The port may contain latched I/O data prior to its use in another mode without affecting operation of either. If lower Port 2 (P20-3) is used to output address for an external program memory fetch, the I/O information previously latched will be automatically removed temporarily while address is present, then retored when the fetch is complete. However, if lower Port 2 is used to communicate with an 8243, previously latched I/O information will be removed and not restored. After an input from the 8243, P20-3 will be left in the input mode (floating). After an output to the 8243, P20-3 will contain the value written, ANDed, or ORed to the 8243 port.



Figure 13-13. MCS®-48 Expansion Capability

# MCS<sup>®</sup>-48 Instruction Set

•

•

х х

## CHAPTER 14 MCS®-48 INSTRUCTION SET

#### **14.0 INTRODUCTION**

The MCS<sup>Φ</sup>-48 instruction set is extensive for a machine of its size and has been tailored to be straightforward and very efficient in its use of program memory. All instructions are either one or two bytes in length and over 80% are only one byte long. Also, all instructions execute in either one or two cycles and over 50% of all instructions execute in a single cycle. Double cycle instructions include all immediate instructions, and all I/O instructions.

The MCS-48 microcomputers have been designed to handle arithmetic operations efficiently in both binary and BCD as well as handle the single-bit operations required in control applications. Special instructions have also been included to simplify loop counters, table look-up routines, and N-way branch routines.

#### 14.0.1 Data Transfers

As can be seen in Figure 14.1, the 8-bit accumulator is the central point for all data transfers within the 8048. Data can be transferred between the 8 registers of each working register bank and the accumulator directly, i.e., the source or destination register is specified by the instruction. The remaining locations of the internal RAM array are referred to as Data Memory and are addressed indirectly via an address stored in either R0 or R1 of the active register bank. R0 and R1 are also used to indirecly address external data memory when it is present. Transfers to and from internal RAM require one cycle, while transfers to external RAM require two. Constants stored in Program Memory can be loaded directly to the accumulator and to the 8 working registers. Data can also be transferred directly between the accumulator and the on-



Figure 14-1. Data Transfer Instructions

board timer counter or the accumulator and the Program Status word (PSW). Writing to the PSW alters machine status accordingly and provides a means of restoring status after an interrupt or of altering the stack pointer if necessary.

#### 14.0.2 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.

In addition, the lower 4 bits of the accumulator can be exchanged with the lower 4-bits of any of the internal RAM locations. This instruction, along with an instruction which swaps the upper and lower 4-bit halves of the accumulator, provides for easy handling of 4-bit quantities, including BCD numbers. To facilitate BCD arithmetic, a Decimal Adjust instruction is 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 required BCD result.

Finally, 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.

Although there is no subtract instruction in the 8048AH, this operation can be easily implemented with three singlebyte single-cycle instructions.

A value may be subtracted from the accumulator with the result in the accumulator by:

- Complementing the accumulator
- Adding the value to the accumulator
- Complementing the accumulator

#### 14.0.3 Register Operations

The working registers can be accessed via the accumulator as explained above, or can be loaded immediate with constants from program memory. In addition, they can be incremented or decremented or used as loop counters using the decrement and jump, if not zero instruction, as explained under branch instructions.

All Data Memory including working registers can be accessed with indirect instructions via R0 and R1 and can be incremented.

#### 14.0.4 Flags

There are four user-accessible flags in the 8048AH: Carry, Auxiliary Carry, F0 and F1. Carry indicates overflow of the accumulator, and Auxiliary Carry is used to indiate overflow between BCD digits and is used during decimaladjust operation. Both Carry and Auxiliary Carry are accessible as part of the program status word and are stored on the stack during subroutines. F0 and F1 are undedicated general-purpose flags to be used as the programmer desires. Both flags can be cleared or complemented and tested by conditional jump instructions. F0 is also accessible via the Program Status word and is stored on the stack with the carry flags.

#### 14.0.5 Branch Instructions

The unconditional jump instruction is two bytes and allows jumps anywhere in the first 2K words of program memory. Jumps to the second 2K of memory (4K words are directly addressable) are made first by executing a select memory bank instruction, then executing the jump instruction. The 2K boundary can only be crossed via a jump or subroutine call instruction, i.e., the bank switch does not occur until a jump is executed. Once a memory bank has been selected all subsequent jumps will be to the selected bank until another select memory bank instruction is executed. A subroutine in the opposite bank can be accessed by a select memory bank instruction followed by a call instruction. Upon completion of the subroutine, execution will automatically return to the original bank; however, unless the original bank is reselected, the next jump instruction encountered will again transfer execution to the opposite bank.

Conditional jumps can test the following inputs and machine status:

- T0 Input Pin
- T1 Input Pin
- INT Input Pin
- Accumulator Zero
- Any bit of Accumulator
- Carry Flag
- F0 Flag
- F1 Flag

Conditional jumps allow a branch to any address within the current page (256 words) of execution. The conditions tested are the instantaneous values at the time the conditional jump is executed. For instance, the jump on accumulator zero instruction tests the accumulator itself, not an intermediate zero flag. The decrement register and jump if not zero instruction combines a decrement and a branch instruction to create an instruction very useful in implementing a loop counter. This instruction can designate any one of the 8 working registers as a counter and can effect a branch to any address within the current page of execution.

A single-byte indirect jump instruction 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 points to a location in program memory which contains the jump address. The 8-bit jump address refers to the current page of execution. This instruction could be used, for instance, to vector to any one of several routines based on an ASCII character which has been loaded in the accumulator. In this way ASCII key inputs can be used to initiate various routines.

#### 14.0.6 Subroutines

Subroutines are entered by executing a call instruction. Calls can be made like unconditional jumps to any address in a 2K word bank, and jumps across the 2K boundary are executed in the same manner. Two separate return instructions determine whether or not status (upper 4-bits of PSW) is restored upon return from the subroutine.

The return and restore status instruction also signals the end of an interrupt service routine if one has been in progress.

#### 14.0.7 Timer Instructions

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 an event counter or timer with an external clock applied to the T1 input 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.

#### **14.0.8 Control Instructions**

Two instructions allow the external interrupt source to be enabled or disabled. Interrupts are initially disabled and are automatically disabled while an interrupt service routines is in progress and re-enabled afterward.

There are four memory bank select instructions, two to designate the active working register bank and two to control program memory banks. The operation of the program memory bank switch is explained in section 13.1.2.

The working register bank switch instructions allow the programmer to immediately substitute a second 8-register working register bank for the one in use. This effectively provides 16 working registers or it can be used as a means of quickly saving the contents of the registers in response to an interrupt. The user has the option to switch or not to switch banks on interrupt. However, if the banks are switched, the original bank will be automatically restored upon execution of a return and restore status instruction at the end of the interrupt service routine.

A special instruction enables an internal clock, which is the XTAL frequency divided by three to be output on pin T0. This clock can be used as a general-purpose clock in the user's system. This instruction should be used only to initialize the system since the clock output can be disabled only by application of system reset.

#### 14.0.9. Input/Output Instructions

Ports 1 and 2 are 8-bit static I/O ports which can be loaded to and from the accumulator. Outputs are statically latched but inputs are not latched and must be read while inputs are present. In addition, immediate data from program memory can be ANDed or ORed directly to Port 1 and Port 2 with the result remaining on the port. This allows "masks" stored in program memory to selectively set or reset individual bits of the I/O ports. Ports 1 and 2 are configured to allow input on a given pin by first writing a "1" out to the pin.

An 8-bit port called BUS can also be accessed via the accumulator and can have statically latched outputs as well. It too can have immediate data ANDed or ORed directly to its outputs, however, unlike ports 1 and 2, all eight lines of BUS must be treated as either input or output at any one time. In addition to being a static port, BUS can be used as a true synchronous bi-directional port using the Move External instructions used to access external data memory. When these instructions are executed, a corresponding READ or WRITE pulse is generated and data is valid only at that time. When data is not being transferred, BUS is in a high impedance state. Note that the OUTL, ANL, and the ORL instructions for the BUS are for use with internal program memory only.

The basic three on-board I/O ports can be expanded via a 4-bit expander bus using half of port 2. I/O expander devices on this bus consist of four 4-bit ports which are addressed as ports 4 through 7. These 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 and OR instructions, however, combine the contents of accumulator with the selected port rather than immediate data as is done with the on-board ports. I/O devices can also be added externally using the BUS port as the expansion bus. In this case the I/O ports become "memory mapped", i.e., they are addressed in the same way as external data memory and exist in the external data memory address space addressed by pointer register R0 or R1.

#### **14.1 INSTRUCTION SET DESCRIPTION**

The following pages describe the MCS®-48 instruction set in detail. The instruction set is first summarized with instructions grouped functionally. This summary page is followed by a detailed description listed alphabetically by mnemonic opcode. The alphabetical listing includes the following information.

- Mnemonic
- Machine Code
- Verbal Description
- Symbolic Description
- Assembly Language Example

The machine code is represented with the most significant bit (7) to the left and two byte instructions are represented with the first byte on the left. The assembly language examples are formulated as follows:

Arbitrary

Label: Mnemonic, Operand; Descriptive Comment

#### 8048AH/8748H/8049AH/8050AH/8749H Instruction Set Summary

**Bytes** 

Cycles

| Mnemonic           | Description                     | Bytes | Cycle | Mnemonic ·    | Description                           |
|--------------------|---------------------------------|-------|-------|---------------|---------------------------------------|
| Accumulator        |                                 |       |       | Registers     |                                       |
| ADD A, R           | Add register to A               | 1     | 1     | INC R         | Increment register                    |
| ADD A, @R          | Add data memory to A            | 1     | 1     | INC @R        | Increment data memo                   |
| ADD A, # data      | Add immediate to A              | 2     | 2     | DEC R         | Decrement register                    |
| ADDC A, R          | Add register with carry         | 1     | 1     | Branch        |                                       |
| ADDC A,            | Add data memory<br>with carry   | 1     | 1     | JMP addr      | Jump unconditional                    |
| @R<br>ADDC A.      | Add immediate                   | 2     | 2     | JMPP @A       | Jump indirect                         |
| # data             | with carry                      | -     | -     | DJNZ R, addr  | Decrement register                    |
| ANLA, R            | And register to A               | 1     | 1     |               | and jump                              |
| ANL A, @R          | And data memory to A            | 1     | 1     | JC addr       | Jump on carry = 1                     |
| ANL A, # data      | And immediate to A              | 2     | 2     | JNC addr      | Jump on carry = 0                     |
| ORLA, R            | Or register to A                | 1     | 1     | JZ addr       | Jump on A Zero                        |
| ORL A @R           | Or data memory to A             | 1     | 1     | JNZ addr      | Jump on A not Zero                    |
| ORL A, # data      | Or immediate to A               | 2     | 2     | JT0 addr      | Jump on T0 = 1                        |
| XRLA, R            | Exclusive Or register           | 1     | 1     | JNT0 addr     | Jump on T0 = 0                        |
|                    | to A                            |       |       | JT1 addr      | Jump on T1 = 1                        |
| XRLA,@R            | Exclusive or data               | 1     | 1     | JNT1 addr     | Jump on T1 = 0                        |
|                    | memory to A                     |       |       | JF0 addr      | Jump on F0 = 1                        |
| XRL, A, # data     | Exclusive or<br>immediate to A  | 2     | 2     | JF1 addr      | Jump on F1 = 1                        |
|                    | Increment A                     | 1     | 1     | JTF addr      | Jump on timer flag =                  |
| DECA               | Decrement A                     | 1     |       | JNI addr      | Jump on INT = 0                       |
| CLRA               | Clear A                         | 1     |       | JBb addr      | Jump on Accumulato                    |
| CPL A              | Complement A                    | 1     | 1     |               | Bit                                   |
|                    | Decimal adjust A                | 1     | 1     | Subroutine    |                                       |
| SWAP A             | Swap nibbles of A               | i     | 1     | CALL addr     | Jump to subroutine                    |
| RLA                | Rotate A left                   |       | 1     | RET           | Return                                |
| RLCA               | Rotate A left                   | 1     | 1     | RETR          | Return and restore                    |
|                    | through carry                   | 1     | 1     |               | status                                |
| RR A               | Rotate A right                  |       |       | Flags         |                                       |
| RRC A              | Rotate A right<br>through carry |       | 1     | CLR C         | Clear Carry                           |
|                    |                                 |       |       | CPL C         | Complement Carry                      |
| Input/Output       |                                 |       |       | CLR F0        | Clear Flag 0                          |
| IN A, P            | Input port to A                 | 1     | 2     | CPL F0        | Complement Flag 0                     |
| OUTL P, A          | Output A to port                | 1     | 2     | CLR F1        | Clear Flag 1                          |
| ANL P, # data      | And immediate to port           | 2     | 2     | CPL F1        | Complement Flag 1                     |
| ORL P, # data      | Or immediate to port            | 2     | 2     |               | Complement hag i                      |
| INS A, BUS         | Input BUS to A                  | 1     | 2     | Data Moves    |                                       |
| OUTL BUS, A        | Output A to BUS                 | 1     | 2     | MOV A. R      | Move register to A                    |
| ANL BUS,<br># data | And immediate to BUS            | 2     | 2     | MOV A, @R     | Move data memory to A                 |
| ORL BUS,           | Or immediate to BUS             | 2     | 2     | MOV A, # data |                                       |
| # data             |                                 |       |       | MOV R, A      | Move A to register                    |
| MOVD A, P          | Input Expander port<br>to A     | 1     | 2     | MOV @R, A     | Move A to data<br>memory              |
| MOVD P, A          | Output A to Expander<br>port    | 1     | 2     | MOV R, # data | · · · · · · · · · · · · · · · · · · · |
| ANLD P, A          | And A to Expander port          | 1     | 2     | MOV @R,       | Move immediate to                     |
| ORLD P, A          | Or A to Expander port           | 1     | 2     | # data        | data memory                           |
|                    |                                 |       |       | MOV A, PSW    | Move PSW to A                         |
|                    |                                 |       |       | MOV PSW, A    | Move A to PSW                         |

Mnemonics copyright Intel Corporation 1983.

\*For use with internal memory only.

8048AH/8748H/8049AH/8050AH/8749H Instruction Set Summary (Con't)

| Mnemonic      | Description                                                                                                      | Bytes | Cycle |
|---------------|------------------------------------------------------------------------------------------------------------------|-------|-------|
| Data Moves    |                                                                                                                  |       |       |
| (Conťd)       | and the second |       |       |
| XCH A, R      | Exchange A and<br>register                                                                                       | 1     | 1     |
| XCH A, @R     | Exchange A and data memory                                                                                       | 1     | 1     |
| XCHD A, @R    | Exchange nibble of A and register                                                                                | 1     | 1     |
| MOVX A, @R    | Move external data<br>memory to A                                                                                | 1     | 2     |
| MOVX @R, A    | Move A to external data memory                                                                                   | 1     | 2     |
| MOVP A, @A    | Move to A from<br>current page                                                                                   | 1     | 2     |
| MOVP3 A, @A   | Move to A from Page 3                                                                                            | 1     | 2     |
| Timer/Counter |                                                                                                                  |       |       |
| 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     | Stop Timer/Counter                                                                                               | 1     | 1     |
| EN TCNTI      | Enable Timer/Counter<br>Interrupt                                                                                | 1     | 1     |
| DIS TCNTI     | Disable Timer/Counter<br>Interrupt                                                                               | 1,    | 1     |

| Mnemonic | Description                   | Bytes | Cycle |
|----------|-------------------------------|-------|-------|
| Control  |                               | 1     |       |
| EN I     | Enable external<br>Interrupt  | 1     | 1     |
| DISI     | Disable external<br>Interrupt | 1     | 1     |
| SEL RB0  | Select register bank 0        | 1     | 1     |
| SEL RB1  | Select register bank 1        | 1     | 1     |
| SEL MB0  | Select memory bank 0          | 1     | 1     |
| SEL MB1  | Select memory bank 1          | 1     | 1     |
| ENT0 CLK | Enable clock output<br>on T0  | .1    | 1     |
| NOP      | No Operation                  | 1     | 1     |

Mnemonics copyright Intel Corporation 1983.

14-6

### **MCS®-48 INSTRUCTION SET** Symbols and Abbreviations Used

| A<br>AC<br>addr<br>Bb<br>BS<br>BUS<br>C<br>CLK | Accumulator<br>Auxiliary Carry<br>12-Bit Program Memory Address<br>Bit Designator (b = 0-7)<br>Bank Switch<br>BUS Port<br>Carry<br>Clock |
|------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| CNT                                            | Event Counter                                                                                                                            |
| CRR<br>D                                       | Conversion Result Register<br>Mnemonic for 4-Bit Digit (Nibble)                                                                          |
| data                                           | 8-Bit Number or Expression                                                                                                               |
| DBF                                            | Memory Bank Flip-Flop                                                                                                                    |
| F0, F1                                         | Flag 0, Flag 1                                                                                                                           |
| 1                                              | Interrupt                                                                                                                                |
| Ρ                                              | Mnemonic for "in-page" Operation                                                                                                         |
| PC                                             | Program Counter                                                                                                                          |
| Рр                                             | Port Designator (p = 1, 2 or 4-7)                                                                                                        |
| PSW                                            | Program Status Word                                                                                                                      |
| Ri                                             | Data memory Pointer (i = 0, or 1)                                                                                                        |
| Rr                                             | Register Designator (r = 0-7)                                                                                                            |
| SP /                                           | Stack Pointer                                                                                                                            |
| T                                              | Timer                                                                                                                                    |
| TF                                             | Timer Flag                                                                                                                               |
| T0, T1                                         | lest 0, lest 1                                                                                                                           |
| X                                              | Mnemonic for External RAM                                                                                                                |
| #                                              | Immediate Data Prefix                                                                                                                    |
| @<br>\$                                        | Indirect Address Prefix                                                                                                                  |
|                                                | Current Value of Program Counter                                                                                                         |
| (X)                                            | Contents of X                                                                                                                            |
| ((X))<br>←                                     | Contents of Location Addressed by X<br>Is Replaced by                                                                                    |

1

Mnemonics copyright Intel Corporation 1983.

| ADD A,R <sub>r</sub> A  | dd Register Contents to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Accumula                        | tor                                                                                       |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|-------------------------------------------------------------------------------------------|
| Encoding:               | 0110 1 r r r                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 68H-6FH                         |                                                                                           |
| Description:            | The contents of registe affected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | r 'r' are ad                    | ded to the accumulator. Carry is                                                          |
| <b>Operation:</b>       | (́A) ← (A) + (Rr)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                 | r = 0-7                                                                                   |
| Example:                | ADDREG: ADD A,R6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                 | ;ADD REG 6 CONTENTS<br>;TO ACC                                                            |
| ADD A,@R <sub>i</sub> A | dd Data Memory Conte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | nts to Acc                      | umulator                                                                                  |
| Encoding;               | 0110000i                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 60H-61H                         |                                                                                           |
| Description:            | The contents of the residue of the residue of the the second seco | dent data r<br>accumulato       | nemory location addressed by register 'i' bits<br>or. Carry is affected.                  |
| Operation:              | (A) ← (A) + ((Ri))                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                 | i = 0-1                                                                                   |
| Example:                | ADDM: MOV R0, #01FI<br>ADD A, @R0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | H                               | ;MOVE '1F' HEX TO REG 0<br>;ADD VALUE OF LOCATION<br>;31 TO ACC                           |
| ADD A,#data             | Add Immediate Data to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | o Accumul                       | ator                                                                                      |
| Encoding:               | 00000011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | d <sub>7</sub> d <sub>6</sub> d | 5 d <sub>4</sub> d <sub>3</sub> d <sub>2</sub> d <sub>1</sub> d <sub>0</sub> 03H          |
| Description:            | This is a 2-cycle instruc<br>Carry is affected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ction. The                      | specified data is added to the accumulator                                                |
| <b>Operation:</b>       | (A) ← (A) + data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                 |                                                                                           |
| Example:                | ADDID: ADD A,#ADDE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ER:                             | ;ADD VALUE OF SYMBOL<br>;ADDER' TO ACC                                                    |
| ADDC A,R <sub>r</sub>   | Add Carry and Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Contents                        | to Accumulator                                                                            |
| Encoding:               | 0111 1 r r r                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 78H-7FH                         | · · ·                                                                                     |
| Description:            | The content of the carr<br>bit cleared. The conten<br>Carry is affected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | y bit is add<br>ts of regis     | led to accumulator location 0 and the carry<br>ter 'r' are then added to the accumulator. |
| Operation:              | (A) ← (A) + (Rr) + (C)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ,                               | r = 0–7                                                                                   |
| Example:                | ADDRGC: ADDC A,R4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                 | ADD CARRY AND REG 4                                                                       |
| . *                     | * 0–5 in 8048AH/8748H<br>0–6 in 8049AH/8749H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                 |                                                                                           |

0-7 in 8050AH

,

.

| ADDC A,@R <sub>i</sub> Add Carry and Data Memory Contents to Accumulator |                                                                                                                                                                                                   |                                                                                                                              |  |
|--------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--|
| Encoding:                                                                | 0 1 1 1 0 0 0 i 70H-71H                                                                                                                                                                           |                                                                                                                              |  |
| Description:                                                             | cleared. Then the contents of the                                                                                                                                                                 | ed to accumulator location 0 and the carry bi resident data memory location addressed by the accumulator. Carry is affected. |  |
| Operation:                                                               | (A) ← (A) + ((Ri)) + (C)                                                                                                                                                                          | i = 0-1                                                                                                                      |  |
| Example:                                                                 | ADDMC: MOV R1,#40<br>ADDC A,@R1                                                                                                                                                                   | ;MOVE '40' DEC TO REG 1<br>;ADD CARRY AND LOCATION 40<br>;CONTENTS TO ACC                                                    |  |
| ADDC A,@data Add Carry and Immediate Data to Accumulator                 |                                                                                                                                                                                                   |                                                                                                                              |  |
| Encoding:                                                                | 0 0 0 1 0 0 1 1 d <sub>7</sub> d <sub>6</sub> c                                                                                                                                                   | $d_5 d_4 d_3 d_2 d_1 d_0$ 13H                                                                                                |  |
| Description:                                                             | This is a 2-cycle instruction. The content of the carry bit is added to accumulator location 0 and the carry bit cleared. Then the specified data is added to the accumulator. Carry is affected. |                                                                                                                              |  |
| <b>Operation:</b>                                                        | (A) ← (A) + data + (C)                                                                                                                                                                            |                                                                                                                              |  |
| Example:                                                                 | ADDC A,#225                                                                                                                                                                                       | ;ADD CARRY AND '225' DEC<br>;TO ACC                                                                                          |  |
| ANL A,R <sub>r</sub> Lo                                                  | gical AND Accumulator with Reg                                                                                                                                                                    | ister Mask                                                                                                                   |  |
| Encoding:                                                                | 0 1 0 1 1 r r r 58H-5FH                                                                                                                                                                           | · · ·                                                                                                                        |  |
| Description:                                                             | Data in the accumulator is logically ANDed with the mask contained in working register 'r'.                                                                                                       |                                                                                                                              |  |
| Operation:                                                               | (A) ← (A) AND (Rr)                                                                                                                                                                                | r = 0-7                                                                                                                      |  |
| Example:                                                                 | ANDREG: ANL A,R3                                                                                                                                                                                  | ;'AND' ACC CONTENTS WITH MASK<br>;IN REG 3                                                                                   |  |
|                                                                          | ANL A,@R <sub>i</sub> Logical AND Accumulator with memory Mask                                                                                                                                    |                                                                                                                              |  |
| ANL A,@R <sub>i</sub>                                                    | Logical AND Accumulator with m                                                                                                                                                                    | emory Mask                                                                                                                   |  |
|                                                                          | Logical AND Accumulator with m                                                                                                                                                                    |                                                                                                                              |  |
| Encoding:                                                                | 0 1 0 1 0 0 0 i 50H-51H                                                                                                                                                                           | H<br>Ily ANDed with the mask contained in the                                                                                |  |
| Encoding:<br>Description:                                                | 0 1 0 1 0 0 0 i 50H-51H<br>Data in the accumulator is logica                                                                                                                                      | H<br>Ily ANDed with the mask contained in the                                                                                |  |
| Encoding:<br>Description:<br>Operation:                                  | 0 1 0 1 0 0 0 i 50H-51H<br>Data in the accumulator is logica<br>data memory location referenced                                                                                                   | H<br>Ily ANDed with the mask contained in the<br>d by register 'i' bits 0-5**.                                               |  |

|                          | Logical AND Accumulator with                                                           | mmediate Mask                                                                                                                        |
|--------------------------|----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Encoding:                | 01010011 d <sub>7</sub> d <sub>6</sub> d                                               | <sup>1</sup> 5 d <sub>4</sub> d <sub>3</sub> d <sub>2</sub> d <sub>1</sub> d <sub>0</sub> 53H                                        |
| Description:             | This is a 2-cycle instruction. Dat<br>with an immediately-specified m                  | a in the accumulator is logically ANDed ask.                                                                                         |
| <b>Operation:</b>        | (A) ← (A) AND data                                                                     |                                                                                                                                      |
| Examples:                | ANDID: ANL A,#0AFH                                                                     | ;'AND' ACC CONTENTS<br>;WITH MASK 10101111                                                                                           |
|                          | ANL A,#3 + X/Y                                                                         | ;'AND' ACC CONTENTS<br>;WITH VALUE OF EXP                                                                                            |
|                          |                                                                                        | ;'3 + XY/Y'                                                                                                                          |
|                          |                                                                                        | nmediate Mask                                                                                                                        |
| ANL BUS,#da<br>Encoding: |                                                                                        |                                                                                                                                      |
| Encoding:                | 1 0 0 1 1 0 0 0 d <sub>7</sub> d <sub>6</sub> d<br>This is a 2-cycle instruction. Dat  | <b>Amediate Mask</b><br>$d_5 d_4 d_3 d_2 d_1 d_0$ 98H<br>a on the BUS port is logically ANDed<br>ask. This instruction assumes prior |
| Description:             | 1 0 0 11 0 0 0d7 d6 dThis is a 2-cycle instruction. Datwith an immediately-specified m | <b>Amediate Mask</b><br>$d_5 d_4 d_3 d_2 d_1 d_0$ 98H<br>a on the BUS port is logically ANDed<br>ask. This instruction assumes prior |

| Encoding:         | 1001 10pp                                          | $d_7 d_6 d_5 d_4 d_3 d_2 d_1 d_0$ 99                       | 9H-9AH    |
|-------------------|----------------------------------------------------|------------------------------------------------------------|-----------|
| Description:      | This is a 2-cycle instruct immediately-specified m | on. Data on port 'p' is logically ANDec<br>ask.            | d with an |
| <b>Operation:</b> | (Pp) ← (Pp) AND DATA                               | p = 1-2                                                    |           |
| Example:          | ANDP2: ANL P2,#0F0H                                | ;'AND' PORT 2 CONTENTS<br>;WITH MASK ' <del>F</del> 0' HEX | 3         |

;(CLEAR P20-23)

\* For use with internal program memory ONLY.

#### ANLD Pp.A Logical AND Port 4-7 with Accumulator Mask Encoding: 1001111pp 9CH-9FH Description: This is a 2-cycle instruction. Data on port 'p' is logically ANDed with the digit mask contained in accumulator bits 0-3. **Operation:** (Pp) ← (Pp) AND (A0-3) p = 4 - 7Note: The mapping of port 'p' to opcode bits 0-1 is as follows: 10 Port 0.0 4 01 5 10 6 11 7 Example: ANDP4: ANLD P4,A :'AND' PORT 4 CONTENTS ;WITH ACC BITS 0-3

#### CALL address Subroutine Call

| Encoding: a <sub>10</sub> a <sub>9</sub> a <sub>8</sub> | 1 0 1 0 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> |
|---------------------------------------------------------|---------------|-------------------------------|-------------------------------|-------------------------------|-------------------------------|
| Pag                                                     | e Hex Op Code | _                             |                               |                               |                               |
| 0                                                       | 14            |                               |                               |                               |                               |
| 1                                                       | 34            |                               | ·                             |                               |                               |
| 2                                                       | 54            |                               |                               |                               |                               |
| 3                                                       | 74            |                               |                               |                               |                               |
| 4                                                       | 94            |                               |                               |                               |                               |
| 5                                                       | B4            |                               |                               |                               |                               |
| 6                                                       | D4            |                               |                               |                               |                               |
| 7                                                       | F4            |                               |                               |                               |                               |

**Description:** 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'. PC bit 11 is determined by the most recent SEL MB instruction.

A CALL cannot begin in locations 2046-2047 or 4094-4095. Execution continues at the instruction following the CALL upon return from the subroutine.

**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<br>;REG 0 |
|---------|-------------|-------------------------------------|
| BEGADD: | MOV Á,R1    | ;MOVE CONTENTS OF REG 1<br>;TO ACC  |
| *       | ADD A,R2    | ;ADD REG 2 TO ACC                   |
|         | CALL SUBTOT | ;CALL SUBROUTINE 'SUBTOT'           |
|         | ADDC A R3   | ;ADD REG 3 TO ACC                   |
|         | ADDC A,R4   | ;ADD REG 4 TO ACC                   |
|         | CALL SUBTOT | ;CALL SUBROUTINE 'SUBTOT'           |
|         | ADDC A,R5   | ;ADD REG 5 TO ACC                   |
|         | ADDC 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

|           | r |   |   |   |   |   |   |   |     |
|-----------|---|---|---|---|---|---|---|---|-----|
| Encoding: | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 27H |

**Description:** The contents of the accumulator are cleared to zero.

**Operation:** A ← 0

## CLR C Clear Carry Bit

|              | 1 0 0 1 0 1 1 1 97H                                                                                                                                                     |  |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Description: | During normal program execution, the carry bit can be set to one by the ADD, ADDC, RLC, CPL C, RRC, and DAA insructions. This instruction resets the carry bit to zero. |  |
| Operation:   | C ← 0                                                                                                                                                                   |  |
|              |                                                                                                                                                                         |  |
| CLR F1 Clea  | ar Flag 1                                                                                                                                                               |  |
|              | ar Flag 1<br>10100101 A5H                                                                                                                                               |  |
| Encoding:    |                                                                                                                                                                         |  |

,

1

# CLR F0 Clear Flag 0

| Encoding    | 1 0 0 0 0 1 0 1 85H                                                                                                                |
|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Descriptior | : Flag 0 is cleared to zero.                                                                                                       |
| Operatior   | i: (F0) ← 0                                                                                                                        |
| CPL A Co    | nplement Accumulator                                                                                                               |
| Encoding    | r: 0 0 1 1 0 1 1 1 37H                                                                                                             |
| Descriptior | The contents of the accumulator are complemented. This is strictly a one's complement. Each one is changed to zero and vice-versa. |
| Operation   | I: (A) ← NOT (A)                                                                                                                   |
| Example     | Assume accumulator contains 01101010.<br>CPLA: CPLA ;ACC CONTENTS ARE COMPLE-<br>;MENTED TO 10010101                               |
| CPL C Co    | mplement Carry Bit                                                                                                                 |
| Encoding    | r 10100111 A7H                                                                                                                     |
|             | <ul> <li>The setting of the carry bit is complemented; one is changed to zero, and zero is changed to one.</li> </ul>              |
| Operatior   | :: (C) ← NOT (C)                                                                                                                   |
| Example     | E: Set C to one; current setting is unknown.<br>CTO1: CLR C ;C IS CLEARED TO ZERO<br>CPL C ;C IS SET TO ONE                        |
| CPL F0 Co   | omplement Flag 0                                                                                                                   |
| Encoding    | : 1 0 0 1 0 1 0 1 95H                                                                                                              |
| Descriptior | The setting of flag 0 is complemented; one is changed to zero, and zero is changed to one.                                         |
| Operatior   | : F0 ← NOT (F0)                                                                                                                    |
| CPL F1 Co   | omplement Flag 1                                                                                                                   |
| Encoding    | 10110101 B5H                                                                                                                       |
| Description | <ul> <li>The setting of flag 1 is complemented; one is changed to zero, and zero is changed to one.</li> </ul>                     |
| Operation   | : (F1) ← NOT (F1)                                                                                                                  |

| Encoding:                                                                                                                                                    | 0 1 0 1 0 1 1 1 57H                                                                                                                                                                                                                                                                        |                                                                                                                 |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Description:                                                                                                                                                 | The 8-bit accumulator value is adjusted to form two 4-bit Binary Coded<br>Decimal (BCD) digits following the binary addition of BCD numbers.<br>The carry bit C is affected. If the contents of bits 0-3 are greater than nine,<br>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. |                                                                                                                                                                                                                                                                                            |                                                                                                                 |  |  |  |  |
| Example:                                                                                                                                                     | Assume accumulator contains 10<br>DA A                                                                                                                                                                                                                                                     | 011011.<br>;ACC Adjusted to 00000001<br>;WITH C SET                                                             |  |  |  |  |
|                                                                                                                                                              | C AC 7 4 3 0<br>0 0 1 0 0 1 1 0 1 1                                                                                                                                                                                                                                                        |                                                                                                                 |  |  |  |  |
| Ţ                                                                                                                                                            | 00000110                                                                                                                                                                                                                                                                                   | ADD SIX TO BITS 0-7                                                                                             |  |  |  |  |
|                                                                                                                                                              | 0 1 10100001                                                                                                                                                                                                                                                                               |                                                                                                                 |  |  |  |  |
|                                                                                                                                                              | 0110<br>100000001                                                                                                                                                                                                                                                                          | ADD SIX TO BITS 4-7<br>OVERFLOW TO C                                                                            |  |  |  |  |
|                                                                                                                                                              |                                                                                                                                                                                                                                                                                            |                                                                                                                 |  |  |  |  |
| DEC A Decr                                                                                                                                                   | ement Accumulator                                                                                                                                                                                                                                                                          | and the second second second and a second |  |  |  |  |
| Encoding:                                                                                                                                                    | 00000111 07H                                                                                                                                                                                                                                                                               | ·                                                                                                               |  |  |  |  |
| Description:                                                                                                                                                 | The contents of the accumulator are decremented by one. The carry flag is not affected.                                                                                                                                                                                                    |                                                                                                                 |  |  |  |  |
| <b>Operation:</b>                                                                                                                                            | (A) ← (A) -1                                                                                                                                                                                                                                                                               |                                                                                                                 |  |  |  |  |
| Example:                                                                                                                                                     | Decrement contents of external d<br>MOV R0,#3FH<br>MOVX A, @R0<br>DEC A                                                                                                                                                                                                                    | ;MOVE '3F' HEX TO REG 0<br>;MOVE CONTENTS OF<br>;LOCATION 63 TO ACC<br>;DECREMENT ACC                           |  |  |  |  |
|                                                                                                                                                              | MOVX @R0,A                                                                                                                                                                                                                                                                                 | ;MOVE CONTENTS OF ACC TO<br>:LOCATION 63 IN EXPANDED                                                            |  |  |  |  |

| Encoding:           | 1100 1 r r r C8H-CF              | н                            |
|---------------------|----------------------------------|------------------------------|
| <b>Description:</b> | The contents of working register | 'r' are decremented by one.  |
| <b>Operation:</b>   | (Rr) ← (Rr) -1°                  | r = 0-7                      |
| Example:            | DECR1: DEC R1                    | ;DECREMENT CONTENTS OF REG 1 |

. . . . . .

## DIS I External Interrupt

| Encoding:                 | 0 0 0 1 0 1 0 1 15H                                                                                                                               | · · · ·                                                                                                  |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| Description:              | External interrupts are disabled. A no effect.                                                                                                    | low signal on the interrupt input pin has                                                                |
|                           |                                                                                                                                                   |                                                                                                          |
| DIS TCNTI                 | Disable Timer/Counter Interrupt                                                                                                                   | X et                                                                                                     |
| Encoding:                 | 001101035H                                                                                                                                        |                                                                                                          |
| Description:              |                                                                                                                                                   | led. Any pending timer interrupt request<br>is not initiated by an overflow, but the<br>ation continues. |
| DJNZ R <sub>r</sub> , add | ress Decrement Register and Tes                                                                                                                   | t s                                                                                                      |
| Encoding:                 | 1 1 1 0 1 r r r 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> E8H-EFH                       |
| Description:              |                                                                                                                                                   | ter 'r' is decremented, then tested for ros, program control falls through to the                        |
|                           |                                                                                                                                                   | ntents are not zero, control jumps to the                                                                |
| ,                         | The address in this case must eval to a location within the current 256                                                                           | uate to 8-bits, that is, the jump must be<br>6-location page.                                            |
| Example:                  | (Rr) ← (Rr) -1<br>If Rr not 0                                                                                                                     | r = 0-7                                                                                                  |
|                           | (PC <sub>0-7</sub> )   ← addr                                                                                                                     |                                                                                                          |
|                           | Note: A 12-bit address specification<br>DJNZ instruction and the jump tar<br>instruction begins in location 255<br>address on the following page. | get are on the same page. If the DJNZ                                                                    |
| Example:                  | Increment values in data memory                                                                                                                   |                                                                                                          |
|                           |                                                                                                                                                   | MOVE '50' DEC TO ADDRESS                                                                                 |
| · · ·                     | •                                                                                                                                                 | MOVE '5' DEC TO COUNTER                                                                                  |
|                           | INCRT: INC @R0                                                                                                                                    | REG 3<br>INCREMENT CONTENTS OF<br>LOCATION ADDRESSED BY                                                  |
|                           |                                                                                                                                                   | REG 0<br>INCREMENT ADDRESS IN REG 0                                                                      |
|                           | DJNZ R3, INCRT                                                                                                                                    | DECREMENT REG 3 — JUMP TO                                                                                |
| ,                         | NEXT —                                                                                                                                            | 'INCRT' IF REG 3 NONZERO<br>('NEXT' ROUTINE EXECUTED<br>(IF R3 IS ZERO                                   |
|                           |                                                                                                                                                   |                                                                                                          |

| NI Enable                               |                                                                                                                                                                                                                                                                                                                  |
|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                         | External Interrupt                                                                                                                                                                                                                                                                                               |
| Encoding:                               | 000000101                                                                                                                                                                                                                                                                                                        |
| -                                       | External interrupts are enabled. A low signal on the interrupt input pin                                                                                                                                                                                                                                         |
|                                         | initiates the interrupt sequence.                                                                                                                                                                                                                                                                                |
| N TCNTI E                               | nable Timer/Counter Interrupt                                                                                                                                                                                                                                                                                    |
| Encoding:                               | 0 0 1 0 0 1 0 1 25H                                                                                                                                                                                                                                                                                              |
| Description:                            | Timer/counter interrupts are enabled. An overflow of the timer/counter initiates the interrupt sequence.                                                                                                                                                                                                         |
| NTO CLK E                               | nable Clock Output                                                                                                                                                                                                                                                                                               |
| Encoding:                               | 0 1 1 1 0 1 0 1 75H                                                                                                                                                                                                                                                                                              |
| Description:                            | The test 0 pin is enabled to act as the clock output. This function is disabled by a system reset.                                                                                                                                                                                                               |
| Example:                                | EMTST0: ENT0 CLK ;ENABLE T0 AS CLOCK OUTPUT                                                                                                                                                                                                                                                                      |
| N A,Pp Inpu                             | It Port or Data to Accumulator                                                                                                                                                                                                                                                                                   |
|                                         |                                                                                                                                                                                                                                                                                                                  |
| Encoding:                               |                                                                                                                                                                                                                                                                                                                  |
| Description:                            | This is a 2-cycle instruction. Data present on port 'p' is transferred (read) to the accumulator.                                                                                                                                                                                                                |
|                                         |                                                                                                                                                                                                                                                                                                                  |
|                                         |                                                                                                                                                                                                                                                                                                                  |
| Operation:                              | (A) ← (Pp) p = 1-2                                                                                                                                                                                                                                                                                               |
| Operation:                              |                                                                                                                                                                                                                                                                                                                  |
| Operation:                              | (A) ← (Pp)       p = 1-2         INP12: IN A,P1       ;INPUT PORT 1 CONTENTS TO ACC         MOV R6,A       ;MOVE ACC CONTENTS TO REG 6                                                                                                                                                                           |
| Operation:                              | (A) ← (Pp)p = 1-2INP12: IN A,P1;INPUT PORT 1 CONTENTS TO ACCMOV R6,A;MOVE ACC CONTENTS TO REG 6IN A,P2;INPUT PORT 2 CONTENTS TO ACC                                                                                                                                                                              |
| Operation:                              | (A) ← (Pp)       p = 1-2         INP12: IN A,P1       ;INPUT PORT 1 CONTENTS TO ACC         MOV R6,A       ;MOVE ACC CONTENTS TO REG 6                                                                                                                                                                           |
|                                         | (A) ← (Pp)p = 1-2INP12: IN A,P1;INPUT PORT 1 CONTENTS TO ACCMOV R6,A;MOVE ACC CONTENTS TO REG 6IN A,P2;INPUT PORT 2 CONTENTS TO ACC                                                                                                                                                                              |
|                                         | (A) ← (Pp)p = 1-2INP12: IN A,P1;INPUT PORT 1 CONTENTS TO ACCMOV R6,A;MOVE ACC CONTENTS TO REG 6IN A,P2;INPUT PORT 2 CONTENTS TO ACCMOV R7,A;MOVE ACC CONTENTS TO REG 7                                                                                                                                           |
| NC A Incre<br>Encoding:                 | (A) ← (Pp) p = 1-2<br>INP12: IN A,P1 ;INPUT PORT 1 CONTENTS TO ACC<br>MOV R6,A ;MOVE ACC CONTENTS TO REG 6<br>IN A,P2 ;INPUT PORT 2 CONTENTS TO ACC<br>MOV R7,A ;MOVE ACC CONTENTS TO REG 7<br>ment Accumulator                                                                                                  |
| NC A Incre<br>Encoding:<br>Description: | $(A) \leftarrow (Pp)$ $p = 1-2$ INP12: IN A,P1;INPUT PORT 1 CONTENTS TO ACCMOV R6,A;MOVE ACC CONTENTS TO REG 6IN A,P2;INPUT PORT 2 CONTENTS TO ACCMOV R7,A;MOVE ACC CONTENTS TO REG 7ment Accumulator $0 \ 0 \ 1 \ 0 \ 1 \ 1 \ 1$ 17HThe contents of the accumulator are incremented by one. Carry is not        |
| NC A Incre<br>Encoding:<br>Description: | $(A) \leftarrow (Pp)$ $p = 1-2$ INP12: IN A,P1;INPUT PORT 1 CONTENTS TO ACCMOV R6,A;MOVE ACC CONTENTS TO REG 6IN A,P2;INPUT PORT 2 CONTENTS TO ACCMOV R7,A;MOVE ACC CONTENTS TO REG 7ment Accumulator $0 \ 0 \ 1 \ 0 \ 1 \ 1 \ 1$ The contents of the accumulator are incremented by one. Carry is not affected. |
| NC A Incre<br>Encoding:<br>Description: | $(A) \leftarrow (Pp)$ $p = 1-2$ INP12: IN A,P1;INPUT PORT 1 CONTENTS TO ACCMOV R6,A;MOVE ACC CONTENTS TO REG 6IN A,P2;INPUT PORT 2 CONTENTS TO ACCMOV R7,A;MOVE ACC CONTENTS TO REG 7ment Accumulator $0 \ 0 \ 1 \ 0 \ 1 \ 1 \ 1$ The contents of the accumulator are incremented by one. Carry is not affected. |

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

## INC R<sub>r</sub> Increment Register

| Encoding:         | 0001      | 1 r r r    | 18H–1FH                                    |
|-------------------|-----------|------------|--------------------------------------------|
| Description:      | The conte | ents of wo | rking register 'r' are incremented by one. |
| <b>Operation:</b> | (Rr) ← (F | Rr) + 1    | r = 0–7                                    |
| Example:          | INCR0: II | NC R0      | ;INCREMENT CONTENTS OF REG 0               |
|                   |           |            |                                            |

## INC @R<sub>i</sub> Increment Data Memory Location

 Encoding:
 0 0 0 1 0 0 0 i
 10H-11H

 Description:
 The contents of the resident data memory location addressed by register 'i' bits 0-5\*\* are incremented by one.

 Operation:
 ((Ri)) ← ((Ri)) + 1 i = 0-1

 Example:
 INCDM: MOV R1,#03FH INC @R1

 Operation:
 (INC @R1

## INS A,BUS\* Strobed input of BUS Data to Accumulator

| Encoding:           | 0000                                                                     | 1000         | 08H               |                       |                   |
|---------------------|--------------------------------------------------------------------------|--------------|-------------------|-----------------------|-------------------|
| <b>Description:</b> | This is a 2                                                              | 2-cycle inst | truction. Data    | present on the BUS po | rt is transferred |
|                     | (read) to the accumulator when the RD pulse is dropped. (Refer to sectio |              | (Refer to section |                       |                   |
| -                   | on progra                                                                | amming me    | mory expansion    | on for details.)      |                   |

**Operation:** (A)  $\leftarrow$  (BUS)

Example: INPBUS: INS A,BUS

;INPUT BUS CONTENTS TO ACC

\* For use with internal program memory ONLY.

\*\* 0-5 in 8048AH/8748H

- 0-6 in 8049AH/8749H
- 0-7 in 8050AH

| JBb address  | Jump If Accumulator Bit Is                                  | Set                                                                                                                     |
|--------------|-------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|
| Encoding:    | b <sub>2</sub> b <sub>1</sub> b <sub>0</sub> 1 0 0 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> |
|              | Accumulat                                                   | or Bit Hex Op Code                                                                                                      |
|              | 0                                                           | 12<br>32                                                                                                                |
|              | 2                                                           | 52                                                                                                                      |
|              | 3<br>4                                                      | 72<br>92                                                                                                                |
|              | 4<br>5                                                      | B2                                                                                                                      |
|              | 6                                                           | D2<br>F2                                                                                                                |
| Description: | This is a 2-cycle instruction accumulator bit 'b' is set to | . Control passes to the specified address if                                                                            |
| Operation:   |                                                             | b = 0-7                                                                                                                 |
|              | (PC <sub>0-7</sub> ) ← addr<br>(PC) = (PC) + 2              | lf Bb = 1<br>lf Bb = 0                                                                                                  |
| Example:     | JB4IS1: JB4 NEXT                                            | ;JUMP TO 'NEXT' ROUTINE<br>;IF ACC BIT 4 = 1                                                                            |
| JC address   | Jump If Carry Is Set                                        |                                                                                                                         |
| Encoding:    | 11110110 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> F6H            |
| Description: | This is a 2-cycle instruction carry bit is set to one.      | . Control passes to the specified address if the                                                                        |
| Operation:   | (PC <sub>0-7</sub> ) ← addr<br>(PC) = (PC) + 2              | If C = 1<br>If C = 0                                                                                                    |
| Example:     | JC1: JC OVFLOW                                              | ;JUMP TO 'OVFLOW' ROUTINE<br>;IF C = 1                                                                                  |
| JF0 address  | Jump If Flag 0 Is Set                                       | · · ·                                                                                                                   |
| Encoding:    | 10110110 a7                                                 | 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> B6H            |

| Encoding:    | 10110110                                            | 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> | B6H                |
|--------------|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|--------------------|
| Description: | This is a 2-cycle instruct<br>flag 0 is set to one. | tion. Control passes to the spe                                                                                         | ecified address if |
| Operation:   | (PC <sub>0−7</sub> )                                | lf F0 = 1<br>lf F0 = 0                                                                                                  |                    |
| Example:     | JF0IS1: JF0 TOTAL                                   | JUMP TO 'TOTAL'                                                                                                         | ROUTINE IF F0 = 1  |

|              | Jump If Flag 1 Is Set                                                                                                                                                                              |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Encoding:    |                                                                                                                                                                                                    |
| Description: | This is a 2-cycle instruction. Control passes to the specified address if flag 1 is set to one.                                                                                                    |
| Operation:   | $(PC_{0-7}) \leftarrow addr$ If F1 = 1<br>(PC) = (PC + 2) If F1 = 0                                                                                                                                |
| Example:     | JF1IS1: JF1 FILBUF ;JUMP TO 'FILBUF'<br>;ROUTINE IF F1 = 1                                                                                                                                         |
| JMP address  | Direct Jump within 2K Block                                                                                                                                                                        |
| Encoding:    | $a_{10}$ $a_{9}$ $a_{8}$ $0$ $0$ $1$ $0$ $0$ $a_{7}$ $a_{6}$ $a_{5}$ $a_{4}$ $a_{3}$ $a_{2}$ $a_{1}$ $a_{0}$                                                                                       |
|              | Page Hex Op Code                                                                                                                                                                                   |
|              | 0 04                                                                                                                                                                                               |
|              | 1 24                                                                                                                                                                                               |
|              | 2 44<br>3 64                                                                                                                                                                                       |
| ,            | 4 84                                                                                                                                                                                               |
|              | 5 A4                                                                                                                                                                                               |
|              | 6 C4                                                                                                                                                                                               |
|              | 7 E4                                                                                                                                                                                               |
| Description: | This is a 2-cycle instruction. Bits 0-10 of the program counter are replaced with the directly-specified address. The setting of PC bit 11 is determined by the most recent SELECT MB instruction. |
| Operation:   | (PC <sub>8-10</sub> ) ← addr 8-10<br>(PC <sub>0-7</sub> ) ← addr 0-7<br>(PC <sub>11</sub> ) ← DBF                                                                                                  |
| Example;     | JMP SUBTOT ;JUMP TO SUBROUTINE 'SUBTOT'<br>JMP \$-6 ;JUMP TO INSTRUCTION SIX<br>;LOCATIONS BEFORE CURRENT<br>;LOCATION                                                                             |
|              | JMP 2FH ;JUMP TO ADDRESS '2F' HEX                                                                                                                                                                  |
| JMPP @A li   | ndirect Jump within Page                                                                                                                                                                           |
| Encoding:    | 10110011 B3H                                                                                                                                                                                       |
| -            | This is a 2-cycle insruction. The contents of the program memory location                                                                                                                          |
|              | pointed to by the accumulator are substituted for the 'page' portion of the program counter (PC bits 0-7).                                                                                         |

|                   |                                                                                                                                                                                                                                                                  | •                                                                                 |  |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--|
| <b>Operation:</b> | (PC <sub>0-7</sub> ) ← ((A))                                                                                                                                                                                                                                     | · · · · · · · · · · · · · · · · · · ·                                             |  |
| Example:          | Assume accumulator contains 0FH.                                                                                                                                                                                                                                 |                                                                                   |  |
|                   | JMPPAG: JMPP @A                                                                                                                                                                                                                                                  | JUMP TO ADDRESS STORED IN                                                         |  |
|                   |                                                                                                                                                                                                                                                                  | ;LOCATION 15 IN CURRENT PAGE                                                      |  |
|                   | and the second                                                                                                                                                 |                                                                                   |  |
| JNC address       | Jump If Carry Is Not Set                                                                                                                                                                                                                                         |                                                                                   |  |
| Encoding:         | 11100110 a <sub>7</sub> a <sub>6</sub> a                                                                                                                                                                                                                         | 15 a <sub>4</sub> a <sub>3</sub> a <sub>2</sub> a <sub>1</sub> a <sub>0</sub> E6H |  |
| Description:      | This is a 2-cycle instruction. Con the carry bit is not set, that is, eq                                                                                                                                                                                         | itrol passes to the specified address if uals zero.                               |  |
| <b>Operation:</b> | (PC <sub>0-7</sub> ) ← addr                                                                                                                                                                                                                                      | If C = 0                                                                          |  |
|                   | (PC) = (PC) + 2                                                                                                                                                                                                                                                  | If C = 1                                                                          |  |
| Example:          | JC0: JNC NOVFLO                                                                                                                                                                                                                                                  | ;JUMP TO 'NOVFLO' ROUTINE<br>;IF C = 0                                            |  |
|                   |                                                                                                                                                                                                                                                                  | · · ·                                                                             |  |
| JNI address       | Jump If Interrupt Input Is Low                                                                                                                                                                                                                                   |                                                                                   |  |
| Encoding:         | 10000110 a <sub>7</sub> a <sub>6</sub> a                                                                                                                                                                                                                         | 15 a <sub>4</sub> a <sub>3</sub> a <sub>2</sub> a <sub>1</sub> a <sub>0</sub> 86H |  |
| Description:      | This is a 2-cycle instruction. Control passes to the specified address if the interrupt input signal is low (= 0), that is, an external interrupt has been signaled. (This signal initiates an interrupt service sequence if the external interrupt is enabled.) |                                                                                   |  |
| <b>Operation:</b> | (PC <sub>0-7</sub> )                                                                                                                                                                                                                                             | lf I = 0<br>lf I = 1                                                              |  |

(PC) = (PC) + 2 • Example: LOC 3: JNI EXTINT If I = 0 If I = 1 ;JUMP TO 'EXTINT' ROUTINE ;IF I = 0

# JNT0 address Jump If Test 0 is Low

| Encoding:    | 0010 0110                                         | $a_7 a_6 a_5 a_4 a_3 a_2 a_1 a_0$ 26H                  |
|--------------|---------------------------------------------------|--------------------------------------------------------|
| Description: | This is a 2-cycle instru<br>test 0 signal is low. | ction. Control passes to the specified address, if the |
| Operation:   | (PC <sub>0−7</sub> )                              | If TO = 0<br>If TO = 1                                 |
| Example:     | JT0LOW: JNT0 60                                   | ;JUMP TO LOCATION 60 DEC<br>;IF T0 = 0                 |

| JNT1 address                                         | Jump If Test 1 Is Low                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                        |
|------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Encoding:                                            | 01000110                                                                                                                                                                                                                                                                                                  | 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> 46H                                                                                                                                                                                                                            |
| Description:                                         | This is a 2-cycle instruc the test 1 signal is low.                                                                                                                                                                                                                                                       | tion. Control passes to the specified address, if                                                                                                                                                                                                                                                                                                      |
| Operation:                                           | (PC <sub>0-7</sub> )                                                                                                                                                                                                                                                                                      | If T1 = 0<br>If T1 = 1                                                                                                                                                                                                                                                                                                                                 |
| JNZ Address                                          | Jump If Accumulator Is Not Zero                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                        |
| Encoding:                                            | 10010110                                                                                                                                                                                                                                                                                                  | $a_7 a_6 a_5 a_4 a_3 a_2 a_1 a_0 96H$                                                                                                                                                                                                                                                                                                                  |
| Description:                                         | -                                                                                                                                                                                                                                                                                                         | tion. Control passes to the specified address if the re nonzero at the time this instruction is executed.                                                                                                                                                                                                                                              |
| Operation:                                           | (PC <sub>0-7</sub> )                                                                                                                                                                                                                                                                                      | If A ≠ 0<br>If A = 0                                                                                                                                                                                                                                                                                                                                   |
| Example:                                             | JACCN0: JNZ 0ABH                                                                                                                                                                                                                                                                                          | ;JUMP TO LOCATION 'AB' HEX<br>;IF ACC VALUE IS NONZERO                                                                                                                                                                                                                                                                                                 |
| JTF address                                          | Jump If Timer Flag Is So                                                                                                                                                                                                                                                                                  | et                                                                                                                                                                                                                                                                                                                                                     |
| Encoding:                                            | 00010110                                                                                                                                                                                                                                                                                                  | a7 a6 a5 a4 a3 a2 a1 a0 16H                                                                                                                                                                                                                                                                                                                            |
| Description:                                         | 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 has overflowed. Testing the timer flag resets it to zero. (This overflow initiates an interrupt service sequence if the timer-overflow interrupt is enabled.) |                                                                                                                                                                                                                                                                                                                                                        |
|                                                      | Testing the timer flag re                                                                                                                                                                                                                                                                                 | sets it to zero. (This overflow initiates an interrupt                                                                                                                                                                                                                                                                                                 |
| Operation:                                           | Testing the timer flag re                                                                                                                                                                                                                                                                                 | sets it to zero. (This overflow initiates an interrupt                                                                                                                                                                                                                                                                                                 |
|                                                      | Testing the timer flag reservice sequence if the $(PC_{0-7}) \leftarrow addr$                                                                                                                                                                                                                             | sets it to zero. (This overflow initiates an interrupt<br>timer-overflow interrupt is enabled.)<br>If TF = 1                                                                                                                                                                                                                                           |
|                                                      | Testing the timer flag reservice sequence if the $(PC_{0-7}) \leftarrow addr$<br>(PC) = (PC) + 2                                                                                                                                                                                                          | sets it to zero. (This overflow initiates an interrupt<br>timer-overflow interrupt is enabled.)<br>If TF = 1<br>If TF = 0<br>;JUMP TO 'TIMER' ROUTINE                                                                                                                                                                                                  |
| Example:<br>JT0 address                              | Testing the timer flag reservice sequence if the (PC <sub>0-7</sub> ) ← addr (PC) = (PC) + 2<br>JTF1: JTF TIMER                                                                                                                                                                                           | sets it to zero. (This overflow initiates an interrupt<br>timer-overflow interrupt is enabled.)<br>If TF = 1<br>If TF = 0<br>;JUMP TO 'TIMER' ROUTINE<br>;IF TF = 1                                                                                                                                                                                    |
| Example:<br>JT0 address<br>Encoding:                 | Testing the timer flag reservice sequence if the $(PC_{0-7}) \leftarrow addr$<br>(PC) = (PC) + 2<br>JTF1: JTF TIMER<br>Jump If Test 0 Is High<br>0 0 1 1 0 1 1 0                                                                                                                                          | sets it to zero. (This overflow initiates an interrupt<br>timer-overflow interrupt is enabled.)<br>If TF = 1<br>If TF = 0<br>;JUMP TO 'TIMER' ROUTINE<br>;IF TF = 1<br>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> 36H<br>tion. Control passes to the specified address if |
| Example:<br>JT0 address<br>Encoding:<br>Description: | Testing the timer flag reservice sequence if the $(PC_{0-7}) \leftarrow addr$<br>(PC) = (PC) + 2<br>JTF1: JTF TIMER<br>Jump If Test 0 Is High<br>$0 \ 0 \ 1 \ 1 \ 0 \ 1 \ 1 \ 0$<br>This is a 2-cycle instruct                                                                                            | sets it to zero. (This overflow initiates an interrupt<br>timer-overflow interrupt is enabled.)<br>If TF = 1<br>If TF = 0<br>;JUMP TO 'TIMER' ROUTINE<br>;IF TF = 1<br>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> 36H<br>tion. Control passes to the specified address if |

;IF T0 = 1

| JT1 address                                                                                                 | Jump If Test 1 Is High                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | All                                                                                                                                                                                                                                                                          |
|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Encoding:                                                                                                   | 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> 56H                                                                                                                                                                                                                                   |
| Description:                                                                                                | This is a 2-cycle instruction. Contr<br>test 1 signal is high (= 1).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | rol passes to the specified address if the                                                                                                                                                                                                                                                                       |
| Operation:                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | lf T1 = 1<br>lf T1 = 0                                                                                                                                                                                                                                                                                           |
| Example:                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | JUMP TO 'COUNT' ROUTINE<br>IF T1 = 1                                                                                                                                                                                                                                                                             |
| JZ address                                                                                                  | Jump If Accumulator Is Zero                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                  |
| Encoding:                                                                                                   | 1 1 0 0 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> C6H                                                                                                                                                                                                                                   |
| Description:                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | rol passes to the specified address if<br>s at the time this instruction is executed.                                                                                                                                                                                                                            |
| Operation:                                                                                                  | $()^{-1}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | If $A = 0$<br>If $A \neq 1$                                                                                                                                                                                                                                                                                      |
| Example:                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | JUMP TO LOCATION 'A3' HEX                                                                                                                                                                                                                                                                                        |
|                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                  |
| MOV A,#data                                                                                                 | Move Immediate Data to Accumu                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | lator                                                                                                                                                                                                                                                                                                            |
| MOV A,#data<br>Encoding:                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | a <sub>4</sub> a <sub>3</sub> a <sub>2</sub> a <sub>1</sub> a <sub>0</sub> 23H                                                                                                                                                                                                                                   |
| Encoding:                                                                                                   | 00100011 a <sub>7</sub> a <sub>6</sub> a <sub>5</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                  |
| Encoding:<br>Description:                                                                                   | 0 0 1 0 0 0 1 1 a <sub>7</sub> a <sub>6</sub> a <sub>5</sub><br>This is a 2-cycle instruction. The 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | a <sub>4</sub> a <sub>3</sub> a <sub>2</sub> a <sub>1</sub> a <sub>0</sub> 23H                                                                                                                                                                                                                                   |
| Encoding:<br>Description:<br>Operation:                                                                     | $\begin{bmatrix} 0 & 0 & 1 & 0 & 0 & 0 & 1 & 1 \\ This is a 2-cycle instruction. The 8 in the accumulator. \\ (A) \leftarrow data \end{bmatrix}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | a <sub>4</sub> a <sub>3</sub> a <sub>2</sub> a <sub>1</sub> a <sub>0</sub> 23H                                                                                                                                                                                                                                   |
| Encoding:<br>Description:<br>Operation:                                                                     | $\begin{bmatrix} 0 & 0 & 1 & 0 & 0 & 0 & 1 & 1 \\ This is a 2-cycle instruction. The 8 in the accumulator. \\ (A) \leftarrow data \end{bmatrix}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | a <sub>4</sub> a <sub>3</sub> a <sub>2</sub> a <sub>1</sub> a <sub>0</sub> 23H<br>3-bit value specified by 'data' is loaded                                                                                                                                                                                      |
| Encoding:<br>Description:<br>Operation:                                                                     | $\begin{bmatrix} 0 & 0 & 1 & 0 \\ 0 & 0 & 1 & 1 \end{bmatrix}$ $\begin{bmatrix} a_7 & a_6 & a_5 \\ a_8 & a_8 & a_8 & a_8 \\ a_$ | a <sub>4</sub> a <sub>3</sub> a <sub>2</sub> a <sub>1</sub> a <sub>0</sub> 23H<br>B-bit value specified by 'data' is loaded                                                                                                                                                                                      |
| Encoding:<br>Description:<br>Operation:<br>Example:<br>MOV A,PSW                                            | $\begin{bmatrix} 0 & 0 & 1 & 0 & 0 & 0 & 1 & 1 \end{bmatrix}$ a <sub>7</sub> a <sub>6</sub> a <sub>5</sub><br>This is a 2-cycle instruction. The 8<br>in the accumulator.<br>(A) ← data<br>MOV A,#0A3H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | a <sub>4</sub> a <sub>3</sub> a <sub>2</sub> a <sub>1</sub> a <sub>0</sub> 23H<br>B-bit value specified by 'data' is loaded                                                                                                                                                                                      |
| Encoding:<br>Description:<br>Operation:<br>Example:<br>MOV A,PSW<br>Encoding:                               | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | a <sub>4</sub> a <sub>3</sub> a <sub>2</sub> a <sub>1</sub> a <sub>0</sub> 23H<br>B-bit value specified by 'data' is loaded                                                                                                                                                                                      |
| Encoding:<br>Description:<br>Operation:<br>Example:<br>MOV A,PSW<br>Encoding:<br>Description:               | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | a <sub>4</sub> a <sub>3</sub> a <sub>2</sub> a <sub>1</sub> a <sub>0</sub> .23H         B-bit value specified by 'data' is loaded         ;MOVE 'A3' HEX TO ACC         tor                                                                                                                                      |
| Encoding:<br>Description:<br>Operation:<br>Example:<br>MOV A,PSW<br>Encoding:<br>Description:<br>Operation: | 001 $a_7 a_6 a_5$ This is a 2-cycle instruction. The accumulator.(A) ← dataMOV A,#0A3HMove PSW Contents to Accumula110111The contents of the program statu(A) ← (PSW)Jump to 'RB1SET' routine if PSWBSCHK: MOV A,PSW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | a <sub>4</sub> a <sub>3</sub> a <sub>2</sub> a <sub>1</sub> a <sub>0</sub> 23H         B-bit value specified by 'data' is loaded         ;MOVE 'A3' HEX TO ACC         tor         a         a       a <sub>3</sub> a <sub>2</sub> a <sub>1</sub> a <sub>0</sub> 23H         sword are moved to the accumulator. |

| MOV A,R <sub>r</sub> M                                         | ove Register Conten                                                                                                                           | ts to Accumu                   | lator                                                                                    |
|----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|------------------------------------------------------------------------------------------|
| Encoding:                                                      | 1111 1 rrr                                                                                                                                    | F8H-FFH                        |                                                                                          |
| <b>Description:</b>                                            | 8-bits of data are removed from working register 'r' into the accumulator.                                                                    |                                |                                                                                          |
| Operation:                                                     | (A) ← (Rr)                                                                                                                                    |                                | r = 0-7                                                                                  |
| Example:                                                       | MAR: MOV A,R3                                                                                                                                 |                                | ;MOVE CONTENTS OF REG 3 TO ACC                                                           |
| MOV A,@R <sub>i</sub> Move Data Memory Contents to Accumulator |                                                                                                                                               |                                |                                                                                          |
| Encoding                                                       | 1 1 1 1 0 0 0 i                                                                                                                               | F0H-F1H                        | ł <sup>,</sup>                                                                           |
| Description:                                                   | The contents of the r<br>register 'i' are moved                                                                                               | esident data r<br>to the accum | nemory location addressed by bits 0-5** of ulator. Register 'i' contents are unaffected. |
| Operation:                                                     | °(A) ← ((Ri))                                                                                                                                 |                                | i = 0-1                                                                                  |
| •                                                              | Assume R1 contains<br>MADM: MOV A,@R                                                                                                          |                                | ;MOVE CONTENTS OF DATA MEM<br>;LOCATION 54 TO ACC                                        |
| MOV A,T M                                                      | ove Timer/Counter C                                                                                                                           | ontents to Ac                  | cumulator                                                                                |
| Encoding:                                                      | 0100 0010                                                                                                                                     | 42H                            |                                                                                          |
| Description:                                                   | The contents of the accumulator.                                                                                                              | timer/event-c                  | counter register are moved to the                                                        |
| <b>Operation:</b>                                              | (A) ← (T)                                                                                                                                     |                                |                                                                                          |
| Example:                                                       | Jump to "EXIT" rout<br>assuming initializati<br>TIMCHK: MOV.A,T                                                                               | on 64,                         | er reaches '64', that is, when bit 6 set—<br>;MOVE TIMER CONTENTS TO ACC                 |
|                                                                | JB6 EXIT                                                                                                                                      |                                | ;JUMP TO 'EXIT' IF ACC BIT 6 = 1                                                         |
| MOV PSW,A                                                      | Move Accumulator                                                                                                                              | Contents to P                  | SW                                                                                       |
| Encoding:                                                      | 11010111                                                                                                                                      | D7H                            |                                                                                          |
| Description:                                                   | The contents of the accumulator are moved into the progam status word.<br>All condition bits and the stack pointer are affected by this move. |                                |                                                                                          |
| Operation:                                                     | (PSW) ← (A)                                                                                                                                   |                                |                                                                                          |
| Example:                                                       | pointer by one.                                                                                                                               |                                | mory locations, that is, increment the                                                   |
|                                                                | INCPTR: MOV A,PS<br>INC A<br>MOV PSW                                                                                                          |                                | ;MOVE PSW CONTENTS TO ACC<br>;INCREMENT ACC BY ONE<br>;MOVE ACC CONTENTS TO PSW          |
| ** 0–5 in 8048AH<br>0–6 in 8049AH<br>0–7 in 8050AH             | /8749H                                                                                                                                        |                                |                                                                                          |

| Encoding:                                                                        | 1010 1 r r r A8H-AFH                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Description:                                                                     | The contents of the accumulator are moved to register 'r'.                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| Operation:                                                                       | (Rr) ← (A) r = 0-7                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| Example:                                                                         | MRA: MOV R0,A                                                                                                                                                                                                                                                                                          | ;MOVE CONTENTS OF ACC TO REG 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| MOV R <sub>r</sub> ,#data Move Immediate Data to Register                        |                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| Encoding:                                                                        | 10111r2r1r0 d7 c                                                                                                                                                                                                                                                                                       | l <sub>6</sub> d <sub>5</sub> d <sub>4</sub> d <sub>3</sub> d <sub>2</sub> d <sub>1</sub> d <sub>0</sub> B8H-BFH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| Description:                                                                     |                                                                                                                                                                                                                                                                                                        | e 8-bit value specified by 'data' is moved to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| <b>Operation:</b>                                                                | (Rr) ← data                                                                                                                                                                                                                                                                                            | r = 0-7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
| Examples:                                                                        | MIR4: MOV R4,#HEXTEN                                                                                                                                                                                                                                                                                   | ;THE VALUE OF THE SYMBOL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|                                                                                  | MIR 5: MOV R5,#PI*(R*R)                                                                                                                                                                                                                                                                                | ;'HEXTEN' IS MOVED INTO REG 4<br>;THE VALUE OF THE EXPRESSION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|                                                                                  |                                                                                                                                                                                                                                                                                                        | ;'PI*(R*R)' IS MOVED INTO REG 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|                                                                                  | MIR 6: MOV R6, #0ADH                                                                                                                                                                                                                                                                                   | ;'AD' HEX IS MOVED INTO REG 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| MOV @ R <sub>i</sub> ,A                                                          | Move Accumulator Contents to                                                                                                                                                                                                                                                                           | Data Memory                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| Encoding:                                                                        | 1010000i A0H-A                                                                                                                                                                                                                                                                                         | 1H No. 3 No. |  |
| Description:                                                                     | The contents of the accumulator are moved to the resident data memory location whose address is specified by bits 0–5** of register 'i'. Register 'i' contents are unaffected.                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| <b>Operation:</b>                                                                | ((Ri)) ← (A)                                                                                                                                                                                                                                                                                           | <sup>c</sup> i = 0-1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|                                                                                  | Assume R0 contains 00000111.<br>MDMA: MOV @R0,A ;MOVE CONTENTS OF ACC TO<br>;LOCATION 7 (REG 7)                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|                                                                                  |                                                                                                                                                                                                                                                                                                        | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| Example:                                                                         |                                                                                                                                                                                                                                                                                                        | ;LOCATION 7 (REG 7)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| Example:<br>MOV @ R <sub>i</sub> ,#da                                            | MDMA: MOV @R0,A                                                                                                                                                                                                                                                                                        | ;LOCATION 7 (REG 7)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| Example:<br>MOV @ R <sub>i</sub> ,#da<br>Encoding:                               | MDMA: MOV @R0,A<br>ta Move Immediate Data to Data to<br>1 0 1 1 0 0 0 i<br>This is a 2-cycle instruction. The 8                                                                                                                                                                                        | ;LOCATION 7 (REG 7)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| Example:<br>MOV @ R <sub>i</sub> ,#da<br>Encoding:<br>Description:               | MDMA: MOV @R0,A<br>ta Move Immediate Data to Data to<br>1 0 1 1 0 0 0 i<br>This is a 2-cycle instruction. The 8                                                                                                                                                                                        | ;LOCATION 7 (REG 7)<br>memory<br>$d_5 d_4 d_3 d_2 d_1 d_0$ B0H-B1H<br>-bit value specified by 'data' is moved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| Example:<br>MOV @ R <sub>i</sub> ,#da<br>Encoding:<br>Description:<br>Operation: | MDMA: MOV @R0,A<br>ta Move Immediate Data to Data (<br>1011000 i<br>$d_7 d_6$<br>This is a 2-cycle instruction. The 8<br>to the resident data memory location                                                                                                                                          | ;LOCATION 7 (REG 7)<br>memory<br>$d_5 d_4 d_3 d_2 d_1 d_0$ B0H-B1H<br>bit value specified by 'data' is moved<br>ion addressed by register 'i', bits 0-5**.<br>i = 0-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
| Example:<br>MOV @ R <sub>i</sub> ,#da<br>Encoding:<br>Description:<br>Operation: | MDMA: MOV @R0,A<br>ta Move Immediate Data to Data to<br>1 0 1 1 0 0 0 i<br>This is a 2-cycle instruction. The 8<br>to the resident data memory locati<br>((Ri)) $\leftarrow$ data<br>Move the hexadecimal value AC<br>MIDM: MOV R0,#62<br>MOV @R0,#0ACH,<br>INC R0<br>MOV @R0,#3FH<br>/8748H<br>/8749H | ;LOCATION 7 (REG 7)<br>memory<br>$d_5 \ d_4 \ d_3 \ d_2 \ d_1 \ d_0$ B0H-B1H<br>-bit value specified by 'data' is moved<br>ion addressed by register 'i', bits 0-5**.<br>i = 0-1<br>C3F to locations 62-63.<br>;MOVE '62' DEC TO ADDR REG 0<br>;MOVE 'AC' HEX TO LOCATION 62<br>;INCREMENT REG 0 to '63'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |

.

,

14-24

| MOV T,A Ma        | ove Accumulator Contents to Ti                                                                                                                                                       | mer/Counter                                                                                    |  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|--|
| Encoding:         | 0 1 1 0 0 0 1 0 62H                                                                                                                                                                  |                                                                                                |  |
| Description:      | The contents of the accumulator are moved to the timer/event-counter register.                                                                                                       |                                                                                                |  |
| <b>Operation:</b> | (T) ← (A)                                                                                                                                                                            |                                                                                                |  |
| Example:          | Initialize and start event counter.                                                                                                                                                  |                                                                                                |  |
|                   | INITEC: CLR A<br>MOV T,A<br>START CNT                                                                                                                                                | ;CLEAR ACC TO ZEROS<br>;MOVE ZEROS TO EVENT COUNTER<br>;START COUNTER                          |  |
| MOVD A,Pp         | Move Port 4-7 Data to Accumu                                                                                                                                                         | lator                                                                                          |  |
| Encoding:         | 000011pp 0CH-                                                                                                                                                                        | 0FH                                                                                            |  |
| Description:      | This is a 2-cycle instruction. D<br>accumulator bits 0-3. Accumu                                                                                                                     | ata on 8243 port 'p' is moved (read) to<br>lator bits 4–7 are zeroed.                          |  |
| <b>Operation:</b> | (0-3) ← (Pp)<br>(4-7) ← 0                                                                                                                                                            | p = 4-7                                                                                        |  |
|                   | Note: Bits 0-7 of the opcode are used to represent ports 4-7. If you are coding in binary rather than assembly language, the mapping is as follows:                                  |                                                                                                |  |
|                   | Bits 1                                                                                                                                                                               | 0 Port                                                                                         |  |
|                   | 00                                                                                                                                                                                   | 4                                                                                              |  |
|                   | 01<br>10                                                                                                                                                                             | 5<br>6                                                                                         |  |
| •                 | 11                                                                                                                                                                                   | 7                                                                                              |  |
| Example:          | INPPT5: MOVD A,P5                                                                                                                                                                    | ;MOVE PORT 5 DATA TO ACC<br>;BITS 0-3, ZERO ACC BITS 4-7                                       |  |
| MOVD Pp,A         | Move Accumulator Data to Por                                                                                                                                                         | t 4-7                                                                                          |  |
| Encoding:         | 001111pp 3CH-                                                                                                                                                                        | 3FH                                                                                            |  |
| Description:      | This is a 2-cycle instruction. Data in accumulator bits 0-3 is moved<br>(written) to 8243 port 'p'. Accumulator bits 4-7 are unaffected. (See NOTE<br>above regarding port mapping.) |                                                                                                |  |
| <b>Operation:</b> | (Pp) ← (A <sub>0-3</sub> )                                                                                                                                                           | P = 4-7                                                                                        |  |
| Example:          | Move data in accumulator to p                                                                                                                                                        | orts 4 and 5.                                                                                  |  |
|                   | OUTP45: MOVD P4,A<br>SWAP A<br>MOVD P5,A                                                                                                                                             | ;MOVE ACC BITS 0-3 TO PORT 4<br>;EXCHANGE ACC BITS 0-3 and 4-7<br>;MOVE ACC BITS 0-3 TO PORT 5 |  |
|                   |                                                                                                                                                                                      |                                                                                                |  |

| MOVP A,@A    | Move Current Page Data to Accu                                                                                 | mulator                                                                                                                                                                          |
|--------------|----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | 10100011 A3H                                                                                                   | 46                                                                                                                                                                               |
|              |                                                                                                                |                                                                                                                                                                                  |
| Description: | counter are affected, limiting the                                                                             | nory location addressed by the<br>cumulator. Only bits 0-7 of the program<br>program memory reference to the<br>ter is restored <i>following</i> this operation.                 |
| Operation:   |                                                                                                                | struction. If it appears in location 255 of a esses a location in the <i>following</i> page.                                                                                     |
| Example:     | MOV128: MOV A,#128<br>MOVP A,@A                                                                                | ;MOVE '128' DEC TO ACC<br>;CONTENTS OF 129th LOCATION IN<br>;CURRENT PAGE ARE MOVED TO ACC                                                                                       |
|              |                                                                                                                | · · · · · · · · · · · · · · · · · · ·                                                                                                                                            |
| MOVP3 A,@A   | Move Page 3 Data to Accumula                                                                                   | tor                                                                                                                                                                              |
|              | kannan an a                                                                      |                                                                                                                                                                                  |
| Encoding:    | 11100011 E3H                                                                                                   |                                                                                                                                                                                  |
| Description: | (within page 3) addressed by the                                                                               | contents of the program memory location<br>accumulator are moved to the<br>er is restored following this operation.                                                              |
| Operation:   | (PC <sub>0-7</sub> ) ← (A)<br>(PC <sub>8-11</sub> ) ← 0011<br>(A) ← ((PC))                                     |                                                                                                                                                                                  |
| Example:     |                                                                                                                | adecimal code in table contained at the<br>SCII characters are designated by a<br>'s reset.<br>;MOVE 'B8' HEX TO ACC (10111000)<br>;LOGICAL AND ACC TO MASK BIT<br>;7 (00111000) |
|              | MOVP3 A,@A                                                                                                     | ;MOVE CONTENTS OF LOCATION '38'<br>;HEX IN PAGE 3 TO ACC (ASCII '8')                                                                                                             |
|              | Access contents of location in pa<br>Assume current program location<br>TABSCH: MOV A,#LOW TAB 1<br>MOVP3 A,@A | ige 3 labelled TAB1.                                                                                                                                                             |
|              |                                                                                                                |                                                                                                                                                                                  |

| MOVX A,@R <sub>j</sub>                                          | Move External-Data-Memory Co                      | ontents to Accumulator                                                                                       |  |  |
|-----------------------------------------------------------------|---------------------------------------------------|--------------------------------------------------------------------------------------------------------------|--|--|
| Encoding:                                                       | 1000000i 80H-81H                                  | 4                                                                                                            |  |  |
| Description:                                                    |                                                   | contents of the external data memory<br>are moved to the accumulator. Register 'i'<br>pulse is generated.    |  |  |
| Operation:                                                      | (A) ← ((Ri))                                      | i = 0–1                                                                                                      |  |  |
| Example:                                                        | Assume R1 contains 01110110.<br>MAXDM: MOVX A,@R1 | ;MOVE CONTENTS OF LOCATION<br>;118 TO ACC                                                                    |  |  |
| MOVX @R <sub>i</sub> ,A                                         | Move Accumulator Contents to Ext                  | ernal <sup>′</sup> Data Memory                                                                               |  |  |
| Encoding:                                                       | 1001000i 90H-91H                                  | 4                                                                                                            |  |  |
| Description:                                                    |                                                   | contents of the accumulator are moved to<br>n addressed by register 'i'. Register 'i'<br>pulse is generated. |  |  |
| <b>Operation:</b>                                               | ((Ri)) ← A                                        | i = 0–1                                                                                                      |  |  |
| Example:                                                        | Assume R0 contains 11000111.<br>MXDMA: MOVX @R0,A | MOVE CONTENTS OF ACC TO<br>LOCATION 199 IN EXPANDED<br>DATA MEMORY                                           |  |  |
| NOP The NOP Instruction                                         |                                                   |                                                                                                              |  |  |
| Encoding:                                                       | 00000000000000                                    |                                                                                                              |  |  |
| Description:                                                    | No operation is performed. Execution.             | ution continues with the following                                                                           |  |  |
| ORL A, R <sub>r</sub> Logical OR Accumulator With Register Mask |                                                   |                                                                                                              |  |  |

 Encoding:
 0 1 0 0 1 r r r
 48H-4FH

 Description:
 Data in the accumulator is logically ORed with the mask contained in working register 'r'.

 Operation:
 (A) ← (A) OR (Rr)
 r = 0-7

 Example:
 ORREG: ORL A,R4
 ;'OR' ACC CONTENTS WITH

;'OR' ACC CONTENTS WITH ;MASK IN REG 4

| ORL A,@R <sub>İ</sub>                             | Logical OR Accumulator With Memory Mask                                                                                                                                                |  |  |
|---------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Encoding:                                         | 0 1 0 0 0 0 i 40H-41H                                                                                                                                                                  |  |  |
| Description:                                      | Data in the accumulator is logically ORed with the mask contained in the resident data memory location referenced by register "i", bits 0–5**.                                         |  |  |
| <b>Operation:</b>                                 | (A) ← (A) OR ((Ri)) i = 0-1                                                                                                                                                            |  |  |
| Example:                                          | ORDM: MOV R0,#3FH ;MOVE '3F' HEX TO REG 0<br>ORL A,@R0 ;'OR' AC CONTENTS WITH MASK<br>;IN LOCATION 63                                                                                  |  |  |
| ORL A,#data                                       | Logical OR Accumulator With Immediate Mask                                                                                                                                             |  |  |
| Encoding:                                         | $\begin{bmatrix} 0 & 1 & 0 & 0 & 0 & 1 & 1 \end{bmatrix}$ $\begin{bmatrix} d_7 & d_6 & d_5 & d_4 & d_3 & d_2 & d_1 & d_0 \end{bmatrix}$ 43H                                            |  |  |
| Description:                                      | This is a 2-cycle instruction. Data in the accumulator is logically ORed with an immediately-specified mask.                                                                           |  |  |
| <b>Operation:</b>                                 | (A) ← (A) OR data                                                                                                                                                                      |  |  |
| Example:                                          | ORID: ORL A,#'X' ;'OR' ACC CONTENTS WITH MASK<br>;01011000 (ASCII VALUE OF 'X')                                                                                                        |  |  |
| ORL BUS,#data* Logical OR BUS With Immediate Mask |                                                                                                                                                                                        |  |  |
| Encoding:                                         | $\begin{bmatrix} 1 & 0 & 0 & 0 \\ 1 & 0 & 0 & 0 \end{bmatrix} \begin{bmatrix} d_7 & d_6 & d_5 & d_4 \\ d_3 & d_2 & d_1 & d_0 \end{bmatrix} $ 88H                                       |  |  |
| Description:                                      | This is a 2-cycle instruction. Data on the BUS port is logically ORed with an immediately-specified mask. This instruction assumes prior specification on an 'OUTL BUS,A' instruction. |  |  |
| Operation:                                        | (BUS) ← (BUS) OR data                                                                                                                                                                  |  |  |

Example: ORBUS: ORL BUS,#HEXMSK :'OF

:'OR' BUS CONTENTS WITH MASK ;EQUAL VALUE OF SYMBOL 'HEXMSK'

# ORL Pp, #data Logical OR Port 1 or 2 With Immediate Mask

| Encoding:       | 1000 10pp                                             | d <sub>7</sub> d <sub>6</sub> d | 5 d4   | $d_3 d_2 d_1 d_0$                 | 89H-8AH     |
|-----------------|-------------------------------------------------------|---------------------------------|--------|-----------------------------------|-------------|
| Description:    | This is a 2-cycle instruction immediately-specified m |                                 | on po  | rt 'p' is logically Ol            | Red with an |
| Operation:      | (Pp) ← (Pp) OR data                                   |                                 | p = 1- | 2                                 | \$          |
| Example:        | ORP1: ORL P1, #0FFH                                   |                                 |        | PORT 1 CONTENT<br>IEX (SET PORT 1 |             |
| * For use with  | internal program memory ONLY.                         |                                 |        |                                   |             |
| ** 0-5 in 8048A | NH/8748H                                              |                                 |        |                                   |             |
| 0–6 in 8049A    | NH/8749H                                              |                                 |        |                                   |             |
| 0 7 1 0050      |                                                       |                                 |        |                                   |             |

0–7 in 8050AH

.

| ORLD Pp,A         | Logical OR Port 4-7 With                                                                                                                    | Accumulator Mask                                                                                                                                                                                                                                     |  |  |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Encoding:         | 1000 11pp                                                                                                                                   | 8CH-8FH                                                                                                                                                                                                                                              |  |  |
| Description:      | This is a 2-cycle instructi digit mask contained in a                                                                                       | on. Data on port 'p' is logically ORed with the<br>ccumulator bits 0-3.                                                                                                                                                                              |  |  |
| <b>Operation:</b> | (Pp) ← (Pp) OR (A <sub>0-3</sub> )                                                                                                          | p = 4-7                                                                                                                                                                                                                                              |  |  |
| Example:          | ORP7: ORLD P7,A                                                                                                                             | ; OR' PORT 7 CONTENTS WITH ACC<br>;BITS 0-3                                                                                                                                                                                                          |  |  |
| OUTL BUS,A        | * Output Accumulator Da                                                                                                                     | ta to BUS                                                                                                                                                                                                                                            |  |  |
| Encoding:         | 0000 0010                                                                                                                                   | 02H                                                                                                                                                                                                                                                  |  |  |
|                   | latched. The latched data<br>another OUTL instruction<br>use of the BUS port (exce<br>the BUS latch. This inclu<br>(such as the MOVX instru | d (written) to the BUS port and<br>a remains valid until altered by<br>n. Any other instruction requiring<br>ept INS) destroys the contents of<br>des expanded memory operations<br>uction). Logical operations on<br>ume the OUTL BUS,A instruction |  |  |
| -                 | OUTLBP: OUTL BUS, A                                                                                                                         | OUTPUT ACC CONTENTS TO BUS                                                                                                                                                                                                                           |  |  |
| OUTL Pp,A         | Output Accumulator Data                                                                                                                     | to Port 1 or 2                                                                                                                                                                                                                                       |  |  |
| Encoding:         | 0011 10pp                                                                                                                                   | 39H-3AH                                                                                                                                                                                                                                              |  |  |
| Description:      | This is a 2-cycle instruction. Data residing in the accumulator is transferred (written) to port 'p' and latched.                           |                                                                                                                                                                                                                                                      |  |  |
| Operation:        | (Pp) ← (A)                                                                                                                                  | p = 1–2                                                                                                                                                                                                                                              |  |  |
|                   | OUTLP: MOV A,R7<br>OUTL P2,A<br>MOV A, R6<br>OUTL P1,A                                                                                      | ;MOVE REG 7 CONTENTS TO ACC<br>;OUTPUT ACC CONTENTS TO PORT 2<br>;MOV REG 6 CONTENTS TO ACC<br>;OUTPUT ACC CONTENTS TO PORT 1                                                                                                                        |  |  |
| For use with      | internal program memory ONLY.                                                                                                               |                                                                                                                                                                                                                                                      |  |  |

(

.

| Encoding:    | 10000011                                          | 83H |             | ,          |
|--------------|---------------------------------------------------|-----|-------------|------------|
| Description: | This is a 2-cycle instru<br>decremented. The pro- |     |             |            |
|              | bits 4-7 are not restor                           |     | inen restor | Slack. FOW |

## **RETR** Return with PSW Restore

| Encoding:    | 1 0 0 1 0 0 1 1 93H                                                                                                                                                                                                                                                                                                                                                   |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description: | 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 by resetting the Interrupt in Progress flip-flop. |
| Operation:   | (SP) ← (SP)-1<br>(PC) ← ((SP))<br>(PSW 4-7) ← ((SP))                                                                                                                                                                                                                                                                                                                  |

14-30

| RLA Rotate   | Left without Carry                                                               | e a construction de la construction                                                                                                        |
|--------------|----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Encoding:    | 11100111 E7H                                                                     |                                                                                                                                                                                                                        |
| Description: | The contents of the accumulator into the bit 0 position.                         | are rotated left one bit. Bit 7 is rotated                                                                                                                                                                             |
| Operation:   | (An + 1) ← (An)<br>(A0) ← (A7)                                                   | n = 0–6                                                                                                                                                                                                                |
| Example:     | Assume accumulator contains 10<br>RLNC: RL A                                     | 0110001.<br>;NEW ACC CONTENTS ARE 01100011                                                                                                                                                                             |
| RLC A Rota   | te Left through Carry                                                            |                                                                                                                                                                                                                        |
| Encoding:    | 1 1 1 1 0 1 1 1 F7H                                                              |                                                                                                                                                                                                                        |
| Description: | The contents of the accumulator carry bit; the carry bit is rotatd in            | are rotated left one bit. Bit 7 replaces the ito the bit 0 position.                                                                                                                                                   |
| Operation:   |                                                                                  |                                                                                                                                                                                                                        |
| Example:     | Assume accumulator contains a<br>changing value.<br>RLTC: CLR C<br>RLC A<br>RR A | 'signed' number; isolate sign without<br>;CLEAR CARRY TO ZERO<br>;ROTATE ACC LEFT, SIGN<br>;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                                                              |                                                                                                                                                                                                                        |
| Encoding:    | 0 1 1 1 0 1 1 1 77H                                                              |                                                                                                                                                                                                                        |
| Description: | The contents of the accumulator into the bit 7 position.                         | r are rotated right one bit. Bit 0 is rotated                                                                                                                                                                          |
| Operation:   | (An) ← (An + 1)<br>(A7) ← (A0)                                                   | n = 0-6                                                                                                                                                                                                                |
| Example:     | Assume accumulator contains 1<br>RRNC: RR A                                      | 0110001.<br>;NEW ACC CONTENTS ARE 11011000                                                                                                                                                                             |
|              |                                                                                  |                                                                                                                                                                                                                        |

| RRC A Rota   | te Right through Carry                                                                                 |                                     | - 0   |         | р <u>5</u><br> |           |       |
|--------------|--------------------------------------------------------------------------------------------------------|-------------------------------------|-------|---------|----------------|-----------|-------|
| Encoding:    | 01100111                                                                                               | 67H                                 |       | •       |                | 11 × 1    |       |
| Description: | The contents of the acc carry bit; the carry bit is                                                    |                                     | •     |         | bit. Bit 0     | ) replace | s the |
| Operation:   | $\begin{array}{l} (An) \leftarrow (An + 1) \\ (A7) \leftarrow (C) \\ (C) \leftarrow (A_0) \end{array}$ | n = 0-6                             |       | · · . · |                | х<br>,*   |       |
| Example:     | Assume carry is not set<br>RRTC: RRC A                                                                 | and accumulator<br>;CARR)<br>;CONT/ | IS SE | T AND   | D ACC          | ,         |       |

SEL MB0 Select Memory Bank 0

| Encoding:         | 1 1 1 0 0 1 0 1 E5H                                                                                                                |  |  |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Description:      | PC bit 11 is set to zero on next JMP or CALL instruction. All references to program memory addresses fall within the range 0-2047. |  |  |
| <b>Operation:</b> | (DBF) ← 0                                                                                                                          |  |  |
| Example:          | Assume program counter contains 834 Hex.SEL MB0;SELECT MEMORY BANK 0JMP \$+20;JUMP TO LOCATION 58 HEX                              |  |  |
| SEL MB1 Se        | elect Memory Bank 1                                                                                                                |  |  |
| Encoding:         | 1 1 1 1 0 1 0 1 F5H                                                                                                                |  |  |

Description: PC bit 11 is set to one on next JMP or CALL instruction. All references to program memory addresses fall within the range 2048-4095.

Operation: (DBF) ← 1

| SEL RB0 Select Register Ba | nk O |  |
|----------------------------|------|--|
|----------------------------|------|--|

| Encoding:         | 1 1 0 0 0 1 0 1 C5H                                                                        |                                                                                                                                                                                                                                             |
|-------------------|--------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description:      |                                                                                            | ences to working registers 0-7 address data<br>the recommended setting for normal                                                                                                                                                           |
| Operation:        | (BS) ← 0                                                                                   |                                                                                                                                                                                                                                             |
| SEL RB1 Se        | lect Register Bank 1                                                                       |                                                                                                                                                                                                                                             |
| Encoding:         | 1 1 0 1 0 1 0 1 D5H                                                                        |                                                                                                                                                                                                                                             |
| Description:      | memory locations 24-31. This is<br>routines, since locations 0-7 a                         | nces to working registers 0-7 address data<br>s the recommended setting for interrupt service<br>re left intact. The setting of PSW bit 4 in<br>ot is restored by the RETR instruction when<br>completed.                                   |
| <b>Operation:</b> | (BS) ← 1                                                                                   |                                                                                                                                                                                                                                             |
| Example:          | •                                                                                          | nas occurred, control has passed to program<br>bit 4 was zero before the interrupt.                                                                                                                                                         |
| Operation:        | LOC3: JNI INIT<br>INIT: MOV R7,A<br>SEL RB1<br>MOV R7,#0FAH<br>SEL RB0<br>MOV A,R7<br>RETR | ;JUMP TO ROUTINE 'INIT' IF<br>;INTERRUPT INPUT IS ZERO<br>;MOVE ACC CONTENTS TO<br>;LOCATION 7<br>;SELECT REG BANK 1<br>;MOVE 'FA' HEX TO LOCATION 31<br>;SELECT REG BANK 0<br>;RESTORE ACC FROM LOCATION 7<br>;RETURN — RESTORE PC AND PSW |
| STOP TCNT         | Stop Timer/Event-Counter                                                                   |                                                                                                                                                                                                                                             |

# Encoding: 0 1 1 0 0 1 0 1 65H

**Description:** 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. Count overflows in register 7. START: DIS TCNTI : DISABLE TIMER INTERRUPT

START: DIS TCNTI CLR A MOV T,A MOV R7,A STRT T MAIN: JTF COUNT

JMP MAIN COUNT: INC R7 MOV A,R7 JB3 INT

JMP MAIN

CLEAR ACC TO ZEROS MOVE ZEROS TO TIMER MOVE ZEROS TO REG 7 START TIMER JUMP TO ROUTINE 'COUNT' IF TF = 1 AND CLEAR TIMER FLAG CLOSE LOOP INCREMENT REG 7 MOVE REG 7 CONTENTS TO ACC JUMP TO ROUTINE 'INT' IF ACC BIT 3 IS SET (REG 7 = 8) OTHERWISE RETURN TO ROUTINE MAIN

## INT: STOP TCNT JMP 7H

## STOP TIMER JUMP TO LOCATION 7 (TIMER) INTERRUPT ROUTINE

| STRT CNT     | Start Event Conter                                                                     |                                |                                                                                                                                                               |
|--------------|----------------------------------------------------------------------------------------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Encoding:    | 01000101                                                                               | 45H                            | х                                                                                                                                                             |
| Description: | · · ·                                                                                  | counter register               | event-counter input and the counter is incremented with each high-to-low                                                                                      |
| Example:     | Initialize and start ev<br>input.<br>STARTC: EN TCNT<br>MOV A,#0<br>MOV T,A<br>STRT CN | ;EN<br>FFH ;M0<br>;M0<br>Г ;EN | ume overflow is desired with first T1<br>IABLE COUNTER INTERRUPT<br>OVE 'FF'HEX (ONES) TO ACC<br>OVES ONES TO COUNTER<br>IABLE T1 AS COUNTER<br>PUT AND START |

| STRT T Star            | t Timer                                                                                                                   |                                                                                                                                                                                                                                                        |
|------------------------|---------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Encoding:              | 0 1 0 1 0 1 0 1 55H                                                                                                       | •                                                                                                                                                                                                                                                      |
| Description:           |                                                                                                                           | n the timer register. The register is<br>n cycles. The prescaler which counts the<br>r register is not.                                                                                                                                                |
| Example:               | Initialize and start timer.                                                                                               | н                                                                                                                                                                                                                                                      |
|                        | STARTT: CLR A<br>MOV T,A<br>EN TCNTI<br>STRT T                                                                            | ;CLEAR ACC TO ZEROS<br>;MOVE ZEROS TO TIMER<br>;ENABLE TIMER INTERRUPT<br>;START TIMER                                                                                                                                                                 |
| SWAP A Sw              | ap Nibbles within Accumulator                                                                                             |                                                                                                                                                                                                                                                        |
| Encoding:              | 0 1 0 0 0 1 1 1 47H                                                                                                       | 1                                                                                                                                                                                                                                                      |
| <b>Description:</b>    | Bits 0-3 of the accumulator are                                                                                           | swapped with bits 4-7 of the accumulator.                                                                                                                                                                                                              |
| <b>Operation:</b>      | (A <sub>4-7</sub> ) ≒ (A <sub>0-3</sub> )                                                                                 |                                                                                                                                                                                                                                                        |
| Example:               | Pack bits 0-3 of locations 50-51<br>PCKDIG: MOV R0, #50<br>MOV R1, #51<br>XCHD A,@R0<br>SWAP A<br>XCHD A,@R1<br>MOV @R0,A | into location 50.<br>;MOVE '50' DEC TO REG 0<br>;MOVE '51' DEC TO REG 1<br>;EXCHANGE BITS 0-3 OF ACC<br>;AND LOCATION 50<br>;SWAP BITS 0-3 AND 4-7 OF ACC<br>;EXCHANGE BITS 0-3 OF ACC AND<br>;LOCATION 51<br>;MOVE CONTENTS OF ACC TO<br>;LOCATION 50 |
| XCH A,R <sub>r</sub> E | xchange Accumulator-Register C                                                                                            | ontents                                                                                                                                                                                                                                                |
| Encoding:              | 00101rrr 28H-2FH                                                                                                          | 4                                                                                                                                                                                                                                                      |
| Description:           | The contents of the accumulato are exchanged.                                                                             | r and the contents of working register 'r'                                                                                                                                                                                                             |
| <b>Operation:</b>      | (A) 车 (Rr)                                                                                                                | r = 0-7                                                                                                                                                                                                                                                |
| Example:               | Move PSW contents to Reg 7 wi<br>XCHAR7: XCH A,R7<br>MOV A, PSW<br>XCH A,R7                                               | thout losing accumulator contents.<br>;EXCHANGE CONTENTS OF REG 7<br>;AND ACC<br>;MOVE PSW CONTENTS TO ACC<br>;EXCHANGE CONTENTS OF REG 7<br>'AND ACC AGAIN                                                                                            |

.

| XCH A,@R <sub>i</sub>   | Exchange Accumulator and E                                                                                                                                                         | Data Memory Contents                                                                                                                                                         |  |  |  |  |  |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Encoding:               | 00100001 20H-21H                                                                                                                                                                   |                                                                                                                                                                              |  |  |  |  |  |
| Description:            | The contents of the accumulator and the contents of the resident data memory location addressed by bits 0-5** of register 'i' are exchanged. Register 'i' contents are unaffected. |                                                                                                                                                                              |  |  |  |  |  |
| <b>Operation:</b>       | (A) ≒ ((Ri))                                                                                                                                                                       | i = 0-1                                                                                                                                                                      |  |  |  |  |  |
| Example:                | Decrement contents of locati<br>DEC52: MOV R0,#52<br>XCH A,@R0<br>DEC A<br>XCH A,@R0                                                                                               | on 52.<br>;MOVE '52' DEC TO ADDRESS REG 0<br>;EXCHANGE CONTENTS OF ACC<br>;AND LOCATION 52<br>;DECREMENT ACC CONTENTS<br>;EXCHANGE CONTENTS OF ACC<br>;AND LOCATION 52 AGAIN |  |  |  |  |  |
| XCHD A,@R <sub>i</sub>  | Exchange Accumulator and                                                                                                                                                           | Data Memory 4-Bit Data                                                                                                                                                       |  |  |  |  |  |
| Encoding:               | 0011000i 30H                                                                                                                                                                       | -31H                                                                                                                                                                         |  |  |  |  |  |
| Description:            | the data memory location ad                                                                                                                                                        | its 0–3 of the accumulator with bits 0–3 of<br>dressed by bits 0–5** of register 'i'. Bits 4–7 of<br>he data memory location, and the contents of                            |  |  |  |  |  |
| <b>Operation:</b>       | (A <sub>0-3</sub> ) ≒ ((Ri0-3))                                                                                                                                                    | i = 0-1                                                                                                                                                                      |  |  |  |  |  |
| Example:                | Assume program counter co                                                                                                                                                          | ntents have been stacked in locations 22-23.                                                                                                                                 |  |  |  |  |  |
|                         | XCHNIB: MOV R0,#23<br>CLR A<br>XCHD A,@R0                                                                                                                                          | ;MOVE '23' DEC TO REG 0<br>;CLEAR ACC TO ZEROS<br>;EXCHANGE BITS 0-3 OF ACC AND<br>;LOCATION 23 (BTS 8-11 OF PC ARE<br>;ZEROED, ADDRESS REFERS<br>:TO PAGE 0)                |  |  |  |  |  |
| XRL A,R <sub>r</sub> Lo | ogical XOR Accumulator With                                                                                                                                                        | Register Mask                                                                                                                                                                |  |  |  |  |  |
| Encoding:               | 1 1 0 1 1 r r r D8H                                                                                                                                                                | -DFH                                                                                                                                                                         |  |  |  |  |  |
| Description:            | Data in the accumulator is E<br>working register 'r'.                                                                                                                              | XCLUSIVE ORed with the mask contained in                                                                                                                                     |  |  |  |  |  |
| <b>Operation:</b>       | (A) ← (A) XOR (Rr)                                                                                                                                                                 | r = 0-7                                                                                                                                                                      |  |  |  |  |  |
| Example:                | XORREG: XRL A,R5                                                                                                                                                                   | ;'XOR' ACC CONTENTS WITH<br>MASK IN REG 5                                                                                                                                    |  |  |  |  |  |

\*\* 0-5 in 8048AH/8748H 0-6 in 8049AH/8749H 0–7 in 8050AH

;MASK IN REG 5

|                                                 | ogical XOR Accumulator with memory mask                                                                                                     |
|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Encoding:                                       | 1 1 0 1 0 0 0 i D0H-D1H                                                                                                                     |
| Description:                                    | Data in the accumulator is EXCLUSIVE ORed with the mask contained in the data memory location addressed by register 'i', bits 0–5.**        |
| <b>Operation:</b>                               | (A) ← (A) XOR ((Ri)) i = 0-1                                                                                                                |
| Example:                                        | XORDM: MOV R1,#20H;MOVE '20' HEX TO REG 1XRL A,@R1;'XOR' ACC CONTENTS WITH MASK;IN LOCATION 32                                              |
| XRL A,#data                                     | Logical XOR Accumulator With Immediate Mask                                                                                                 |
| Encoding:                                       | 1 1 0 1 0 0 1 1 d <sub>7</sub> d <sub>6</sub> d <sub>5</sub> d <sub>4</sub> d <sub>3</sub> d <sub>2</sub> d <sub>1</sub> d <sub>0</sub> D3H |
| Description:                                    | This is a 2-cycle instruction. Data in the accumulator is EXCLUSIVE ORed with an immediately-specified mask.                                |
| <b>Operation:</b>                               | (A) ← (A) XOR data                                                                                                                          |
| Example:                                        | XORID: XOR A, #HEXTEN ;XOR CONTENTS OF ACC WITH MASK ;EQUAL VALUE OF SYMBOL 'HEXTEN'                                                        |
| ** 0–5 in 8048A<br>0–6 in 8049A<br>0–7 in 8050A | H/8749H                                                                                                                                     |

# XRL A,@R<sub>i</sub> Logical XOR Accumulator With Memory Mask

,

# MCS<sup>®</sup>-48 Data Sheets

15

ſ

1

# 8243 MCS®-48 INPUT/OUTPUT EXPANDER

## ■ 0° C to 70° C Operation



Figure 1. 8243 Block Diagram

| Symbol  | Pin No. | Function                                                                                                                                                                                                 |
|---------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PROG    | 7       | Clock Input A high to low transi-<br>tion on PROG signifies that ad-<br>dress and control are available on<br>P20-P23, and a low to high transi-<br>tion signifies that data is available<br>on P20-P23. |
| CS      | 6       | Chip Select Input A high on CS<br>inhibits any change of output or<br>internal status                                                                                                                    |
| P20-P23 | 11-8    | Four (4) bit bi-directional port con-<br>tains the address and control bits<br>on a high to low transition of<br>PROG During a low to high tran-<br>sition contains the data for a sel-                  |

## Table 1. Pin Description

|                    |                   | on P20-P23.                                                                                                                                                                                                                                                                                                                             |
|--------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CS                 | 6                 | Chip Select Input A high on CS<br>inhibits any change of output or<br>internal status                                                                                                                                                                                                                                                   |
| P20-P23            | 11-8              | Four (4) bit bi-directional port con-<br>tains the address and control bits<br>on a high to low transition of<br>PROG During a low to high tran-<br>sition contains the data for a sel-<br>ected output port if a write opera-<br>tion, or the data from a selected<br>port before the low to high transi-<br>tion if a read operation. |
| GND                | 12                | 0 volt supply                                                                                                                                                                                                                                                                                                                           |
| P40-P43            | 2-5               | Four (4) bit bi-directional I/O ports                                                                                                                                                                                                                                                                                                   |
| P50-P53<br>P60-P63 | 1, 23-21<br>20-17 | May be programmed to be input                                                                                                                                                                                                                                                                                                           |
| P70-P73            | 13-16             | (during read), low impedance                                                                                                                                                                                                                                                                                                            |
| P/0-P/3            | , 13-16           | latched output (after write), or a tri-                                                                                                                                                                                                                                                                                                 |
|                    |                   | state (after read). Data on pins<br>P20-P23 may be directly written,                                                                                                                                                                                                                                                                    |
|                    |                   | ANDed or ORed with previous                                                                                                                                                                                                                                                                                                             |
|                    |                   | data.                                                                                                                                                                                                                                                                                                                                   |
| Vcc                | 24                | +5 volt supply                                                                                                                                                                                                                                                                                                                          |

## FUNCTIONAL DESCRIPTION

#### **General Operation**

The 8243 contains four 4-bit I/O ports which serve as an extension of the on-chip I/O and are addressed as ports 4-7. The following operations may be performed on these ports.

- Transfer Accumulator to Port.
- Transfer Port to Accumulator.
- AND Accumulator to Port.
- OR Accumulator to Port.

All communication between the 8048 and the 8243 occurs over Port 2 (P20-P23) with timing provided by an output pulse on the PROG pin of the processor. Each transfer consists of two 4-bit nibbles:

The first containing the "op code" and port address and the second containing the actual 4-bits of data. A high to low transition of the PROG line indicates that address is present while a low to high transition indicates the presence of data. Additional 8243's may be added to the 4-bit bus and chip selected using additional output lines from the 8048/8748/ 8035.

## Power On Initialization

Initial application of power to the device forces input/output ports 4, 5, 6, and 7 to the tri-state and port 2 to the input mode. The PROG pin may be either high or low when power is applied. The first high to low transition of PROG causes device to exit power on mode The power on sequence is initiated if VCC drops below 1V.

| P21 | P20 | Address<br>Code | P23 | P22 | Instruction<br>Code |
|-----|-----|-----------------|-----|-----|---------------------|
| 0   | 0   | Port 4          | 0   | 0   | Read                |
| 0   | 1   | Port 5          | 0   | 1   | Write               |
| 1   | 0   | Port 6          | 1   | 0   | ORLD                |
| 1   | 1   | Port 7          | 1   | 1   | ANLD                |
|     |     |                 |     |     |                     |

## Write Modes

The device has three write modes. MOVD Pi, A directly writes new data into the selected port and old data is lost. ORLD Pi, A takes new data, OR's it with the old data and then writes it to the port. ANLD Pi, A takes new data, AND's it with the old data and then writes it to the port. Operation code and port address are latched from the input port 2 on the high to low transition of the PROG pin. On the low to high transition of PROG data on port 2 is transferred to the logic block of the specified output port.

After the logic manipulation is performed, the data is latched and outputed. The old data remains latched until new valid outputs are entered.

### **Read Mode**

The device has one read mode. The operation code and port address are latched from the input port 2 on the high to low transition of the PROG pin. As soon as the read operation and port address are decoded, the appropriate outputs are tri-stated, and the input buffers switched on. The read operation is terminated by a low to high transition of the PROG pin. The port (4, 5, 6 or 7) that was selected is switched to the tri-stated mode while port 2 is returned to the input mode.

Normally, a port will be in an output (write mode) or input (read mode). If modes are changed during operation, the first read following a write should be ignored; all following reads are valid. This is to allow the external driver on the port to settle after the first read instruction removes the low impedance drive from the 8243 output. A read of any port will leave that port in a high impedance state.

## ABSOLUTE MAXIMUM RATINGS\*

| Ambient Temperature Under Bias 0°C to 70°C<br>Storage Temperature                       |  |
|-----------------------------------------------------------------------------------------|--|
| Voltage on Any Pin                                                                      |  |
| With Respect to Ground         -0.5 V to +7V           Power Dissipation         1 Watt |  |

\*NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

| Symbol | Parameter                      | Min  | Тур | Max     | Units | Test<br>Conditions |
|--------|--------------------------------|------|-----|---------|-------|--------------------|
| VIL    | Input Low Voltage              | -0.5 |     | 0.8     | V     |                    |
| VIH    | Input High Voltage             | 2.0  |     | VCC+0.5 | V     |                    |
| VOL1   | Output Low Voltage Ports 4-7   |      |     | 0.45    | v     | IOL = 4.5 mA*      |
| VOL2   | Output Low Voltage Port 7      |      |     | 1       | V     | IOL = 20 mA        |
| VOH1   | Output High Voltage Ports 4-7  | 2.4  |     |         | V     | IOH = 240μA        |
| HL1    | Input Leakage Ports 4-7        | -10  |     | 20      | μA    | Vin = VCC to OV    |
| IIL2   | Input Leakage Port 2, CS, PROG | -10  |     | 10      | μA    | Vin = VCC to OV    |
| VOL3   | Output Low Voltage Port 2      |      |     | 0.45    | V     | IOL = 0.6 mA       |
| ICC    | VCC Supply Current             |      | 10  | 20      | mA    | Note 1             |
| VOH2   | Output Voltage Port 2          | 2.4  |     |         |       | IOH = 100µA        |
| IOL    | Sum of all IOL from 16 Outputs |      |     | 72      | mA    | 4.5 mA Each Pin    |

\*See following graph for additional sink current capability

## A.C. CHARACTERISTICS (T<sub>A</sub> = 0° C to 70° C, V<sub>CC</sub> = 5V $\pm$ 10%)

| Symbol | Parameter                         | Min | Max | Units | Test Conditions |
|--------|-----------------------------------|-----|-----|-------|-----------------|
| tA     | Code Valid Before PROG            | 50  |     | ns    | 80 pF Load      |
| tB     | Code Valid After PROG             | 60  |     | ns    | 20 pF Load      |
| tC     | Data Valid Before PROG            | 200 |     | ns    | 80 pF Load      |
| tD     | Data Valid After PROG             | 20  |     | ns    | 20 pF Load      |
| tH     | Floating After PROG               | 0   | 150 | ns    | 20 pF Load      |
| tK     | PROG Negative Pulse Width         | 700 |     | ns    |                 |
| tCS    | CS Valid Before/After PROG        | 50  |     | ns    |                 |
| tPO    | Ports 4-7 Valid After PROG        |     | 700 | ns    | 100 pF Load     |
| tLP1   | Ports 4-7 Valid Before/After PROG | 100 |     | ns    |                 |
| tACC   | Port 2 Valid After PROG           |     | 650 | ns    | 80 pF Load      |

Note 1: I<sub>CC</sub> (-40°C to 85°C EXPRESS options) 15 mA typical/25 mA maximum.



## WAVEFORMS







#### **Sink Capability**

The 8243 can sink 5 mA @ .45V on each of its 16 I/O lines simultaneously. If, however, all lines are not sinking simultaneously or all lines are not fully loaded, the drive capability of any individual line increases as is shown by the accompanying curve.

For example, if only 5 of the 16 lines are to sink current at one time, the curve shows that each of those 5 lines is capable of sinking 9 mA @ .45V (if any lines are to sink 9 mA the total IOL must not exceed 45 mA or five 9 mA loads).

Example: How many pins can drive 5 TTL loads (1.6 mA) assuming remaining pins are unloaded?

IOL = 5 x 1.6 mA = 8 mA cIOL = 60 mA from curve # pins = 60 mA ÷ 8 mA/pin = 7.5 = 7

In this case, 7 lines can sink 8 mA for a total of 56mA. This leaves 4 mA sink current capability which can be divided in any way among the remaining 8 I/O lines of the 8243.

Example: This example shows how the use of the 20 mA sink capability of Port 7 affects the sinking capability of the other I/O lines.

An 8243 will drive the following loads simultaneously.

2 loads – 20 mA @ 1V (port 7 only) 8 loads – 4 mA @ .45V 6 loads – 3.2 mA @ .45V Is this within the specified limits?

 $\epsilon IOL$  = (2 x 20) + (8 x 4) + (6 x 3.2) = 91.2 mA. From the curve. for IOL = 4 mA,  $\epsilon IOL \approx$  93 mA. since 91.2 mA < 93 mA the loads are within specified limits.

Although the 20 mA @ 1V loads are used in calculating  $\epsilon IOL$ , it is the largest current required @ .45V which determines the maximum allowable  $\epsilon IOL$ .

NOTE: A10 to 50K Q pullup resistor to +5V should be added to 8243 outputs when driving to 5V CMOS directly













## intel

## 8048AH/8035AHL/8049AH 8039AHL/8050AH/8040AHL HMOS SINGLE-COMPONENT 8-BIT MICROCOMPUTER

- High Performance HMOS II
- Interval Timer/Event Counter
- Two Single Level Interrupts
- Single 5-Volt Supply
- Over 96 Instructions; 90% Single Byte
- Reduced Power Consumption
- Compatible with 8080/8085 Peripherals
- Easily Expandable Memory and I/O
- Up to 1.36 µSec Instruction Cycle All Instructions 1 or 2 cycles

The Intel MCS®-48 family are totally self-sufficient, 8-bit parallel computers fabricated on single silicon chips using Intel's advanced N-channel silicon gate HMOS process.

The family contains 27 I/O lines, an 8-bit timer/counter, and on-board oscillator/clock circuits. For systems that require extra capability, the family can be expanded using MCS®-80/MCS®-85 peripherals.

To minimize development problems and provide maximum flexibility, a logically and functionally pin-compatible version of the ROM devices with UV-erasable user-programmable EPROM program memory is available with minor differences.

These microcomputers are designed to be efficient controllers as well as arithmetic processors. They have extensive bit handling capability as well as facilities for both binary and BCD arithmetic. Efficient use of program memory results from an instruction set consisting mostly of single byte instructions and no instructions over 2 bytes in length.

| Device  | Interna    | Internal Memory |     |
|---------|------------|-----------------|-----|
| 8050AH  | 4K × 8 ROM | 256 × 8 RAM     | yes |
| 8049AH  | 2K × 8 ROM | 128 × 8 RAM     | yes |
| 8048AH  | 1K × 8 ROM | 64 × 8 RAM      | yes |
| 8040AHL | none       | 256 × 8 RAM     | yes |
| 8039AHL | none       | 128 × 8 RAM     | yes |
| 8035AHL | , none     | 64 × 8 RAM      | yes |



×1.

| Symbol                       | Pin<br>No.     | Function                                                                                                                                                                                                                                                                                                |
|------------------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| V <sub>SS</sub>              | 20             | Circuit GND potential                                                                                                                                                                                                                                                                                   |
| V <sub>DD</sub>              | 26             | +5V during normal operation.                                                                                                                                                                                                                                                                            |
| j.                           | , r            | Low power standby pin.                                                                                                                                                                                                                                                                                  |
| VCC                          | 40             | Main power supply; +5V<br>during operation.                                                                                                                                                                                                                                                             |
| PROG                         | 25             | Output strobe for 8243 I/O expander.                                                                                                                                                                                                                                                                    |
| P10-P17<br>Port 1            | 27-34          | 8-bit quasi-bidirectional port.                                                                                                                                                                                                                                                                         |
| P20-P23<br>P24-P27<br>Port 2 | 21-24<br>35-38 | 8-bit quasi-bidirectional port.<br>P20-P23 contain the four high<br>order program counter bits<br>during an external program<br>memory fetch and serve as a<br>4-bit I/O expander bus for<br>8243.                                                                                                      |
| DB0-DB7<br>BUS               | 12-19          | True bidirectional port which<br>can be written or read<br>synchronously using the RD,<br>WR strobes. The port can also<br>be statically latched.                                                                                                                                                       |
|                              |                | Contains the 8 low order<br>program counter bits during an<br>external program memory<br>fetch, and receives the<br>addressed instruction under the<br>control of PSEN. Also contains<br>the address and data during an<br>external RAM data store<br>instruction, under control of<br>ALE, RD, and WR. |
| то                           | 1              | Input pin testable using the<br>conditional transfer instructions<br>JT0 and JNT0. T0 can be<br>designated as a clock output<br>using ENT0 CLK instruction                                                                                                                                              |
| T1                           | 39             | Input pin testable using the<br>JT1, and JNT1 instructions.<br>Can be designated the timer/<br>counter input using the STRT<br>CNT instruction.                                                                                                                                                         |
| ÎNT                          | 6              | Interrupt input. Initiates an<br>interrupt if interrupt is enabled.<br>Interrupt is disabled after a<br>reset. Also testable with<br>conditional jump instruction.<br>(Active low) interrupt must<br>remain low for at least 3<br>machine cycles for proper<br>operation.                               |

| j. | Table | 1. | Pin | Description |
|----|-------|----|-----|-------------|
|    |       |    |     |             |

| SymbolPin<br>No.FunctionRD8Output strobe activated during<br>a BUS read. Can be used to<br>enable data onto the bus from<br>an external device.Used as a read strobe to<br>external data memory.<br>(Active low)Used as a read strobe to<br>external data memory.<br>(Active low)RESET4Input which is used to initialize<br>the processor. (Active low)<br>(Non TTL VIH)Used during power down.<br>Used during power down.<br>Used during ROM verification.WR10Output strobe during a bus<br>write. (Active low)<br>Used as write strobe to<br>external data memory.ALE11Address latch enable. This<br>signal occurs once during each<br>cycle and is useful as a clock<br>output.PSEN9Program store enable. This<br>output occurs only during a<br>fetch to external program<br>memory. (Active low)SS5Single step input can be used<br>in conjunction with ALE to<br>"single step" the processor<br>through each instruction.<br>(Active Low)Used in sync modeEA7EA7External access input which<br>forces all program memory<br>fetches to reference external<br>memory. Useful for emulation<br>and debug. (Active high)XTAL12One side of crystal input for<br>internal oscillator. Also input for<br>external accurse. (Non TTL VIH)XTAL23Other side of crystal input.                                                                                                                                                         | · · · · · · · · · · · · · · · · · · ·    |            | · · · · · · · · · · · · · · · · · · ·                                                      |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|------------|--------------------------------------------------------------------------------------------|
| a BUS read. Can be used to enable data onto the bus from an external device.         Used as a read strobe to external data memory. (Active low)         RESET       4         Input which is used to initialize the processor. (Active low) (Non TTL VIH)         Used during power down.         Used during ROM verification.         WR       10         Output strobe during a bus write. (Active low)         Used during ROM verification.         WR       10         Output strobe during a bus write. (Active low)         Used as write strobe to external data memory.         ALE       11         Address latch enable. This signal occurs once during each cycle and is useful as a clock output.         The negative edge of ALE strobes address into external data and program memory.         PSEN       9         Program store enable. This output occurs only during a fetch to external program memory. (Active low)         SS       5         Single step input can be used in conjunction with ALE to "single step" the processor through each instruction. (Active Low)         Used in sync mode       EA         EA       7         External access input which forces all program memory fetches to reference external memory. Useful for emulation and debug. (Active high)         Used during ROM verification (12V)         XTAL1       2 <th>Symbol</th> <th>Pin<br/>No.</th> <th>Function</th> | Symbol                                   | Pin<br>No. | Function                                                                                   |
| RESET4Input which is used to initialize<br>the processor. (Active low)<br>(Non TTL VIH)<br>Used during power down.<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RD                                       | 8          | a BUS read. Can be used to<br>enable data onto the bus from<br>an external device.         |
| the processor. (Active low)<br>(Non TTL V <sub>IH</sub> )         Used during power down.         Used during ROM verification.         WR       10         Output strobe during a bus<br>write. (Active low)         Used as write strobe to<br>external data memory.         ALE       11         Address latch enable. This<br>signal occurs once during each<br>cycle and is useful as a clock<br>output.         The negative edge of ALE<br>strobes address into external<br>data and program memory.         PSEN       9         Program store enable. This<br>output occurs only during a<br>fetch to external program<br>memory. (Active low)         SS       5         Single step input can be used<br>in conjunction with ALE to<br>"single step" the processor<br>through each instruction.<br>(Active Low)         Used in sync mode         EA       7         External access input which<br>forces all program memory<br>fetches to reference external<br>memory. Useful for emulation<br>and debug. (Active high)         Used during ROM verification<br>(12V)         XTAL1       2         One side of crystal input for<br>internal oscillator. Also input for<br>external source. (Non TTL V <sub>IH</sub> )                                                                                                                                                                                              |                                          |            | external data memory.                                                                      |
| WR10Used during ROM verification.WR10Output strobe during a bus<br>write. (Active low)<br>Used as write strobe to<br>external data memory.ALE11Address latch enable. This<br>signal occurs once during each<br>cycle and is useful as a clock<br>output.<br>The negative edge of ALE<br>strobes address into external<br>data and program memory.PSEN9Program store enable. This<br>output occurs only during a<br>fetch to external program<br>memory. (Active low)SS5Single step input can be used<br>in conjunction with ALE to<br>"single step" the processor<br>through each instruction.<br>(Active Low)EA7External access input which<br>forces all program memory<br>useful for emulation<br>and debug. (Active high)Used during ROM verification<br>(12V)Cone side of crystal input for<br>internal oscillator. Also input for<br>external source. (Non TTL VIH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RESET                                    | 4          | the processor. (Active low)                                                                |
| WR10Output strobe during a bus<br>write. (Active low)<br>Used as write strobe to<br>external data memory.ALE11Address latch enable. This<br>signal occurs once during each<br>cycle and is useful as a clock<br>output.<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                          |            | Used during power down.                                                                    |
| ALE       Virite. (Active low)         Used as write strobe to<br>external data memory.         ALE       11         Address latch enable. This<br>signal occurs once during each<br>cycle and is useful as a clock<br>output.         The negative edge of ALE<br>strobes address into external<br>data and program memory.         PSEN       9         Program store enable. This<br>output occurs only during a<br>fetch to external program<br>memory. (Active low)         SS       5         Single step input can be used<br>in conjunction with ALE to<br>"single step" the processor<br>through each instruction.<br>(Active Low)         Used in sync mode         EA       7         External access input which<br>forces all program memory<br>fetches to reference external<br>memory. Useful for emulation<br>and debug. (Active high)         Used during ROM verification<br>(12V)         XTAL1       2         One side of crystal input for<br>internal oscillator. Also input for<br>external source. (Non TTL VIH)                                                                                                                                                                                                                                                                                                                                                                                          |                                          |            | Used during ROM verification.                                                              |
| ALE11Address latch enable. This<br>signal occurs once during each<br>cycle and is useful as a clock<br>output.The negative edge of ALE<br>strobes address into external<br>data and program memory.PSEN9Program store enable. This<br>output occurs only during a<br>fetch to external program<br>memory. (Active low)SS5Single step input can be used<br>in conjunction with ALE to<br>"single step" the processor<br>through each instruction.<br>(Active Low)EA7External access input which<br>forces all program memory<br>used in sync modeEA7External access input which<br>forces all program memory<br>and debug. (Active high)<br>Used during ROM verification<br>(12V)XTAL12One side of crystal input for<br>internal oscillator. Also input for<br>external source. (Non TTL VIH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | WR                                       | 10         | Output strobe during a bus<br>write. (Active low)                                          |
| Signal occurs once during each cycle and is useful as a clock output.         The negative edge of ALE strobes address into external data and program memory.         PSEN       9         Program store enable. This output occurs only during a fetch to external program memory. (Active low)         SS       5         Single step input can be used in conjunction with ALE to "single step" the processor through each instruction. (Active Low)         Used in sync mode         EA       7         External access input which forces all program memory Useful for emulation and debug. (Active high)         Used during ROM verification (12V)         XTAL1       2         One side of crystal input for internal source. (Non TTL VIH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                          |            |                                                                                            |
| Strobes address into external data and program memory.         PSEN       9         Program store enable. This output occurs only during a fetch to external program memory. (Active low)         SS       5         Single step input can be used in conjunction with ALE to "single step" the processor through each instruction. (Active Low)         Used in sync mode         EA       7         External access input which forces all program memory fetches to reference external memory. Useful for emulation and debug. (Active high)         Used during ROM verification (12V)         XTAL1       2         One side of crystal input for internal source. (Non TTL VIH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ALE                                      | 11         | signal occurs once during each<br>cycle and is useful as a clock                           |
| SS       5       Single step input can be used in conjunction with ALE to "single step" the processor through each instruction. (Active Low)         Used in sync mode       EA       7       External access input which forces all program memory Useful for emulation and debug. (Active high)         Used during ROM verification (12V)       XTAL1       2       One side of crystal input for internal oscillator. Also input for external source. (Non TTL VIH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | L. L. L. L. L. L. L. L. L. L. L. L. L. L |            | strobes address into external                                                              |
| in conjunction with ALE to         "single step" the processor         through each instruction.         (Active Low)         Used in sync mode         EA       7         External access input which forces all program memory fetches to reference external memory. Useful for emulation and debug. (Active high)         Used during ROM verification (12V)         XTAL1       2         One side of crystal input for internal oscillator. Also input for external source. (Non TTL VIH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | PSEN                                     | 9          | output occurs only during a<br>fetch to external program                                   |
| EA       7       External access input which forces all program memory fetches to reference external memory. Useful for emulation and debug. (Active high)         Used during ROM verification (12V)         XTAL1       2         One side of crystal input for internal oscillator. Also input for external source. (Non TTL VIH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | SS                                       | 5          | in conjunction with ALE to<br>"single step" the processor<br>through each instruction.     |
| forces all program memory         fetches to reference external         memory. Useful for emulation         and debug. (Active high)         Used during ROM verification         (12V)         XTAL1       2         One side of crystal input for         internal oscillator. Also input for         external source. (Non TTL VIH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                          |            | Used in sync mode                                                                          |
| (12V)         XTAL1       2       One side of crystal input for internal oscillator. Also input for external source. (Non TTL VIH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | EA                                       | 7          | forces all program memory<br>fetches to reference external<br>memory. Useful for emulation |
| internal oscillator. Also input for<br>external source. (Non TTL VIH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                          |            |                                                                                            |
| XTAL2 3 Other side of crystal input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | XTAL1                                    | 2          | internal oscillator. Also input for                                                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | XTAL2                                    | 3          | Other side of crystal input.                                                               |

#### Table 2. Instruction Set

| Accumulator    |                                  |       |        |
|----------------|----------------------------------|-------|--------|
| Mnemonic       | Description                      | Bytes | Cycles |
| ADD A, R       | Add register to A                | 1     | 1      |
| ADD A, @R      | Add data memory to A             | 1     | 1      |
| ADD A, # data  | Add immediate to A               | 2     | 2      |
| ADDC A, R      | Add register with carry          | 1     | 1      |
| ADDC A, @R     | Add data memory<br>with carry    | 1     | 1      |
| ADDC A, # data | Add immediate<br>with carry      | 2     | 2      |
| ANL A, R       | And register to A                | 1     | 1      |
| ANL A, @R      | And data memory to A             | 1 1   | 1      |
| ANL A, # data  | And immediate to A               | 2     | 2      |
| ORL A, R       | Or register to A                 | 1     | 1      |
| ORL A @R       | Or data memory to A              | 1     | 1      |
| ORL A, # data  | Or immediate to A                | 2     | 2      |
| XRL A, R       | Exclusive or register to A       | 1     | 1      |
| XRL A, @R      | Exclusive or data<br>memory to A | 1     | 1      |
| XRL, A, # data | Exclusive or<br>immediate to A   | 2     | 2      |
| INC A          | Increment A                      | 1     | 1      |
| DEC A          | Decrement A                      | 1     | 1      |
| CLR A          | Clear A                          | 1     | 1      |
| CPL A          | Complement A                     | 1     | 1      |
| DA A           | 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<br>through carry   | 1     | 1      |
| RR A           | Rotate A right                   | 1     | 1      |
| RRC A          | Rotate A right through carry     | 1     | 1      |

#### Input/Output

| Mnemonic        | Description                  | Bytes | Cycles |
|-----------------|------------------------------|-------|--------|
| IN A, P         | Input port to A              | 1     | 2      |
| OUTL P, A       | Output A to port             | 1     | 2      |
| ANL P, # data   | And immediate to port        | 2     | 2      |
| ORL P, # data   | Or immediate to port         | 2     | 2      |
| INS A, BUS      | Input BUS to A               | 1     | 2      |
| OUTL BUS, A     | Output A to BUS              | 1     | 2      |
| ANL BUS, # data | And immediate to BUS         | 2     | 2      |
| ORL BUS, # data | Or immediate to BUS          | 2     | 2      |
| MOVD A, P       | Input expander port to A     | 1     | 2      |
| MOVD P, A       | Output A to expander<br>port | 1     | 2      |
| ANLD P, A       | And A to expander port       | 1     | 2      |
| ORLD P, A       | Or A to expander port        | 1     | 2      |

| Registers    | ,                              |       |        |
|--------------|--------------------------------|-------|--------|
| Mnemonic     | Description                    | Bytes | Cycles |
| INC R        | Increment register             | 1     | 1      |
| INC @R       | Increment data memory          | 1     | 1      |
| DEC R        | Decrement register             | 1     | 1      |
| Branch       |                                |       |        |
| Mnemonic     | Description                    | Bytes | Cycles |
| JMP addr     | Jump unconditional             | 2     | 2      |
| JMPP @A      | Jump indirect                  | 1     | 2      |
| DJNZ R, addr | Decrement register<br>and skip | 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 T0 = 1                 | 2     | 2      |
| JNT0 addr    | Jump on T0 = 0                 | 2     | 2      |
| JT1 addr     | Jump on T1 = 1                 | 2     | 2      |
| JNT1 addr    | Jump on T1 = 0                 | 2     | 2      |
| JF0 addr     | Jump on F0 = 1                 | 2     | 2      |
| JF1 addr     | Jump on F1 = 1                 | 2     | 2      |
| JTF addr     | Jump on timer flag             | 2     | 2      |
| JNI addr     | Jump on INT = 0                | 2     | 2      |
| JBb addr     | Jump on accumulator<br>bit     | 2     | 2      |

#### Subroutine

| <b>Mnemonic</b> | <b>Description</b>        | Bytes | <b>Cycles</b> |
|-----------------|---------------------------|-------|---------------|
| CALL addr       | Jump to subroutine        | 2     | 2             |
| RFT             | Return                    | 1     | 2             |
| RETR            | Return and restore status | i.    | 2             |

.

#### Flags

| Mnemonic | Description       | Bytes | Cycles |
|----------|-------------------|-------|--------|
| 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 flag 1      | 1     | 1      |
| CPL F1   | Complement flag 1 | 1     | 1      |
|          |                   |       |        |
|          | ,                 |       |        |
|          |                   |       |        |
|          |                   |       |        |
|          |                   |       |        |

### Table 2. Instruction Set (Continued)

| Data Moves     | х<br>Х                            |       |        |
|----------------|-----------------------------------|-------|--------|
| Mnemonic       | Description                       | Bytes | Cycles |
| MOV A, R       | Move register to A                | 1     | 1      |
| MOV A, @R      | Move data memory to A             | 1     | 1      |
| MOV A, # data  | Move immediate to A               | · 2   | 2      |
| MOV R, A       | Move A to register                | 1     | 1      |
| MOV @R, A      | Move A to data<br>memory          | 1     | 1      |
| MOV R, # data  | Move immediate<br>to register     | 2     | 2      |
| MOV @R, # data | Move immediate to<br>data memory  | 2     | 2      |
| MOV A, PSW     | Move PSW to A                     | 1     | 1      |
| MOV PSW, A     | Move A to PSW                     | 1     | 1      |
| XCH A, R       | Exchange A and<br>register        | 1     | 1      |
| XCH A, @R      | Exchange A and data memory        | 1     | 1      |
| XCHD A, @R     | Exchange nibble of A and register | 1     | 1      |
| MOVX A, @R     | Move external data memory to A    | 1     | 2      |
| MOVX @R, A     | Move A to external data memory    | 1     | 2      |
| MOVP A, @A     | Move to A from<br>current page    | 1     | 2      |
| MOVP3 A, @     | Move to A from page 3             | 1     | 2      |
|                |                                   |       |        |
|                |                                   |       |        |

| Timer/Counter |                                    |       | · · · · · |
|---------------|------------------------------------|-------|-----------|
| Mnemonic      | Description                        | Bytes | Cycles    |
| 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 timer                        | 1 '   | 1         |
| STOP TONT     | Stop timer/counter                 | 1     | 1         |
| EN TCNTI      | Enable timer/counter<br>interrupt  | 1     | 1         |
| DIS TCNTI     | Disable timer/counter<br>interrupt | 1     | <b>1</b>  |
| Control       |                                    |       |           |
| Mnemonic      | Description                        | Bytes | Cycles    |
| ENI           | Enable external<br>interrupt       | 1     | 1         |
| DISI          | Disable external<br>interrupt      | 1     | 1         |
| SEL RB0       | Select register bank 0             | 1     | 1         |
| SEL RB1       | Select register bank 1             | 1     | 1         |
| SEL MB0       | Select memory bank 0               | 1     | 1         |
| SEL MB1       | Select memory bank 1               | 1     | 1         |
| ENT0 CLK      | Enable clock output<br>on T0       | 1     | 1         |
| Mnemonic      | Description                        | Bytes | Cycles    |
| NOP           | No operation                       | 1     | 1         |
|               |                                    |       |           |

#### **ABSOLUTE MAXIMUM RATINGS\***

Ambient Temperature Under Bias  $\dots 0^{\circ}$  C to 70° C Storage Temperature  $\dots -65^{\circ}$  C to +150° C Voltage On Any Pin With Respect

 \*NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

#### **D.C. CHARACTERISTICS:** (T<sub>A</sub> = 0° C to 70° C; $V_{CC} = V_{DD} = 5V \pm 10\%$ ; $V_{SS} = 0V$ )

|        |                                                           | Limits |     |     |      | V.                        |        |
|--------|-----------------------------------------------------------|--------|-----|-----|------|---------------------------|--------|
| Symbol | Parameter                                                 | Min    | Тур | Max | Unit | Test Conditions           | Device |
| VIL    | Input Low Voltage (All<br>Except RESET, X1, X2)           | 5      |     | .8  | ۰V   |                           | All    |
| VIL1   | Input Low Voltage<br>(RESET, X1, X2)                      | -5     |     | .6  | v    |                           | All    |
| ЧΗ     | Input High Voltage<br>(All Except XTAL1,<br>XTAL2, RESET) | 2.0    |     | Vcc | v    |                           | - All  |
| VIH1   | Input High Voltage<br>(X1, X2, RESET)                     | 3.8    |     | Vcc | v    |                           | AļI    |
| VOL    | Output Low Voltage<br>(BUS)                               |        |     | .45 | v    | I <sub>OL</sub> = 2.0 mA  | All    |
| VOL1   | Output Low Voltage<br>(RD, WR, PSEN, ALE)                 |        |     | .45 | v    | I <sub>OL</sub> = 1.8 mA  | All    |
| VOL2   | Output Low Voltage<br>(PROG)                              |        |     | .45 | v    | I <sub>OL</sub> = 1.0 mA  | · All  |
| VQL3   | Output Low Voltage<br>(All Other Outputs)                 |        |     | .45 | v    | I <sub>OL</sub> = 1.6 mA  | All    |
| VOH    | Output High Voltage<br>(BUS)                              | 2.4    |     |     | v    | I <sub>OH</sub> = -400 μA | All    |
| VOH1   | Output High Voltage<br>(RD, WR, PSEN, ALE)                | 2.4    | , ŕ |     | v    | l <sub>OH</sub> = -100 μA | All    |
| VOH2   | Output High Voltage<br>(All Other Outputs)                | 2.4    |     |     | v    | l <sub>OH</sub> = -40 μA  | All    |

15-11

**D.C. CHARACTERISTICS:** (T<sub>A</sub> = 0°C to 70°C;  $V_{CC} = V_{DD} = 5V \pm 10\%$ ;  $V_{SS} = 0V$ ) (Continued)

| ۰      | , D                                                    | Limits |     |       |      |                                                       |                   |
|--------|--------------------------------------------------------|--------|-----|-------|------|-------------------------------------------------------|-------------------|
| Symbol | Parameter                                              | Min    | Тур | Max   | Unit | Test Conditions                                       | Device            |
| IL1    | Leakage Current<br>(T1, INT)                           |        |     | ±10   | μA   | V <sub>SS</sub> ≤VIN≤V <sub>CC</sub>                  | All               |
| ILI1   | Input Leakage Current<br>(P10-P17, P20-P27,<br>EA, SS) |        | ,   | - 500 | μA   | V <sub>SS</sub> +.45≤V <sub>IN</sub> ≤V <sub>CC</sub> | All               |
| ILI2   | Input Leakage Current<br>RESET                         | 20     |     | 300   | μA   | V <sub>SS</sub> ≤V <sub>IN</sub> ≤3.8V                | All               |
| ILO    | Leakage Current<br>(BUS, T0) (High<br>Impedance State  |        |     | ± 10  | μΑ   | V <sub>SS</sub> ≪V <sub>IN</sub> ≪V <sub>CC</sub>     | All               |
| DD     | V <sub>DD</sub> Supply Current<br>(RAM Standby)        |        | 3   | 5     | mA   |                                                       | 8048AH<br>8035AHL |
|        |                                                        |        | 4   | 7     | mA   |                                                       | 8049AH<br>8039AHL |
|        |                                                        | ,      | 5   | 10    | mA   |                                                       | 8050AH<br>8040AHL |
| IDD+   | Total Supply Current*                                  |        | 30  | 65    | mA   |                                                       | 8048AH<br>8035AHL |
|        | ,<br>,                                                 |        | 35  | 70    | mA   |                                                       | 8049AH<br>8039AHL |
|        |                                                        |        | 40  | 80    | mA   |                                                       | 8050AH<br>8040AHL |
| VDD    | RAM Standby Voltage                                    | 2.2    |     | 5.5   | ۷    | Standby Mode Reset<br>≤VIL1                           | All               |

\*I<sub>CC</sub> + I<sub>DD</sub> is measured with all outputs disconnected;  $\overline{SS}$ ,  $\overline{RESET}$ , and  $\overline{INT}$  equal to V<sub>CC</sub>; EA equal to V<sub>SS</sub>.

١

## **A.C. CHARACTERISTICS:** (T<sub>A</sub> = 0°C to 70°C; V<sub>CC</sub> = V<sub>DD</sub> = 5V $\pm$ 10%; V<sub>SS</sub> = 0V)

|                   |                                | f (t)<br>(Note 3) | 11   | MHz  | Unit | Conditions |
|-------------------|--------------------------------|-------------------|------|------|------|------------|
| Symbol            | Parameter                      |                   | Min  | Max  |      | (Note 1)   |
| t                 | Clock Period                   | 1/xtal freq       | 90.9 | 1000 | ns   | (Note 3)   |
| tLL               | ALE Pulse Width                | 3.5t-170          | 150  |      | ns   |            |
| tAL               | Addr Setup to ALE              | 2t-110            | 70   |      | ns   | (Note 2)   |
| <sup>t</sup> LA   | Addr Hold from ALE             | t-40              | 50   |      | ns   | ,          |
| tCC1              | Control Pulse Width (RD, WR)   | 7.5t-200          | 480  | 1    | ns   |            |
| tCC2              | Control Pulse Width (PSEN)     | 6t-200            | 350  |      | ns   |            |
| tDW               | Data Setup before WR           | 6.5t-200          | 390  |      | ns   |            |
| twD               | Data Hold after WR             | t-50              | 40   |      | ns   |            |
| t <sub>DR</sub>   | Data Hold (RD, PSEN)           | 1.5t-30           | 0    | 110  | ns   |            |
| <sup>t</sup> RD1  | RD to Data in ,                | 6t-170            |      | 375  | ns   |            |
| tRD2              | PSEN to Data in                | 4.5t-170          |      | 240  | ns   |            |
| t <sub>AW</sub>   | Addr Setup to WR               | 5t-150            | 300  |      | ns   |            |
| <sup>t</sup> AD1  | Addr Setup to Data (RD)        | 10.5t-220         |      | 730  | ns   |            |
| tAD2              | Addr Setup to Data (PSEN)      | 7.5t-200          |      | 460  | ns   |            |
| tAFC1             | Addr Float to RD, WR           | 2t-40             | 140  |      | ns   | (Note 2)   |
| tAFC2             | Addr Float to PSEN             | .5t-40            | 10   |      | ns   | (Note 2)   |
| tLAFC1            | ALE to Control (RD, WR)        | 3t-75             | 200  |      | ns   |            |
| tLAFC2            | ALE to Control (PSEN)          | 1.5t-75           | 60   |      | ns   |            |
| <sup>t</sup> CA1  | Control to ALE (RD, WR, PROG), | t-65              | 25   |      | ns   |            |
| tCA2              | Control to ALE (PSEN)          | 4t - 70           | 290  |      | ns   |            |
| tCP               | Port Control Setup to PROG     | 1.5t-80           | 50   |      | ns   |            |
| tPC               | Port Control Hold to PROG      | 4t-260            | 100  |      | ns   |            |
| tpR               | PROG to P2 Input Valid         | 8.5t-120          |      | 650  | ns   |            |
| tPF               | Input Data Hold from PROG      | 1.5t              | 0    | 140  | ns   |            |
| <sup>t</sup> DP   | Output Data Setup              | 6t-290            | 250  |      | ns   |            |
| tPD               | Output Data Hold               | 1.5t-90           | 40   |      | ns   |            |
| tpp               | PROG Pulse Width               | 10.5t-250         | 700  |      | ns   |            |
| tpL               | Port 2 I/O Setup to ALE        | 4t-200            | 160  |      | ns   |            |
| tLP               | Port 2 I/O Hold to ALE         | .5t-30            | 15   |      | ns   |            |
| tpv               | Port Output from ALE           | 4.5t+100          |      | 510  | ns   |            |
| <sup>t</sup> OPRR | T0 Rep Rate                    | 3t                | 270  |      | ns   |            |
| tCY               | Cycle Time                     | 15t               | 1.36 | 15.0 | μs   |            |

#### Notes:

1 Control Outputs CL = 80pF BUS Outputs CL = 150pF 2. BUS High Impedance Load 20pF  3. f(t) assumes 50% duty cycle on X1, X2. Max clock period is for a 1 MHz crystal input.

#### WAVEFORMS



#### PORT 1/PORT 2 TIMING







# intel

## 8748H/8035H/8749H/8039H HMOS-E SINGLE-COMPONENT 8-BIT MICROCOMPUTER

- High Performance HMOS-E
- Interval Timer/Event Counter
- Two Single Level Interrupts
- Single 5-Volt Supply
- Over 96 Instructions; 90% Single Byte

- Compatible with 8080/8085
   Peripherals
- **Easily Expandable Memory and I/O**
- Up to 1.35 μSec Instruction Cycle All Instructions 1 or 2 cycles

The Intel 8749H/8039H/8748H/8035H are totally self-sufficient, 8-bit parallel computers fabricated on single silicon chips using Intel's advanced N-channel silicon gate HMOS-E process.

The family contains 27 I/O lines, an 8-bit timer/counter, on-chip RAM and on-board oscillator/clock circuits. For systems that require extra capability, the family can be expanded using MCS®-80/MCS®-85 peripherals.

These microcomputers are designed to be efficient controllers as well as arithmetic processors. They have extensive bit handling capability as well as facilities for both binary and BCD arithmetic. Efficient use of program memory results from an instruction set consisting mostly of single byte instructions and no instructions over 2 bytes in length.

| , Device | Internal     | Internal Memory |  |  |
|----------|--------------|-----------------|--|--|
| 8039H    | none         | 128 x 8 RAM     |  |  |
| 8035H    | none         | 64 x 8 RAM      |  |  |
| 8749H    | 2K x 8 EPROM | 128 x 8 RAM     |  |  |
| 8748H    | 1K x 8 EPROM | 64 x 8 RAM      |  |  |



#### Table 1. Pin Description

| Symbol                       | Pin<br>No. | Function                                                                                                                                                                                                             | Device                       |
|------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|
| V <sub>SS</sub>              | 20         | Circuit GND<br>potential                                                                                                                                                                                             | All                          |
| VDD                          | 26         | +5V during<br>normal operation.                                                                                                                                                                                      | All                          |
|                              |            | Programming<br>power supply<br>(+21V).                                                                                                                                                                               | 8748H<br>8749H               |
| VCC                          | 40         | Main power<br>supply; +5V dur-<br>ing operation and<br>programming.                                                                                                                                                  | All                          |
| PROG                         | 25         | Output strobe<br>for 8243<br>I/O expander.                                                                                                                                                                           | All                          |
| -                            |            | Program pulse<br>(+18V) input pin<br>during<br>programming.                                                                                                                                                          | 8748H<br>8749H<br>(See Note) |
| P10-P17<br>Port 1            | 27-34      | 8-bit quasi-<br>bidirectional port.                                                                                                                                                                                  | All                          |
| P20-P23<br>P24-P27<br>Port 2 | 35-38      | 8-bit quasi-<br>bidirectional port.<br>P20-P23 contain<br>the four high<br>order program<br>counter bits dur-<br>ing an external<br>program memory<br>fetch and serve<br>as a 4-bit I/O<br>expander bus<br>for 8243. | All                          |
| DB0-<br>DB7<br>BUS           | 12-19      | True bidirectional<br>port which can be<br>written or read<br>synchronously<br>using the RD, WR<br>strobes. The port<br>can also be<br>statically latched.                                                           | All.                         |

|         | Din        | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                   |                |
|---------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| Symbol  | Pin<br>No. | Function                                                                                                                                                                                                                                                                                                                                | Device         |
| (Con't) |            | Contains the 8<br>low order pro-<br>gram counter bits<br>during an external<br>program memory<br>fetch, and<br>receives the<br>addressed in-<br>struction under<br>the control of<br>PSEN. Also con-<br>tains the address<br>and data during<br>an external RAM<br>data store in-<br>struction, under<br>control of ALE,<br>RD, and WR. |                |
| то      | 1          | Input pin testable<br>using the con-<br>ditional transfer<br>instructions JTO<br>and JNTO. TO can<br>be designated as<br>a clock output<br>using ENTO CLK<br>instruction                                                                                                                                                                | All            |
|         |            | Used during programming.                                                                                                                                                                                                                                                                                                                | 8748H<br>8749H |
| T1      | 39         | Input pin testable<br>using the JT1,<br>and JNT1 instruc-<br>tions. Can be des-<br>ignated the timer/<br>counter input<br>using the STRT<br>CNT instruction.                                                                                                                                                                            | All            |
| ÎNT     | 6          | Interrupt input.<br>Initiates an inter-<br>rupt if interrupt is<br>enabled. Interrupt<br>is disabled after a<br>reset. Also testable<br>with conditional<br>jump instruction.<br>(Active low) inter-<br>rupt must remain<br>low for at least 3<br>machine cycles<br>for proper<br>operation.                                            | All            |

.

| Symbol | Pin<br>No. | Function                                                                                                                      | Device         |
|--------|------------|-------------------------------------------------------------------------------------------------------------------------------|----------------|
| RD     | 8          | Output strobe<br>activated during<br>a BUS read. Can<br>be used to enable<br>data onto the bus<br>from an external<br>device. | All            |
|        |            | Used as a read<br>strobe to external<br>data memory.<br>(Active low)                                                          |                |
| RESET  | 4          | Input which is<br>used to initialize<br>the processor.<br>(Active low)<br>(Non TTL VIH)                                       | AİI            |
|        |            | Used during<br>programming.                                                                                                   | 8748H<br>8749H |
| WR     | 10         | Output strobe<br>during a bus<br>write. (Active low)                                                                          | All            |
|        |            | Used as write<br>strobe to external<br>data memory.                                                                           |                |
| ALE    | 11         | Address latch<br>enable. This sig-<br>nal occurs once<br>during each cycle<br>and is useful as<br>a clock output.             | All            |
|        |            | The negative edge<br>of ALE strobes<br>address into<br>external data and<br>program memory                                    |                |

|        | Pin    | _                                                                                                                                                                        |                |
|--------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| Symbol | No.    | Function                                                                                                                                                                 | Device         |
| PSEN   | 9      | Program store<br>enable. This out-<br>put occurs only<br>during a fetch to<br>external pro-<br>gram memory.<br>(Active low)                                              | ALL            |
| SS     | 5      | Single step input<br>can be used in<br>conjunction with<br>ALE to "single<br>step" the proces-<br>sor through each<br>instruction.                                       | All            |
| EA     | 7      | External access<br>input which<br>forces all pro-<br>gram memory<br>fetches to refer-<br>ence external<br>memory. Useful<br>for emulation<br>and debug.<br>(Active high) | All            |
|        |        | Used during<br>(18V)<br>programming                                                                                                                                      | 8748H<br>8749H |
| XTAL1  | 2<br>、 | One side of<br>crystal input for<br>internal oscillator.<br>Also input for<br>external source.<br>(Non TTL VIH)                                                          | All            |
| XTAL2  | 3      | Other side of<br>crystal input                                                                                                                                           | All            |

NOTE: On the 8749H/8039H, PROG must be clamped to  $V_{CC}$  when not programming. A diode should be used when using an 8243; otherwise, a direct connection is permissible.

#### Table 2. Instruction Set

| Accumulator    | ,                                |       |        |
|----------------|----------------------------------|-------|--------|
| Mnemonic       | Description                      | Bytes | Cycles |
| ADD A, R       | Add register to A                | 1     | 1      |
| ADD A, @R      | Add data memory to A             | 1     | 1      |
| ADD A, # data  | Add immediate to A               | 2     | 2      |
| ADDC A, R      | Add register with carry          | 1     | 1      |
| ADDC A, @R     | Add data memory<br>with carry    | 1     | 1      |
| ADDC A, # data | Add immediate<br>with carry      | 2     | 2      |
| ANL A, R       | And register to A                | 1     | 1      |
| ANL A, @R      | And data memory to A             | 1     | 1      |
| ANL A, # data  | And immediate to A               | 2     | 2      |
| ORL A, R       | Or register to A                 | 1     | 1      |
| ORL A @R       | Or data memory to A              | 1     | 1      |
| ORL A, # data  | Or immediate to A                | 2     | 2      |
| XRL A, R       | Exclusive or register to A       | 1     | - 1    |
| XRL A, @R      | Exclusive or data<br>memory to A | 1     | 1      |
| XRL, A, # data | Exclusive or<br>immediate to A   | 2     | 2      |
| INC A          | Increment A                      | 1     | 1      |
| DEC A          | Decrement A                      | 1     | 1      |
| CLR A          | Clear A                          | 1     | 1      |
| CPL A          | Complement A                     | 1     | 1      |
| DA A           | 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<br>through carry   | 1     | 1      |
| RR A           | Rotate A right                   | 1     | 1      |
| RRC A          | Rotate A right through carry     | 1     | 1      |

#### Input/Output

| Mnemonic        | Description               | Bytes | Cycles |
|-----------------|---------------------------|-------|--------|
| IN A, P         | Input port to A           | 1     | 2      |
| OUTL P, A       | Output A to port          | 1     | 2      |
| ANL P, # data   | And immediate to port     | 2     | 2      |
| ORL P, # data   | Or immediate to port      | 2     | 2      |
| INS A, BUS      | Input BUS to A            | 1     | 2      |
| OUTL BUS, A     | Output A to BUS           | 1     | 2      |
| ANL BUS, # data | And immediate to BUS      | 2     | 2      |
| ORL BUS, # data | Or immediate to BUS       | 2     | 2      |
| MOVD A, P       | Input expander port to A  | 1     | 2      |
| MOVD P, A       | Output A to expander port | 1     | 2      |
| ANLD P, A       | And A to expander port    | 1     | 2      |
| ORLD P, A       | Or A to expander port     | 1     | 2      |

| Registers    |                                |       |        |
|--------------|--------------------------------|-------|--------|
| Mnemonic     | Description                    | Bytes | Cycles |
| INCR         | Increment register             | 1     | 1      |
| INC @R       | Increment data memory          | 1     | 1      |
| DEC R        | Decrement register             | 1     | 1      |
| Branch       |                                |       |        |
| Mnemonic     | Description                    | Bytes | Cycles |
| JMP addr     | Jump unconditional             | 2     | 2      |
| JMPP @A      | Jump indirect                  | 1     | 2      |
| DJNZ R, addr | Decrement register<br>and skip | 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 T0 = 1                 | 2     | 2      |
| JNT0 addr    | Jump on T0 = 0                 | 2     | 2      |
| JT1 addr     | Jump on T1 = 1                 | 2     | 2      |
| JNT1 addr    | Jump on T1 = 0                 | 2     | 2      |
| JF0 addr     | Jump on F0 = 1                 | 2     | 2      |
| JF1 addr     | Jump on F1 = 1                 | 2     | 2      |
| JTF addr     | Jump on timer flag             | 2     | 2      |
| JNI addr     | Jump on INT = 0                | 2     | 2      |
| JBb addr     | Jump on accumulator<br>bit     | 2     | 2      |

#### Subroutine

| Mnemonic  | Description                  | Bytes | Cycles |
|-----------|------------------------------|-------|--------|
| CALL addr | Jump to subroutine           | 2     | 2      |
| RET       | Return                       | 1 -   | 2      |
| RETR      | Return and restore<br>status | · 1   | 2      |

#### Flags

| Mnemonic | Description       | Bytes | Cycles |
|----------|-------------------|-------|--------|
| 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 flag 1      | 1     | 1      |
| CPL F1   | Complement flag 1 | 1     | 1      |
|          |                   |       |        |
|          | 1                 |       |        |
| ,        |                   |       |        |
|          |                   |       |        |
|          |                   |       |        |

| Data Moves     |                                   |           |        |
|----------------|-----------------------------------|-----------|--------|
| Mnemonic       | Description                       | Bytes     | Cycles |
| MOV A, R       | Move register to A                | 1         | 1      |
| MOV A, @R      | Move data memory to A             | 1         | 1      |
| MOV A, # data  | Move immediate to A               | 2         | 2      |
| MOV R, A       | Move A to register                | 1         | 1      |
| MOV @R, A      | Move A to data<br>memory          | 1         | 1      |
| MOV R, # data  | Move immediate to register        | 2         | 2      |
| MOV @R, # data | Move immediate to data memory     | 2         | 2      |
| MOV A, PSW     | Move PSW to A                     | 1         | 1      |
| MOV PSW, A     | Move A to PSW                     | 1         | 1      |
| XCH A, R       | Exchange A and<br>register        | 1         | 1      |
| XCH A, @R      | Exchange A and data memory        | <u></u> 1 | 1      |
| XCHD A, @R     | Exchange nibble of A and register | 1         | 1      |
| MOVX A, @R     | Move external data<br>memory to A | 1         | 2      |
| MOVX @R, A     | Move A to external data memory    | 1         | 2      |
| MOVP A, @A     | Move to A from<br>current page    | 1         | 2      |
| MOVP3 A, @A    | Move to A from page 3             | 1         | , 2    |
|                | N                                 |           |        |

| Table 2. | Instruction | Set (Continued) |
|----------|-------------|-----------------|
|----------|-------------|-----------------|

| Timer/Counter |                                       |       |        |
|---------------|---------------------------------------|-------|--------|
| Mnemonic      | Description                           | Bytes | Cycles |
| 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     | Stop timer/counter                    | 1     | 1      |
| EN TCNTI      | Enable timer/counter<br>interrupt     | 1     | 1      |
| DIS TCNTI     | Disable timer/counter<br>interrupt    | 1     | 1      |
|               | · · · · · · · · · · · · · · · · · · · |       |        |
| Control       |                                       |       |        |
| Mnemonic      | Description                           | Bytes | Cycles |
| EN I          | Enable external<br>interrupt          | 1     | 1      |
| DISI          | Disable external<br>interrupt         | 1     | 1      |
| SEL RB0       | Select register bank 0                | 1     | ·1     |
| SEL RB1       | Select register bank 1                | 1     | 1      |
| SEL MB0       | Select memory bank 0                  | 1     | 1      |
| SEL MB1       | Select memory bank 1                  | 1     | 1      |
| ENTO CLK      | Enable clock output<br>on T0          | 1     | 1      |
| Mnemonic      | Description                           | Putes | Cycles |

| Mnemonic | Description  | Bytes | Cycles |
|----------|--------------|-------|--------|
| NOP      | No operation | 1     | 1      |



#### **ABSOLUTE MAXIMUM RATINGS\***

Ambient Temperature Under Bias ... 0° C to 70° C Storage Temperature ...... -65° C to +150° C Voltage On Any Pin With Respect

 \*NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

| <b>D.O. OTATAO I ETISTICO.</b> $(TA = 0 \ O (0 \ 0 \ 0, v(y)) = 0 \ 10 \ 0, v(y) = 0$ | $C = V_{DD} = 5V \pm 10\%; V_{SS} = 0V)$ | <b>STICS:</b> (T <sub>A</sub> = 0 | D.C. CHARACTE |
|---------------------------------------------------------------------------------------|------------------------------------------|-----------------------------------|---------------|
|---------------------------------------------------------------------------------------|------------------------------------------|-----------------------------------|---------------|

|                  |                                                           |     | Limits |     |      |                                        |        |
|------------------|-----------------------------------------------------------|-----|--------|-----|------|----------------------------------------|--------|
| Symbol           | Parameter                                                 | Min | Тур    | Max | Unit | Test Conditions                        | Device |
| VIL              | Input Low Voltage (All<br>Except RESET, X1, X2)           | 5   |        | .8  | v    | ,                                      | All    |
| VIL1             | Input Low Voltage<br>(RESET, X1, X2)                      | 5   |        | .6  | v    | r.                                     | All    |
| VIH              | Input High Voltage<br>(All Except XTAL1,<br>XTAL2, RESET) | 2.0 |        | Vcc | v    | к.                                     | All    |
| VIH1             | Input High Voltage<br>(X1, X2, RESET)                     | 3.8 |        | Vcc | v    |                                        | All    |
| VOL              | Output Low Voltage<br>(BUS)                               |     | 1      | .45 | v    | I <sub>OL</sub> = 2.0 mA               | All    |
| VOL1             | Output Low Voltage<br>(RD, WR, PSEN, ALE)                 |     | ·      | .45 | v    | I <sub>OL</sub> = 1.8 mA               | All    |
| V <sub>OL2</sub> | Output Low Voltage<br>(PROG)                              | ,   |        | .45 | v    | I <sub>OL</sub> = 1.0 mA               | All    |
| V <sub>OL3</sub> | Output Low Voltage<br>(All Other Outputs)                 |     |        | .45 | v    | I <sub>OL</sub> = 1.6 mA               | All    |
| Vон              | Output High Voltage<br>(BUS <u>)</u>                      | 2.4 |        |     | V ·  | I <sub>OH</sub> = -400 μA              | All    |
| VOH1             | Output High Voltage<br>(RD, WR, PSEN, ALE)                | 2.4 |        |     | v    | l <sub>OH</sub> = -100 <sub>.</sub> μA | All    |
| VOH2             | Output High Voltage<br>(All Other Outputs)                | 2.4 |        |     | v    | I <sub>OH</sub> = -40 μA               | All    |

| ,                   |                                                        |      | Limits | 3          |      |                                                       |        |
|---------------------|--------------------------------------------------------|------|--------|------------|------|-------------------------------------------------------|--------|
| Symbol              | Parameter                                              | Min  | Тур    | Max        | Unit | Test Conditions                                       | Device |
| . <sup>I</sup> L1   | Leakage Current<br>(T1, INT)                           |      |        | ±10        | μΑ   | V <sub>SS</sub> ≤VIN≤VCC                              | All    |
| ILI1                | Input Leakage Current<br>(P10–P17, P20–P27,<br>EA, SS) |      |        | - 500      | μA   | V <sub>SS</sub> +.45≤V <sub>IN</sub> ≤V <sub>CC</sub> | All    |
| <sup>I</sup> LI2    | Input Leakage Current<br>RESET                         | - 10 | -      | - 300      | μA   | V <sub>SS</sub> ≤V <sub>IN</sub> ≤3.8V                | All    |
| · I <sub>LO</sub> · | Leakage Current<br>(BUS, T0) (High<br>Impedance State) |      |        | : -<br>±10 | μA   | V <sub>SS</sub> ≤VIN≤VCC                              | All    |
| IDD +               | Total Supply Current*                                  |      | 80     | 100        | mA   | ·                                                     | 8035H  |
|                     |                                                        | ,    | 95     | 110        | mA   |                                                       | 8039H  |
|                     |                                                        |      | .80    | 100        | mA   |                                                       | 8748H  |
|                     |                                                        |      | 95     | 110        | mA   |                                                       | 8749H  |

## **D.C. CHARACTERISTICS:** (T<sub>A</sub> = 0° C to 70° C; V<sub>CC</sub> = V<sub>DD</sub> = 5V $\pm$ 10%; V<sub>SS</sub> = 0V) (Continued)

\*ICC + IDD is measured with all outputs disconnected; SS, RESET, and INT equal to VCC; EA equal to VSS.

|                   |                               | f (t)       | 11 / | MHz  |      | Conditions |
|-------------------|-------------------------------|-------------|------|------|------|------------|
| Symbol            | Parameter                     | (Note 3)    | Min  | Max  | Unit | (Note 1)   |
| t                 | Clock Period                  | 1/xtal freq | 90.9 | 1000 | ns   | (Note 3)   |
| t <sub>LL</sub>   | ALE Pulse Width               | 3.5t-170    | 150  | 1    | ns   |            |
| tAL               | Addr Setup to ALE             | 2t-110      | 70   |      | ns   | (Note 2)   |
| t <sub>LA</sub>   | Addr Hold from ALE            | t-40        | 50   |      | ns   | 1          |
| tCC1              | Control Pulse Width (RD, WR)  | 7.5t-200    | 480  |      | ns   |            |
| tCC2              | Control Pulse Width (PSEN)    | 6t-200      | 350  | 1    | ns   |            |
| tDW               | Data Setup before WR          | 6.5t-200    | 390  | 1    | ns   |            |
| twD               | Data Hold after WR            | t-50        | 40   |      | ns   |            |
| <sup>t</sup> DR   | Data Hold (RD, PSEN)          | 1.5t-30     | 0    | 110  | ns   | · ·        |
| t <sub>RD1</sub>  | RD to Data in                 | 6t-170      |      | 375  | ns   | 1          |
| t <sub>RD2</sub>  | PSEN to Data in               | 4.5t-170    |      | 240  | ns   |            |
| t <sub>AW</sub>   | Addr Setup to WR              | 5t-150      | 300  |      | ns   |            |
| t <sub>AD1</sub>  | Addr Setup to Data (RD)       | 10.5t-220   |      | 730  | ns   |            |
| t <sub>AD2</sub>  | Addr Setup to Data (PSEN)     | 7.5t-200    |      | 460  | ns   | 1          |
| tAFC1             | Addr Float to RD, WR          | 2t-40       | 140  |      | ns   | (Noté 2)   |
| tAFC2             | Addr Float to PSEN            | .5t-40      | 10   | 1    | ns   | (Note 2)   |
| tLAFC1            | ALE to Control (RD, WR)       | 3t-75       | 200  |      | ns   |            |
| tLAFC2            | ALE to Control (PSEN)         | 1.5t-75     | 60   |      | ns   |            |
| <sup>t</sup> CA1  | Control to ALE (RD, WR, PROG) | t-65        | 25   |      | ns   |            |
| tCA2              | Control to ALE (PSEN)         | 4t-70       | 290  |      | ns   |            |
| tCP               | Port Control Setup to PROG    | 1.5t-80     | 50   |      | ns   |            |
| t <sub>PC</sub>   | Port Control Hold to PROG     | 4t-260      | 100  |      | ns   |            |
| t <sub>PR</sub>   | PROG to P2 Input Valid        | 8.5t-120    |      | 650  | ns   |            |
| tpF               | Input Data Hold from PROG     | 1.5t        | 0 ′  | 140  | ns   |            |
| t <sub>DP</sub>   | Output Data Setup             | 6t-290      | 250  |      | ns   |            |
| tPD               | Output Data Hold              | 1.5t-90     | 40   |      | ns   |            |
| tpp.              | PROG Pulse Width              | 10.5t-250   | 700  |      | ns   |            |
| tpL               | Port 2 I/O Setup to ALE       | 4t-200      | 160  |      | ns   |            |
| t <sub>LP</sub>   | Port 2 I/O Hold to ALE        | .5t–30      | 15   |      | ns   |            |
| tpv               | Port Output from ALE          | 4.5t+100    |      | 510  | ns   |            |
| t <sub>OPRR</sub> | T0 Rep Rate                   | 3t          | 270  |      | ns   |            |
| tCY               | Cycle Time                    | 15t         | 1.36 | 15.0 | μS   | -          |

**A.C. CHARACTERISTICS:** (T<sub>A</sub> = 0°C to 70°C;  $V_{CC} = V_{DD} = 5V \pm 10\%$ ;  $V_{SS} = 0V$ )

#### Notes:

1. Control Outputs CL = 80pF BUS Outputs CL = 150pF 2. BUS High Impedance Load 20pF 3. f(t) assumes 50% duty cycle on X1, X2. Max clock period is for a 1 MHz crystal input.

INPUT

DATA

#### WAVEFORMS



PORT 20-23 DATA

PORT CONTROL

-tCP ->

-tPC -

tpp

PCH

INPUT

PROG



#### PROGRAMMING, VERIFYING, AND ERASING THE 8749H (8748H) EPROM

#### **Programming Verification**

In brief, the programming process consists of: activating the program mode, applying an address, latching the address, applying data, and applying a programming pulse. Each word is programmed completely before moving on to the next and is followed by a verification step. The following is a list of the pins used for programming and a description of their functions:

| Pin              | Function                            |
|------------------|-------------------------------------|
| XTAL 1<br>XTAL 2 | Clock Input (3 to 4.0 MHz)          |
| Reset            | Initialization and Address Latching |
| Test 0           | Selection of Program or Verify Mode |
| EA               | Activation of Program/Verify Modes  |
| BUS              | Address and Data Input              |
|                  | Data Output During Verify           |
| P20-P22          | Address Input                       |
| VDD              | Programming Power Supply            |
| PROG             | Program Pulse Input                 |
|                  |                                     |

#### WARNING:

An attempt to program a missocketed 8749H (8748H) will result in severe damage to the part. An indication of a properly socketed part is the appearance of the ALE clock output The lack of this clock may be used to disable the programmer

The Program/Verify sequence is:

- 1 V<sub>DD</sub> = 5V, Clock applied or internal oscillator operating. RESET = 0V, TEST 0 = 5V, EA = 5V, BUS and PROG floating P10 and P11 must be tied to ground.
- 2. Insert 8749H (8748H) in programming socket.
- 3. TEST 0 = 0V (select program mode)
- 4 EA = 18V (activate program mode)
- 5. Address applied to BUS and P20-22
- 6. RESET = 5V (latch address)
- 7 Data applied to BUS
- 8. VDD = 21V (programming power)
- 9. PROG =  $V_{CC}$  or float followed by one 50ms pulse to 18V
- 10 V<sub>DD</sub> = 5V
- 11. TEST 0 = 5V (verify mode)
- 12 Read and verify data on BUS
- 13. TEST 0 = 0V
- 14. RESET = 0V and repeat from step 5
- 15. Programmer should be at conditions of step 1 when 8749H (8748H) is removed from socket.

#### A.C. TIMING SPECIFICATION FOR PROGRAMMING 8748H/8749H ONLY:

 $(T_A = 25^{\circ}C \pm 5^{\circ}C; V_{CC} = 5V \pm 5\%; V_{DD} = 21 \pm .5V)$ 

| Symbol                          | Parameter                                    | Min              | Max  | Unit | Test Conditions |
|---------------------------------|----------------------------------------------|------------------|------|------|-----------------|
| tAW                             | Address Setup Time to RESET                  | 4tCY             |      |      |                 |
| twa                             | Address Hold Time After RESET                | 4tCY             |      |      |                 |
| tDW                             | Data in Setup Time to PROG                   | 4t <sub>CY</sub> |      |      |                 |
| twD                             | Data in Hold Time After PROG                 | 4tCY             |      |      | •               |
| tPH                             | RESET Hold Time to Verify                    | 4t <sub>CY</sub> |      |      |                 |
| <sup>t</sup> VDDW               | VDD Hold Time Before PROG                    | 0                | 1.0  | ms   |                 |
| <sup>t</sup> VDDH               | VDD Hold Time After PROG                     | 0                | 1.0  | ms   | <i>.</i>        |
| <sup>t</sup> PW                 | Program Pulse Width                          | 50               | 60   | ms   |                 |
| tTW                             | Test 0 Setup Time for Program Mode           | 4tCY             |      |      |                 |
| twr                             | Test 0 Hold Time After Program Mode          | 4tCY             | 4    |      |                 |
| tDO                             | Test 0 to Data Out Delay                     |                  | 4tCY |      |                 |
| tww                             | RESET Pulse Width to Latch Address           | 4tCY             |      |      |                 |
| t <sub>r</sub> , t <sub>f</sub> | V <sub>DD</sub> and PROG Rise and Fall Times | 0.5              | 100  | μs   |                 |
| tCY                             | CPU Operation Cycle Time                     | 3.75             | 5    | μs   |                 |
| tRE                             | RESET Setup Time before EAt                  | 4tCY             |      |      |                 |

NOTE: If Test 0 is high, tDO can be triggered by RESET!

#### D.C. TIMING SPECIFICATION FOR PROGRAMMING 8748H/8749H ONLY:

 $(T_A = 25^{\circ}C \pm 5^{\circ}C; V_{CC} = 5V \pm 5\%; V_{DD} = 21 \pm .5V)$ 

| Symbol          | Parameter                                   | Min  | Max  | Unit | Test Conditions |
|-----------------|---------------------------------------------|------|------|------|-----------------|
| VDDH            | V <sub>DD</sub> Program Voltage High Level  | 20.5 | 21.5 | V    |                 |
| VDDL            | V <sub>DD</sub> Voltage Low Level           | 4.75 | 5.25 | V    |                 |
| VPH '           | PROG Program Voltage High Level             | 17.5 | 18.5 | . V  |                 |
| V <sub>PL</sub> | PROG Voltage Low Level                      | 4.0  | Vcc  | V    |                 |
| VEAH            | EA Program or Verify Voltage High Level     | 17.5 | 18.5 | V    |                 |
| JDD             | V <sub>DD</sub> High Voltage Supply Current |      | 20.0 | mA   |                 |
| IPROG           | PROG High Voltage Supply Current            |      | 1.0  | mA   |                 |
| IEA             | EA High Voltage Supply Current              |      | 1.0  | mA   |                 |

#### WAVEFORMS

2 1 1





| SUGGESTED EPROM VERIFICATION                   | ALGORITHM FOR HMOS-E DEVICE ONLY        |
|------------------------------------------------|-----------------------------------------|
|                                                |                                         |
| +12V<br>EA                                     | (INPUT)                                 |
| DB ADDRESS ROM DATA<br>(INPUT) (OUTPUT)        | ADDRESS ROM<br>DATA<br>(INPUT) (OUTPUT) |
| T0, RESET ADDRESS                              | (INPUT)                                 |
|                                                | (INPUT)                                 |
| 48H 49H<br>A10 0 ADDR<br>A11 0 0               | VCC = VDD = + 5V<br>VSS = 0V            |
| <b>NOTE:</b> ALE is function of X1, X2 inputs. |                                         |

## SINGLE-COMPONENT 8-BIT MICROCOMPUTERS

#### EXPRESS

0° C to 70° C Operation
 +40° C to 85° C Operation
 168 Hr. Burn-In

| 8048AH/8035AHL |     | 8748H |
|----------------|-----|-------|
| 8049AH/8039AHL |     | 8243  |
| 8050AH/8040AHL | · 🔳 | 8749H |

The new Intel EXPRESS family of single-component 8-bit microcomputers offers enhanced processing options to the familiar 8048AH/8035AHL, 8748H, 8049AH/8039AHL, 8749H, 8050AH/8040AHL Intel components. These EXPRESS products are designed to meet the needs of those applications whose operating requirements exceed commercial standards, but fall short of military conditions.

The EXPRESS options include the commercial standard and  $-40^{\circ}$ C to 85°C operation with or without 168 ±8 hours of dynamic burn-in at 125°C per MIL-STD-883, method 1015. Figure 1 summarizes the option marking designators and package selections.

For a complete description of 8048AH/8035AHL, 8748H, 8049AH/8309AHL, 8749H, 8040AHL and 8050AH, features and operating characteristics, refer to the respective standard commercial grade data sheet. This document highlights only the electrical specifications which differ from the respective commercial part.

| Temp Range | $\sim$                                                                                                                                                               | 0-70 | $\smallsetminus$                                                                       | -40-85                                                                                                 |                                                                                                                                                       | 0-70                                                                                              | $\sim$                                                                                 | -40-85                                                                                                    |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|
| Burn In    | 0 Hrs                                                                                                                                                                |      | 0 Hrs                                                                                  |                                                                                                        | 168 Hrs                                                                                                                                               | $\searrow$                                                                                        | 168 Hrs                                                                                | 3                                                                                                         |
| · · ·      | P8048A<br>D8048A<br>D8748F<br>P8035A<br>P8049A<br>D8049A<br>D8749F<br>P8039A<br>D8039A<br>P8050A<br>P8050A<br>P8050A<br>P8040A<br>P8040A<br>P8040A<br>P8243<br>D8243 |      | TD803<br>TP804<br>TD804<br>TD874<br>TP803<br>TD803<br>TD805<br>TD805<br>TD805<br>TD805 | 18AH<br>18AH<br>19AH<br>19AH<br>19AH<br>19AH<br>19AH<br>19AHL<br>19AHL<br>10AH<br>10AHL<br>10AHL<br>13 | QP804<br>QD804<br>QD803<br>QP803<br>QP804<br>QD804<br>QD804<br>QD804<br>QD803<br>QP803<br>QP803<br>QP803<br>QP804<br>QD804<br>QD804<br>QD804<br>QD824 | 8AH<br>8H<br>5AHL<br>9AH<br>9AH<br>9AH<br>9AHL<br>9AHL<br>0AH<br>0AH<br>0AHL<br>0AHL<br>0AHL<br>3 | LD803<br>LP804<br>LD804<br>LD874<br>LP803<br>LD803<br>LD805<br>LD805<br>LD805<br>LP804 | 48AH<br>48H<br>35AHL<br>35AHL<br>49AH<br>49AH<br>49AH<br>39AHL<br>39AHL<br>50AH<br>50AH<br>40AHL<br>40AHL |

\* Commercial Grade

P Plastic Package

D Cerdip Package

#### Extended Temperature Electrical Specification Deviations\*

#### TP8048AH/TP8035AHL/LP8048AH/LP8035AHL TD8048AH/TD8035AHL/LD8048AH/LD8035AHL

#### **D.C. CHARACTERISTICS:** $(T_A = -40^{\circ} \text{ C to } 85^{\circ} \text{ C}; V_{CC} = V_{DD} = 5V \pm 10\%; V_{SS} = 0V)$

|              |                                                        | Limits |     |     |      |                 |
|--------------|--------------------------------------------------------|--------|-----|-----|------|-----------------|
| Symbol       | Parameter                                              | Min    | Тур | Max | Unit | Test Conditions |
| VIH          | Input High Voltage (All Except<br>XTAL1, XTAL2, RESET) | 2.2    |     | Vcc | V    |                 |
| IDD          | VDD Supply Current                                     | •      | 4   | 8   | mA   | ٤               |
| IDD +<br>ICC | Total Supply Current                                   |        | 40  | 80  | mA   |                 |

#### TP8049AH/TP8039AHL/LP8049AH/LP8039AHL TD8049AH/TD8039AHL/LD8049AH/LD8039AHL

## **D.C. CHARACTERISTICS:** $(T_A = -40^{\circ} \text{ C to } 85^{\circ} \text{ C}; V_{CC} = V_{DD} = 5V \pm 10\%; V_{SS} = 0V)$

|              |                                                     | Limits |     |     |      |                 |
|--------------|-----------------------------------------------------|--------|-----|-----|------|-----------------|
| Symbol       | Parameter                                           | Min    | Тур | Max | Unit | Test Conditions |
| VIH          | Input High Voltage (All Except XTAL1, XTAL2, RESET) | 2.2    |     | Vcc | V    | s               |
| IDD          | V <sub>DD</sub> Supply Current                      |        | 5   | 10  | mA   |                 |
| IDD +<br>ICC | Total Supply Current                                |        | 50  | 100 | mA   |                 |

#### TP8050AH/TP8040AHL/LP8050AHL/LP8040AHL TD8050AH/TD8040AHL/LD8050AH/LD8040AHL

#### **D.C. CHARACTERISTICS:** (T<sub>A</sub> = -40° C to 85° C; V<sub>CC</sub> = V<sub>DD</sub> = 5V $\pm$ 10%; V<sub>SS</sub> = 0V)

|              | ·                                                      |     | Limits |     |      |                 |
|--------------|--------------------------------------------------------|-----|--------|-----|------|-----------------|
| Symbol       | Parameter                                              | Min | Тур    | Max | Unit | Test Conditions |
| VIН          | Input High Voltage (All,Except<br>XTAL1, XTAL2, RESET) | 2.2 |        | Vcc | V    | -               |
| IDD          | V <sub>DD</sub> Supply Current                         |     | 10     | 20  | mA   |                 |
| IDD +<br>ICC | Total Supply Current                                   |     | 75     | 120 | mA   |                 |

#### Extended Temperature Electrical Specification Deviations\*

#### TD8748H/LD8748H

## **D.C. CHARACTERISTICS:** (T<sub>A</sub> = -40° C to 85° C; V<sub>CC</sub> = V<sub>DD</sub> = 5V $\pm$ 10%; V<sub>SS</sub> = 0V)

|                          |                                                        | Limits |     |     |      |                 |
|--------------------------|--------------------------------------------------------|--------|-----|-----|------|-----------------|
| Symbol                   | Parameter                                              | Min    | Тур | Max | Unit | Test Conditions |
| VIH                      | Input High Voltage (All Except<br>XTAL1, XTAL2, RESET) | 2.2    |     | Vcc | V    |                 |
| I <sub>DD</sub> +<br>ICC | Total Supply Current                                   |        | 50  | 130 | mA   |                 |

#### TD8749H/LD8749H

## D.C. CHARACTERISTICS: (T<sub>A</sub> = -40° C to 85° C; V<sub>CC</sub> = V<sub>DD</sub> = 5V $\pm$ 10%; V<sub>SS</sub> = 0V)

|              |                                                        | Limits |     |     |      |                 |
|--------------|--------------------------------------------------------|--------|-----|-----|------|-----------------|
| Symbol       | Parameter                                              | Min    | Тур | Max | Unit | Test Conditions |
| ViH          | Input High Voltage (All Except<br>XTAL1, XTAL2, RESET) | 2.2    |     | Vcc | V    |                 |
| IDD +<br>ICC | Total Supply Current                                   |        | 75  | 150 | mA   |                 |

#### TP8243/TD8243/LD8243

## **D.C. CHARACTERISTICS:** (T<sub>A</sub> = $-40^{\circ}$ C to $85^{\circ}$ C; V<sub>CC</sub> = $5V \pm 10\%$ ; V<sub>SS</sub> = 0V)

|        |                                |     | Limits |     |      |                 |
|--------|--------------------------------|-----|--------|-----|------|-----------------|
| Symbol | Parameter                      | Min | Тур    | Max | Unit | Test Conditions |
| ICC    | V <sub>CC</sub> Supply Current |     | 15     | 25  | mA   |                 |

#### Extended Temperature Electrical Specification Deviations\*

#### TD8022/LD8022

#### **D.C. CHARACTERISTICS:** ( $T_A = -40^{\circ}C$ to $85^{\circ}C$ ; $V_{CC} = 5.5V \pm 1V$ ; $V_{SS} = 0V$ )

|                 |                                                              |                      | Limits |                      |            |                                                                |
|-----------------|--------------------------------------------------------------|----------------------|--------|----------------------|------------|----------------------------------------------------------------|
| Symbol          | Parameter                                                    | Min                  | Тур    | Max                  | Unit       | Test Conditions                                                |
| VIL1            | Input Low Voltage (Port 0)                                   | -0.5                 |        | V <sub>TH</sub> -0.2 | V          |                                                                |
| ⊻н              | Input High Voltage<br>(All Except XTAL1, RESET)              | 2.3                  |        | Vcc                  | . <b>V</b> | V <sub>CC</sub> = 5.0V ± 10%<br>V <sub>TH</sub> Floating       |
| Ин1             | Input High Voltage<br>(All Except XTAL1, RESET)              | 3.8                  |        | Vcc                  | V          | V <sub>CC</sub> = 5.5V ± 1V<br>V <sub>TH</sub> Floating        |
| VIH2            | Input High Voltage (Port 0)                                  | V <sub>TH</sub> +0.2 |        | VCC                  | V          |                                                                |
| VIH3            | Input High Voltage (RESET, XTAL1)                            | 3.8                  |        | Vcc                  | V          |                                                                |
| VIL             | Input Low Voltage                                            | -0.5                 |        | 0.5                  | V          |                                                                |
| VOL             | Output Low Voltage                                           |                      |        | 0.45                 | V          | I <sub>OL</sub> = 0.8 mA                                       |
| VOL1            | Output Low Voltage (P10, P11)                                |                      |        | 2.5                  | V          | I <sub>OL</sub> = 3 mA                                         |
| ∨он             | Output High Voltage (All unless<br>open drain option Port 0) | 2.4                  |        |                      | v          | I <sub>OH</sub> = 30 μA                                        |
| <sup>I</sup> LI | Input Current (T1)                                           |                      |        | ±700                 | μA         | V <sub>CC</sub> ≥ V <sub>IN</sub> ≥<br>V <sub>SS</sub> + 0.45V |
| ILI1            | Input Current to Ports                                       |                      |        | 500                  | μA         | V <sub>IN</sub> = 0.45V                                        |
| ICC             | V <sub>CC</sub> Supply Current                               |                      |        | 120                  | mA         |                                                                |

#### A.C. CHARACTERISTICS: (T<sub>A</sub> = -40°C to 85°C; V<sub>CC</sub> = $5.5V \pm 1V$ ; V<sub>SS</sub> = 0V)

| Symbol          | Parameter                                    | Min  | Max  | Unit  | Test Conditions                         |
|-----------------|----------------------------------------------|------|------|-------|-----------------------------------------|
| tCY             | Cycle Time                                   | 8.38 | 50.0 | μS    | 3.58 MHz XTAL = 8.38 μs t <sub>CY</sub> |
| V <sub>T1</sub> | Zero-Cross Detection Input (T1)              | 1    | 3    | VACpp | AC Coupled                              |
| AZC             | Zero-Cross Accuracy                          |      | ±200 | m۷    | 60 Hz Sine Wave                         |
| FTi             | Zero-Cross Detection Input<br>Frequency (T1) | 0.05 | 1    | kHz   |                                         |
| tĿL             | ALE Pulse Width                              | 3.9  | 23.0 | μs    | $t_{CY}$ = 8.38 $\mu$ s for min         |

**NOTE:** Control Outputs:  $C_L = 80 \text{ pf}$ ;  $T_{CY} = 8.38 \mu \text{sec}$ .

#### A/D CONVERTER CHARACTERISTICS: (AVCC = 5.5V ± 1V; AVSS = 0V; AVCC/2 ≤ VAREF ≤ AVCC)

|                   |             | Li |                      |     |                 |
|-------------------|-------------|----|----------------------|-----|-----------------|
| Parameter         | Min Typ Max |    |                      |     | Test Conditions |
| Absolute Accuracy |             |    | 1.6% FSR $\pm$ ½ LSB | LSB |                 |

**NOTE:** The analog input must be maintained at a constant voltage during the sample time (tss + tsh). \*Refer to individual commercial grade data sheets for complete operating characteristics.

## 80C49-7/80C39-7 CHMOS SINGLE-COMPONENT 8-BIT MICROCOMPUTER

- 80C49-7 Low Power Mask Programmable ROM
- 80C39-7 Low Power, CPU only
- Pin-to-pin Compatible with Intel's 8049AH/8039AHL
- 1.36 µsec Instruction Cycle. All Instructions 1 or 2 Cycles
- Ability to Maintain Operation during AC Power Line Interruptions
- Exit Idle Mode with an External or Internal Interrupt Signal

- Battery Operation
- 3 Power Consumption Selections

   —Normal Operation: 12 mA@ 11 MHz@ 5V
   —Idle Mode: 5 mA@ 11 MHz@ 5V
   —Power Down: 2 µA@ 2.0V
- 11 MHz, TTL Compatible Operation: V<sub>CC</sub> = 5V ± 10% CMOS Compatible Operation; V<sub>CC</sub> = 5V ± 20%

Intel's 80C49-7/80C39-7 are low power, CHMOS versions of the popular MCS®-48 HMOS family members. CHMOS is a technology built on HMOS II and features high resistivity P substrate, diffused N well, and scaled N and P channel devices. The 80C49-7/80C39-7 have been designed to provide low power consumption and high performance.

The 80C49-7 contains a 2K x 8 program memory, a 128 x 8 x 8 RAM data memory, 27 I/O lines, and an 8-bit timer/counter in addition to an on-board oscillator and clock circuits. For systems that require extra capability, the 80C49-7 can be expanded using CMOS external memories and MCS®-80 and MCS®-85 peripherals. The 80C39-7 is the equivalent of the 80C49-7 without program memory on-board.

The CHMOS design of the 80C49-7 opens new application areas that require battery operation, low power standby, wide voltage range, and the ability to maintain operation during AC power line interruptions. These applications include portable and hand-held instruments, telecommunications, consumer, and automotive.



| Symbol            | Pin No. | Function                                                                                                                                                                                                                                                                                                     |
|-------------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| V <sub>SS</sub>   | 20      | Circuit GND potential                                                                                                                                                                                                                                                                                        |
| V <sub>DD</sub>   | 26      | Low Power standby pin                                                                                                                                                                                                                                                                                        |
| VCC               | 40      | Main power supply;<br>+5V during operation.                                                                                                                                                                                                                                                                  |
| PROG              | 25      | Output strobe for 82C43<br>I/O expander.                                                                                                                                                                                                                                                                     |
| P10-P17<br>Port 1 | 27-34   | 8-bit quasi-bidirectional<br>port.                                                                                                                                                                                                                                                                           |
| P20-P23           | 21–24   | 8-bit quasi-bidirectional port.                                                                                                                                                                                                                                                                              |
| P24-P27<br>Port 2 | 35–38   | P20–P23 contain the four<br>high order program counter<br>bits during an external<br>program memory fetch<br>and serve as a 4-bit I/O<br>expander bus for 8243.                                                                                                                                              |
| DB0-DB7<br>BUS    | 12–19   | True bidirectional port<br>which can be written or<br>read synchronously using<br>the RD, WR strobes. The<br>port can also be statically<br>latched.                                                                                                                                                         |
|                   |         | Contains the 8 low order<br>program counter bits dur-<br>ing an external program<br>memory fetch, and receives<br>the addressed instruction<br>under the control of PSEN.<br>Also contains the address<br>and data during an external<br>RAM data store instruction,<br>under control of ALE, RD,<br>and WR. |
| ТО                | 1       | Input pin testable using the<br>conditional transfer instruc-<br>tions JT0 and JNT0. T0 can<br>be designated as a clock<br>output using ENT0 CLK<br>instruction.                                                                                                                                             |
| T1                | 39      | Input pin testable using the JT1, and JNT1 instructions.                                                                                                                                                                                                                                                     |

#### Table 1. Pin Description

| Symbol | Pin No. | Function                                                                                                                                                                                                                                                                      |
|--------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |         | Can be designated the timer/counter input using the STRT CNT instruction.                                                                                                                                                                                                     |
| INT    | 6       | Interrupt input. Initiates an<br>interrupt if interrupt is en-<br>abled. Interrupt is disabled<br>after a reset. Also testable<br>with conditional jump in-<br>struction. (Active low)<br>Interrupt must remain low<br>for at least 3 machine<br>cycles for proper operation. |
| RD     | 8       | Output strobe activated<br>during a BUS read. Can be<br>used to enable data onto<br>toe bus from an external<br>device.                                                                                                                                                       |
|        |         | Used as a read strobe to<br>external data memory.<br>(Active low)                                                                                                                                                                                                             |
| RESET  | 4       | Input which is used to<br>initialize the processor.<br>(Active low) (Non TTL VIH)                                                                                                                                                                                             |
| WR     | 10      | Output strobe during a bus write. (Active low)                                                                                                                                                                                                                                |
|        |         | Used as write strobe to external data memory.                                                                                                                                                                                                                                 |
| ALE    | . 11    | Address latch enable. This<br>signal occurs once during<br>each cycle and is useful as<br>a clock output.                                                                                                                                                                     |
|        |         | The negative edge of ALE<br>strobes address into<br>external data and program<br>memory.                                                                                                                                                                                      |
| PSEN   | 9       | Program store enable. This<br>output occurs only during<br>a fetch to external program<br>memory. (Active low)                                                                                                                                                                |
| SS     | 5       | Single step input can be used in conjunction with                                                                                                                                                                                                                             |

| Symbol     | Pin No. | Function                                                                                                                                                             |
|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SS (Con't) |         | ALE to "single step" the<br>processor through each<br>instruction (Active low)                                                                                       |
| EA         | 7       | External access input which<br>forces all program memory<br>fetches to reference<br>external memory. Useful<br>for emulation and debug,<br>and essential for testing |

| Symbol | Pin No. | Function                                                                                                  |
|--------|---------|-----------------------------------------------------------------------------------------------------------|
|        |         | and program verification.<br>(Active high)                                                                |
| XTAL1  | 2       | One side of crystal input<br>for internal oscillator. Also<br>input for external source.<br>(Non TTL VIH) |
| XTAL2  | 3       | Other side of crystal input.                                                                              |

#### Table 1. Pin Description (Continued)

#### IDLE MODE DESCRIPTION

The 80C49-7, when placed into Idle mode, keeps the oscillator, the internal timer and the external interrupt and counter pins functioning and maintains the internal register and RAM status.

To place the 80C49-7 in Idle mode, a command instruction (op code 01H) is executed. To terminate Idle mode, a reset must be performed or interrupts must be enabled and an interrupt signal generated. There are two interrupt sources that can restore normal operation. One is an external signal applied to the interrupt pin. The other is from the overflow of the timer/counter. When either interrupt is invoked, the CPU is taken out of Idle mode and vectors to the interrupt's service routine address. Along with the Idle mode, the standard MCS®-48 power-down mode is still maintained.

#### Table 2. Instruction Set

| Accumulator    |                                  | ,,       |        |
|----------------|----------------------------------|----------|--------|
| Mnemonic       | Description                      | Bytes    | Cycles |
| ADD A, R       | Add register to A                | 1        | 1      |
| ADD A, @R      | Add data memory to A             | <u> </u> | 1      |
| ADD A, # data  | Add immediate to A               | 2        | 2      |
| ADDC A, R      | Add register with carry          | 1        | 1      |
| ADDC A, @R     | Add data memory<br>with carry    | 1        | 1      |
| ADDC A, # data | Add immediate<br>with carry      | 2        | 2      |
| ANL A, R       | And register to A                | 1        | 1      |
| ANL A, @R      | And data memory to A             | 1        | 1      |
| ANL A, # data  | And immediate to A               | 2        | 2      |
| ORL A, R       | Or register to A                 | 1        | 1 `    |
| ORL A @R       | Or data memory to A              | 1        | 1      |
| ORL A, # data  | Or immediate to A                | 2        | 2      |
| XRL A, R       | Exclusive₋or register<br>to A    | 1        | 1      |
| XRL A, @R      | Exclusive or data<br>memory to A | 1        | 1      |
| XRL, A, # data | Exclusive or<br>immediate to A   | 2        | 2      |
| INC A          | Increment A                      | ່ 1      | 1      |
| DEC A          | Decrement A                      | 1        | 1      |
| CLR A          | Clear A                          | 1        | 1 ′    |
| 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<br>through carry   | 1        | 1      |
| RR A           | Rotate A right                   | 1        | 1      |
| RRC A          | Rotate A right                   | 1        | 1      |
|                | through carry                    |          |        |
| Input/Output   |                                  |          |        |
|                | Deserverting                     | <b>D</b> | 0      |
|                | Description                      | Bytes    | •      |
| IN A, P        | Input port to A                  | 1        | 2      |

|                 | webbliption               | <i>by</i> (65 | 0,0103 |
|-----------------|---------------------------|---------------|--------|
| IN A, P         | Input port to A           | 1             | 2      |
| OUTL P, A       | Output A to port          | 1             | 2      |
| ANL P, # data   | And immediate to port     | 2             | 2      |
| ORL P, # data   | Or immediate to port      | 2             | 2      |
| INS A, BUS      | Input BUS to A            | 1             | 2      |
| OUTL BUS, A     | Output A to BUS           | 1             | 2      |
| ANL BUS, # data | And immediate to BUS      | 2             | 2      |
| ORL BUS, # data | Or immediate to BUS       | 2             | 2      |
| MOVD A, P       | Input expander port to A  | 1             | 2      |
| MOVD P, A       | Output A to expander port | 1 ·           | ° · 2  |
| ANLD P, A       | And A to expander port    | 1             | 2      |
| ORLD P, A       | Or A to expander port     | 1             | 2      |

| Registers    |                                |       |        |
|--------------|--------------------------------|-------|--------|
| Mnemonic     | Description                    | Bytes | Cycles |
| INC R        | Increment register             | 1     | 1      |
| INC @R       | Increment data memory          | 1     | 1      |
| DEC R        | Decrement register             | 1     | 1      |
| DLON         | Decrement register             |       | '      |
|              |                                |       |        |
| Branch       | *<br>*                         |       |        |
| Mnemonic     | Description                    | Bytes | Cycles |
| JMP addr     | Jump unconditional             | 2     | 2      |
| JMPP @A      | Jump indirect                  | 1     | 2      |
| DJNZ R, addr | Decrement register<br>and skip | 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 T0 = 1                 | 2     | 2      |
| JNT0 addr    | Jump on T0 = 0                 | 2     | 2      |
| JT1 addr     | Jump on T1 = 1                 | 2     | . 2    |
| JNT1 addr    | Jump on T1 = 0                 | 2     | 2      |
| JF0 addr     | Jump on F0 = 1                 | 2     | 2      |
| JF1 addr     | Jump on F1 = 1                 | 2     | 2      |
| JTF addr     | Jump on timer flag             | 2     | 2      |
|              | Jump on INT = 0                | 2     | 2      |
| JBb addr     | Jump on accumulator            | 2     | 2      |
| 000 4441     | bit                            | _     | ,      |
| <u> </u>     |                                |       |        |
| Subroutine   |                                |       |        |
| Mnemonic     | Description                    | Bytes | Cycles |
| CALL addr    | Jump to subroutine             | 2     | 2      |
| RET          | Return                         | 1     | 2      |
| RETR         | Return and restore             | 1     | 2      |
|              | status                         |       |        |
|              | 1                              |       |        |
| Flags        |                                |       |        |
| Mnemonic     | Description                    | Bytes | Cycles |
| CLR C        | Clear carry                    | 1     | 1      |
| CPLC         | Complement carry               | 1     | 1      |
| CLR F0       | Clear flag 0                   | 1     | 1      |
| CPL F0       | Complement flag 0              | 1     | 1 1    |
| CLR F1       | Clear flag 1                   | 1     | 1      |
| CPL F1       | Complement flag 1              | 1     | 1 -    |
|              | · · · ·                        |       |        |
|              | 1 e x                          |       |        |
| -            |                                | • •   |        |
|              |                                |       |        |

| Table 2. In | nstruction Set ( | Continued) |
|-------------|------------------|------------|
|-------------|------------------|------------|

| Data Moves     |                                   |       |        |
|----------------|-----------------------------------|-------|--------|
| Mnemonic       | Description                       | Bytes | Cycles |
| MOV A, R       | Move register to A                | 1     | 1      |
| MOV A, @R      | Move data memory to A             | 1     | 1      |
| MOV A, # data  | Move immediate to A               | 2     | 2      |
| MOV R, A       | Move A to register                | 1     | 1      |
| MOV @R, A      | Move A to data<br>memory          | 1     | 1      |
| MOV R, # data  | Move immediate<br>to register     | 2     | 2      |
| MOV @R, # data | Move immediate to<br>data memory  | 2     | 2      |
| MOV A, PSW     | Move PSW to A                     | 1     | 1      |
| MOV PSW, A     | Move A to PSW                     | 1     | 1      |
| XCH A, R       | Exchange A and<br>register        | 1     | 1      |
| XCH A, @R      | Exchange A and data memory        | 1     | 1      |
| XCHD A, @R     | Exchange nibble of A and register | 1     | 1      |
| MOVX A, @R     | Move external data memory to A    | 1     | 2      |
| MOVX @R, A     | Move A to external data memory    | 1     | 2      |
| MOVP A, @A     | Move to A from<br>current page    | 1     | , 2    |
| Movp3 a, @a    | Move to A from page 3             | 1     | 2      |
|                |                                   | ,     |        |
| ł              |                                   |       |        |

| Timer/Counter | · · · · · · · · · · · · · · · · · · · |       |            |
|---------------|---------------------------------------|-------|------------|
| Mnemonic      | Description                           | Bytes | Cycles     |
| MOV A, T      | Read timer/counter                    | 1     | 1          |
| MOV T, A      | Load timer/counter                    | 1     | 1          |
| STRT T        | Start timer                           | 1     | <b>´</b> 1 |
| STRT CNT      | Start counter                         | 1     | 1          |
| STOP TCNT     | Stop timer/counter                    | 1     | 1          |
| EN TCNTI      | Enable timer/counter<br>interrupt     | 1     | 1          |
| DIS TCNTI     | Disable timer/counter interrupt       | 1     | 1          |

| Control   |                               |       |        |
|-----------|-------------------------------|-------|--------|
| Mnemonic  | Description                   | Bytes | Cycles |
| EN I      | Enable external<br>interrupt  | 1     | 1      |
| DIS I     | Disable external<br>interrupt | 1     | 1      |
| SEL RB0   | Select register bank 0        | · 1   | 1      |
| SEL RB1   | Select register bank 1        | . 1   | 1      |
| SEL MB0   | Select memory bank 0          | ์ 1   | 1      |
| SEL MB1   | Select memory bank 1          | 1     | 1      |
| 'ENTO CLK | Enable clock output<br>on T0  | 1     | 1      |
|           |                               |       |        |
| Mnemonic  | Description                   | Bytes | Cycles |

## MnemonicDescriptionBytesCyclesNOPNo operation11IDLSelect Idle Operation11

#### **ABSOLUTE MAXIMUM RATINGS\***

| Ambient Temperature Under Bias 0°C to 70°C<br>Storage Temperature 65°C to + 150°C |  |
|-----------------------------------------------------------------------------------|--|
| Voltage On Any Pin With Respect                                                   |  |
| to Ground                                                                         |  |
| Maximum Voltage On Any Pin                                                        |  |
| With Respect to Ground                                                            |  |
| Power Dissipation 1.0 Watt                                                        |  |

\*NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

15-38

|                    | *                                                          | Limits                       |     |                     |          |                                                      |
|--------------------|------------------------------------------------------------|------------------------------|-----|---------------------|----------|------------------------------------------------------|
| Symbol             | Parameter                                                  | Min                          | Тур | Max                 | Unit     | Test Conditions                                      |
| VIL                | Input Low Voltage<br>(All Except X1, RESET)                | <b>5</b>                     |     | .18 V <sub>CC</sub> | V        | ,                                                    |
| VIL1               | Input Low Voltage X1, RESET                                | -5                           |     | .13 V <sub>CC</sub> | ` ۷      | J                                                    |
| VIH                | Input High Voltage<br>(All Except XTAL1, RESET)            | 0.2 V <sub>CC</sub><br>+ 1.2 |     | Vcc                 | V        |                                                      |
| VIH1               | Input High Voltage (X1, RESET)                             | .7 V <sub>CC</sub>           |     | V <sub>CC</sub>     | V        |                                                      |
| VOL                | Output Low Voltage (BUS)                                   |                              |     | .6                  | V        | $I_{OL} = 2.0 \text{ mA}$                            |
| VOL1               | Output Low Voltage<br>(RD, WR, PSEN, ALE)                  |                              |     | .6                  | v        | l <sub>OL</sub> = 1.8 mA                             |
| VOL2               | Output Low Voltage (PROG)                                  |                              |     | .6                  | V        | $I_{OL} = 1.0 \text{ mA}$                            |
| V <sub>OL3</sub>   | Output Low Voltage<br>(All Other Outputs)                  |                              |     | .6                  | V        | i <sub>OL</sub> = 1.6 mA                             |
| VOH                | Output High Voltage (BUS)                                  | .75 V <sub>CC</sub>          |     |                     | V        | $I_{OH} = -400 \ \mu A$                              |
| VOH1               | Output High Voltage<br>(RD, WR, PSEN, ALE)                 | .75 V <sub>CC</sub>          |     |                     | <b>V</b> | $I_{OH} = -100 \ \mu A$                              |
| VOH2               | Output High Voltage<br>(All Other Outputs)                 | 2.4<br>3.0                   |     |                     | V        | $I_{OH} = -40 \ \mu A$ $I_{OH} = -20 \ \mu A$        |
| IL1                | Input Leakage Current (T1, INT, EA)                        |                              |     | ±5                  | μA       | $V_{SS} \le V_{IN} \le V_{CC}$                       |
| <sup>1</sup> L11 . | Input Leakage Current<br>(P10–P17, P20–P27, SS)            |                              |     | - 500               | μΑ       | $V_{SS} \leq V_{IN} \leq V_{CC}$                     |
| ILO                | Output Leakage Current (BUS, TO)<br>(High Impedance State) |                              |     | ±5                  | μA       | V <sub>SS</sub> ≤ V <sub>IN</sub> ≤ V <sub>CC</sub>  |
| <sup>I</sup> LR    | Input Leakage Current (RESET)                              | - 10                         |     | - 300               | μA       | V <sub>SS</sub> ≤ V <sub>IN</sub> ≤ V <sub>IH1</sub> |
| IPD                | Power Down Standby Current                                 |                              |     | 2                   | μA       | V <sub>DD</sub> = 2.0V RESET ≤ 1                     |

**D.C. CHARACTERISTICS:**  $(T_A = 0^{\circ}C \text{ to } 70^{\circ}C; V_{CC} = V_{DD} = 5V \pm 20\%; |V_{CC} - V_{DD}| \le 1.5V; V_{SS} = 0V)$ 

ICC Active Current (mA)

| V <sub>CC</sub> | 4V  | 5V  | <sup>°</sup> 6V |
|-----------------|-----|-----|-----------------|
| 1 MHz           | 2.5 | 3.3 | 4.0             |
| 6 MHz           | 5   | 6.8 | 8.5             |
| 11 MHz          | 9   | 12  | 15              |

| Icc | Idle | Current           | (m∆) |
|-----|------|-------------------|------|
| -00 |      | • • • • • • • • • |      |

| V <sub>CC</sub> | 4V  | 5V  | 6V  |
|-----------------|-----|-----|-----|
| 1 MHz           | 1.7 | 2.0 | 2.2 |
| 6 MHz           | 2   | 3   | 4   |
| 11 MHz          | 3.5 | 4.8 | 6   |

Absolute Maximum Unloaded Current

#### **ICC Test Conditions:**

#### **ICC** Active

All outputs disconnected T1,  $\overline{INT}$ , SS, T0 connected to HIGH (V<sub>I</sub>) EA,  $\overline{RST}$  connected to LOW (V<sub>I</sub>) XTAL1 External Drive Rise Time = 10 ns, Fall Time = 10 ns XTAL2 No connection V<sub>I</sub>H = V<sub>C</sub>C - 0.5V V<sub>I</sub>L = V<sub>SS</sub> + 0.5V

#### ICC Idle

All outputs disconnected XTAL1 External Drive Rise Time = 10 ns, Fall Time = 10 ns XTAL2 No connection  $V_{IH} = V_{CC} - 0.5V \cdot V_{IL} = V_{SS} + 0.5V$ 

|                   | Parameter                     | f (t)<br>(Note 3) | 11   | MHz . | Unit | Conditions<br>(Note 1) |
|-------------------|-------------------------------|-------------------|------|-------|------|------------------------|
| Symbol            |                               |                   | Min  | Max   |      |                        |
| t                 | Clock Period                  | 1/xtal freq       | 90.9 | 1000  | ns   | (Note 3)               |
| tLL               | ALE Pulse Width               | 3.5t-170          | 150  |       | ns . |                        |
| t <sub>AL</sub>   | Addr Setup to ALE             | 2t-110            | 70   |       | ns   | (Note 2)               |
| t <sub>LA</sub>   | Addr Hold from ALE            | t-40              | 50   |       | ns   |                        |
| tCC1              | Control Pulse Width (RD, WR)  | 7.5t-200          | 480  |       | ns   |                        |
| tCC2              | Control Pulse Width (PSEN)    | 6t-200            | 350  |       | ns   |                        |
| tDW               | Data Setup before WR          | 6.5t-200          | 390  |       | ns   |                        |
| twD               | Data Hold after WR            | t-50              | 40   |       | ns   |                        |
| <sup>t</sup> DR   | Data Hold (RD, PSEN)          | 1.5t-30           | 0    | 110   | ns   |                        |
| <sup>t</sup> RD1  | RD to Data in                 | 6t-170            |      | 350   | ns   |                        |
| t <sub>RD2</sub>  | PSEN to Data in               | 4.5t-170          |      | 190   | ns   |                        |
| t <sub>AW</sub>   | Addr Setup to WR              | 5t-150            | 300  |       | ns   |                        |
| t <sub>AD1</sub>  | Addr Setup to Data (RD)       | 10.5t-220         |      | 730   | ns   | 2.5                    |
| t <sub>AD2</sub>  | Addr Setup to Data (PSEN)     | 7.5t-220          |      | 460   | ns   |                        |
| <sup>t</sup> AFC1 | Addr Float to RD, WR          | 2t-40             | 140  |       | ns   | (Note 2)               |
| tAFC2             | Addr Float to PSEN            | .5t-40            | 10   |       | ns   | (Note 2)               |
| tLAFC1            | ALE to Control (RD, WR)       | 3t-75             | 200  |       | ns   |                        |
| tLAFC2            | ALE to Control (PSEN)         | 1.5t-75           | 60   |       | ns'  |                        |
| <sup>t</sup> CA1  | Control to ALE (RD, WR, PROG) | t-65              | 25   | T     | ns   |                        |
| tCA2              | Control to ALE (PSEN)         | 4t-70             | 290  |       | ns   |                        |
| tCP               | Port Control Setup to PROG    | 1.5t-80           | 50   | '     | ns   |                        |
| t <sub>PC</sub>   | Port Control Hold to PROG     | 4t-260            | 100  |       | ns   |                        |
| t <sub>PR</sub>   | PROG to P2 Input Valid        | 8.5t-120          |      | 650   | ns   |                        |
| tpF               | Input Data Hold from PROG     | 1.5t              | 0    | 140   | ns   | ·                      |
| t <sub>DP</sub>   | Output Data Setup             | 6t-290            | 250  |       | ns   |                        |
| t <sub>PD</sub>   | Output Data Hold              | 1.5t-90           | 40   |       | ns   |                        |
| tpp               | PROG Pulse Width              | 10.5t-250         | 700  |       | ns   |                        |
| tPL               | Port 2 I/O Setup to ALE       | 4t-200            | 160  |       | ns   |                        |
| tLP               | Port 2 I/O Hold to ALE        | 1.5t-120          | 15   | [     | ns   |                        |
| tPV               | Port Output from ALE          | 4.5t+100          |      | 510   | ns   |                        |
| toprr -           | T0 Rep Rate                   | 3t                | 270  |       | ns   |                        |
| tCY               | Cycle Time                    | 15t               | 1.36 | 15.0  | μs   | ×.                     |

**A.C. CHARACTERISTICS:**  $(T_A = 0^{\circ}C \text{ to } 70^{\circ}C; V_{CC} = V_{DD} = 5V \pm 20\%; |V_{CC} - V_{DD}| \le 1.5V; V_{SS} = 0V)$ 

#### Notes:

- 1. Control Outputs CL = 80pF BUS Outputs CL = 150pF
- 2. BUS High Impedance Load 20pF

3. f(t) assumes 50% duty cycle on X1, X2. Maxclock period is for a 1 MHz crystal input.

#### WAVEFORMS

inte







## The RUPI<sup>™</sup>-44 Family

16

### CHAPTER 16 THE RUPI™-44 FAMILY: MICROCONTROLLER WITH ON-CHIP COMMUNICATION CONTROLLER

#### **16.0 INTRODUCTION**

The RUPI-44 family is designed for applications requiring local intelligence at remote nodes, and communication capability among these distributed nodes. The RUPI-44 integrates onto a single chip Intel's highest performance microcontroller, the 8051-core, with an intelligent and high performance Serial communication controller, called the Serial Interface Unit, or SIU. See Figure 16-1. This dual controller architecture allows complex control and high speed data communication functions to be realized cost effectively.

The RUPI-44 family consists of three pin compatible parts:

- 8344—8051 Microcontroller with SIU
- 8044—An 8344 with 4K bytes of on-chip ROM program memory.
- 8744—An 8344 with 4K bytes of on-chip EPROM program memory.

#### **16.1 ARCHITECTURE OVERVIEW**

The 8044's dual controller architecture enables the RUPI to perform complex control tasks and high speed communication in a distributed network environment.

The 8044 microcontroller is the 8051-core, and maintains complete software compatibility with it. The microcontroller contains a powerful CPU with on-chip peripherals, making it capable of serving sophisticated real-time control applications such as instrumentation, industrial control, and intelligent computer peripherals. The microcontroller features on-chip peripherals such as two 16-bit timer/counters and 5 source interrupt capability with programmable priority levels. The microcontroller's high performance CPU executes most instructions in 1 microsecond, and can perform an  $8 \times 8$ multiply in 4 microseconds. The CPU features a Boolean processor that can perform operations on 256 directly addressable bits. 192 bytes of on-chip data RAM can be extended to 64K bytes externally. 4K bytes of on-chip program ROM can be extended to 64K bytes externally. The CPU and SIU run concurrently. See Figure 16-2.

The SIU is designed to perform serial communications with little or no CPU involvement. The SIU supports data rates up to 2.4Mbps, externally clocked, and 375K bps self clocked (i.e., the data clock is recovered by an on-chip digital phase locked loop). SIU hardware supports the HDLC/SDLC protocol: zero bit insertion/deletion, address recognition, cyclic redundancy check, and frame number sequence check are automatically performed.

The SIU's Auto mode greatly reduces communication software overhead. The AUTO mode supports the SDLC Normal Response Mode, by performing secondary station responses in hardware without any CPU involvement. The Auto mode's interrupt control and frame sequence numbering capability eliminates software overhead normally required in conventional systems. By using the Auto mode, the CPU is free to concentrate on real time control of the application.



Figure 16-1. RUPI<sup>™</sup>-44 Dual Controller Architecture



Figure 16-2. Simplified 8044 Block Diagram

16-2

nte

RUPI<sup>m</sup>-44

#### 16.2 THE HDLC/SDLC PROTOCOLS

### 16.2.1 HDLC/SDLC Advantages over Async

The High Level Data Link Control, HDLC, is a standard communication link control established by the International Standards Organization (ISO). SDLC is a subset of HDLC.

HDLC and SDLC are both well recognized standard serial protocols. The Synchronous Data Link Control, SDLC, is an IBM standard communication protocol. IBM originally developed SDLC to provide efficient, reliable and simple communication between terminals and computers.

The major advantages of SDLC/HDLC over Asynchronous communications protocol (Async):

#### • SIMPLE: Data Transparency

- EFFICIENT: Well Defined Message-Level Operation
- RELIABLE: Frame Check Sequence and Frame Numbering

The SDLC reduces system complexity. HDLC/SDLC are "data transparent" protocols. Data transparency means that an arbitrary data stream can be sent without concern that some of data could be mistaken for a protocol controller. Data transparency relieves the communication controller having to detect special characters.

SDLC/HDLC provides more data throughout than Async. SDLC/HDLC runs at Message-level Operation which transmits multiple bytes within the frame. Whereas Async is based on character-level operation. Async transmits or receives a character at a time. Since Async requires start and stop bits in every transmission, there is a considerable waste of overhead compared to SDLC/HDLC.



Figure 16-3. RUPI<sup>™</sup>-44 Supported Network Configurations

Due to SDLC/HDLC's well delineated field (see Figure 16-4) the CPU does not have to interpret character by character to determine control field and information field. In the case of Async, CPU must look at each character to interpret what it means. The practical advantage of such feature is straight forward use of DMA for information transfer.

In addition, SDLC/HDLC further improves Data throughput using implied Acknowledgement of transferred information. A station using SDLC/HDLC may acknowledge previously received information while transmitting different information in the same frame. In addition, up to 7 messages may be outstanding before an acknowledgement is required.

The HDLC/SDLC protocol can be used to realize reliable data links. Reliable Data transmission is ensured at the bit level by sending a frame check sequence. cyclic redundancy checking, within the frame. Reliable frame transmission is ensured by sending a frame number identification with each frame. This means that a receiver can sequentially count received frames and at any time infer what the number of the next frame to be received should be. More important, it provides a means for the receiver to identify to the sender some particular frame that it wishes to have resent because of errors.

### 16.2.2 HDLC/SDLC Networks

In both the HDLC and SDLC line protocols a (Master) primary station controls the overall network (data link) and issues commands to the secondary (Slave) stations. The latter complies with instructions and responds by sending appropriate responses. Whenever a transmitting station must end transmission prematurely, it sends an abort character. Upon detecting an abort character, a receiving station ignores the transmission block called a frame.

RUPI-44 supported HDLC/SDLC network configurations are point to point (half duplex) multipoint (half duplex), and loop. In the loop configuration the stations themselves act as repeaters, so that long links can be easily realized, see Figure 16-3.

#### 16.2.3 Frames

An HDLC/SDLC frame consists of five basic fields: Flag, Address, Control, Data and Error Detection. A frame is bounded by flags—opening and closing flags. An address field is 8 bits wide in SDLC, extendable to 2 or more bytes in HDLC. The control field is also 8 bits wide, extendable to two bytes in HDLC. The SDLC data field or information field may be any number of bytes. The HDLC data field may or may not be on an 8 bit boundary. A powerful error detection code called Frame Check Sequence contains the calculated CRC (Cycle Redundancy Code) for all the bits between the flags. See Figure 16-4.

In HDLC and SDLC are three types of frames; an Information Frame is used to transfer data, a Supervisory Frame is used for control purposes, and a Nonsequenced Frame is used for initialization and control of the secondary stations.

For a more detailed discussion of higher level protocol functions interested readers may refer to the references listed in Section 16.2.6.

#### 16.2.4 Zero Bit Insertion

In data communications, it is desirable to transmit data which can be of arbitrary content. Arbitrary data transmission requires that the data field cannot contain characters which are defined to assist the transmission protocol (like opening flag in HDLC/SDLC communications). This property is referred to as "data transparency". In HDLC/SDLC, this code transparency is made possible by Zero Bit Insertion (ZBI).

The flag has a unique binary bit pattern: 01111110 (7E HEX). To eliminate the possibility of the data field containing a 7E HEX pattern, a bit stuffing technique

| OPENING  | ADDRESS | CONTROL | INFORMATION                           | FRAME CHECK    | CLOSING  |
|----------|---------|---------|---------------------------------------|----------------|----------|
| FLAG     |         | FIELD   | FIELD                                 | SEQUENCE (FCS) | FLAG     |
| 01111110 | 8 BITS  | 8 BITS  | VARIABLE LENGTH<br>(ONLY IN I FRAMES) | 16 BITS        | 01111110 |

Figure 16-4. Frame Format

16-4

called Zero Bit Insertion is used. This technique specifies that during transmission, a binary 0 be inserted by the transmitter after any succession of five contiguous binary 1's. This will ensure that no pattern of  $0 \ 1 \ 1 \ 1 \ 1 \ 1 \ 0$  is ever transmitted between flags. On the receiving side, after receiving the flag, the receiver hardware automatically deletes any 0 following five consecutive 1's. The 8044 performs zero bit insertion and deletion automatically.

#### 16.2.5 Non-return to Zero Inverted (NR21)

NRZI is a method of clock and data encoding that is well suited to the HDLC/SDLC protocol. It allows HDLC/SDLC protocols to be used with low cost asynchronous modems. NRZI coding is done at the transmitter to enable clock recovery from the data at the receiver terminal by using standard digital phase locked loop (DPLL) techniques. NRZI coding specifies that the signal condition does not change for transmitting a 1, while an 0 causes a change of state. NRZI coding ensures that an active data line will have a transition at least every 5-bit times (recall Zero Bit Insertion), while contiguous 0's will cause a change of state. Thus, ZBI and NRZI encoding makes it possible for the 8044's onchip DPLL to recover a receive clock (from received data) synchronized to the received data and at the same time ensure data transparency.

#### 16.2.6 References

- 1. IBM Synchronous Data Link Control General Information GA27-3093-2 File No. GENL-09.
- 2. Standard Network Access Protocol Specification, DATAPAC Trans-Canada Telephone System CCG111.
- 3. IBM 3650 Retail Store System Loop Interface OEM Information, IBM, GA27-3098-0
- 4. Guidebook to Data Communications, Training Manual, Hewlett-Packard 5955-1715
- "Serial Backplane Suits Multiprocessor Architectures", Mike Webb, Computer Design, July 1984, p. 85-96.
- "Serial Bus Simplifies Distributed Control", P.D. MacWilliams, Control Engineering, June 1984, p. 101-104.
- 7. "Chips Support Two Local Area Networks", Bob Dahlberg, Computer Design, May 1984, p. 107-114.
- "Build a VLSI-based Workstation for the Ethernet Environment", Mike Webb, EDN, 23 February 1984, p. 297-307.
- 9. "Networking With the 8044", Young Sohn & Charles Gopen, Digital Design, May 1984, p. 136-137.

#### 16.3 RUPI™-44 DESIGN SUPPORT

#### 16.3.1 Design Tool Support

A critical design consideration is time to market. Intel provides a sophisticated set of design tools to speed hardware and software development time of 8044 based products. These include ICE-44, ASM-51, PL/M-51, and EMV-44.



#### Figure 16-5. RUPI<sup>™</sup>-44 Development Support Configuration Intellec® System, ICE<sup>™</sup>-44 Buffer Box, and ICE-44 Module Plugged into a User Prototype Board.

A primary tool is the 8044 In Circuit Emulator, called ICE-44. See Figure 16-5. In conjunction with Intel's Intellec<sup>®</sup> Microprocessor Development System, the ICE-44 emulator allows hardware and software development to proceed interactively. This approach is more effective than the traditional method of independent hardware and software development followed by system integration. With the ICE-44 module, prototype hardware and hardware and hardware integration occurs while the product is being developed.

The ICE-44 emulator assists four stages of development:

1) Software Debugging

It can be operated without being connected to the user's system before any of the user's hardware is available. In this stage ICE-44 debugging capabilities can be used in conjunction with the Intellec text ediRUPI<sup>™</sup>-44

tor and 8044 macroassembler to facilitate program development.

2) Hardware Development

The ICE-44 module's precise emulation characteristics and full-speed program RAM make it a valuable tool for debugging hardware, including the timecritical SDLC serial port, parallel port, and timer interfaces.

3) System Integration

Integration of software and hardware can begin when any functional element of the user system hardware is connected to the 8044 socket. As each section of the user's hardware is completed, it is added to the prototype. Thus, each section of the hardware and software is system tested in real-time operation as it becomes available.

4) System Test

When the user's prototype is complete, it is tested with the final version of the user system software. The ICE-44 module is then used for real-time emulation of the 8044 to debug the system as a completed unit.

The final product verification test may be performed using the 8744 EPROM version of the 8044 microcomputer. Thus, the ICE-44 module provides the user with the ability to debug a prototype or production system at any stage in its development.

A conversion kit, ICE-44 CON, is available to upgrade an ICE-51 module to ICE-44.

Intel's ASM-51 Assembler supports the 8044 special function registers and assembly program development. PL/M-51 provides designers with a high level language for the 8044. Programming in PL/M can greatly reduce development time, and ensure quick time to market.

These tools have recently been expanded with the addition of the EMV-44CON. This conversion kit allows you to convert an EMV-51 into an EMV-44 emulation vehicle. The resultant low cost emulator is design for use

with an iPDS Personal Development System, which also supports the ASM-51 assembler and  $PL/\dot{M}$ -51. See Figure 16-6.



#### Figure 16-6. RUPI-44 iPDS Personal Development System, EMV-44 Buffer Box, and EMV-44 Module Plugged into a User Prototype Board.

Emulation support is similar to the ICE-44 with support for Software and Hardware Development, System Integration, and System Test. The iPDS's rugged portability and ease of use also make it an ideal system for production tests and field service of your finished design. In addition, the iPDS offers EPROM programming module for the 8744, and direct communications with the 8044-based BITBUS via an optional iSBX 344 distributed control module.

#### 16.3.2 8051 Workshop

Intel provides 8051 training to its customers through the 5-day 8051 workshop. Familiarity with the 8051 and 8044 is achieved through a combination of lecture and laboratory exercises.

For designers not familiar with the 8051, the workshop is an effective way to become proficient with the 8051 architecture and capabilities.

# 8044 Architecture

17

### CHAPTER 17 8044 ARCHITECTURE

#### 17.0 GENERAL

The 8044 is based on the 8051 core. The 8044 replaces the 8051's serial port with an intelligent HDLC/SDLC controller called the Serial Interface or SIU. Thus the differences between the two result from the 8044's increased on-chip RAM (192 bytes) and additional special function registers necessary to control the SIU. Aside from the increased memory, the SIU itself, and differences in 5 pins (for the serial port), the 8044 and 8051 are compatible.

This chapter describes the differences between the 8044 and 8051. Information pertaining to the 8051 core, eg. instruction set, port operation, EPROM programming, etc. is located in the 8051 sections of this manual.

A block diagram of the 8044 is shown in Figure 17-1. The pinpoint is shown on the inside front cover.

#### 17.1 MEMORY ORGANIZATION OVERVIEW

The 8044 maintains separate address spaces for Program Memory and Data Memory. The Program Memory can be up to 64K bytes long, of which the lowest 4K bytes are in the on-chip ROM.

If the  $\overline{EA}$  pin is held high, the 8044 executes out of internal ROM unless the Program Counter exceeds 0FFFH. Fetches from locations 1000H through FFFFH are directed to external Program Memory.

If the  $\overline{EA}$  pin is held low, the 8044 fetches all instructions from external Program Memory.

The Data Memory consists of 192 bytes of on-chip RAM, plus 35 Special Function Registers, in addition to which the device is capable of accessing up to 64K bytes of external data memory.

The Program Memory uses 16-bit addresses. The external Data Memory can use either 8-bit or 16-bit addresses. The internal Data Memory uses 8-bit addresses, which provide a 256-location address space. The lower 192 addresses access the on-chip RAM. The Special Function Registers occupy various locations in the upper 128 bytes of the same address space.

The lowest 32 bytes in the internal RAM (locations 00 through 1FH) are divided into 4 banks of registers, each bank consisting of 8 bytes. Any one of these banks can be selected to be the "working registers" of the CPU, and can be accessed by a 3-bit address in the same byte as the opcode of an instruction. Thus, a large number of instructions are one-byte instructions.

The next higher 16 bytes of the internal RAM (locations 20H through 2FH) have individually addressable bits. These are provided for use as software flags or for onebit (Boolean) processing. This bit-addressing capability is an important feature of the 8044. In addition to the 128 individually addressable bits in RAM, twelve of the Special Function Registers also have individually addressable bits.

A memory map is shown in Figure 17-2.

#### 17.1.1 Special Function Registers

The Special Function Registers are as follows:

| * | ACC        | Accumulator (A Register)        |  |  |  |
|---|------------|---------------------------------|--|--|--|
| * | В          | B Register                      |  |  |  |
| * | PSW        | Program Status Word             |  |  |  |
|   | SP         | Stack Pointer                   |  |  |  |
|   | DPTR       | Data Pointer (consisting of DPH |  |  |  |
|   |            | AND DPL)                        |  |  |  |
| * | <b>P</b> 0 | Port 0                          |  |  |  |
| * | Pl         | Port 1                          |  |  |  |
| * | P2         | Port 2                          |  |  |  |
| * | P3         | Port 3                          |  |  |  |
| * | IP         | Interrupt Priority              |  |  |  |
| * | IE         | Interrupt Enable                |  |  |  |
|   | TMOD       | Timer/Counter Mode              |  |  |  |
| * | TCON       | Timer/Counter Control           |  |  |  |
|   | TH0        | Timer/Counter 0 (high byte)     |  |  |  |
|   | TL0        | Timer/Counter 0 (low byte)      |  |  |  |
|   | THI        | Timer/Counter 1 (high byte)     |  |  |  |
|   | TLI        | Timer/Counter 1 (low byte)      |  |  |  |
|   | SMD        | Serial Mode                     |  |  |  |
| * | STS        | Status/Command                  |  |  |  |
| * | NSNR       | Send/Receive Count              |  |  |  |
|   | STAD       | Station Address                 |  |  |  |
|   | TBS        | Transmit Buffer Start Address   |  |  |  |
|   | TBL        | Transmit Buffer Length          |  |  |  |
|   | тсв        | Transmit Control Byte           |  |  |  |
| - | RBS        | Receive Buffer Start Address    |  |  |  |
|   | RBL        | Receive Buffer Length           |  |  |  |
|   | RFL        | Received Field Length           |  |  |  |
|   | RCB        | Received Control Byte           |  |  |  |
|   | DMA CNT    | DMA Count                       |  |  |  |
|   | FIFO       | FIFO (three bytes)              |  |  |  |
|   | SIUST      | SIU State Counter               |  |  |  |
|   | PCON       | Power Control                   |  |  |  |
|   |            |                                 |  |  |  |

The registers marked with \* are both byte- and bitaddressable.



RUPI<sup>m</sup>-44



17-2

FFFF FFFF EXTERNAL 1000 OFFF OFFF OVERLAPPED SPACE INTERNAL (EA 1) EXTERNAL FF SPECIAL REGISTERS INTERNAL DATA RAM 00 0000 0000 0000 EXTERNAL DATA MEMORY INTERNAL DATA MEMORY PROGRAM MEMORY

Figure 17-2. RUPI™-44 Memory Map

#### **Stack Pointer**

The Stack Pointer is 8 bits wide. The stack can reside anywhere in the 192 bytes of on-chip RAM. When the 8044 is reset, the stack pointer is initialized to 07H. When executing a PUSH or a CALL, the stack pointer is incremented before data is stored, so the stack would begin at location 08H.

#### 17.1.2 Interrupt Control Registers

The Interrupt Request Flags are as listed below:

| Source                | Request Flag                                                               | Location       |
|-----------------------|----------------------------------------------------------------------------|----------------|
| External Interrupt 0  | $\overline{\text{INT0}}$ , if $\text{IT0} = 0$<br>IE0, if $\text{IT0} = 1$ | P3.2<br>TCON.1 |
| Timer 0 Overflow      | TF0                                                                        | TCON.5         |
| External Interrupt 1  | $\overline{\text{INT1}}$ , if IT1 = 0<br>IE1, if IT1 = 1                   | P3.3<br>TCON.3 |
| Timer 1 Overflow      | TF1                                                                        | TCON.7         |
| Serial Interface Unit | SI                                                                         | STS.4          |

External Interrupt control bits IT0 and IT1 are in TCON.0 and TCON.2, respectively. Reset leaves all flags inactive, with IT0 and IT1 cleared.

All the interrupt flags can be set or cleared by software, with the same effect as by hardware.

The Enable and Priority Control Registers are shown below. All of these control bits are set or cleared by software. All are cleared by reset.

#### IE: Interrupt Enable Register (bit-addressable)

| Bit: | 7  | 6 | 5 | 4  | 3   | 2   | 1   | 0   |  |
|------|----|---|---|----|-----|-----|-----|-----|--|
|      | EA | X | X | ES | ET1 | EX1 | ET0 | EX0 |  |

where:

EA disables all interrupts. If EA = 0, no interrupt will be acknowledged. If EA = 1, each interrupt source is individually enabled or disabled by setting or clearing its enable bit.

17-3

- ES enables or disables the Serial Interface Unit interrupt. If ES = 0, the Serial Interface Unit interrupt is disabled.
- ET1 enables or disables the Timer 1 Overflow interrupt. If ET1 = 0, the Timer 1 interrupt is disabled.
- EX1 enables or disables External Interrupt 1. If EX1 = 0, External Interrupt 1 is disabled.
- ET0 enables or disables the Timer 0 Overflow interrupt. If ET0 = 0, the Timer 0 interrupt is disabled.

#### IP: Interrupt Priority Register (bit-addressable)

| Bit: | 7 | 6 | 5 | 4  | 3   | 2   | 1   | 0   |  |
|------|---|---|---|----|-----|-----|-----|-----|--|
|      | X | Х | X | PS | PT1 | PX1 | PT0 | PX0 |  |

where:

- PS defines the Serial Interface Unit interrupt priority level. PS = 1 programs it to the higher priority level.
- PT1 defines the Timer 1 interrupt priority level. PT1 = 1 programs it to the higher priority level.
- PX1 defines the External Interrupt 1 priority level. PX1 = 1 programs it to the higher priority level.
- PT0 defines the Timer 0 interrupt priority level. PT0 = 1 programs it to the higher priority level.
- PX0 defines the External Interrupt 0 priority level. PX0 = 1 programs it to the higher priority level.

#### 17.2 Memory Organization Details

In the 8044 family the memory is organized over three address spaces and the program counter. The memory spaces shown in Figure 18-2 are the:

- 64K-byte Program Memory address space
- 64K-byte External Data Memory address space
- 320-byte Internal Data Memory address space

The 16-bit Program Counter register provides the 8044 with its 64K addressing capabilities. The Program Counter allows the user to execute calls and branches to any location within the Program Memory space. There are no instructions that permit program execution to move from the Program Memory space to any of the data memory spaces.

In the 8044 and 8744 the lower 4K of the 64K Program Memory address space is filled by internal ROM and EPROM, respectively. By tying the  $\overline{EA}$  pin high, the processor can be forced to fetch from the internal ROM/EPROM for Program Memory addresses 0 through 4K: Bus expansion for accessing Program Memory beyond 4K is automatic since external instruction fetches occur automatically when the Program Counter increases above 4095. If the EA pin is tied low all Program Memory fetches are from external memory. The execution speed of the 8044 is the same regardless of whether fetches are from internal or external Program Memory. If all program storage is on-chip, byte location 4095 should be left vacant to prevent an undesired prefetch from external Program Memory address 4096.

Certain locations in Program Memory are reserved for specific programs. Locations 0000 through 0002 are reserved for the initialization program. Following reset, the CPU always begins execution at location 0000. Locations 0003 through 0042 are reserved for the five interrupt-request service programs. Each resource that can request an interrupt requires that its service program be stored at its reserved location.

The 64K-byte External Data Memory address space is automatically accessed when the MOVX instruction is executed.

Functionally the Internal Data Memory is the most flexible of the address spaces. The Internal Data Memory space is subdivided into a 256-byte Internal Data RAM address space and a 128-byte Special Function Register address space as shown in Figure 17-3.

The Internal Data RAM address space is 0 to 255. Four 8-Register Banks occupy locations 0 through 31. The stack can be located anywhere in the Internal Data RAM address space. In addition, 128 bit locations of the on-chip RAM are accessible through Direct Addressing. These bits reside in Internal Data RAM at byte locations 32 through 47. Currently locations 0 through 191 of the Internal Data RAM address space are filled with on-chip RAM.

The stack depth is limited only by the available Internal Data RAM, thanks to an 8-bit reloadable Stack Pointer. The stack is used for storing the Program Counter during subroutine calls and may be used for passing parameters. Any byte of Internal Data RAM or Special Function Register accessible through Direct Addressing can be pushed/popped.



Figure 17-3. Internal Data Memory Address Space

The Special Function Register address space is 128 to 255. All registers except the Program Counter and the four 8-Register Banks reside here. Memory mapping the Special Function Registers allows them to be accessed as easily as internal RAM. As such, they can be operated on by most instructions. In the overlapping memory space (address 128-191), indirect addressing is used to access RAM, and direct addressing is used to access the SFR's at addresses 192-255 are also accessed using direct addressing. The Special Function Registers are listed in Figure 17-4. Their mapping in the Special Function Register address space is shown in Figures 17-5 and 17-6.

Performing a read from a location of the Internal Data memory where neither a byte of Internal Data RAM (i.e., RAM addresses 192-255) nor a Special Function Register exists will access data of indeterminable value.

Architecturally, each memory space is a linear sequence of 8-bit wide bytes. By Intel convention the storage of multi-byte address and data operands in program and data memories is the least significant byte at the loworder address and the most significant byte at the highorder address. Within byte X, the most significant bit is



Figure 17-4. Special Function Registers

represented by X.7 while the least significant bit is X.0. Any deviation from these conventions will be explicitly stated in the text.

#### 17.2.1 Operand Addressing

There are five methods of addressing source operands. They are Register Addressing, Direct Addressing, Register-Indirect Addressing, Immediate Addressing and Base-Register-plus Index-Register-Indirect Addressing. The first three of these methods can also be used to address a destination operand. Since operations in the 8044 require 0 (NOP only), 1, 2, 3 or 4 operands, these five addressing methods are used in combinations to provide the 8044 with its 21 addressing modes.

Most instructions have a "destination, source" field that specifies the data type, addressing methods and operands involved. For operations other than moves, the destination operand is also a source operand. For example, in "subtract-with-borrow A, #5" the A register receives the result of the value in register A minus 5, minus C.

Most operations involve operands that are located in Internal Data Memory. The selection of the Program Memory space or External Data Memory space for a

| ARITHMETIC REGISTERS:                         |  |
|-----------------------------------------------|--|
| Accumulator*, B register*,                    |  |
| Progam Status Word*                           |  |
| POINTERS:                                     |  |
| Stack Pointer, Data Pointer (high &           |  |
| low)                                          |  |
| PARALLEL I/O PORTS:                           |  |
|                                               |  |
| Port 3*, Port 2*, Port 1*, Port 0*            |  |
| INTERRUPT SYSTEM:                             |  |
| Interrupt Priority Control*,                  |  |
| Interrupt Enable Control*                     |  |
| TIMERS:                                       |  |
| Timer Mode, Timer Control*, Timer 1           |  |
| (high & low), Timer 0 (high & low)            |  |
| SERIAL INTERFACE UNIT:                        |  |
| Serial Mode, Status/Command*,                 |  |
| Send/Receive Count*, Station Address,         |  |
| Transmit Buffer Start Address,                |  |
| Transmit Buffer Length,                       |  |
| Transmit Control Byte,                        |  |
| Receive Buffer Start Address,                 |  |
| Receive Buffer Length,                        |  |
| Receive Field Length,                         |  |
| Receive Control Byte,                         |  |
| DMA Count,                                    |  |
| FIFO (three bytes),                           |  |
| SIU Controller State Counter                  |  |
|                                               |  |
|                                               |  |
| * Bits in these registers are bit-addressable |  |
|                                               |  |

#### Figure 17-5. Mapping of Special Function Registers

second operand is determined by the operation mnemonic unless it is an immediate operand. The subset of the Internal Data Memory being addressed is determined by the addressing method and address value. For example, the Special Function Registers can be accessed only through Direct Addressing with an address of 128– 255. A summary of the operand addressing methods is shown in Figure 17-6. The following paragraphs describe the five addressing methods.

#### 17.2.2 Register Addressing

Register Addressing permits access to the eight registers (R7-R0) of the selected Register Bank (RB). One of the four 8-Register Banks is selected by a two-bit field in the PSW. The registers may also be accessed through Direct Addressing and Register-Indirect Addressing, since the four Register Banks are mapped into the lowest 32 bytes of Internal Data RAM as shown in Figures 17-9 and 17-10. Other Internal Data Memory locations that are addressed as registers are A, B, C, AB and DPTR.

| REGISTER NAMES                     | ADDRESS  | B     | IT ADDRESS | 6          | ADI   | DRESS |                         |
|------------------------------------|----------|-------|------------|------------|-------|-------|-------------------------|
|                                    | $\frown$ |       |            |            |       | •     | г                       |
| B REGISTER                         | в        | 247   | through    | 240        | 240   | (FOH) | 1                       |
| ACCUMULATOR                        | ACC      | 231   | through    | 224        | 224   | (E0H) |                         |
| *THREE BYTE FIFO                   | FIFO     |       |            |            | 223   | (DFH) |                         |
|                                    | FIFO     | · · · |            |            | 222   | (DEH) |                         |
|                                    | FIFO     |       |            |            | .221  | (DDH) |                         |
| TRANSMIT BUFFER START              | TBS      |       |            |            | 220   | (DCH) |                         |
| TRANSMIT BUFFER LENGTH             | TBL      |       |            |            | 219   | (DBH) |                         |
| TRANSMIT CONTROL BYTE              | TCB      |       |            |            | 218   | (DAH) |                         |
| *SIU STATE COUNTER                 | SIUST    |       |            |            | 217   | (D9H) |                         |
| SEND COUNT RECEIVE COUNT           | NSNR     | 223   | through    | 216        | 216   | (D8H) |                         |
| PROGRAM STATUS WORD                | PSW      | 215   | through    | 208        | 208   | (D0H) | 1                       |
| *DMA COUNT                         | DMA CNT  |       |            |            | 207   | (CFH) |                         |
| STATION ADDRESS                    | STAD     |       |            |            | 206   | (CEH) |                         |
| RECEIVE FIELD LENGTH               | RFL      |       |            |            | 205   | (CDH) |                         |
| RECEIVE BUFFER START               | RBS      |       |            |            | 204   | (CCH) |                         |
| RECEIVE BUFFER LENGTH              | RBL      |       |            |            | 203   | (CBH) | SFR's CONTAINING        |
| RECEIVE CONTROL BYTE               | RCB.     | - N   |            |            | 202   | (CAH) | DIRECT ADDRESSABLE BITS |
| SERIAL MODE                        | SMD      |       |            |            | 201   | (C9H) |                         |
| STATUS REGISTER                    | STŚ      | 207   | through    | 200        | 200   | (C8H) | f <sup>1</sup>          |
| INTERRUPT PRIORITY CONTROL         | IP       | 191   | through    | 184        | 184   | (B8H) | 4                       |
| PORT 3                             | P3       | 183   | through    | 176        | 176   | (B0H) | 4                       |
| INTERRUPT ENABLE CONTROL           | IE       | 175   | through    | 168        | 168   | (A8H) | 4                       |
| PORT 2                             | P2       | 167   | through    | 160        | 160   | (A0H) |                         |
| PORT 1                             | P1       | 151   | through    | 144        | 144   | (90H) | 4                       |
| TIMER HIGH 1                       | TH1      |       |            |            | 141   | (8DH) |                         |
| TIMER HIGH 0                       | TH0      |       |            |            | 140   | (8CH) |                         |
| TIMER LOW 1                        | TL1      |       |            |            | 139   | (8BH) |                         |
| TIMER LOW 0                        | TLO      |       |            |            | 138   | (8AH) |                         |
| TIMER MODE                         | TMOD     |       |            |            | 137   | (89H) | 1                       |
| TIMER CONTROL                      | TCON     | 143   | through    | 136        | 136   | (88H) | • ·                     |
| DATA POINTER HIGH                  | DPH      |       |            |            | 131   | (83H) |                         |
| DATA POINTER LOW                   | DPL ;    |       |            | <u>```</u> | 130   | (82H) |                         |
| STACK POINTER                      | SP       |       |            |            | 129   | (81H) |                         |
| PORT 0                             | PO       | 135   | through    | 128        | ] 128 | (80H) |                         |
| *ICE Support Hardware registers. L |          |       |            |            |       |       |                         |

Figure 17-6. Mapping of Special Function Registers



Figure 17-7. Special Function Register Bit Address



Figure 17-9. RAM Bit Addresses



Figure 17-8. Operand Addressing Methods



Figure 17-10. Addressing Operands in Internal Data Memory

#### 17.2.3 Direct Addressing

Direct Addressing provides the only means of accessing the memory-mapped byte-wide Special Function Registers and memory mapped bits within the Special Function Registers and Internal Data RAM. Direct Addressing of bytes may also be used to access the lower 128 bytes of Internal Data RAM. Direct Addressing of bits gains access to a 128 bit subset of the Internal Data RAM and 128 bit subset of the Special Function Registers as shown in Figures 17-5, 17-6, 17-9, and 17-10.

Register-Indirect Addressing using the content of R1 or R0 in the selected Register Bank, or using the content of the Stack Pointer (PUSH and POP only), addresses the Internal Data RAM. Register-Indirect Addressing is also used for accessing the External Data Memory. In this case, either R1 or R0 in the selected Register Bank may be used for accessing locations within a 256-byte block. The block number can be preselected by the contents of a port. The 16-bit Data Pointer may be used for accessing any location within the full 64K external address space.

#### 17.3 RESET

Reset is accomplished by holding the RST pin high for at least two machine cycles (24 oscillator periods) while the oscillator is running. The CPU responds by executing an internal reset. It also configures the ALE and PSEN pins as inputs. (They are quasi-bidirectional.) The internal reset is executed during the second cycle in which RST is high and is repeated every cycle until RST goes low. It leaves the internal registers as follows:

| Register |      | Content    |
|----------|------|------------|
| PC       |      | 0000H      |
| Α        | · `` | 00H        |
| В        |      | 00H        |
| PSW      |      | 00H        |
| SP       |      | 07H        |
| DPTR     |      | 0000H      |
| P0 - P3  |      | 0FFH       |
| IP       |      | (XXX00000) |
| IE       |      | (0XX00000) |
| TMOD     |      | 00H        |
| TCON     |      | 00H        |
| TH0      |      | 00H        |
| TL0      |      | 00H        |
| тні      |      | 00H        |
| TL1      |      | 00H        |

| SMD     | 00H        |
|---------|------------|
| STS     | 00H        |
| NSNR    | 00H        |
| STAD    | 00H        |
| TBS     | 00H        |
| TBL     | 00H        |
| ТСВ     | 00H        |
| RBS     | 00H        |
| RBL     | 00H        |
| RFL     | 00H        |
| RCB     | 00H        |
| DMA CNT | 00H        |
| FIFO1   | 00H        |
| FIFO2   | 00H        |
| FIFO3   | 00H        |
| SIUST   | 01H        |
| PCON    | (0XXXXXXX) |
|         |            |

The internal RAM is not affected by reset. When VCC is turned on, the RAM content is indeterminate unless VPD was applied prior to VCC being turned off (see Power Down Operation.)

#### 17.4 RUPI™-44 FAMILY PIN DESCRIPTION

#### **VSS:** Circuit ground potential.

VCC: Supply voltage during programming (of the 8744), verification (of the 8044 or 8744), and normal operation.

**Port 0:** Port 0 is an 8-bit open drain bidirectional I/O port. It is also the multiplexed low-order address and data bus during accesses to external memory (during which accesses it activates internal pullups). It also outputs instruction bytes during program verification. (External pullups are required during program verification.) Port 0 can sink eight LS TTL inputs.

**Port 1:** Port 1 is an 8-bit bidirectional I/O port with internal pullups. It receives the low-order address byte during program verification in the 8044 or 8744. Port 1 can sink/source four LS TTL inputs. It can drive MOS inputs without external pullups.

Two of the Port 1 pins serve alternate functions, as listed below:

#### Port Pin Alternate Function

P1.6 RTS (Request to Send). In a non-loop configuration, RTS signals that the 8044 is ready to transmit data. P1.7 CTS (Clear to Send). In a non-loop configuration, CTS signals to the 8044 that the receiving station is ready to accept data.

**Port 2:** Port 2 is an 8-bit bidirectional I/O port with internal pullups. It emits the high-order address byte during accesses to external memory. It also receives the high-order address bits and control signals during program verification in the 8044 or 8744. Port 2 can sink/ source four LS TTL inputs. It can drive MOS inputs without external pullups.

**Port 3:** Port 3 is an 8-bit bidirectional I/O port with internal pullups. Port 3 can sink/source four LS TTL inputs. It can drive MOS inputs without external pullups.

Port 3 pins also serve alternate functions, as listed below:

#### Port Pin Alternate Function

- P3.0 RXD (serial input port in loop configuration).  $I/\overline{O}$  (data direction control in nonloop configuration).
- P3.1 TXD (serial output port in loop configuration). DATA input/output pin in nonloop configuration.
- P3.2 **INTO** (external interrupt)
- P3.3 **INT1** (external interrupt)
- P3.4 T0 (Timer 0 external input)
- P3.5 T1 (Timer 1 external input) SCLK (Serial Data Clock Input)
- P3.6 WR (external Data Memory write strobe)
- P3.7 RD (external Data Memory read strobe)

**RST/VPD:** A high level on this pin for two machine cycles while the oscillator is running resets the device. An

internal pulldown permits Power-On reset using only a capacitor connected to VCC.

**ALE/PROG:** Address Latch Enable output for latching the low byte of the address during accesses to external memory. ALE is activated though for this purpose at a constant rate of 1/6 the oscillator frequency even when external memory is not being accessed. Consequently it can be used for external clocking or timing purposes. (However, one ALE pulse is skipped during each access to external *Data* Memory.) This pin is also the program pulse input (PROG) during EPROM programming.

**PSEN:** Program Store Enable <u>output</u> is the read strobe to external Program Memory. <u>PSEN</u> is activated twice each machine cycle during fetches from external Program Memory. (However, when executing <u>out of exter-</u> nal Program Memory two activations of <u>PSEN</u> are <u>skipped</u> during each access to external *Data* Memory.) <u>PSEN</u> is not activated during fetches from internal Program Memory.

**EA**/VPP: When EA is held high the CPU executes out of internal Program Memory (unless the Program Counter exceeds (0FFFH). When EA is held low the CPU executes only out of external Program Memory. In the 8344, EA must be externally wired low. In the 8744, this pin also receives the 21V programming supply voltage (VPP) during EPROM programming.

**XTAL1:** Input to the inverting amplifier that forms the oscillator. Should be grounded when an external oscillator is used.

**XTAL2:** Output of the inverting amplifier that forms the oscillator, and input to the internal clock generator. Receives the external oscillator signal when an external oscillator is used.

•

## **8044 Serial Interface**

18



and sector in the sector of the sector of the sector of the sector of the sector of the sector of the sector of The sector of the sector of the sector of the sector of the sector of the sector of the sector of the sector of 

. .

· · · ·

### CHAPTER 18 THE 8044 SERIAL INTERFACE UNIT

#### **18.0 SERIAL INTERFACE**

The serial interface provides a high-performance communication link. The protocol used for this communication is based on the IBM Synchronous Data Link Control (SDLC). The serial interface also supports a subset of the ISO HDLC (International Standards Organization High-Level Data Link Control) protocol.

The SDLC/HDLC protocols have been accepted as standard protocols for many high-level teleprocessing systems. The serial interface performs many of the functions required to service the data link without intervention from the 8044's own CPU. The programmer is free to concentrate on the 8044's function as a peripheral controller, rather than having to deal with the details of the communication process.

Five pins on the 8044 are involved with the serial interface (refer to Section 12.4, Family Pin Description, for details):

| Pin 7  | RTS/P16      |
|--------|--------------|
| Pin 8  | CTS/P17      |
| Pin 10 | I/O/RXD/P30  |
| Pin 11 | DATA/TXD/P31 |
| Pin 15 | SCLK/T1/P35  |
|        |              |

Figure 18-1 is a functional block diagram of the serial interface unit (SIU). More details on the SIU hardware are given in Section 18.9.

#### **18.1 DATA LINK CONFIGURATIONS**

The serial interface is capable of operating in three serial data link configurations:

- 1) Half-Duplex, point-to-point
- Half-Duplex, multipoint (with a half-duplex or fullduplex primary)
- 3) Loop

Figure 18-2 shows these three configurations. The RTS (Request to Send) and CTS (Clear to Send) handshaking signals are available in the point-to-point and multipoint configurations.

#### **18.2 DATA CLOCKING OPTIONS**

The serial interface can operate in an externally clocked mode or in a self clocked mode.

#### **Externally Clocked Mode**

In the externally clocked mode, a common Serial Data Clock (SCLK on pin 15) synchronizes the serial bit stream. This clock signal may come from the master CPU or primary station, or from an external phaselocked loop local to the 8044. Figure 18-3 illustrates the timing relationships for the serial interface signals when the externally clocked mode is used in point-to-point and multipoint data link configurations.

Incoming data is sampled at the rising edge of SCLK, and outgoing data is shifted out at the falling edge of SCLK. More detailed timing information is given in the 8044 data sheet.

#### Self Clocked (Asynchronous) Mode

The self clocked mode allows data transfer without a common system data clock. Using an on-chip DPLL (digital phase locked loop) the serial interface recovers the data clock from the data stream itself. The DPLL requires a reference clock equal to either 16 times or 32 times the data rate. This reference clock may be externally supplied or internally generated. When the serial interface generates this clock internally, it uses either the 8044's internal logic clock (half the crystal frequency's PH2) or the "timer 1" overflow. Figure 18-4 shows the serial interface signal timing relationships for the loop configuration, when the unclocked mode is used.

The DPLL monitors the received data in order to derive a data clock that is centered on the received bits. Centering is achieved by detecting all transitions of the received data, and then adjusting the clock transition (in increments of 1/16 bit period) toward the center of the received bit. The DPLL converges to the nominal bit center within eight bit transitions, worst case.

To aid in the phase locked loop capture process, the 8044 has a NRZI (non-return-to-zero inverted) data encoding and decoding option. NRZI coding specifies that a signal does not change state for a transmitted binary 1, but does change state for a binary 0. Using the NRZI coding with zero-bit insertion, it can be guaranteed that an active signal line undergoes a transition at least every six bit times.

#### **18.3 DATA RATES**

The maximum data rate in the externally clocked mode is 2.4M bits per second (bps) a half-duplex configuration, and 1.0M in a loop configuration.

PH2 -BIT PROCESSOR BYTE PROCESSOR TIMER 4 OVERFLOW - 2 SYNCHRONIZED & DIGITAL PHASE LOCK LOCK SCLK RXD > CONTROL SAMPLE & HOLD BIT TIMING GENERATOR ZERO INSERTION/ DELETION LOGIC SYNCHRONZIED RB TEMP START DETECT & NRZI DECODE LOGIC TXD ◄ SCND < SIUST r NRZI ENCODE LOGIC SERIAL/PARALLEL CONVERT LOGIC CONDITION LOGIC ALU FCS GEN/CHK SERIAL INTERFACE BUS SRAR SIU HARDWARE REGISTER (2 PORT) INTERNAL TWO PORT RAM RAR 18

Figure 18-1 . SIU Block Diagram

18-2

RUPI™–44



RUPI<sup>™</sup>-44

Figure 18-2 . RUPI-44 Data Link Configurations

In the self clocked mode with an external reference clock, the maximum data rate is 375K bps.

In the self clocked mode with an internally generated reference clock, and the 8044 operating with a 12 MHz crystal, the available data rates are 244 bps to 62.5k bps, 187.5K bps and 375K bps.

For more details see the table in the SMD register description, below.

#### **18.4 OPERATIONAL MODES**

The Serial Interface Unit (SIU) can operate in either of two response modes:

1) AUTO mode

2) FLEXIBLE (NON-AUTO) mode

In the AUTO mode, the SIU performs in hardware a subset of the SDLC protocol called the normal response mode. The AUTO mode enables the SIU to recognize and respond to certain kinds of SDLC frames without intervention from the 8044's CPU. AUTO mode provides a faster turnaround time and a simplified software interface, whereas NON-AUTO mode provides a greater flexibility with regard to the kinds of operation permitted.

In AUTO mode, the 8044 can act only as a normal response mode secondary station—that is, it can transmit only when instructed to do so by the primary station. All such AUTO mode responses adhere strictly to IBM's SDLC definitions.

In the FLEXIBLE mode, reception or transmission of each frame by the SIU is performed under the control of the CPU. In this mode the 8044 can be either a primary station or a secondary station.

In both AUTO and FLEXIBLE modes, short frames, aborted frames, or frames which have had CRC's are ignored by the SIU.

| The basi | c forma | t of an | SDLC | frame | is as : | follows: |
|----------|---------|---------|------|-------|---------|----------|
|          |         |         |      |       |         |          |

| Flag Address Control Information FCS Flag |
|-------------------------------------------|
|-------------------------------------------|

Format variations consist of omitting one or more of the fields in the SDLC frame. For example, a supervisory frame is formed by omitting the information field. Supervisory frames are used to confirm received frames, indicate ready or busy conditions, and to report errors. More details on frame formats are given in the SDLC Frame Format Options section, below.

#### 18.4.1 AUTO Mode

To enable the SIU to receive a frame in AUTO mode, the 8044 CPU sets up a receive buffer. This is done by writing two registers—Receive Buffer Start (RBS) Address and Receive Buffer Length (RBL).

The SIU receives the frame, examines the control byte, and takes the appropriate action. If the frame is an information frame, the SIU will load the receive buffer, interrupt the CPU (to have the receive buffer read), and make the required acknowledgement to the primary station. Details on these processes are given in the Operation section, below.

In addition to receiving the information frames, the SIU in AUTO mode is capable of responding to the following commands (found in the control field of supervisory frames) from the primary station:

RR (Receive Ready): Acknowledges that the Primary station has correctly received numbered frames up through  $N_R - 1$ , and that it is ready to receive frame  $N_R$ .

RNR (Receive Not Ready): Indicates a temporary busy condition (at the primary station) due to buffering or other internal constraints. The quantity  $N_R$ in the control field indicates the number of the frame expected after the busy condition ends, and may be used to acknowledge the correct reception of the frames up through  $N_R - 1$ .

REJ (Reject): Acknowledges the correct reception of frames up through  $N_R - 1$ , and requests transmission or retransmission starting at frame  $N_R$ . The 8044 is capable of retransmitting at most the previous frame, and then only if it is still available in the transmit buffer.

UP (Unnumbered Poll): Also called NSP (Non-Sequenced Poll) or ORP (Optional Response Poll). This command is used in the loop configuration.

To enable the SIU to transmit an information frame in AUTO mode, the CPU sets up a transmit buffer. This is done by writing two registers—Transmit Buffer Start (TBS) Address and Transmit Buffer Length (TBL), and filling the transmit buffer with the information to be transmitted.

When the transmit buffer is full, the SIU can automatically (without CPU intervention) send an information frame (1-frame) with the appropriate sequence numbers, when the data link becomes available (when the 8044 is polled for information). After the SIU has transmitted the I-frame, it waits for acknowledgement from the receiving station. If the acknowledgement is negative, the SIU retransmits the frame. If the acknowledgement is positive, the SIU interrupts the CPU, to indicate that the transmit buffer may be reloaded with new information.



Figure 18-3. Serial Interface Timing—Clocked Mode

18-5





18<u>-6</u>

RUPI-44

In addition to transmitting the information frames, the SIU in AUTO mode is capable of sending the following responses to the primary station:

RR (Receive Ready): Acknowledges that the 8044 has correctly received numbered frames up through  $N_R - 1$ , and that it is ready to receive frame  $N_R$ .

RNR (Receive Not Ready): Indicates a temporary busy condition (at the 8044) due to buffering or other internal constraints. The quantity  $N_R$  in the control field indicates the number of the frame expected after the busy condition ends, and acknowledges the correct reception of the frames up through  $N_R - 1$ .

#### 18.4.2 FLEXIBLE Mode

In the FLEXIBLE (or non-auto) mode, all reception and transmission is under the control of the CPU. The full SDLC and HDLC protocols can be implemented, as well as any bit-synchronous variants of these protocols.

FLEXIBLE mode provides more flexibility than AUTO mode, but it requires more CPU overhead, and much longer recognition and response times. This is especially true when the CPU is servicing an interrupt that has higher priority than the interrupts from the SIU.

In FLEXIBLE mode, when the SIU receives a frame, it interrupts the CPU. The CPU then reads the control byte from the Receive Control Byte (RCB) register. If the received frame is an information frame, the CPU also reads the information from the receive buffer, according to the values in the Receive Buffer Start (RBS) address register and the Received Field Length (RFL) register.

In FLEXIBLE mode, the 8044 can initiate transmissions without being polled, and thus it can act as the primary station. To initiate transmission or to generate a response, the CPU sets up and enables the SIU. The SIU then formats and transmits the desired frame. Upon completion of the transmission, without waiting for a positive acknowledgement from the receiving station, the SIU interrupts the CPU.

#### **18.5 8044 FRAME FORMAT OPTIONS**

As mentioned above, variations on the basic SDLC frame consist of omitting one or more of the fields. The choice of which fields to omit, as well as the selection of AUTO mode versus FLEXIBLE mode, is specified by the settings of the following three bits in the Serial Mode Register (SMD) and the Status/Control Register (STS):

SMD Bit 0: NFCS (No Frame Check Sequence)

SMD Bit 1: NB (Non-Buffered Mode—No Control Field)

STS Bit 1: AM (AUTO Mode or Addressed Mode)

Figure 18-5 shows how these three bits control the frame format.

The following paragraphs discuss some properties of the standard SDLC format, and the significance of omitting some of the fields.

#### 18.5.1 Standard SDLC Format

The standard SDLC format consists of an opening flag, an 8-bit address field, and 8-bit control field, an n-byte information field, a 16-bit Frame Check Sequence (FCS), and a closing flag. The FCS is based on the CCITT-CRC polynominal  $(X^{16} + X^{12} + X^5 + 1)$ . The address and control fields may not be extended. Within the 8044, the address field is held in the Station Address (STAD) register, and the control field is held in the Receive Control Byte (RCB) or Transmit Control Byte (TCB) register. The standard SDLC format may be used in either AUTO mode or FLEXIBLE mode.

#### 18.5.2 No Control Field (Non-Buffered Mode)

When the control field is not present, the RCB and TCB registers are not used. The information field begins immediately after the address field, or, if the address field is also absent, immediately after the opening flag. The entire information field is stored in the 8044's on-chip RAM. If there is no control field, FLEXIBLE mode must be used. Control information may, of course, be present in the information field, and in this manner the NO Control Field option may be used for implementing extended control fields.

#### 18.5.3 No Control Field and No Address Field

The No Address Field option is available only in conjunction with the No Control Field option. The STAD, RCB, and TCB registers are not used. When both these fields are absent, the information field begins immediately after the opening flag. The entire information field is stored in on-chip RAM. FLEXIBLE mode must be used. Formats without an address field have the following applications:

Point-to-point data links (where no addressing is necessary)

Monitoring line activity (receiving all messages regardless of the address field)

Extended addressing

| FRAME OPTION                                                          | NFCS | NB | AM |               |  |  |  |
|-----------------------------------------------------------------------|------|----|----|---------------|--|--|--|
| Standard SDLC<br>FLEXIBLE Mode                                        | 0    | 0  | 0  | F A C I FCS F |  |  |  |
| Standard SDLC<br>AUTO Mode                                            | 0    | 0  | 1  | F A C I FCS F |  |  |  |
| No Control Field<br>FLEXIBLE Mode                                     | 0    | 1  | 1  | F A I FCS F   |  |  |  |
| No Control Field<br>No Address Field<br>FLEXIBLE Mode                 | 0    | 1  | 0  | F I FCS F     |  |  |  |
| No FCS Field<br>FLEXIBLE Mode                                         | 1    | 0  | 0  | F A C I F     |  |  |  |
| No FCS Field<br>AUTO Mode                                             | 1    | 0  | 1  | F A C I F     |  |  |  |
| No FCS Field<br>No Control Field<br>FLEXIBLE Mode                     | 1    | 1  | 1  | F A I F       |  |  |  |
| No FCS Field<br>No Control Field<br>No Address Field<br>FLEXIBLE Mode | 1    | 1  | 0  | FIF           |  |  |  |
| Key to Abbreviations:                                                 |      |    |    |               |  |  |  |
|                                                                       |      |    |    |               |  |  |  |

Figure 18-5 . Frame Format Options

#### 18.5.4 No FCS Field

In the normal case (NFCS=0), the last 16 bits before the closing flag are the Frame Check Sequence (FCS) field. These bits are not stored in the 8044's RAM. Rather, they are used to compute a cyclic redundancy check (CRC) on the data in the rest of the frame. A received frame with a CRC error (incorrect FCS) is ignored. In transmission, the FCS field is automatically computed by the SIU, and placed in the transmitted frame just prior to the closing flag. The NFCS bit (SMD Bit 0) gives the user the capability of overriding this automatic feature. When this bit is set (NFCS=1), all bits from the beginning of the information field to the beginning of the closing flag are treated as part of the information field, and are stored in the onchip RAM. No FCS checking is done on the received frames, and no FCS is generated for the transmitted frames. The No FCS Field option may be used in conjunction with any of the other options. It is typically used in FLEXIBLE mode, althought it does not strictly include AUTO mode. Use of the No FCS Field option AUTO Mode may, however, result in SDLC protocol violations, since the data integrity is not checked by the SIU.

Formats without an FCS field have the following applications:

Receiving and transmitting frames without verifying data integrity

Using an alternate data verification algorithm

Using an alternate CRC-16 polynomial (such as  $X^{16}$ . +  $X^{15}$  +  $X^2$  + 1), or a 32-bit CRC

Performing data link diagnosis by forcing false CRCs to test error detection mechanisms

In addition to the applications mentioned above, all of the format variations are useful in the support of nonstandard bit-synchronous protocols.

#### 18.6 HDLC

In addition to its support of SDLC communications, the 8044 also supports some of the capabilities of HDLC. The following remarks indicate the principal differences between SDLC and HDLC.

HDLC permits any number of bits in the information field, whereas SDLC requires a byte structure (multiple of 8 bits). The 8044 itself operates on byte boundaries, and thus it restricts fields to multiples of 8 bits.

HDLC provides functional extensions to SDLC: an unlimited address field is allowed, and extended frame number sequencing.

HDLC does not support operation in loop configurations.

#### **18.7 SIU SPECIAL FUNCTION REGISTERS**

The 8044 CPU communicates with and controls the SIU through hardware registers. These registers are accessed using direct addressing. The SIU special function registers (SIU SFRs) are of three types:

Control and Status Registers

Parameter Registers

ICE Support Registers

#### 18.7.1 Control and Status Registers

There are three SIU Control and Status Registers:

Serial Mode Register (SMD)

Status/Command Register (STS)

Send/Receive Count Register (NSNR)

The SMD, STS, and NSNR registers are all cleared by system reset. This assures that the SIU will power up in an idle state (neither receiving nor transmitting).

These registers and their bit assignments are described below (see also the More Details on Registers section).

#### SMD: Serial Mode Register (byte-addressable)

| Bit: | 7    | 6    | 5    | 4    | · 3  | 2   | 1  | 0    |  |
|------|------|------|------|------|------|-----|----|------|--|
|      | SCM2 | SCM1 | SCM0 | NRZI | LOOP | PFS | NB | NFCS |  |

The Serial Mode Register (Address C9H) selects the operational modes of the SIU. The 8044 CPU can both read and write SMD. The SIU can read SMD but cannot write to it. To prevent conflict between CPU and SIU access to SMD, the CPU should write SMD only when the Request To Send (RTS) and Receive Buffer Empty (RBE) bits (in the STS register) are both false (0). Normally, SMD is accessed only during initialization.

The individual bits of the Serial Mode Register are as follows:

| Name | Description                                                                                                                                                                                                                                                      |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NFCS | No FCS field in the SDLC frame.                                                                                                                                                                                                                                  |
| NB   | Non-Buffered mode. No control field in the SDLC frame.                                                                                                                                                                                                           |
| PFS  | Pre-Frame Sync mode. In this<br>mode, the 8044 transmits two bytes<br>before the first flag of a frame, for<br>DPLL synchronization. If NRZI is<br>enabled, 00H is sent; otherwise,<br>55H is sent. In either case, 16 pre-<br>frame transitions are guaranteed. |
| LOOP | Loop configuration.                                                                                                                                                                                                                                              |
| NRZI | NRZI coding option.                                                                                                                                                                                                                                              |
| SCM0 | Select Clock Mode — Bit 0                                                                                                                                                                                                                                        |
| SCM1 | Select Clock Mode — Bit 1                                                                                                                                                                                                                                        |
|      | NFCS<br>NB<br>PFS<br>LOOP<br>NRZI<br>SCM0                                                                                                                                                                                                                        |

SMD.7 SCM2 Select Clock Mode — Bit 2

The SCM bits decode as follows:

| 5 | <u>SCN</u> | 1 |                              | Data Rate   |  |  |
|---|------------|---|------------------------------|-------------|--|--|
| 2 | 1          | 0 | Clock Mode                   | (Bits/sec)* |  |  |
| 0 | 0          | 0 | Externally clocked           | 0-2.4M**    |  |  |
| 0 | 0          | 1 | Undefined                    |             |  |  |
| 0 | 1          | 0 | Self clocked, timer overflow | 244-62.5K   |  |  |
| 0 | 1          | 1 | Undefined                    | ×           |  |  |
| 1 | 0          | 0 | Self clocked, external 16x   | 0-375K      |  |  |

STS.6

STS.7

| <u>SCM</u> |   |          | ана <sup>се</sup> та с       | Data Rate   |
|------------|---|----------|------------------------------|-------------|
| 2          | 1 | <u>0</u> | Clock Mode                   | (Bits/sec)* |
| 1          | 0 | <b>1</b> | Self clocked, external 32x   | 0-187.5K    |
| 1          | 1 | 0        | Self clocked, internal fixed | 375K        |
| 1          | 1 | 1        | Self clocked, internal fixed | 187.5k      |

\*Based on a 12 Mhz crystal frequency \*\*0-1M bps in loop configuration

#### STS: Status/Command Register (bit-addressable)

| Bit: | 7   | 6   | 5   | 4  | 3   | 2   | 1  | 0   |
|------|-----|-----|-----|----|-----|-----|----|-----|
|      | TBF | RBE | RTS | SI | BOV | OPB | AM | RBP |

The Status/Command Register (Address C8H) provides operational control of the SIU by the 8044 CPU, and enables the SIU to post status information for the CPU's access. The SIU can read STS, and can alter certain bits, as indicated below. The CPU can both read and write STS asynchronously. However, 2-cycle instructions that access STS during both cycles (JBC/B, REL' and 'MOV / B,C.') should not be used, since the SIU may write to STS between the two CPU accesses.

The individual bits of the Status/Command Register are as follows:

. . .

| Bit # | Name | Description                                                                                                                                                                                                             |
|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| STS.0 | RBP  | Receive Buffer Protect. Inhibits<br>writing of data into the receive buff-<br>er. In AUTO mode, RBP forces an<br>RNR response instead of an RR.                                                                         |
| STS.1 | ΑΜ   | AUTO Mode/Addressed Mode. Selects AUTO mode where AUTO mode is allowed. If NB is true, $(=1)$ , the AM bit selects the addressed mode. AM may be cleared by the SIU.                                                    |
| STS.2 | ОРВ  | Optional Poll Bit. Determines<br>whether the SIU will generate an<br>AUTO response to an optional poll<br>(UP  with  P=0). OPB may be set or<br>cleared by the SIU.                                                     |
| STS.3 | BOV  | Receive Buffer Overrun. BOV may be set or cleared by the SIU.                                                                                                                                                           |
| STS.4 | SI   | SIU Interrupt. This is one of the five<br>interrupt sources to the CPU. The<br>vector location = $23H$ . SI may be<br>set by the SIU. It should be cleared<br>by the CPU before returning from<br>an interrupt routine. |
| STS.5 | RTS  | Request To Send. Indicates that the 8044 is ready to transmit or is trans-                                                                                                                                              |

mitting. RTS may be read or written by the CPU. RTS may be read by the SIU, and in AUTO mode may be written by the SIU.

RBE Receive Buffer Empty. RBE can be thought of as Receive Enable. RBE is set to one by the CPU when it is ready to receive a frame, or has just read the buffer, and to zero by the SIU when a frame has been received.

TBF Transmit Buffer Full. Written by the CPU to indicate that it has filled the transmit buffer. TBF may be cleared by the SIU.

#### NSNR: Send/Receive Count Register (bitaddressable)

| Bit: | ל"  | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |
|------|-----|-----|-----|-----|-----|-----|-----|-----|--|
|      | NS2 | NS1 | NS0 | SES | NR2 | NR1 | NR0 | SER |  |

The Send/Receive Count Register (Address D8H) contains the transmit and receive sequence numbers, plus tally error indications. The SIU can both read and write NSNR. The 8044 CPU can both read and write NSNR asynchronously. However, 2-cycle instructions that access NSNR during both cycles ('JBC /B, REL', and 'MOV /B,C') should not be used, since the SIU may write to NSNR between the two 8044 CPU accesses.

The individual bits of the Send/Receive Count Register are as follows:

| <u>Bit #</u> | Name | Description                                                                  |
|--------------|------|------------------------------------------------------------------------------|
| NSNR.0       | SER  | Receive Sequence Error:<br>NS (P) $\neq$ NR (S)                              |
| NSNR.1       | NR0  | Receive Sequence Counter-Bit 0                                               |
| NSNR.2       | NR1  | Receive Sequence Counter-Bit 1                                               |
| NSNR.3       | NR2  | Receive Sequence Counter-Bit 2                                               |
| NSNR.4       | SES  | Send Sequence Error:<br>NR (P) $\neq$ NS (S) and<br>NR (P) $\neq$ NS (S) + 1 |
| NSNR.5       | NS0  | Send Sequence Counter — Bit 0                                                |
| NSNR.6       | NS1  | Send Sequence Counter — Bit 1                                                |
| NSNR.7       | NS2  | Send Sequence Counter — Bit 2                                                |

#### **18.7.2 Parameter Registers**

There are eight parameter registers that are used in connection with SIU operation. All eight registers may be read or written by the 8044 CPU. RFL and RCB are normally loaded by the SIU. The eight parameter registers are as follows:

### STAD: Station Address Register (byte-addressable)

The Station Address register (Address CEH) contains the station address. To prevent access conflict, the CPU should access STAD only when the SIU is idle (RTS=0and RBE=0). Normally, STAD is accessed only during initialization.

### TBS: Transmit Buffer Start Address Register (byte-addressable)

The Transmit Buffer Start address register (Address DCH) points to the location in on-chip RAM for the beginning of the I-field of the frame to be transmitted. The CPU should access TBS only when the SIU is not transmitting a frame (when TBF=0).

### TBL: Transmit Buffer Length Register (byte-addressable)

The Transmit Buffer Length register (Address DBH) contains the length (in bytes) of the I-field to be transmitted. A blank I-field (TBL=0) is valid. The CPU should access TBL only when the SIU is not transmitting a frame (when TBF=0).

NOTE: The transmit and recieve buffers are not allowed to "wrap around" in the on-chip RAM. A "buffer end" is automatically generated if address 191 (BFH) is reached.

### TCB: Transmit Control Byte Register (byte-addressable)

The Transmit Control Byte register (Address DAH) contains the byte which is to be placed in the control field of the transmitted frame, during NON-AUTO mode transmission. The CPU should access TCB only when the SIU is not transmitting a frame (when TBF=0). The  $N_S$  and  $N_R$  counters are not used in the NON-AUTO mode.

## RBS: Receive Buffer Start Address Register (byte-addressable)

The Receive Buffer Start address register (Address CCH) points to the location in on-chip RAM where the beginning of the I-field of the frame being received is to ' be stored. The CPU should write RBS only when the SIU is not receiving a frame (when RBE=0).

## RBL: Receive Buffer Length Register (byte-addressable)

The Receive Buffer Length register (Address CBH) contains the length (in bytes) of the area in on-chip

RAM allocated for the received I-field. RBL=0 is valid. The CPU should write RBL only when RBE=0.

## RFL: Receive Field Length Register (byte-addressable)

The Received Field Length register (Address CDH) contains the length (in bytes) of the received I -field that has just been loaded into on-chip RAM. RFL is loaded by the SIU. RFL=0 is valid. RFL should be accessed by the CPU only when RBE=0.

### RCB: Receive Control Byte Register (byte-addressable)

The Received Control Byte register (Address CAH) contains the control field of the frame that has just been received. RCB is loaded by the SIU. The CPU can only read RCB, and should only access RCB when RBE=0.

#### **18.7.3 ICE Support Registers**

The 8044 In-Circuit Emulator (ICE-44) allows the user to exercise the 8044 application system and monitor the execution of instructions in real time.

The emulator operates with Intel's Intellec<sup>®</sup> development system. The development system interfaces with the user's 8044 system through an in-cable buffer box. The cable terminates in a 8044 pin-compatible plug, which fits into the 8044 socket in the user's system. With the emulator plug in place, the user can excercise his system in real time while collecting up to 255 instruction cycles of real-time data. In addition, he can single-step the program.

Static RAM is available (in the in-cable buffer box) to emulate the 8044 internal and external program memory and external data memory. The designer can display and alter the contents of the replacement memory in the buffer box, the internal data memory, and the internal 8044 registers, including the SFRs.

Among the SIU SFRs are the following registers that support the operation of the ICE:

## DMA CNT: DMA Count Register (byte-addressable)

The DMA Count register (Address CFH) indicates the number of bytes remaining in the information block that is currently being used.

#### FIFO: Three-Byte (byte-addressable)

The Three-Byte FIFO (Address DDH, DEH, and DFH) is used between the eight-bit shift register and the information buffer when an information block is received.

#### SIUST: SIU State Counter (byte-addressable)

The SIU State Counter (Address D9H) reflects the state of the internal logic which is under SIU control. Therefore, care must be taken not to write into this register.

The SIUST register can serve as a helpful aid to determine which field of a receive frame that the SIU expects next. The table below will help in debugging 8044 reception problems.

#### SIUST

#### VALUE FUNCTION

- 01H Waiting for opening flag.
- 08H Waiting for address field.
- 10H Waiting for control field.
- 18H Waiting for first byte of I field. This state is only entered if a FCS is expected. It pushes the received byte onto the top of the FIFO.
- 20H Waiting for second byte of I field. This state always follows state 18H
- 28H Waiting for I field byte. This sate can be en-

tered from state 20H or from states 01H, 08H, or 10H depending upon the SIU's mode configuration. (Each time a byte is received, it is pushed onto the top of the FIFO and the byte at the bottom is put into memory. For no FCS formatted frames, the FIFO is collapsed into a single register).

30H Waiting for the closing flag after having overflowed the receive buffer. Note that even if the receive frame overflows the assigned receive buffer length, the FCS is still checked.

Examples of SIUST status sequences for different frame formats are shown below. Note that status changes after acceptance of the received field byte.

#### **18.8 OPERATION**

The SIU is initialized by a reset signal (on pin 9), followed by write operations to the SIU SFRs. Once initialized, the SIU can function in AUTO mode or NON-AUTO mode. Details are given below.

#### Frame Option Example 1: NFCS NB AM (Idle) С FCS 0 Frame Format F I F 1 A SIUST Value 01 08 10 18 28 01 01 20 28 Example 2: FCS Frame Format (Idle) F I F A ۵ 1 1 SIUST Value 01 01 08 18 20 28 28 01 Example 3: FCS Frame Format (Idle) F I F 0 0 1 SIUST Value 01 01 18 20 28 28 01 Example 4: Frame Format (Idle) F I F 1 A 1 1 SIUST Value 01 01 08 28 01 Example 5: (Idle) Frame Format F ľ F 0 1 1 SIUST Value 01 01 28 01 Example 6: Frame Format (Idle) F I **I OVERFLOW** FCS F 0 1 n SIUST Value 01 20 01 18 28 30 30 01

#### Table 18-1. SIUST Status Sequences

#### **18.8.1 Initialization**

Figure 18-6 is the SIU. Registers SMD, STS, and NSNR are cleared by reset. This puts the 8044 into an idle state—neither receiving nor transmitting. The following registers must be initialized before the 8044 leaves the idle state:

- STAD-to establish the 8044's SDLC station address.
- SMD-to configure the 8044 for the proper operating mode.
- RBS, RBL—to define the area in RAM allocated for the Receive Buffer.

### TBS, TBL—to define the area in RAM allocated for the Transmit Buffer.

Once these registers have been initialized, the user may write to the STS register to enable the SIU to leave the idle state, and to begin transmits and/or receives.

Setting RBE to 1 enables the SIU for receive. When RBE = 1, the SIU monitors the received data stream for a flag pattern. When a flag pattern is found, the SIU enters Receive mode and receives the frame.

Setting RTS to 1 enables the SIU for transmit. When RTS = 1, the SIU monitors the received data stream for a GA pattern (loop configuration) or waits for a CTS



Figure 18-6. SIU State Diagram

(non-loop configuration). When the GA or CTS arrives, the SIU enters Transmit mode and transmits a frame.

In AUTO mode, the SIU sets RTS to enable automatic transmissions of appropriate responses.

#### 18.8.2 AUTO Mode

Figure 18-7 illustrates the receive operations in AUTO mode. The overall operation is shown in Figure 18-7a. Particular cases are illustrated in Figures 18-7b through 18-7j. If any Unnumbered Command other than UP is received, the AM bit is cleared and the SIU responds as if in the FLEXIBLE mode, by interrupting the CPU for supervision. This will also happen if a BOV or SES condition occurs. If the received frame contains a poll, the SIU sets the RTS bit to generate a response.

Figure 18-8 illustrates the transmit operations in AUTO mode. When the SIU gets the opportunity to transmit, and if the transmit buffer is full, it sends an I-frame. Otherwise, it sends an RR if the buffer is free, or an RNR if the buffer is protected. The sequence counters NS and NR are used to construct the appropriate control fields.

Figure 18-9 shows how the CPU responds to an SI (serial interrupt) in AUTO mode. The CPU tests the AM bit (in the STS register). If AM = 1, it indicates that the SIU has received either an I-frame, or a positive response to a previously transmitted I-frame.

#### 18.8.3 FLEXIBLE Mode

ζ.

Figure 18-10 illustrates the receive operations in NON-AUTO mode. When the SIU successfully completes a task, it clears RBF and interrupts the CPU by setting SI to 1. The exact CPU response to SI is determined by software. A typical response is shown in Figure 18-11.

Figure 18-12 illustrates the transmit operations in FLEXIBLE mode. The SIU does not wait for a positive acknowledge response to the transmitted frame. Rather, it interrupts the CPU (by setting SI to 1) as soon as it finishes transmitting the frame. The exact CPU response to SI is determined by software. A typical response is shown in Figure 18-13. This response results in another transmit frame being set up. The sequence of operations shown in Figure 18-13 can also be initiated by the CPU, without an SI. Thus the CPU can initiate a transmission in FLEXIBLE mode without a poll, simply by setting the RTS bit in the STS register. The RTS bit is always used to initiate a transmission, but it is applied to the RTS pin only when a non-loop configuration is used.

#### 18.8.4 8044 Data Link Particulars

The following facts should be noted:

- 1) In a non-loop configuration, one or two bits are transmitted before the opening flag. This is necessary for NRZI synchronization.
- 2) In a non-loop configuration, one to eight extra dribble bits are transmitted after the closing flag. These bits are a zero followed by ones.
- 3) In a loop configuration, when a GA is received and the 8044 begins transmitting, the sequence is 01111110101111110... (FLAG, 1, FLAG, AD-DRESS, etc.). The first flag is created from the GA. The second flag begins the message.
- 4) CTS is sampled after the rising edge of the serial data, at about the center of the bit cell, except during a non-loop, externally clocked mode transmit, in which case it is sampled just after the falling edge.
- 5) The SIU does not check for illegal I-fields. In particular, if a supervisory command is received in AUTO mode, and if there is also an I-field, it will be loaded into the receive buffer (if RBP=0), but it cannot cause a BOV.
- 6) In relation to the Receive Buffer Protect facility, the user should set RFL to 0 when clearing RBP, such that, if the SIU is in the process of receiving a frame, RFL will indicate the proper value when reception of the frame has been completed.

#### 18.8.5 Turn Around Timing

In AUTO mode, the SIU generates an RTS immediately upon being polled. Assuming that the 8044 sends an information frame in response to the poll, the primary station sends back an acknowledgement. If, in this acknowledgement, the 8044 is polled again, a response may be generated even before the CPU'gets around to processing the interrupt caused by the acknowledge. In such a case, the response would be an RR (or RNR), since TBF would have been set to 0 by the SIU, due to the acknowledge.

If the system designer does not wish to take up channel time with RR responses, but prefers to generate a new Iframe as a response, there are several ways to accomplish this:

- 1) Operate the 8044 in FLEXIBLE mode.
- 2) Specify that the master should never acknowledge and poll in one message. This is typically how a loop system operates, with the poll operation confined to the UP command. This leaves plenty of time for the



Figure 18-7a. SIU AUTO Mode Receive Flowchart-General





18-16





18-17

RUPI™–44



Figure 18-7d. SIU AUTO Mode Receive Flowchart-Supervisory Command

. 17



Figure 18-7e . SIU AUTO Mode Receive Flowchart—I Command: Prior Transmitted I-Field Confirmed, Current Received I-Field in Sequence



Figure 18-7f . SIU AUTO Mode Receive Flowchart—I Command: Prior Transmitted I-Field Not Confirmed, Current Received I-Field in Sequence







Figure 18-7h. SIU AUTO Mode Receive Flowchart—I Command: Prior Transmitted I-Field Confirmed Sequence Error Receive



Figure 18-7i. SIU AUTO Mode Receive Flowchart—I Command: Prior Transmitted I-Field Not Confirmed, Sequence Error Receive



Figure 18-7j. SIU SUTO Mode Receive Flowchart—I Command: Sequence Error Send and Sequence Error Receive



Figure 18-8. SIU AUTO Mode Transmit Flowchart



### Figure 18-9. AUTO Mode Response to "SI"



Figure 18-10. SIU FLEXIBLE Mode Receive Flowchart



Figure 18-11. FLEXIBLE Mode Response to Receive "SI"



Figure 18-12. SIU FLEXIBLE Mode Transmit Flowchart

,



Figure 18-13. FLEXIBLE Mode Response to Transmit "SI"

8044 to get its transmit buffer loaded with new information after an acknowledge.

3) The 8044 CPU can clear RTS. This will prevent a response from being sent, or abort it if it is already in progress. A system using external RTS/CTS handshaking could use a one-shot to delay RTS or CTS, thereby giving the CPU more time to disable the response.

#### **18.9 MORE DETAILS ON SIU HARDWARE**

The SIU divides functionally into two sections—a bit processor (BIP) and a byte processor (BYP)—sharing some common timing and control logic. As shown in Figure 18-14, the BIP operates between the serial port pins and the SIU bus, and performs all functions necessary to transmit/receive a byte of data to/from the serial data stream. These operations include shifting, NRZI encoding/decoding, zero insertion/deletion, and FCS generation/checking. The BYP manipulates bytes of data to perform message formatting, and other transmitting and receiving functions. It operates between the SIU bus (SIB) and the 8044's internal bus (IB). The interface between the SIU and the CPU involves an interrupt and some locations in on-chip RAM space which are managed by the BYP.

The maximum possible data rate for the serial port is limited to 1/2 the internal clock rate. This limit is imposed by both the maximum rate of DMA to the on-chip RAM, and by the requirements of synchronizing to an external clock. The internal clock rate for an 8044 running on a 12 MHz crystal is 6 MHz. Thus the maximum 8044 serial data rate is 3 MHz. This data rate drops down to 2.4 MHz when time is allowed for external clock synchronization.

#### 18.9.1 The Bit Processor

In the asynchronous (self clocked) modes the clock is extracted from the data stream using the on-chip digital phase-locked-loop (DPLL). The DPLL requires a clock input at 16 times the data rate. This  $16 \times$  clock may originate from SCLK, Timer 1 Overflow, or PH2 (one half the oscillator frequency). The extra divide by-two described above allows these sources to be treated alternatively as  $32 \times$  clocks.

The DPLL is a free-running four-bit counter running off the  $16 \times$  clock. When a transition is detected in the receive data stream, a count is dropped (by suppressing the carry-in) if the current count value is greater than 8. A count is added (by injecting a carry into the second stage rather than the first) if the count is less than 8. No adjustment is made if the transition occurs at the count of 8. In this manner the counter locks in on the point at which transitions in the data stream occur at the count of 8, and a clock pulse is generated when the count overflows to 0.

In order to perform NRZI decoding, the NRZI decoder compares each bit of input data to the previous bit. There are no clock delays in going through the NRZI decoder.

The zero insert/delete circuitry (ZID) performs zero insertion/deletion, and also detects flags, GA's (Go-Ahead's), and aborts (same as GA's) in the data stream. The pattern 1111110 is detected as an early GA, so that the GA may be turned into a flag for loop mode transmission.

The shut-off detector monitors the receive data stream for a sequence of eight zeros, which is a shut-off command for loop mode transmissions. The shut-off detector is a three-bit counter which is cleared whenever a one is found in the receive data stream. Note that the ZID logic could not be used for this purpose, because the receive data must be monitored even when the ZID is being used for transmission.

As an example of the operation of the bit processor, the following sequence occurs in relation to the receive data:

- 1) RXD is sampled by SCLK, and then synchronized to the internal processor clock (IPC).
- 2) If the NRZI mode is selected, the incoming data is NRZI decoded.
- 3) When receiving other than the flag pattern, the ZID deletes the '0' after 5 consecutive '1's (during transmission this zero is inserted). The ZID locates the byte boundary for the rest of the circuitry. The ZID deletes the '0's by preventing the SR (shift register) from receiving a clocking pulse.
- 4) The FCS (which is a function of the data between the flags—not including the flags) is initialized and started at the detection of the byte boundary at the end of the opening flag. The FCS is computed each bit boundary until the closing flag is detected. Note that the received FCS has gone through the ZID during transmission.

#### 18.9.2 The Byte Processor

Figure 18-15 is a block diagram of the byte processor (BYP). The BYP contains the registers and controllers necessary to perform the data manipulations associated with SDLC communications. The BYP registers may be read or written by the CPU over the 8044's internal bus



Figure 18-14. The Bit and Byte Processors

(IB), using standard 8044 hardware register operations. The 8044 register select PLA controls these operations. Three of the BYP registers connect to the IB through the IBS, a sub-bus which also connects to the CPU interrupt control registers.

Simultaneous access of a register by both the IB and the SIB is prevented by timing. In particular, RAM access is restricted to alternate internal processor cycles for the CPU and the SIU, in such a way that collisions do not occur.

As an example of the operation of the byte processor, the following sequence occurs in relation to the receive data:

1) Assuming that there is an address field in the frame, the BYP takes the station address from the register file into temporary storage. After the opening flag, the next field (the address field) is compared to the station address in the temporary storage. If a match occurs, the operation continues.

- 2) Assuming that there is a control field in the frame, the BYP takes the next byte and loads it into the RCB register. The RCB register has the logic to update the NSNR register (increment receive count, set SES and SER flags, etc.).
- 3) Assuming that there is an information field, the next byte is dumped into RAM at the RBS location. The DMA CNT (RBL at the opening flag) is loaded from the DMA CNT register into the RB register and decremented. The RFL is then loaded into the RB register, incremented, and stored back into the register file.



Figure 18-15. The Byte Processor

4) This process continues until the DMA CNT reaches zero, or until a closing flag is received. Upon either event, the BYP updates the status, and, if the CRC is good, the NSNR register.

#### **18.10 DIAGNOSTICS**

An SIU test mode has been provided, so that the on-chip CPU can perform limited diagnostics on the SIU. The test mode utilizes the output latches for P3.0 and P3.1 (pins 10 and 11). These port 3 pins are not useful as out-put ports, since the pins are taken up by the serial port functions. Figure 18-16 shows the signal routing associated with the SIU test mode.

Writing a 0 to P3.1 enables the serial test mode (P3.1 is set to 1 by reset). In test mode the P3.0 bit is mapped into the received data stream, and the 'write port 3' control signal is mapped into the SCLK path in place of T1. Thus, in test mode, the CPU can send a serial data stream to the SIU by writing to P3.0. The transmit data stream can be monitored by reading P3.1. Each sucessive bit is transmitted from the SIU by writing to any bit in Port 3, which generates SCLK.

In test mode, the P3.0 and P3.1 pins are placed in a high voltage, high impedance state. When the CPU reads P3.0 and P3.1 the logic level applied to the pin will be returned. In the test mode, when the CPU reads 3.1, the transmit data value will be returned, not the voltage on the pin. The transmit data remains constant for a bit time. Writing to P3.0 will result in the signal being outputted for a short period of time. However, since the signal not latched, P3.0 will quickly return to a high voltage, high impedance state.

P35 OUTPUT D LATCH PIN 15 SCLK/ TI/ P35 CPU BUS Q ^ TIMER 1 OVF SYS CLK SIU SERIAL DATA CLOCK P30 OUTPUT LATCH PIN 10 1/0/ RXD/ P30 1/0/ 0 n SIU RECEIVE DATA STREAM SELF TEST LOOP P31 OUTPUT LATCH Q D READ PORT 3 WRITE PORT 3 PIN11 DATA/ TXD/ P31 SIU TRANSMIT DATA STREAM

Figure 18-16. SIU Test Mode

18-34

RUPI<sup>m</sup>-44

The serial test mode is disabled by writing a 1 to P3.1. Care must be taken that a 0 is never written to P3.1 in the course of normal operation, since this causes the test mode to be entered.

Figure 18-17 is an example of a simple program segment that can be imbedded into the user's diagnostic program. That example shows how to put the 8044 into "Loop-back mode" to test the basic transmitting and receiving functions of the SIU.

Loop-back mode is functionally equivalent to a hardwire connection between pins 10 and 11 on the 8044.

In this example, the 8044 CPU plays the role of the primary station. The SIU is in the AUTO mode. The CPU sends the SIU a supervisory frame with the poll bit set and an RNR command. The SIU responds with a supervisory frame with the poll bit set and an RR command.

The operation proceeds as follows:

Interrupts are disabled, and the self test mode is enabled by writing a zero to P3.1. This establishes P3.0 as the data path from the CPU to the SIU. CTS (clear-tosend) is enabled by writing a zero to P1.7. The station address is initialized by writing 08AH into the STAD (station address register).

The SIU is configured for receive operation in the clocked mode and in AUTO mode. The CPU then transmits a supervisory frame. This frame consists of an

opening flag, followed by the station address, a control field indicating that this is a supervisory frame with an RNR command, and then a closing flag.

Each byte of the frame is transmitted by writing that byte into the A register and then calling the subroutine XMIT8. Two additional SCLKs are generated to guarantee that the last bits in the frame have been clocked into the SIU. Finally the CPU reads the status register (STS). If the operation has proceeded correctly, the status will be 072H. If it is not, the program jumps to the ERROR loop and terminates.

The SIU generates an SI (SIU interrupt) to indicate that it has received a frame. The CPU clears this interrupt, and then begins to monitor the data stream that is being generated by the SIU in response to what it has received. As each bit arrives (via P3.1), it is moved into the accumulator, and the CPU compares the byte in the accumulator with 07EH, which is the opening flag. When a match occurs, the CPU identifies this as byte boundary, and thereafter processes the information byte-by-byte.

The CPU calls the RCV8 subroutine to get each byte into the accumulator. The CPU performs compare operations on (successively) the station address, the control field (which contains the RR response), and the closing flag. If any of these do not compare, the program jumps to the ERROR loop. If no error is found, the program jumps to the DONE loop.

|                                                 | 1 - 1 - No 1 - 1                           |                         | 1               |                                   | A second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second s |
|-------------------------------------------------|--------------------------------------------|-------------------------|-----------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 1                                           |                                            |                         |                 | · · · · · ·                       | х.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                 | MCS-51 MACRO ASSEMB                        | LER DATA                | , · ·           |                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                 | ISIS-II MCS-51 MACR                        | D ASSEMBLER V2 0        |                 |                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| a di kan sa sa sa sa sa sa sa sa sa sa sa sa sa | OBJECT MODULE PLACE<br>ASSEMBLER INVOKED B | D IN F1 DATA OB         | )<br>Sa man dev | 1ce(44)                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                 |                                            |                         |                 |                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                 | LOC OBJ                                    | L'INE SOURCE            |                 |                                   | ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2.11                                            |                                            | 1                       |                 |                                   | 1 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1                                               | 0000 750800                                | 3 INIT                  |                 | STS, #00H                         | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                 | 0003 C281<br>0005 C297                     | 4<br>5                  |                 | P3 1<br>P1 7                      | , Enable self test mode , Enable CTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                 | 0005 C297                                  | 6                       | MOV             | STAD, WBAH                        | , Enable CIS<br>, Initialize address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                 |                                            | 7<br>8 , COM            | NÉIGURE RE      | CEIVE OPERATION                   | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                 | 000A 75086A                                | 9<br>10                 |                 | NSNR, #6AH                        | , NS(S)=3, SES=0, NR(S)=5, SER≠0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                 | 000D 75C901<br>0010 75C8C2                 | 11                      | MOV             | SMD, #01H                         | NFCS=1<br>TBF=1, RBE=1, AM=1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| •                                               | 0010 /00802                                | 12<br>13                |                 | STS, #0C2H                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                 |                                            | 15 . BIT                | NSMITAS         | UPERVISORY FRAME<br>A RNR COMMAND | FROM THE PRIMARY STATION WITH THE POLL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                 | 0013 747E                                  | 16<br>17 SEND           | MOV             | A, #7EH                           | , The SIU receives a flag first                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                 | 0015 120066                                | 18                      | CALL            | XMITB                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                 | 0018 748A<br>001A 120066<br>001D 7495      | 20                      | CALL            | A, WBAH<br>XMITB                  | The address is next                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ,                                               | 001D 7495<br>001F 120044                   | 21                      |                 | A; #095H<br>XMIT8                 | , RNR SUP FRAME with P/F=1, NR(P)=4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                 | 001F 120066<br>0022 747E                   | 22                      | MOV             | A, #7EH                           | , Receive closing flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                 | 0024 120066<br>0027 D280                   | 24<br>25                | SETB            | XMITB<br>P3 0                     | , Generate extra SCLK's to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 4                                               | 0029 D2B0                                  | 26<br>27                | SETB            | P3 0                              | ; Initiate receive action                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                 | 0028 E5C8                                  | 28                      | MOV             | A, STS                            | , Check for appropriate status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                                 | 002D B4722A                                | 29<br>30                |                 | A, #72H, ERROR                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                 | 1 - C                                      |                         | ARE TO REC      | EIVE RUPI'S RESP                  | ONCE TO PRIMARY'S RNR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                 | x                                          | 33 .                    |                 |                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2                                               | 0030 C2CC                                  | 34<br>35 RECV           | CLR             | SI                                | · Clear SI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                                 | 0032 7400                                  | 36                      | MOV             | A, #00H                           | , Clear ACC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                                 | 0034 7BOC                                  | 37<br>38                |                 | R3, #12                           | , Try 12 times                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| •                                               |                                            | 39 , LOOM<br>40         | FOR THE         | OPENING FLAG                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                 | 0036 D280                                  | 41 WFLAG1<br>42         |                 |                                   | , SCLK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                 | 0038 A281<br>003A 13                       | 43                      | RRC             | A                                 | > Transmitted data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                 | 003B B47E03<br>003E 020046                 | 44<br>45                | CUNE<br>UMP     | A, #07EH, WFLG1<br>CNTINU         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                 | 0041 DBF3                                  | 46 WFLG1                | DJNZ            | R3, WFLAG1                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                 | 0043 02005A                                | 47                      | JMP '           | ERROR                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                 | 0044 100080                                | 49                      |                 | 8010                              | Onto CTURE Terresident address Maria                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                 | 0046 12005C<br>0049 348A0E                 | 50 CNTINU<br>51         | CUNE            | RCVB<br>A, #08AH, ERROR           | , Get SIU's Transmitted address field                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                 | 004C 12005C<br>004F 348108                 | 52<br>53                |                 | RCVB<br>A. #0B1H, ERROR           | , Primary expects to receive RR from SIU                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                 | 0052 12005C                                | 54                      | CALL            | RCVB                              | , Receive closing flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                 | 0055 B47E02                                | 55<br>56                | · ·             | A, #07EH, ERROR                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                 | 0058 80FE                                  | 57 DONE<br>58           | JMP             | DONE                              | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                 | 005A 80FE                                  | 59 ERROR                | JMP             | ERROR                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                 |                                            | 60<br>61                |                 |                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                 | 005C 7808<br>005E D280                     | 62 RCVB<br>63 GETBIT    |                 | RO, #08<br>P3 0                   | , Initialize the bit counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                 | 0060 A2B1                                  | 64                      | MOV             | P3 0<br>C, P3 1                   | , SCLK<br>, Transmitted data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                 | 0062 13<br>0063 D8F9                       | 65<br>66                |                 | A<br>RO, GETBIT                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                 | 0065 22                                    | 67                      | RET             |                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                 |                                            | 68<br>69                |                 |                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                 | 0066 7809                                  | 70                      | MOV             | RO, #9                            | , Initialize the bit counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                 | 0068 13                                    | 71 XMITB<br>72 L3<br>73 |                 | A                                 | , Put the bit to be transmitted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| •                                               | 0069 D801                                  | 74                      | DJNZ            | R0, L1                            | , in the Carry<br>, When all bits have been sent                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                 | 006B 22                                    | 75                      | RET             |                                   | , return                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                 | 006C 4004                                  | 76<br>77 L1             | JC              | L2                                | , If the carry bit is set, set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                                 | 006E C2B0                                  | 78<br>79                | CLR             | P3 0                              | <pre>, port P3 0 else , clear port P3 0</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                 | 0070 BOF6                                  | 80<br>81                |                 | L3                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                 | 0072 D2B0                                  | 82 L2                   |                 | P3 0                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                 | 0074 80F2                                  | 83<br>84 end            | JMP             | L3                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                 |                                            |                         |                 |                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

Figure 18-17. Loop-Back Mode Software

#### 18-36

# **8044 Application Examples**

19

.

# CHAPTER 19 8044 APPLICATION EXAMPLES

# **19.0 8044 APPLICATIONS EXAMPLES**

#### 19.1 INTERFACING THE 8044 TO A MICROPROCESSOR

The 8044 is designed to serve as an intelligent controller for remote peripherals. However, it can also be used as an intelligent HDLC/SDLC front end for a microprocessor, capable of extensively off-loading link control functions for the CPU. In some applications, the 8044 can even be used for communications preprocessing, in addition to data link control.

This section describes a sample hardware interface for attaching the 8044 to an 8088. It is general enough to be extended to other microprocessors such as the 8086 or the 80186.

#### OVERVIEW

A sample interface is shown in Figure 19-1. Transmission occurs when the 8088 loads a 64 byte block of memory with some known data. The 8088 then enables the 8237A to DMA this data to the 8044. When the 8044 has received all of the data from the 8237A, it sends the data in a SDLC frame. The frame is captured by the Spectron Datascope®\* which displays it on a CRT in hex format.

In reception, the Datascope sends an SDLC information frame to the 8044. The 8044 receives the SDLC frame, buffers it, and sends it to the 8088's memory. In this example the 8044 is being operated in the NON-AUTO mode; therefore, it does not need to be polled by a primary station in order to transmit.

#### THE INTERFACE

The 8044 does not have a parallel slave port. The 8044's 32 I/O lines can be configured as a local microprocessor bus master. In this configuration, the 8044 can expand the ROM and RAM memory, control peripherals, and communicate with a microprocessor.

The 8044, like the 8051, does not have a Ready line, so there is no way to put the 8044 in wait state. The clock on the 8044 cannot be stopped. Dual port RAM could still be used, however, software arbitration would be the only way to prevent collisions. Another way to interface the 8044 with another CPU is to put a FIFO or queue between the two processors, and this was the method chosen for this design.

Figure 19-2 shows the schematic of the 8044/8088 interface. It involves two 8 bit tri-state latches, two SR flipflops, and some logic gates (6 TTL packs). The circuitry implements a one byte FIFO. RS422 transceivers are used, which can be connected to a multidrop link. Figure 19-3 shows the 8088 and support circuitry; the memory and decoders are not shown. It is a basic 8088 Min Mode system with an 8237A DMA controller and an 8259A interrupt controller.

DMA Channel One transfers a block of memory to the tri-state latch, while Channel Zero transfers a block of data from the latch to 8088's memory. The 8044's Interrupt 0 signal vectors the CPU into a routine which reads from the internal RAM and writes to the latch. The 8044's Interrupt 1 signal causes the chip to read from the latch and write to its on-chip data RAM. Both DMA requests and acknowledges are active low.

Initially, when the power is applied, a reset pulse coming from the 8284A initializes the SR flip-flops. In this initialization state, the 8044's transmit interrupt and the 8088's transmit DMA request are active; however, the software keeps these signals disabled until either of the two processors are ready to transmit. The software leaves the receive signals enabled, unless the receive buffers are full. In this way either the 8088 or the 8044 are always ready to receive, but they must enable the transmit signal when they have prepared a block to transmit. After a block has been transmitted or received, the DMA and interrupt signals return to the initial state.

The receive and transmit buffer sizes for the blocks of data sent between the 8044 and the 8088 have a maximum fixed length. In this case the buffer size was 64 bytes. The buffer size must be less than 192 bytes to enable 8044 to buffer the data in its on-chip RAM. This design allows blocks of data that are less than 64 bytes. and accommodates networks that allow frames of varying size. The first byte transferred between the 8088 and the 8044 is the byte count to follow; thus the 8044 knows how many bytes to receive before it transmits the SDLC frame. However, when the 8044 sends data to the 8088's memory, the 8237A will not know if the 8044 will send less than the count the 8237A was programmed for. To solve this problem, the 8237A is operated in the single mode. The 8044 uses an I/O bit to generate an interrupt request to the 8259A. In the 8088's interrupt routine, the 8237A's receive DMA channel is disabled, thus allowing blocks of data less than 64 bytes to be received.

#### THE SOFTWARE

The software for the 8044 and the 8088 is shown in Table 19-1. The 8088 software was written in PL/M86, and the 8044 software was written in assembly language.

The 8044 software begins by initializing the stack, interrupt priorities, and triggering types for the interrupts. At this point, the SIU parameter registers are initialized. The receive and transmit buffer starting addresses and lengths are loaded for the on-chip DMA. This DMA is for the serial port. The serial station address and the transmit control bytes are loaded too.



Figure 19-1. Block Diagram of 8088/8044 Interface Test

Once the initialization has taken place, the SIU interrupt is enabled, and the external interrupt which receives bytes from the 8088 is enabled. Setting the 8044's Receive Buffer Empty (RBE) bit enables the receiver. If this bit is reset, no serial data can be received. The 8044 then waits in a loop for either RECEIVE DMA interrupt or the SERIAL INT interrupt.

The RECEIVE DMA interrupt occurs when the 8237A is transferring a block of data to the 8044. The first time this interrupt occurs, the 8044 reads the latch and loads the count value into the R2 register. On subsequent interrupts, the 8044 reads the latch, loads the data into the transmit buffer, and decrements R2. When R2 reaches zero, the interrupt routine sends the data in an SDLC frame, and disables the RECEIVE DMA interrupt. After the frame has been transmitted, a serial interrupt is generated. The SERIAL INT routine detects that a frame has been transmitted and re-enables the RECEIVE DMA interrupt. CEIVE DMA interrupt. Thus, while the frame is being transmitted through the SIU, the 8237A is inhibited from sending data to the 8044's transmit buffer.

The TRANSMIT DMA routine sends a block of data from the 8044's receive buffer to the 8088's memory. Normally this interrupt remains disabled. However, if a serial interrupt occurs, and the SERIAL INT routine detects that a frame has been received, it calls the SEND subroutine. The SEND subroutine loads the number of bytes which were received in the frame into the receive buffer. Register R1 points to the receive buffer and R2 is loaded with the count. The TRANSMIT DMA interrupt is enabled, and immediately upon returning from the SERIAL INT routine, the interrupt is acknowledged. Each time the TRANSMIT DMA interrupt occurs, a byte is read from the receive buffer, written to the latch, and R2 is decremented. When R2 reaches 0, the TRANSMIT DMA interrupt is disabled, the SIU receiver is re-enabled, and the 8044 interrupts the 8088.

The 8088 software simply transmits a block of data and receives a block of data, then stops. The software begins by initializing the 8237A, and the 8259A. It then loads a block of memory with some data and enables the 8237A to transmit the data. In the meantime the 8088 waits in a loop. After a block of data is received from the 8044, the 8088 is interrupted, and it shuts off the 8237A receive DMA.

#### CONCLUSION

For the software shown in Table 19-1, the transfer rate from the 8088's memory to the 8044 was measured at 75K bytes/sec. This transfer rate largely depends upon the number of instructions in the 8044's interrupt service routine. Fewer instructions result in a higher transfer rate.

There are many ways of interfacing the 8044 locally to another microprocessor: FIFO's, dual port RAM with software arbitration, and 8255's are just a few. Alternative approaches, which may be more optimal for certain applications, are certainly possible.

RUPI<sup>m</sup>-44



Figure 19-2. 8044 Interface to the 8088

1<del>9</del>-3



RUPI<sup>m</sup>-44



| LOC OBJ                               | LINE     | SOURC         | E       |                |                                                          |
|---------------------------------------|----------|---------------|---------|----------------|----------------------------------------------------------|
|                                       | 1        | \$debug       | title   | (8044/8088 INT | TERFACE)                                                 |
|                                       | 2        |               |         |                |                                                          |
|                                       | 3        |               |         |                |                                                          |
| 0000                                  | 4        | FIRST_B       | YTE     | BIT 0          | ; FLAG                                                   |
|                                       | 5        |               |         |                |                                                          |
| 0000                                  | 6        |               | ORG     | 0              |                                                          |
| 0000 8024                             | 7<br>8   |               | SJMP    | INIT           |                                                          |
| 0026                                  | 8<br>9   |               | ORG     | 26H            |                                                          |
| 5020                                  | 10       |               | ONO     | 2011           |                                                          |
| 0026 7581AA                           | 10       | INIT:         | MOV     | SP, #170       | ; INITIALIZE STACK                                       |
| 0029 75B800                           | 12       |               | MOV     | IP, #00        | ; ALL INTERRUPTS ARE EQUAL PRIORITY                      |
| 02C 75C954                            | 13       |               | MOV     | SMD, #54H      | ; TIMER 1 OVERFLOW, NRZI, PRE-FRAME SYNC                 |
| 02F 758844                            | 14       |               | MOV     | TCON, #44H     | ; EDGE TRIGGERED EXTERNAL INTERRUPT 1                    |
|                                       | 15       |               |         |                | ; LEVEL TRIGGERED EXTERNAL INTERRUPT (                   |
|                                       | 16       |               |         |                | ; TIMER 1 ON                                             |
| 032 758DEC                            | 17       |               | MOV     | TH1, #0ECH     | ; INITIALIZE TIMER, 3125 BPS                             |
| 035 758920                            | 18       |               | MOV     | TMOD, #20H     | ; TIMER 1 AUTO RELOAD                                    |
|                                       | 19       |               |         |                |                                                          |
| 0038 75DC6A                           | 20       |               | MOV     | TBS, #106      | ; SET UP SIU PARAMETER REGISTERS                         |
| 003B 75DB40                           | 21       | 1             | MOV     | TBL, #64       |                                                          |
| 003E 75CC2A                           | 22       |               | MOV     | RBS, #42       |                                                          |
| 0041 75CB40                           | 23       |               | MOV     | RBL, #64       | ,                                                        |
| 0044 75CE55                           | 24       |               | MOV     | STAD, #55H     |                                                          |
| 0047 75DA11                           | 25       |               | MOV     | TCB, #00010001 | B; RR, P/F = 1                                           |
| 004A 901000                           | 26<br>27 |               | MOV     | DPTR, #1000H   | ; DPTR POINTS TO TRI-STATE LATCH                         |
| 04A 901000                            | 27       |               | SETB    | FIRST_BYTE     | ; FLAG TO INDICATE FIRST BYTE                            |
| 04D D200                              | 28<br>29 |               | SEID    | TIKSI_DI IL    | ; FOR RECEIVE INTERRUPT ROUTINE                          |
| 004F D2CE                             | 30       |               | SETB    | RBE            | ; READY TO RECEIVE                                       |
| 0051 75A894                           | 31       |               | MOV     | IE, #10010100B | -                                                        |
| · · · · · · · · · · · · · · · · · · · | 32       | 1.1           |         |                | ,                                                        |
| 0054 80FE                             | 33       |               | SJMP    | \$             | ; WAIT HERE FOR INTERRUPTS                               |
|                                       | 34       |               |         |                |                                                          |
| 0056 80FE                             | 35       | ERROR:        | SJMP    | ERROR          |                                                          |
|                                       | 36 +     | 1 \$EJ        |         |                |                                                          |
|                                       | 37       | .******       | ******* | ********       | UBROUTINES *********************************             |
|                                       | 38       | ,             |         | 5              | CBROOTH LD                                               |
| 058 85CD29                            | 39       | SEND:         | MOV     | 41, RFL        | ; FIRST BYTE IN BLOCK IS COUNT                           |
| 05B 7929                              | 40       |               | MOV     | R1, #41        | ; POINT TO BLOCK OF DATA                                 |
| 005D AACD                             | 41       |               | MOV     | R2, RFL        | ; LOAD COUNT                                             |
| 05F 0A                                | 42       |               | INC     | R2             |                                                          |
| 060 D2A8                              | 43       |               | SETB    | EX0            | ; ENABLE DMA TRANSMIT INTERRUPT                          |
| 062 22                                | 44       |               | RET     |                |                                                          |
|                                       | 45       |               |         |                |                                                          |
|                                       | 46       |               |         |                |                                                          |
| 1                                     | 47       |               |         | 4              |                                                          |
|                                       | 48       | ;******       | ******* | *** INTERRU    | PT SERVICE ROUTINES ************************************ |
|                                       | 49       |               |         |                |                                                          |
| 0063                                  | 50       | LOC_TM        |         | <b>\$</b> "    | ; SET UP INTERRUPT TABLE JUMP                            |
| 0013                                  | 51       |               | ORG     | 0013H          |                                                          |
| 0013 020063                           | 52       |               | LJMP    | RECEIVE_DMA    | A                                                        |
| 0063                                  | 53       |               | ORG     | LOC_TMP        | */                                                       |
| *                                     | 54       | <b>D</b> DODU |         |                | н — С. С. С. С. С. С. С. С. С. С. С. С. С.               |
|                                       | 55       | RECEIV        | E_DMA:  |                | а. <sub>А.</sub> А.                                      |

# Table 19-1. Transmit and Receive Software for an 8044/8088 System

| 10   |     |   |       |
|------|-----|---|-------|
| 1    |     | ÷ | · `** |
| 1.5  | ×., |   | J.    |
| - N. |     |   | - 1.  |
|      | ÷ . |   |       |

|              |      |                                       |          | ···· ,                                  |                                                                                                                  |
|--------------|------|---------------------------------------|----------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------|
| ,<br>        | 56   | ,*                                    |          |                                         |                                                                                                                  |
| 0063 10000E  | 57   |                                       | JBC      | FIRST_BYTE, LI                          | ; THE FIRST BYTE TRANSFERRED IS THE COUN                                                                         |
| 00// F0      | 58   |                                       | MONIN    |                                         |                                                                                                                  |
| 0066 E0      | 59   |                                       | MOVX     | .0                                      | ; READ THE LATCH                                                                                                 |
| 0067 F6      | 60   |                                       | MOV      | @R0, A                                  | ; PUT IT IN TRANSMIT BUFFER                                                                                      |
| 0068 08      | 61   |                                       | INC      | R0                                      | APTER READING RUTES                                                                                              |
| 0069 DA08    | 62   |                                       | DJNZ     | R2, L2                                  | ; AFTER READING BYTES,                                                                                           |
|              | 63   |                                       |          |                                         |                                                                                                                  |
| 006B D2CF    | 64   |                                       | SETB     | TBF                                     | ; SEND DATA                                                                                                      |
| 006D D2CD    | 65   |                                       | SETB     | RTS                                     |                                                                                                                  |
| 006F D200    | 66   |                                       | SETB     | FIRST_BYTE                              |                                                                                                                  |
| 0071 C2AA    | 67   |                                       | CLR      | EX1                                     |                                                                                                                  |
|              | 68   |                                       |          |                                         |                                                                                                                  |
| 0073 32      | 69   | L2:                                   | RETI     |                                         |                                                                                                                  |
|              | 70   |                                       |          |                                         |                                                                                                                  |
| 0074 786A    | · 71 | L1:                                   | MOV      | R0, #106                                | ; R0 IS A POINTER TO THE TRANSMIT                                                                                |
|              | 72   |                                       |          |                                         | ; BUFFER STARTING ADDRESS                                                                                        |
| 0076 E0      | 73   |                                       | MOVX     | A, @DPTR                                | ; PUT THE FIRST BYTE INTO                                                                                        |
| 0077 FA      | 74   | <b>*</b>                              | MOV      | R2, A                                   | ; R2 FOR THE COUNT                                                                                               |
| 0078 32      | 75   |                                       | RETI     |                                         |                                                                                                                  |
|              | 76   |                                       | ×        |                                         |                                                                                                                  |
| 0079         | 77   | LOC_TM                                | IPSET    | \$                                      |                                                                                                                  |
| 0003         | 78   |                                       | ORG      | 0003H                                   |                                                                                                                  |
| 0003 020079  | 79   |                                       | LJMP     | TRANSMIT_DM                             | fA · · · ·                                                                                                       |
| 0079         | 80   |                                       | ORG      | LOC_TMP                                 |                                                                                                                  |
|              | 81   |                                       |          |                                         | м.                                                                                                               |
|              |      |                                       |          |                                         |                                                                                                                  |
|              | 82   | TRANSN                                | /IT_DMA  |                                         | · · · · · · · · · · · · · · · · · · ·                                                                            |
|              | 83   |                                       |          |                                         |                                                                                                                  |
| 0079 E7      | 84   |                                       | MOV      | A, @R1                                  | ; READ BYTE OUT OF THE RECEIVE BUFFER                                                                            |
| 007A F0      | 85   |                                       | MOVX     | @DPTR, A                                | ; WRITE IT TO THE LATCH                                                                                          |
| 007B 09      | 86   |                                       | INC      | R1                                      | р с. с.<br>/                                                                                                     |
| 007C DA08    | 87   | ,                                     | DJNZ     | R2, L3                                  | ; WHEN ALL BYTES HAVE BEEN SENT                                                                                  |
|              | 88   |                                       |          |                                         | 1                                                                                                                |
| 007E C2A8    | 89   |                                       | CLR      | IE. 0                                   | ; DISABLE INTERRUPT                                                                                              |
| 0080 C294    | 90   |                                       | CLR      | P1. 4                                   | ; CAUSE 8088 INTERRUPT TO TERMINATE DM                                                                           |
| 0082 D294    | 91 - |                                       | SETB     | P1. 4                                   | 1 A.                                                                                                             |
| 0084 D2CE    | 92   |                                       | SETB     | RBE                                     | ; ENABLE RECEIVER AGAIN                                                                                          |
| 1            | 93   |                                       |          |                                         | 1                                                                                                                |
| 0086 32      | 94   | L3:                                   | RETI     |                                         |                                                                                                                  |
|              | .95  |                                       |          | ,                                       |                                                                                                                  |
| *            | 96   | · ,                                   |          |                                         | 8 C                                                                                                              |
|              | 97   |                                       |          |                                         | r.                                                                                                               |
| 0087         | 981  | LOC_TM                                | IPSET    | \$                                      | т. — — — — — — — — — — — — — — — — — — —                                                                         |
| 0023         | 99   | · · · · · · · · · · · · · · · · · · · | ORG      | 0023H                                   |                                                                                                                  |
| 0023 020087  | 100  |                                       | LJMP     | SERIAL_INT                              | • · · · · · · · · · · · · · · · · · · ·                                                                          |
| 0087         | 101  |                                       | ORG      | LOC_TMP                                 | · · · · · · · · · · · · · · · · · · ·                                                                            |
|              | 101  |                                       | 0110     | ~~~ · · · · · · · · · · · · · · · · · · |                                                                                                                  |
|              | 102  | SERIAL.                               | INT:     |                                         | 1                                                                                                                |
|              | 104  |                                       |          |                                         | į                                                                                                                |
| 0087 30CE06  | 105  |                                       | JNB      | RBE, RCV                                | ; WAS A FRAME RECEIVED                                                                                           |
| 008A 30CF0B  | 105  |                                       | JNB      | TBF, XMIT                               | ; WAS A FRAME TRANSMITTED                                                                                        |
| 008D 020056  | 100  |                                       | LJMP     | ERROR                                   | ; IF NEITHER ERROR                                                                                               |
| 00000 020000 | 107  |                                       | 2.5 1411 | LINICAL                                 | ,                                                                                                                |
| 0090 20CBC3  | 108  | RCV:                                  | JB       | BOV, ERROR                              | ; IF BUFFER OVERRUN THEN ERROR                                                                                   |
|              |      | KCV.                                  | CALL     | SEND                                    | ; SEND THE FRAME TO THE 8088                                                                                     |
| 0093 1158    | 110  |                                       |          |                                         | , SEND THE INAME TO THE 6000                                                                                     |
| 0095 C2CC    | 111  | •                                     | CLR      | SI                                      | and the second second second second second second second second second second second second second second second |
| 0097 32      | 112  |                                       | RETI     | 7                                       |                                                                                                                  |
| 0000 0000    | 113  | <b>W</b> 1 (177)                      |          | 61                                      | 1                                                                                                                |
| 0098 C2CC    | 114  | XMIT:                                 | CLR      | SI                                      |                                                                                                                  |

.

| 009A D2AA 115<br>009C 32 116<br>117                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                  | TB EX1<br>ETI      |            |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--------------------|------------|
| 117                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | EN               | ۱D                 |            |
| SYMBOL TABLE LISTI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | NG               | F.                 |            |
| ΝΑΜΕ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ТҮРЕ             | VALUE              | ATTRIBUTES |
| BOV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | <b>B</b> ADDR    | 00C8H.3 A          |            |
| ERROR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | C ADDR           | 0056H A            |            |
| EX0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | B ADDR           | 00A8H.0 A          |            |
| EX1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | B ADDR           | 00A8H.2 A          |            |
| FIRST_BYTE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | B ADDR           | 0020H.0 A          | 1          |
| IE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | D ADDR           | 00A8H A            |            |
| INIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | C ADDR           | 0026H A            | 、          |
| IP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | D ADDR           | 00B8H A            |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | C ADDR           | 0074H A            |            |
| $\begin{bmatrix} L2 & . & . & . & . \\ L2 & . & . & . & . \\ L2 & . & . & . & . \\ L2 & . & . & . & . \\ L2 & . & . & . & . \\ L2 & . & . & . & . \\ L2 & . & . & . & . \\ L2 & . & . & . & . \\ L2 & . & . & . & . \\ L2 & . & . & . \\ L2 & . & . & . \\ L2 & . & . & . \\ L2 & . & . & . \\ L2 & . & . & . \\ L2 & . & . & . \\ L2 & . & . & . \\ L2 & . & . \\ L2 & . & . \\ L2 & . & . \\ L2 & . & . \\ L2 & . & . \\ L2 & . & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ L2 & . \\ $ | C ADDR           | 0073H A            |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | C ADDR           | 0086H A<br>0087H A |            |
| LOC_TMP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | C ADDR<br>D ADDR | 0087H A<br>0090H A |            |
| P1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | B ADDR           | 0000H A            |            |
| RBL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | D ADDR           | 00CBH A            |            |
| <b>RBS</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | D ADDR           | 00CCH A            | ,          |
| RCV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | C ADDR           | 0090H A            | ×          |
| RECEIVE_DMA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | C ADDR           | 0063H A            |            |
| RFL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | D ADDR           | 00CDH A            |            |
| RTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | B ADDR           | 00C8H.5 A          | i -        |
| SEND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | C ADDR           | 0058H A            |            |
| SERIAL_INT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | C ADDR           | 0087H A            |            |
| SI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <b>B</b> ADDR    | 00C8H.4 A          |            |
| SMD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | D ADDR           | 00C9H A            |            |
| SP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | D ADDR           | 0081H A            |            |
| STAD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | D ADDR           | 00CEH A            |            |
| TBF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | <b>B</b> ADDR    | 00C8H.7 A          |            |
| TBL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | D ADDR           | 00DBH A            |            |
| TBS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | D ADDR           | 00DCH A            | '          |
| ТСВ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | D ADDR           | 00DAH A            |            |
| TCON                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | D ADDR           | 0088H A            |            |
| TH1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | D ADDR           | 008DH A            |            |
| TMOD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | D ADDR           | 0089H A            |            |
| TRANSMIT_DMA .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | C ADDR           | 0079H A            |            |
| XMIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | C ADDR           | 0098H A            |            |
| REGISTER BANK(S)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | USED: 0, TARC    | GET MACHINE        | (S): 8044  |
| ASSEMBLY COMPLE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | TE, NO ERROI     | RS FOUND           |            |

.

| Г |      |        |                                                      |                  |                        |   |    |    |
|---|------|--------|------------------------------------------------------|------------------|------------------------|---|----|----|
|   | OBJE | ст мол | I PL/M-86 V1 O COMPILATI<br>DULE PLACED IN 'F1'R88.( | 3B'I             | UPI_88                 |   |    |    |
|   | COMP | ILER   | INVOKED BY: PLM86 86 F                               | F1 R88. SRC      | · ·                    |   |    | ×. |
|   |      |        |                                                      |                  |                        |   |    |    |
|   |      |        | \$DEBUG<br>\$TITLE ('RUPI/8088                       | B INTERFACE EXA  | MPLE()                 |   |    |    |
| 1 | 1    |        | RUP I_88: DO;                                        | -                |                        | 4 |    |    |
|   | 2    | 1      | DECLARE                                              |                  |                        |   |    |    |
|   |      |        | LIT                                                  | LITERALLY        | LITERALLY',            |   |    |    |
|   |      |        | TRUE                                                 | LIT              | '01H')                 |   |    | ,  |
|   |      |        | FALSE                                                | LIT              | '00H',                 |   |    |    |
|   |      |        | RECV_BUFFER(64)                                      |                  |                        |   |    |    |
|   |      |        | XMIT_BUFFER(64)                                      | ) BYTE,<br>BYTE, |                        |   |    |    |
|   |      |        | WAIT                                                 | BYTE,            |                        |   |    |    |
|   |      |        |                                                      | /* 8237 PORTS    | */                     |   |    |    |
|   |      |        | MARTER OLEAR 3                                       | 7 LIT            | OFFDDH '               |   |    |    |
|   |      |        | MASTER_CLEAR_3                                       |                  | OFFDBH',               |   |    |    |
|   |      | ,      | ALL_MASK_37                                          | LIT              | OFFDFH '               |   |    | `  |
|   |      | ,      | SINGLE_MASK_37                                       | LIT              | OFFDAH ()              |   |    |    |
|   |      |        | STATUB_37<br>REQUEST_REG_37                          |                  | OFFD8H ',<br>OFFD9H ', |   |    |    |
|   |      |        | MODE_REG_37                                          | LIT<br>LIT       | OFFDBH'                |   |    |    |
|   |      |        | CLEAR_BYTE_PTR                                       |                  | OFFDCH '               |   |    |    |
|   |      |        | CHO_ADDR                                             | LIT              | 'OFFDOH',              |   |    |    |
|   |      |        | CHO_COUNT                                            | LIT              | OFFD1H',               |   |    |    |
|   |      |        | CH1_ADDR                                             | LIT              | OFFD2H'                |   |    |    |
|   |      |        | CH1_COUNT                                            | LIT              | OFFD3H',               |   | -  |    |
|   |      |        | CH2_ADDR<br>CH2_COUNT                                | LIT              | OFFD4H',<br>OFFD5H',   |   |    |    |
|   |      |        | CH3_ADDR                                             | LIT              | OFFD6H '               |   |    |    |
|   |      |        | CH3_COUNT                                            | LIT              | OFFD7H',               |   |    |    |
|   |      |        | /* 823                                               | 7 BIT ASSIGNMEN  | ITS */                 |   |    |    |
|   |      |        | CHO_SEL                                              | LIT              | '00H',                 |   |    |    |
|   |      |        | CH1_SEL                                              | LIT              | '01H',                 |   |    |    |
|   |      |        | CH2_SEL<br>CH3_SEL                                   | LIT<br>LIT       | 102H1,<br>103H1,       |   |    |    |
|   |      |        | WRITE_XFER                                           | LIT              | '04H',                 |   |    |    |
|   |      |        | READ_XFER                                            | LIT              | '08H ',                | ' |    |    |
| 1 |      |        | DEMAND_MODE                                          | LIT              | 100H1,                 |   |    |    |
|   |      |        | SINGLE_MODE                                          | LIT              | 140H 1,<br>180H 1,     |   |    |    |
|   |      |        | BLOCK_MODE<br>SET_MASK                               | LIT              | '04H'                  |   |    |    |
|   |      |        |                                                      |                  |                        |   | x  |    |
|   |      |        | \$EJECT /* 8                                         | 259 PORTS */     |                        |   |    |    |
|   |      |        |                                                      |                  |                        |   |    |    |
|   |      |        | STATUS_POLL_59<br>ICW1_59                            | LIT<br>LIT       | 'OFFEOH',<br>'OFFEOH', |   |    | •  |
|   |      |        | OCW1_59                                              | LIT              | OFFEIH'                |   |    |    |
|   |      |        | OCW2_59                                              | LIT              | OFFEOH',               |   |    |    |
|   |      |        | OCW3_59                                              | LIT              | OFFEOH '               |   |    |    |
|   |      |        | ICW2_59<br>ICW3_59                                   | LIT<br>LIT       | 'OFFE1H',<br>'OFFE1H', |   |    |    |
|   |      |        | ICW4_59                                              | LIT              | OFFE1H                 |   |    |    |
|   |      |        | /* INTER                                             | RUPT SERVICE R   | DUTINE */              |   |    |    |
|   | з    | 1      | OFF_RECV_DMA PROC                                    | EDURE INTERR     | UPT 32;                |   |    |    |
|   | 4    | 2      | OUTPUT (SINGLE_MA                                    | SK 37)=40H:      |                        |   |    | ,  |
|   | 5    | 2      | WAIT=FALSE;                                          |                  | 1                      |   |    |    |
|   | 6    | 2      | END;                                                 |                  |                        |   | `` |    |

# Table 19-2. PL/M-86 Compiler Rupi/8088 Interface Example

# THE RUPI"-44

| 7        | 1            | DISABLE;                                                                                                                     |      |
|----------|--------------|------------------------------------------------------------------------------------------------------------------------------|------|
|          |              | /* INITIALIZE 8237 */                                                                                                        |      |
| 8        | 1            | DUTPUT (MASTER_CLEAR_37) =0;<br>DUTPUT (COMMAND 37) =040H;                                                                   |      |
| 10       | 1            |                                                                                                                              |      |
| 11       | 1            | OUTPUT(ALL_MASK_37) =OFH;<br>OUTPUT(MODE_REQ_37) =(SINQLE_MODE_OR_WRITE_XFER_OR_CHO_SEL);                                    |      |
| 12       | 1            | OUTPUT(MODE_REG_37) =(SINGLE_MODE OR READ_XFER OR CH0_SEL);                                                                  |      |
| 13       | ī            | OUTPUT(CLEAR_BYTE_PTR_37) =0;                                                                                                |      |
| 14       | 1            | DUTPUT (CHO_ADDR) =OOH;                                                                                                      |      |
| 15       | 1            | DUTPUT(CHO_ADDR) =40H;                                                                                                       |      |
| 16       | 1            | DUTPUT(CHO_CÓUNT) =64;                                                                                                       |      |
| 17       | 1            | DUTPUT(CHO_CQUNT) =00,                                                                                                       |      |
| 18       | <u>'1</u>    | DUTPUT(CH1_ADDR) =40H;                                                                                                       |      |
|          | . 1<br>1     | OUTPUT(CH1_ADDR) =40H;<br>OUTPUT(CH1_COUNT) =64;                                                                             |      |
| 21       | i            | OUTPUT(CH1_COUNT) =00;                                                                                                       |      |
|          | -            |                                                                                                                              |      |
|          |              | /* INITIALIZE 8259 */                                                                                                        |      |
| 22       | 1            | OUTPUT(ICW1_59) =13H, /*SINGLE MODE, EDGE TRIGGERED<br>INPUT, 8086 INTERRUPT TYPE*/                                          |      |
| 23<br>24 | 1            | DUTPUT(ICW2_59) =20H; /*INTERRUPT TYPE 32*/                                                                                  |      |
| 24       | 1            | OUTPUT(ICW4_59) =03H; /*AUTO-EOI*/<br>OUTPUT(OCW1_59) =0FEH; /*ENABLE INTERRUPT LEVEL 0*/                                    |      |
|          | •            | Constructing - Sten / *ENABLE THIERROFT FOR                                                                                  |      |
|          |              | \$EJECT                                                                                                                      |      |
| - 26     | 1            | CALL SET&INTERRUPT (32, OFF_RECV_DMA); /*LOAD INTERRUPT VECTOR LOCATION                                                      | #/   |
| 27       | <b>, 1</b> ` | XMIT_BUFFER(0)=64; /*THE FIRST BYTE IN THE BLOCK OF DATA IS THE NUMBER<br>OF BYTES TO BE TRANSFERED; NOT INCLUDING THE FIRST | BYTE |
|          |              |                                                                                                                              |      |
| 28       | 1 2          | DO I= 1 TO 64;    /* FILL UP THE XMIT_BUFFER WITH DATA */<br>XMIT_BUFFER(I)=I;                                               |      |
| 30       | 2            |                                                                                                                              |      |
| 31       | 1            | OUTPUT(ALL_MASK_37)=OFCH; /*ENABLE CHANNEL 1 AND 2 */                                                                        |      |
| 32       | 1            | ENABLE;                                                                                                                      |      |
| 33       | 1            | WAIT=TRUE;                                                                                                                   |      |
| 34       | 1            | DO WHILE WAIT;                                                                                                               |      |
| 35       | 2            | END; /* A BLOCK OF DATA WILL BE TRANSFERRED TO THE RUPI.<br>WHEN THE RUPI RECEIVES A BLOCK OF DATA IT WILL                   |      |
|          |              | SEND IT TO THE BOBD MEMORY AND INTERRUPT THE BOD                                                                             | 8.   |
|          |              | THE INTERRUPT SERVICE ROUTINE WILL SHUT OFF THE                                                                              |      |
| ļ        |              | CONTROLLER AND SET 'WAIT' FALSE */                                                                                           |      |
| 36       | 1            | DO WHILE 1;                                                                                                                  |      |
| 37       | 2            | END;                                                                                                                         |      |
|          |              |                                                                                                                              |      |
| 1        |              | 1                                                                                                                            |      |
| 38       | 1            | END;                                                                                                                         |      |
|          | -            |                                                                                                                              | ,    |
|          |              |                                                                                                                              |      |
|          |              | 1                                                                                                                            |      |
| MODULE   | E INFO       | FORMATION:                                                                                                                   |      |
| 6        | CODE 4       | AREA SIZE = 00D7H 215D                                                                                                       |      |
|          |              | TANT AREA SIZE = COOCH OD                                                                                                    |      |
| 1 1      | VARIAE       | ABLE AREA SIZE = 0082H 130D                                                                                                  |      |
|          |              | NUMERACK SIZE = 001EH 30D                                                                                                    |      |
|          |              | INES READ<br>JGRAM WARNINGS                                                                                                  |      |
|          |              | JGRAM WARNINGS                                                                                                               |      |
|          |              |                                                                                                                              |      |
| END OF   | F PL/M       | M-86 COMPILATION                                                                                                             |      |
|          |              |                                                                                                                              |      |
| 1        |              |                                                                                                                              |      |
|          |              |                                                                                                                              |      |
|          |              |                                                                                                                              |      |
|          |              |                                                                                                                              |      |
|          |              |                                                                                                                              |      |

# A HIGH PERFORMANCE NETWORK USING THE 8044

#### **19.2.1 Introduction**

This section describes the design of an SDLC data link using the 8044 (RUPI) to implement a primary station and a secondary station. The design was implemented and tested. The following discussion assumes that the reader understands the 8044 and SDLC. This section is divided into two parts. First the data link design example is discussed. Second the software modules used to implement the data link are described. To help the reader understand the discussion of the software, flow charts and software listings are displayed in Appendix A and Appendix B, respectively.

#### Application Description

This particular data link design example uses a two wire half-duplex multidrop topology as shown in figure 19-4. In an SDLC multidrop topology the primary station communicates with each secondary station. The secondary stations communicate only to the primary. Because of this hierarchial architecture, the logical topology for an SDLC multidrop is a star as shown in figure 19-5. Although the physical topology of this data link is multidrop, the easiest way to understand the information flow is to think of the logical (star) topology. The term data link in this case refers to the logical communication pathways between the primary station and the secondary stations. The data links are shown in figure 19-5 as two way arrows.

The application example uses dumb async terminals to interface to the SDLC network. Each secondary station has an async terminal connected to it. The secondary stations are in effect protocol converters which allows any async terminal to communicate with any other async terminal on the network. The secondary stations use an 8044 with a UART to convert SDLC to async. Figure 19-6 displays a block diagram of the data link. The primary station, controls the data link. In addition to data link control the primary provides a higher level layer which is a path control function or networking layer. The primary serves as a message exchange or switch. It receives information from one secondary station and retransmits it to another secondary station. Thus a virtual end to end connection is made between any two secondary stations on the network.

Three separate software modules were written for this network. The first module is a Secondary Station Driver (SSD) which provides an SDLC data link interface and a user interface. This module is a general purpose driver which requires application software to run it. The user interface to the driver provides four functions: OPEN, CLOSE, TRANSMIT, and SIU\_RECV. Using these four functions properly will allow any application software to communicate over this SDLC data link without knowing the details of SDLC. The secondary station driver uses the 8044's AUTO mode.

The second module is an example of application software which is linked to the secondary station driver. This module drives the 8251A, buffers data, and interfaces with the secondary station driver's user interface.

The third module is a primary station, which is a standalone program (i.e., it is not linked to any other module). The primary station uses the 8044's NON-AUTO or FLEXIBLE mode. In addition to controlling the data link it acts as a message switch. Each time a secondary station transmits a frame, it places the destination address of the frame in the first byte of the information or I field. When the primary station receives a frame, it removes the first byte in the I field and retransmits the frame to the secondary station whose address matches this byte.

This network provides two complete layers of the OSI (Open Systems Interconnection) reference model: the physical layer and the data link layer. The physical layer implementation uses the RS-422 electrical interface. The mechanical medium consists of ribbon cable and connectors. The data link layer is defined by SDLC. SDLC's use of acknowledgements and frame numbering guarantees that messages will be received in the same order in which they were sent. It also guarantees message integrity over the data link. However this network will not guarantee secondary to secondary message delivery, since there are acknowledgements between secondary stations.

#### 19.2.2 Hardware

The schematic of the hardware is given in figure 19-7. The 8251A is used as an async communications controller, in support of the 8044. TxRDY and RxRDY on the 8251A are both tied to the two available external interrupts of the 8044 since the secondary station driver is totally interrupt driven. The 8044 buffers the data and some variables in a 2016 (2K x 8 static RAM). The 8254 programmable interval timer is employed as a programmable baud rate generator and system clock driver for the 8251A. The third output from the 8254 could be used as an external baud rate generator for the 8044. The 2732A shown in the diagram was not used since the software for both the primary and secondary stations used far less than the 4 Kbytes provided on the 8744. For the async interface, the standard RS-232



Figure 19-4. SDLC Multidrop Topology

mechanical and electrical interface was used. For the SDLC channel, a standard two wire three state RS-422 driver is used. A DIP switch connected to one of the available ports on the 8044 allows the baud rate, parity, and stop bits to be changed on the async interface. The primary station hardware does not use the USART, 8254, nor the RS-232 drivers.

#### **19.2.3 SDLC Basic Repertoire**

The SDLC commands and responses implemented in the data link include the SDLC Basic Repertoire as defined in the IBM SDLC General Information manual. Table 19-3 shows the commands and responses that the primary and the secondary station in this data link design recognize and send.



Figure 19-5. SDLC Logical Topology



### Figure 19-6. Block Diagram of the Data Link Application Example





# Table 19-3. Data Link Commands and Responses Implemented for This Design

|             | Responses<br>Recognized | Commands<br>Sent |  |  |  |  |
|-------------|-------------------------|------------------|--|--|--|--|
| Unnumbered  | UA<br>DM<br>FRMR<br>*RD | SNRM<br>DISC     |  |  |  |  |
| Supervisory | RR<br>RNR               | RR<br>RNR        |  |  |  |  |
| Information | l                       | 1                |  |  |  |  |

#### PRIMARY STATION

#### SECONDARY STATION

|             | Commands<br>Recognized | Responses<br>Sent                |  |
|-------------|------------------------|----------------------------------|--|
| Unnumbered  | SNRM<br>DISC<br>*TEST  | UA<br>DM<br>FRMR<br>*RD<br>*TEST |  |
| Supervisory | RR<br>RNR<br>REJ       | RR<br>RNR                        |  |
| Information | 1                      | I                                |  |

\*not included in the SDLC Basic Repertoire

The term command specifically means all frames which the primary station transmits and the secondary stations receive. Response refers to frames which the secondary stations transmit and the primary station receives.

#### **Number of Outstanding Frames**

This particular data link design only allows one outstanding frame before it must receive an acknowledgement. Immediate acknowledgement allows the secondary station drivers to use the AUTO mode. In addition, one outstanding frame uses less memory for buffering, and the software becomes easier to manage.

# 19.2.4 Secondary Station Driver using AUTO mode

The 8044 secondary station driver (SSD) was written as a general purpose SDLC driver. It was written to be linked to an application module. The application software implements the actual application in addition to interfacing to the SSD. The main application could be, a printer or plotter, a medical intrument, or a terminal. The SSD is independent of the main application, it just provides the SDLC communications. Existing 8051 applications could add high performance SDLC communications capability by linking the SSD to the existing software and providing additional software to be able to communicate with the SSD.

#### **Data Link Interface and User Interface States**

The SSD has two software interfaces: a data link interface and a user interface as show in Figure 19-8. The data link interface is the part of the software which controls the SDLC communications. It handles link access, command recognition/response, acknowledgements, and error recovery. The user interface provides four functions: OPEN, CLOSE, TRANSMIT, and SIU\_RECV. These are the only four functions which the application software has to interface in order to communicate using SDLC. These four functions are common to many I/O drivers like floppy and hard disks, keyboard/CRT, and async communication drivers.

The data link and the user interface each have their own states. Each interface can only be in one state at any time. The SSD uses the states of these two interfaces to help synchronize the application module to the data link.

There are three states which the secondary station data link interface can be in: Logical Disconnect State (L\_D\_S). Frame Reject State (FRMR\_S), and the Information Transfer State (I\_T\_S). The Logical Disconnect State is when a station is physically connected to the channel but either the primary or secondary have not agreed to enter the Information Transfer State. Both the primary and the secondary stations synchronize to enter into the Information Transfer State. Only when the secondary station is in the I\_T\_S is it able to transfer data or information to the primary. The Frame Reject State (FRMR\_S) indicates that the secondary station has lost software synchronization with the primary or encountered some kind of error condition. When the secondary station is in the FRMR S, the primary station must reset the secondary to resynchronize.

The user interface has two states, open or closed. In the closed state the user program does not want to communicate over the network. The communications channel is closed and not available for use. The secondary station tells the primary this by responding to all commands with DM. The primary continues to poll the secondary in case it wants to enter the  $I\_T\_S$  state. When the user program begins communication over the data link it goes into the open state. It does this by calling the OPEN procedure. When the user interface is in the open state it may transfer information to the primary.

£

19.2

· . & . . . . . . .



### Figure 19-8. Secondary Station Software Modules

## Secondary Stations Commands, Responses and

#### **State Transitions**

Table 19-4 shows the commands which the secondary station recognizes and the responses it generates. The first row in table 19-4 displays commands the secondary station recognizes and each column shows the potential responses with respect to secondary station. For example, if the secondary is in the Logical Disconnect State it will only respond with DM, unless it receives a SNRM command and the user state is open. If this is the case, then the response will be UA and the secondary station will move into the I\_T\_S.

Figure 19-9 shows the state diagram of the secondary station. When power is first applied to the secondary station, it goes into the Logical Disconnect State. As mentioned above, the  $I\_T\_S$  is entered when the secondary station receives a SNRM command and the user state is open. The secondary responds with UA to let the primary know that it has accepted the SNRM and is entering the  $I\_T\_S$ . The  $I\_T\_S$  can go into either the L\_D\_S or the FRMR\_S. The  $I\_T\_S$  goes into the L\_D\_S if the primary sends the secondary DISC. The secondary has to respond with UA, and then goes into the L\_D\_S. If the user interface changes from open to close state, then the secondary sends RD. This causes the primary to send a DISC.

The FRMR\_S is entered when a secondary station is in the  $I_T_S$  and either one of the following conditions occurs.

- A command can not be recognized by the secondary station.
- There is a buffer overrun.
- The Nr that was received from the primary station is invalid.

The secondary station cannot leave the FRMR\_S until it receives a SNRM or a DISC command.

#### Software description of the SSD

To aid in following the description of the software, the reader may either look at the flow charts which are given for each procedure, or read the PL/M-51 listing provided in Appendix A.

A block diagram of the software structure of the SSD is given in figure 19-10. A complete module is identified by the dotted box, and a procedure is identified by the solid box. Therefore the SIU\_\_RECV procedure is not included in the SSD module, it exists in the application software. Two or more procedures connected by a solid line means the procedure above calls the procedure below. Transmit, Power\_\_on\_\_D, Close, and Open are all called by the application software. Procedures without any solid lines connected above are interrupt procedures. The only interrupt procedure in the SSD module is the SIU\_\_INT.

The entire SSD module is interrupt driven. Its design allows the application program could handle real time events or just dedicate more CPU time to the application program. The SIU\_INT is the only interrupt pro-

| Data Link<br>States           | Primary Station Commands |                |                |          |      |      |
|-------------------------------|--------------------------|----------------|----------------|----------|------|------|
| Information<br>transfer state | I<br>RR<br>BNR           | I<br>RR<br>RNR | I<br>RR<br>BNR |          | 0130 |      |
|                               | RD<br>FRMR               | RD<br>FRMR     | RD<br>FRMR     | RD<br>UA | UA   | RĎ   |
|                               |                          |                |                |          |      | Test |
| Logical<br>disconnect state   | DM                       | DM             | DM             | DM<br>UA | DM   | DM   |
| Frame                         | FRMR                     | FRMR           | FRMR           |          |      | FRMR |
| reject state                  |                          |                |                | UA       | UA   |      |

Table 19-4. Secondary Station Responses to Primary Station Commands



### Figure 19-9. State Diagram of Secondary Station



.

Figure 19-10. Secondary Station Driver

cedure in the SSD. It is automatically entered when an SIU interrupt occurs. This particular interrupt can be the lowest priority interrupt in the system.

#### **SSD** Initialization

Upon reset the application software is entered first. The application software initializies its own variables then calls Power On D which is the SSD's initialization routine. The SSD's initialization sets up the transmit and receive data buffer pointers (TBS and RBS), the receive buffer length (RBL), and loads the State variables. The STATION\_STATE begins in the L\_ D\_S state, and the USER\_STATE begins in the closed state. Finally Power\_On\_D initializes XMIT\_ BUFFER\_EMPTY which is a bit flag. This flag serves as a semaphore between the SSD and the application software to indicate the status of the on chip transmit buffer. The SSD does not set the station address. It is the application software's responsibility to do this. After initialization, the SSD is ready to respond to all of the primary stations commands. Each time a frame is received with a matching station address and a good CRC, the SIU\_INT procedure is entered.

#### SIU\_INT Procedure

The first thing the SIU\_INT procedure clears the serial interrupt \_\_bit (SI) in the STS register. If the SIU\_INT procedure returns with this bit set, another SI interrupt will occur.

The SIU\_INT procedure is branches three independent cases. The first case is entered if the STATION\_STATE is not in the I\_T\_S. If this is true, then the SIU is not in the AUTO mode, and the CPU will have to respond to the primary on its own. (Remember that the AUTO mode is entered when the STATION\_STATE enters into I\_T\_S.) If the STATION\_STATE is in the I\_T\_S, then either the SIU has just left the AUTO mode, or is still in the AUTO mode. This is the second and third case respectively.

In the first case, if the STATION\_STATE is not in the I\_T\_S, then it must be in either the L\_D\_S or the FRMR\_S. In either case a separate procedure is called based on which state the station is in. The In\_ Disconnect\_State procedure sends to the primary a DM response, unless it received a SNRM command and the USER\_STATE equals open. In that case the SIU sends an UA and enters into the I\_T\_S. The In\_FRMR\_ State procedure will send the primary the FRMR response unless it received either a DISC or an SNRM. If the primary's command was a DISC, then the secondary will send an UA and enter into the L\_D\_S. If the primary's command was a SNRM, then the secondary will send an UA, enter into the I\_T\_S, and clear NSNR register. For the second case, if the STATION\_STATE is in the I\_T\_S but the SIU left the AUTO mode, then the CPU must determine why the AUTO mode was exited, and generate a response to the primary. There are four reasons for the SIU to automatically leave the AUTO mode. The following is a list of these reasons, and the responses given by the SSD based on each reason.

1. The SIU has received a command field it does not recognize.

Response: If the CPU recognizes the command, it generates the appropriate response. If neither the SIU nor the CPU recognize the command, then a FRMR response is sent.

2. The SIU has received a Sequence Error Sent (SES=1 in NSNR register).  $Nr(P) \neq Ns(S)+1$ , and  $Nr(P) \neq Ns(S)$ .

Response: Send FRMR.

3. A buffer overrun has occured. BOV=1 in STS register.

Response: Send FRMR.

4. An I frame with data was received while RPB=1.

Response: Go back into AUTO mode and send an AUTO mode response.

In addition to the above reasons, there is one condition where the CPU forces the SIU out of the AUTO mode. This is discussed in the SSD's User Interface Procedures section in the CLOSED procedure description.

The other reason this section of code could be entered is if a valid I frame was received. When a good I frame is received the RBE bit equals 0. This means that the receiver is disabled. If the primary were to poll the 8044 while RBE=0, it would time out since no response would given. Time outs reduce network throughput. To improve network performance, the CPU first sets RBP, then sets RBE. Now when the primary polls the 8044 an immediate RNR response is given. At this point the SSD calls the application software procedure SIU\_RECV and passes the length of the data as a parameter. The SIU\_RECV procedure reads the data out of the receive buffer then returns to the SSD module. Now that the receive information has been transfered, RBP can be cleared.

#### Command\_\_Decode Procedure

The Command\_Decode procedure is called from the SIU\_INT procedure when the STATION\_STATE =  $I_T_S$  and the SIU left the AUTO mode as a result



Figure 19-11. Information Field of the FRMR Response, as Transmitted

of not being able to recognize the receive control byte. Commands which the SIU AUTO mode does not recognize are handled here. The commands recognized in this procedure are: SNRM, DISC, and TEST. Any other command received will generate a Frame Reject with the nonimplemented command bit set in the third data byte of the FRMR frame. Any additional unnumbered frame commands which the secondary station is going to implement, should be implemented in this procedure.

If a SNRM is received the command\_decode procedure calls the SNRM\_Response procedure. The SNRM\_ Response procedure sets the STATION\_STATE = I\_ T\_S, clears the NSNR register and responds with an UA frame. If a DISC is received, the command\_decode procedure sets the STATION\_STATE = L\_D\_S, and responds with an UA frame. When a TEST frame is received, and there is no buffer overrun, the command\_decode procedure responds with a TEST frame retransmitting the same data it received. However if a TEST frame is received and there is a buffer overrun, then a TEST frame will be sent without any data, instead of a FRMR with the buffer overrun bit set.

#### Frame Reject Procedures

There are two procedures which handle the FRMR state: XMIT\_FRMR and IN\_FRMR\_STATE. XMIT\_ FRMR is entered when the secondary station first goes into the FRMR state. The frame reject response frame contains the FRMR response in the command field plus three additional data bytes in the I field. Figure 19-11 displays the format for the three data byte in the I field of a FRMR response. The XMIT\_FRMR procedure sets up the Frame Reject response frame based on the parameter REASON which is passed to it. Each place in the SSD code that calls the XMIT\_FRMR procedure, passes the REASON that this procedure was called, which in turn is communicated to the primary station. The XMIT\_FRMR procedure uses three bytes of internal RAM which it initializes for the correct response. The TBS and TBL registers are then changed to point to the FRMR buffer so that when a response is sent these three bytes will be included in the I field.

The IN\_FRMR\_STATE procedure is called by the SIU\_INT procedure when the STATION\_STATE already is in the FRMR state and a response is required. The IN\_FRMR\_STATE procedure will only allow two commands to remove the secondary station from the FRMR state: SNRM and DISC. Any other command which is received while in the FRMR state will result a FRMR response frame.

#### XMIT\_UNNUMBERED Procedure

This is a general purpose transmit procedure, used only in the FLEX1BLE mode, which sends unnumbered responses to the primary. It accepts the control byte as a parameter, and also expects the TBL register to be set before the procedure is called. This procedure waits until the frame has been transmitted before returning. If this procedure returned before the transmit interrupt was generated, the SIU\_INT routine would be entered. The SIU\_INT routine would not be able to distinguish this condition. SSD's User Interface Procedures -- OPEN, CLOSE, TRANSMIT, SIU\_RECV -- are discussed in the following section.

The OPEN procedure is the simplest of all, it changes the USER\_STATE to OPEN\_S then returns. This lets the SSD know that the user wants to open the channel for communications. When the SSD receives a SNRM command, it checks the USER\_STATE. If the USER\_STATE is open, then the SSD will respond with an UA, and the STATION\_STATE enters the  $I_T_S$ .

The CLOSE procedure is also simple, it changes the USER\_STATE to CLOSED\_S and sets the AM bit to 0. Note that when the CPU sets the AM bit to 0 it puts the SIU out of the AUTO mode. This event is asynchronous to the events on the network. As a result an I frame can be lost. This is what can happen.

- 1. AM is set to 0 by the CLOSE Procedure.
- 2. An I frame is received and a SI interrupt occurs.
- 3. The SIU\_INT procedure enters case 2. (STATION\_STATE =  $I_T_S$ , and AM = 0)
- 4. Case 2 detects that the USER\_STATE = CLOSED\_S, sends a RD response and ignores the fact that an I frame was received.

Therefore it is advised to never call the CLOSE procedure or take the SIU out of the AUTO mode when it is receiving I frames or an I frame will be lost.

For both the TRANSMIT and SIU\_RECV procedures, it is the application software's job to put data into the transmit buffer, and take data out of the receive buffer. The SSD does not transfer data in or out of its transmit or receive buffers because it does not know what kind of buffering the application software is implementing. What the SSD does do is notify the application software when the transmit buffer is empty, XMIT\_BUFFER\_EMPTY = 1, and when the receive buffer is full.

One of the functions that the SSD performs to synchronize the application software to the SDLC data link. However some of the synchronization must also be done by the application software. Remember that the SSD does not want to hang up the application software waiting for some event to occur on the SDLC data link, therefore the SSD always returns to the application software as soon as possible.

For example, when the application software calls the OPEN procedure, the SSD returns immediately. The application software thinks that the SDLC channel is now open and it can transmit. This is not the case. For the channel to be open, the SSD must receive a SNRM from the primary and respond with a UA. However, the SSD does not want to hang up the application software waiting for a SNRM from the primary before returning from the OPEN procedure. When the TRANSMIT procedure is called, the SSD expects the STATION STATE to be in the I T S. If it isn't, the SSD refuses to transmit the data. The TRANSMIT procedure first checks to see if the USER STATE is open, if not the USER STATE CLOSED parameter is passed back to the application module. The next thing TRANSMIT checks is the STATION\_STATE. If this is not open, then TRANSMIT passes back LINK DISCONNECTED. This means that the USER STATE is open, but the SSD hasn't received a SNRM command from the primary yet. Therefore, the application software should wait awhile and try again. Based on network performance, one knows the maximum amount of time it will take for a station to be polled. If the application software waits this length of time and tries again but still gets a LINK DISCONNECTED parameter passed back, higher level recovery must be implemented.

Before loading the transmit buffer and calling the TRANSMIT procedure, the application software must check to see that XMIT\_BUFFER\_EMPTY = 1. This flag tells the application software that it can write new data into the transmit buffer and call the TRANSMIT procedure. After the application software has verified that XMIT BUFFER EMPTY = 1, it fills the transmit buffer with the data and calls the TRANSMIT procedure passing the length of the buffer as a parameter. The TRANSMIT procedure checks for three reasons why it might not be able to transmit the frame. If any of these three reasons are true, the TRANSMIT procedure returns a parameter explaining why it couldn't send the frame. If the application software receives one of these responses, it must rectify the problem and try again. Assuming these three conditions are false, then the SSD clears XMIT BUFFER EMPTY, attempts to send the data and returns the parameter DATA\_TRANSMITTED. XMIT\_ BUFFER\_EMPTY will not be set to 1 again until the data has been transmitted and acknowledged.

The SIU\_RECV procedure must be incorporated into the application software module. When a valid I frame is received by the SIU, it calls the SIU\_RECV procedure and passes the length of the received data as a parameter. The SIU\_RECV procedure must remove all of the data from the receive buffer before returning to the SIU\_INT procedure.

#### Linking up to the SSD

Figure 19-12 shows necessary parts to include in a PL/M-51 application program that will be linked to the SSD module. RL51 is used to link and locate the SSD and application modules. The command line used to do this is:

RL51 SSD,obj,filename.obj,PLM51.LIB TO filename & RAMSIZE(192)

\$registerbank(0) user\$mod: do: \$include (reg44.dcl) declare lit literally 'literally'. buffer length liť **'60'**. siu xmit buffer (buffer\_length) external idata. byte siu recv buffer (buffer\_length) byte external. xmit buffer empty bit external:

/\* external procedures \*/

power\_on\_d: procedure external; end power\_on\_d;

close: procedure external using 1; end close;

open: procedure external using 1; end open;

transmit: procedure
(xmit\_buffer\_length) byte external;
 declare xmit\_buffer\_length byte;
end transmit;

/\* local procedures \*/

siu\_recv: procedure (length) public using 1; declare length byte,

end siu\_recv;

#### Figure 19-12. Applications Module Link Information

#### PL/M-51 and Register Banks

The 8044 has four register banks. PL/M-51 assumes that an interrupt procedure never uses the same bank as the procedure it interrupts. The USING attribute of a procedure, or the \$REGISTERBANK control, can be used to ensure that.

The SSD module uses the \$REGISTERBANK(1) attribute. Some procedures are modified with the USING attribute based on the register bank level of the calling procedure.

#### 19.2.5 APPLICATION MODULE; Async to SDLC protocol converter

One of the purposes of this application module is to demonstrate how to interface software to the SSD. Another purpose is to implement and test a pratical application. This application software performs I/O with an async terminal through a USART, buffers data, and also performs I/O with the SSD. In addition, it allows the user on the async terminal to: set the station address, set the destination address, and go online and offline. Setting the station address sets the byte in the STAD register. The destination address is the first byte in the I field. Going online or offline results in either calling the OPEN or CLOSE procedure respectively.

After the secondary station powers up, it enters the 'terminal mode', which accepts data from the terminal. However, before any data is sent, the user must configure the station. The station address and destination address must be set, and the station must be placed online. To configure the station the ESC character is entered at the terminal which puts the protocol converter into the 'configure mode'. Figure 20-13 shows the menu which appears on the terminal screen.

( /) 8044 Secondary Station

- 1 Set the Station Address
- 2 Set the Destination Address
- 3 Go Online
- 4 Go Offline
- 5 Return to terminal mode

Enter option \_\_\_\_

#### Figure 19-13. Menu for the Protocol Converter

In the terminal mode data is buffered up in the secondary station. A Line Feed character 'LF' tells the secondary station to send an I frame. If more than 60 bytes are buffered in the secondary station when a 'LF' is received, the applications software packetizes the data into 60 bytes or less per frame. If a LF is entered when the station is offline, an error message comes on the screen which says 'Unable to Get Online'.

The secondary station also does error checking on the async interface for Parity, Framing Error, and Overrun Error. If one of these errors are detected, an error message is displayed on the terminal screen.

#### Buffering

There are two separate buffers in the application module: a transmit buffer and a receive buffer. The transmit buffer receives data from the USART, and sends data to the SSD. The receive buffer receives data from the SSD, and transmits data to the USART. Each buffer is a 256 byte software FIFO. If the transmit FIFO becomes full and no 'LF' character is received, the secondary station automatically begins sending the data. In addition, the application module will shut off the terminal's transmitter using CTS until the FIFO has been partially emptied. A block diagram of the buffering for the protocol converter is given in Figure 19-14.

#### Application Module Software

A block diagram of the application module software is given in Figure 19-15. There are three interrupt



Figure 19-14. Block Diagram of Secondary Station Protocol Converter Illustrating Buffering

19-23

routines in this module: USART\_RECV\_INT, USART\_XMIT\_INT, and TIMER\_0\_INT. The first two are for servicing the USART. TIMER\_0\_INT is used if the TRANSMIT procedure in the SSD is called and does not return with the DATA\_TRANSMITTED parameter. TIMER\_0\_INT employs Timer 0 to wait a finite amount of time before tring to transmit again. The highest priority interrupt is USART\_RECV\_INT. The main program and all the procedures it calls use register bank 0, USART\_XMIT\_INT and TIMER\_0\_INT and FIFO\_R\_OUT use bank 1, while USART\_ RECV\_INT and all the procedures it calls use register bank 2.

#### Power\_On Procedure

The Power\_On procedure initializes all of the chips in the system including the 8044. The 8044 is initialized to use the on-chip DPLL with NRZI coding, PreFrame Sync, and Timer 1 auto reload at a baud rate of 62.5 Kbps. The 8254 and the 8251A are initialized next based on the DIP switch values attached to port 1 on the 8044. Variables and pointers are initialized, then the SSD's Power-Up Procedure, Power\_On\_ D, is called. Finally the interrupt system is enabled and the main program is entered.

#### Main Program

The main program is a simple loop which waits for a frame transmit command. A frame transmit command is indicated when the variable SEND DATA is greater than 0. The value of SEND\_DATA equals the number of 'LF' characters in the transmit FIFO, hence it also indicates the number of frames pending transmission. Each time a frame is sent, SEND DATA is decremented by one. Thus when SEND DATA is greater than 0, the main program falls down into the next loop which polls the XMIT\_BUFFER\_EMPTY bit. When XMIT BUFFER EMPTY equals 1, the SIU XMIT BUFFER can be loaded. The first byte in the buffer is loaded with the destination address while the rest of the buffer is loaded with the data. Bytes are removed from the transmit FIFO and placed into the SIU\_XMIT\_BUFFER until one of three things happen: 1. a 'LF' character is read out of the FIFO, 2. the number of bytes loaded equals the size of the SIU\_XMIT\_BUFFER, or 3. the transmit FIFO is empty.

After the SIU\_XMIT\_BUFFER is filled, the SSD TRANSMIT procedure is called and the results from the procedure are checked. Any result other than DATA\_TRANSMITTED will result in several retries within a finite amount of time. If all the retries fail then the LINK\_DISC procedure is called which sends a message to the terminal, 'Unable to Get Online'.

#### USART\_RECV\_INT Procedure

When the 8251A receives a character, the RxRDY pin

on the 8251A is activated, and this interrupt procedure is entered. The routine reads the USART status register to determine if there are any errors in the character received. If there are, the character is discarded and the ERROR procedure is called which prints the type of error on the screen. If there are no errors, the received character is checked to see if it's an ESC. If it is an ESC, the MENU procedure is called which allows the user to change the configuration. If neither one of these two conditions exits the received character is inserted into the transmit FIFO. The received character may or may not be echoed back to the terminal based on the dip switch settings.

#### **Transmit FIFO**

The transmit FIFO consists of two procedures: FIFO T\_IN and FIFO\_T\_OUT. FIFO\_T\_IN inserts a character into the FIFO, and FIFO\_T\_OUT removes a character from the FIFO. The FIFO itself is an array of 256 bytes called FIFO\_T. There are two pointers used as indexes in the array to address the characters: IN PTR T and OUT PTR T. IN PTR T points to the location in the array which willstore the next byte of data inserted. OUT PTR T points to the next byte of data removed from the array. Both IN\_PTR\_T and OUT\_PTR\_T are declared as bytes. The FIFO\_T\_ IN procedure receives a character from the USART\_RECV\_INT procedure and stores it in the array location pointed to by IN\_PTR\_T, then IN\_PTR\_T is incremented. Similarly, when FIFO\_ T\_OUT is called by the main program, to load the SIU XMIT BUFFER, the byte in the array pointed to by OUT PTR T is read, then OUT PTR T is incremented. Since IN PTR T and OUT PTR T are always incremented, they must be able to roll over when they hit the top of the 256 byte address space. This is done automatically by having both IN PTR T and OUT\_PTR\_T declared as bytes. Each character inserted into the transmit FIFO is tested to see if it's a LF. If it is a LF, the variable SEND\_DATA is incremented which lets the main program know that it is time to send an I frame. Similarly each character removed from the FIFO is tested. SEND\_DATA is decremented for every LF character removed from the FIFO.

IN\_PTR\_T and OUT\_PTR\_T are also used to indicate how many bytes are in the FIFO, and whether it is full or empty. When a character is placed into the FIFO and IN\_PTR\_T is incremented, the FIFO is full if IN\_PTR\_T equals OUT\_PTR\_T. When a character is read from the FIFO and OUT\_PTR\_T is incremented, the FIFO is empty if OUT\_PTR\_T equals IN\_PTR\_T. If the FIFO is neither full nor empty, then it is in use. A byte called BUFFER\_ STATUS\_T is used to indicate one of these three conditions. The application module uses the buffer status information to control the flow of data into and out of the FIFO. When the transmit FIFO is empty, the main program must stop loading bytes into the SIU



Figure 19-15. Block Diagram of User Software

19-25

XMIT\_BUFFER. Just before the FIFO is full, the async input must be shut off using CTS. Also if the FIFO is full and SEND\_DATA=0, then SEND\_DATA must be incremented to automatically send the data without a LF.

#### Receive FIFO

The receive FIFO operates in a similiar fashion as the transmit FIFO does. Data is inserted into the receive FIFO from the SIU\_RECV procedure. The SIU RECV procedure is called by the SIU\_INT procedure when a valid I frame is received. The SIU RECV procedure mearly polls the receive FIFO status to see if it's full before transfering each byte from the SIU RECV\_BUFFER into the receive FIFO. If the receive FIFO is full, the SIU RECV procedure remains polling the FIFO status until it can insert the rest of the data. In the meantime, the SIU AUTO mode is responding to all polls from the primary with a RNR supervisory frame. The USART\_XMIT\_INT interrupt procedure removes data from the receive FIFO and transmits it to the terminal. The USART transmit interrupt remains enabled while the receive FIFO has data in it. When the receive FIFO becomes empty, the USART transmit interrupt is disabled.

#### **19.2.6 PRIMARY STATION**

The primary station is responsible for controlling the data link. It issues commands to the secondary stations and receives responses from them. The primary station controls link access, link level error recovery, and the flow of information. Secondaries can only transmit when polled by the primary.

Most primary stations are either micro/minicomputers, or front end processors to a mainframe computer. The example primary station in this design is standalone. It is possible for the 8044 to be used as an intelligent front end processor for a microprocessor, implementing the primary station functions. This latter type of design would extensively off-load link control functions for the microprocessor. The code listed in this paper can be used as the basis for this primary station design. Additional software is required to interface to the microprocessor. A hardware design example for interfacing the 8044 to a microprocessor can be found in the applications section of this handbook.

The primary station must know the addresses of all the stations which will be on the network. The software for this primary needs to know this before it is compiled, however a more flexible system would down load these parameters.

From the listing of the software it can be seen that the variable NUMBER\_OF\_STATIONS is a literal declaration, which is 2 in this design example. There were three stations tested on this data link, two secondaries and one primary. Following the NUMBER\_OF\_STATIONS declaration is a table, loaded into the

object code file at compile time, which lists the addresses of each secondary station on the network.

#### **Remote Station Database**

The primary station keeps a record of each secondary station on the network. This is called the Remote Station Database (RSD). The RSD in this software is an array of structures, which can be found in the listing and also in Figure 19-16. Each RSD stores the necessary information about that secondary station.

To add additional secondary stations to the network, one simply adjusts the NUMBER\_OF\_STATIONS declaration, and adds the additional addresses to the SECONDARY\_ADDRESSES table. The number of RSDs is automatically allocated at compile time, and the primary automatically polls each station whose address is in the SECONDARY ADDRESSES table.

Memory for the RSDs resides in external RAM. Based on memory requirements for each RSD, the maximum number of stations can be easily buffered in external RAM. (254 secondary stations is the maximum number SDLC will address on the data link; i.e. 8 bit address, FF H is the broadcast address, and 0 is the nul address. Each RSD uses 70 bytes of RAM. 70 x 254 = 17,780.)

The station state, in the RSD structure, maintain the status of the secondary. If this byte indicates that the secondary is in the DISCONNECT\_S, then the primary tries to put the station in the I\_T\_S by sending a SNRM. If the response is an UA then the station state changes into the I\_T\_S. Any other frame received results in the station state remaining in the DISCONNECT S. When the RSD indicates that the station state is in the I\_T\_S, the primary will send either a I, RR, or RNR command, depending on the local and remote buffer status. When the station state equals GO TO DISC the primary will send a DISC command. If the response is an UA frame, the station state will change to DISCONNECT\_S, else the station state will remain in GO\_TO\_DISC. The station state is set to GO\_TO\_DISC when one of the following responses occur:

1. A receive buffer overrun in the primary.

2. An I frame is received and  $Nr(P) \neq Ns(S)$ .

3. An I frame or a Supervisory frame is received and  $N_S(P) + 1 \neq Nr(S)$  and  $N_S(P) \neq Nr(S)$ .

4. A FRMR response is received.

5. An RD response is received.

6. An unknown response is received.

The send count (Ns) and receive count (Nr) are also maintained in the RSD. Each time an I frame is sent by the primary and acknowledged by the secondary, Ns is incremented. Nr is incremented each time a valid I frame is received. BUFFER\_STATUS indicates the status of the secondary stations buffer. If a RR response is received, BUFFER\_STATUS is set to BUFFER\_ 

#### Buffering

The buffering for the primary station is as follows: within each RSD is a 64 byte array buffer which is initially empty. When the primary receives an I frame, it looks for a match between the first byte of the I frame and the addresses of the secondaries on the network. If a match exits, the primary places the data in the RSD buffer of the destination station. The INFO\_LENGTH in the RSD indicates how many bytes are in the buffer. If INFO\_LENGTH equals 0,then the buffer is empty. The primary can buffer only one I frame per station. If a second I frame is received while the addressed secondary's RSD buffer is full, the primary cannot receive any more I frames. At this point the primary continues to poll the secondaries using RNR supervisory frame.

#### **Primary Station Software**

A block diagram of the primary station software is shown in Figure 19-17. The primary station software consists of a main program, one interrupt routine, and several procedures. The POWER\_ON procedure begins by initializing the SIU's DMA and enabling the receiver. Then each RSD is initialized. The DPLL and the timers are set, and finally the TIMER 0 interrupt is enabled.

The main program consists of an iterative do loop within a do forever loop. The iterative do loop polls each secondary station once through the do loop. The variable STATION\_NUMBER is the counter for the iterative do statement which is also used as an index to the array of RSD structures. The primary station issues one command and receives one response from every secondary station each time through the loop. The first statement in the loop loads the secondary station address, indexed by STATION\_NUMBER into the array of the RSD structures. Now when the primary sends a command, it will have the secondary's address in the address field of the frame. The automatic address recognition feature is used by the primary to recognize the response from the secondary.

Next the main program determines the secondary stations state. Based on this state, the primary knows what command to send. If the station is in the DISCONNECT\_S, the primary calls the SNRM\_P



# Figure 19-16 . Remote Station Database Structure

procedure to try and put the secondary in the I\_T\_ S. If the station state is in the GO\_TO\_DISC state, the DISC\_P is called to try and put the secondary in the L\_D\_S. If the secondary is in neither one of the above two states, then it is in the I\_T\_S. When the secondary is in the I\_T\_S, the primary could send one of three commands: I, RR, or RNR. If the RSD's buffer has data in it, indicated by INFO LENGTH being greater than zero, and the secondary's BUFFER STATUS equals BUFFER READY, then an I frame will be sent. Else if RPB=0, a RR supervisory frame will be sent. If neither one of these cases is true, then an RNR will be sent. The last statement in the main program checks the RPB bit. If set to one, the BUFFER\_TRANSFER procedure is called, which transfers the data from the SIU receive buffer to the appropriate RSD buffer.

#### **Receive Time Out**

Each time a frame is transmitted, the primary sets a receive time out timer; Timer 0. If a response is not received within a certain time, the primary returns to the main program and continues polling the rest of the stations. The minimum length of time the primary should wait for a response can be calculated as the sum of the following parameters.

- 1. propagation time to the secondary station
- 2. clear-to-send time at the secondary station's DCE

- 3. appropriate time for secondary station processing
- 4. propagation time from the secondary station
- 5. maximum frame length time

The clear-to-send time and the propagation time are negligible for a local network at low bit rates. However, the turnaround time and the maximum frame length time are significant factors. Using the 8044 secondaries in the AUTO mode minimizes turnaround time. The maximum frame length time comes from the fact the 8044 does not generate an interrupt from a received frame until it has been completely received, and the CRC is verified as correct. This means that the time-out is bit rate dependent.

#### **Ns and Nr check Procedures**

Each time an I frame or supervisory frame is received, the Nr field in the control byte must be checked. Since this data link only allows one outstanding frame, a valid Nr would satisfy either one of two equations; Ns(P) + 1 = Nr(S) the I frame previously sent by the primary is acknowledged, Ns(P) = Nr(S) the I frame previously sent is not acknowledged. If either one of these two cases is true, the CHECK\_NR procedure returns a parameter of TRUE; otherwise a FALSE parameter is returned. If an acknowledgement is received, the Ns byte in the RSD structure is incremented, and the Information buffer may be cleared. Otherwise the information buffer remains full.



Figure 19-17. Block Diagram of Primary Station Software Structure

When an I frame is received, the Ns field has to be checked also. If Nr(P) = Ns(S), then the procedure returns TRUE, otherwise a FALSE is returned.

#### **Receive Procedure**

The receive procedure is called when a supervisory or information frame is sent, and a response is received before the time-out period. The RECEIVE procedure can be broken down into three parts. The first part is entered if an I frame is received. When an I frame is received, Ns, Nr and buffer overrun are checked. If there is a buffer overrun, or there is an error in either Ns or Nr, then the station state is set to GO\_TO\_DISC. Otherwise Nr in the RSD is incremented, the receive field length is saved, and the RPB bit is set. By incrementing the Nr field, the I frame just received is acknowledged the next time the primary polls the secondary with an I frame or a supervisory frame. Setting RBP protects the received data, and also tells

the main program that there is data to transfer to one of the RSD buffers.

If a supervisory frame is received, the Nr field is checked. If a FALSE is returned, then the station state is set to GO\_TO\_DISC. If the supervisory frame received was an RNR, buffer status is set to not ready. If the response is not an I frame, nor a supervisory frame, then it must be an Unnumbered frame.

The only Unnumbered frames the primary recognizes are UA, DM, and FRMR. In any event, the station state is set to GO\_TO\_DISC. However if the frame received is a FRMR, Nr in the second data byte of the I field is checked to see if the secondary acknowledged an I frame received before it went into the FRMR state. If this is not done and the secondary acknowledged an I frame which the primary did not recognize, the primary transmits, the I frame when the secondary returns to the I\_T\_S. In this case, the secondary would receive duplicate I frames.

# APPENDIX A 8044 SOFTWARE FLOWCHARTS





١



#### Figure 19-19. Secondary Station Driver Flow Chart

~ ~

XMIT-FRMR PROCEDURE TCB = FRMR TBS = FRMR-BUFFER (0) TBL = 3 FRMR-BUFFER (0) = RCB FRMR-BUFFERED (1) = NR NSFRMR-BUFFER (2) = REASON STATION-STATE = FRMR-S P/F = 1 Ν Y SEND FRMR FRAME RETURN





.

Figure 19-21. Secondary Station Driver Flow Chart



# Figure 19-22 . Secondary Station Driver Flow Chart

.





Figure 19-23. Secondary Station Driver Flow Chart



.

RUPI<sup>TM</sup>-44

Figure 19-24. Secondary Station Driver Flow Chart

19-37



Figure 19-25. Application Module Flow Chart



Figure 19-26. Application Module Flow Chart







Figure 19-28 Application Module Flow Chart

•









. .



Figure 19-31. Application Module Flow Chart





and the method of the second second second second second second second second second second second second second



Figure 19-33. Primary Station Flow Charts



Figure 19-34. Primary Station Flow Charts



RUPI<sup>™</sup>-44

#### Figure 19-35. Primary Station Flow Charts



Figure 19-36. Primary Station Flow Charts

RUPI<sup>™</sup>-44



Figure 19-37. Primary Station Flow Charts



Figure 19-38. Primary Station Flow Charts

19-51

RUPI<sup>TM</sup>-44

### APPENDIX B LISTINGS OF SOFTWARE MODULES

### int

PL/M-51.COMPILER . RUPI-44 Secondary Station Driver

20.24.47 09/20/83 PAGE 1

ISIS-II PL/M-51 V1 O COMPILER INVOKED BY. . F2 PLM51 : F2. APNOTE. SRC

\$TITLE ('RU \$DEBUQ \$REGISTERBANK(1) MAIN\$MOD'DO; \$NOLIST ('RUPI-44 Secondary Station Driver')

/\* To save paper the RUPI registers are not listed, but this is the statement used to include them \$INCLUDE (.F2 REQ44.DCL) \*/ DECLARE LIT TRVE FALSE FOREVER

5 1

> 6 1

1 1

> LITERALLY LIT LIT LIT 'LITERALLY', 'OFFH', 'OOH', 'WHILE 1';

/\* SDLC commands and responses \*/

| DECLARE | SNRM<br>UA |
|---------|------------|
|         | DISC       |
|         | DM         |

| SNRM     | LIT | 183H 1, |
|----------|-----|---------|
| UA       | LIT | '73H',  |
| DISC     | LIT | '43H',  |
| DM       | LIT | '1FH')  |
| FRMR     | LIT | '97H',  |
| REG DISC | LIT | 153H1,  |
| UP       | LIT | '33H',  |
| TEST     | LIT | '0E3H', |
|          |     |         |

/\* User states \*/

| OPEN_S<br>CLOSED_S                                             | LIT<br>LIT        | 100H1,<br>101H1,                     |                                                                                 |
|----------------------------------------------------------------|-------------------|--------------------------------------|---------------------------------------------------------------------------------|
| /* Sta                                                         | tion states       | : #/                                 | •                                                                               |
| DISCONNECT_S<br>FRMR_S<br>I_T_S                                | LIT<br>LIT<br>LIT | '01H', /* FRA                        | ICALLY DISCONNECTED STATE*/<br>HE REJECT STATE */<br>DRMATION TRANSFER STATE */ |
| /* Status valu                                                 | es returned       | from TRANSMIT p                      |                                                                                 |
| USER_STATE_CLO<br>LINK_DISCONNEC<br>OVERFLOW<br>DATA_TRANSMITT | TED LIT<br>LIT    | (00H',<br>(01H',<br>(02H',<br>(03H', |                                                                                 |

/\* Parameters passed to XMIT\_FRMR \*/

| UNASSIGNED_C       | LIT | '00H', |
|--------------------|-----|--------|
| NO_I_FIELD_ALLOWED | LIT | '01H', |
| BUFF_OVERRUN       | LIT | 102H1, |
| SES ERR            | LIT | '03H', |

PAGE 2

09/20/83

| PL/M-!                                 | 51 COMP         | ILER RUPI-44 Secondary Station Driver                                                                                                                                         | 20.24.47 |
|----------------------------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
|                                        |                 | /* Variables */                                                                                                                                                               |          |
|                                        |                 | USER_STATE BYTE AUXILIARY,<br>STATION_STATE BYTE AUXILIARY,<br>I_FRAME_LENGTH BYTE AUXILIARY,                                                                                 |          |
|                                        |                 | /* Buffers */                                                                                                                                                                 |          |
|                                        |                 | BUFFER_LENGTH LIT '60',<br>SIU_XMIT_BUFFER(BUFFER_LENGTH) BYTE PUBLIC IDATA,<br>SIU_RECY_BUFFER(BUFFER_LENGTH) BYTE PUBLIC,<br>FRRM_BUFFER(3) BYTE,                           | ·        |
|                                        |                 | /* Flags */                                                                                                                                                                   |          |
|                                        |                 | XMIT_BUFFER_EMPTY BIT PUBLIC:                                                                                                                                                 |          |
| 7<br>8<br>9                            | 2<br>2<br>1     | SIU_RECV: PROCEDURE (LENGTH) EXTERNAL;<br>DECLARE LENGTH BYTE;<br>END SIU_RECV;                                                                                               |          |
| 10<br>11<br>12                         | 2<br>2<br>1     | OPEN: PROCEDURE FUBLIC USING 2;<br>USER_STATE=OPEN_S;<br>END OPEN;                                                                                                            |          |
| 13<br>14                               | 2               | CLOSE: PROCEDURE PUBLIC USING 2;<br>AM=0;                                                                                                                                     |          |
| 15<br>16                               | 2               | USER_STATE=CLOSED_S;<br>END CLOSE;                                                                                                                                            |          |
| 17                                     | 2               | POWER_ON_D: PROCEDURE PUBLIC USING 0;                                                                                                                                         |          |
| 18<br>19<br>20<br>21<br>22<br>23<br>24 | N N N N N N N N | UBER_STATE=CLOSED_S;<br>STATION_STATE=DISCONNECT_S;<br>TBS=.SIU_XMIT_BUFFER(O);<br>RBS=.SIU_REOV_BUFFER(O);<br>RB==UFFER_LENOTH;<br>RBE=1;<br>RBE=1;<br>XMIT_BUFFER_LENOTH=1; |          |
| 25                                     | 1               | END POWER_ON_D;                                                                                                                                                               |          |
| 26                                     | 2               | TRANSMIT: PROCEDURE (XMIT_BUFFER_LENGTH) BYTE PUBLIC USING 0;<br>/* User must check XMIT_BUFFER_EMPTY flag before calling this procedure */                                   |          |
| 27                                     | 2               | DECLARE XMIT_BUFFER_LENOTH BYTE,<br>I Byte Auxiliary,                                                                                                                         |          |
|                                        | ,               | STATUS BYTE AUXILIARY;                                                                                                                                                        |          |
| 28                                     | 2               | IF USER_STATE=CLOSED_S<br>THEN STATUS=USER_STATE_CLOSED,                                                                                                                      |          |
| 30                                     | 2               | ELSE IF STATION_STATE=DISCONNECT_S<br>Then status=link_disconnected;                                                                                                          |          |
| 32                                     | 2               | ELSE IF XMIT_BUFFER_LENGTH>BUFFER_LENGTH<br>THEN STATUS=OVERFLOW;                                                                                                             |          |
| 34                                     | з,              | ELSE DO;                                                                                                                                                                      |          |

| PL/M-5         | L COMP      | ILER RUPI-44 Secondary Station Driver                                                                                                                                   | 20: 24: 47 | 09/20/83 | PAGE |
|----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------|------|
| 35<br>36<br>37 | 3<br>3<br>3 | XMIT_BUFFER_EMPTY=0;<br>TBL=XMIT_BUFFER_LENOTH; /* Store length in case st<br>I_FRAME_LENOTH=XMIT_BUFFER_LENOTH; /* Store length in case st<br>is reset by FRMR. SNRM ( |            |          |      |
| 38<br>39       | 3<br>3      | TBF=1;<br>STATUS=DATA_TRANSMITTED;                                                                                                                                      |            |          |      |
| 40             | 3           | END;                                                                                                                                                                    |            |          |      |
| 41             | 2           | RETURN STATUS;                                                                                                                                                          |            |          |      |
| 42             | 1           | END TRANSMIT:                                                                                                                                                           |            |          |      |
| 43             | 5           | XMIT_UNNUMBERED: PROCEDURE (CONTROL_BYTE) ;                                                                                                                             |            |          |      |
| 44             | 2           | DECLARE CONTROL_BYTE BYTE,                                                                                                                                              |            |          |      |
| 45             | 2           | TCB=CONTROL_BYTE;                                                                                                                                                       |            |          |      |
| 46             | 2           | TBF=1;                                                                                                                                                                  |            |          |      |
| 47             | 2           | RTS=1;                                                                                                                                                                  |            |          |      |
| 48             | 3           | DO WHILE NOT SI;                                                                                                                                                        |            |          |      |
| 49             | з           | END;                                                                                                                                                                    |            |          | `    |
| 50             | 2           | SI=0;                                                                                                                                                                   |            |          |      |
| <b>9</b> 1     | 1           | END XMIT_UNNUMBERED;                                                                                                                                                    |            |          |      |
| 52             | 2           | SNRM_RESPONSE: PROCEDURE ;                                                                                                                                              |            |          |      |
| 53             | 2           | STATION_BTATE=1_T_S;                                                                                                                                                    |            |          |      |
| 54             | 2           | NSNR=0;                                                                                                                                                                 |            |          |      |
| 55             | 2           | IF (RCB AND 10H) <> 0 /* Respond if polled */<br>THEN DO;                                                                                                               |            |          |      |
| 57             | 3           | TBL=0;                                                                                                                                                                  |            |          |      |
| 58             | 3           | CALL XMIT_UNNUMBERED(UA);                                                                                                                                               |            |          |      |
| 59             | 3           | END;                                                                                                                                                                    |            |          |      |
| 60             | 2           | IF XMIT_BUFFER_EMPTY=O /* If an I frame was left pending transmission<br>then restore it */<br>THEN DO;                                                                 |            |          |      |
| 62             | з           | TBL=I_FRAME_LENGTH;                                                                                                                                                     |            |          |      |
| 63             | 3           |                                                                                                                                                                         |            |          |      |
| 64             | 3           | END                                                                                                                                                                     |            |          |      |
| 65             | 2           | AM=1;                                                                                                                                                                   |            |          |      |
| 66             | 1           | END SNRM_RESPONSE;                                                                                                                                                      |            |          |      |
| 67             | 2           | XMIT_FRMR: PROCEDURE (REASON)                                                                                                                                           |            |          |      |
| 68             | 2           | DECLARE REASON BYTE:                                                                                                                                                    |            |          |      |
| 69             | 2           | TCB=FRMR;                                                                                                                                                               |            |          |      |
| 70             | 2           | TBS=. FRMR_BUFFER(0);                                                                                                                                                   |            |          |      |
| 71             | 2           | TBL=3;                                                                                                                                                                  |            |          |      |
| 72             | 2           | FRMR_BUFFER(0)=RCB;                                                                                                                                                     |            |          |      |
| . –            | -           | /* Swap nibbles in NSNR */                                                                                                                                              |            |          |      |
| 73             | 2           | FRMR_BUFFER(1)=(SHL((NSNR AND OEH),4) DR SHR((NSNR AND OEOH),4)),                                                                                                       |            |          |      |
| 74             | 3           | DO CASE REASON;                                                                                                                                                         |            |          |      |
| 75             | 3 (         | FRMR_BUFFER(2)=01H; /* UNASSIGNED_C */                                                                                                                                  |            |          |      |

з

#### PL/M-51 COMPILER. RUPI-44 Secondary Station Driver 20: 24: 47 09/20/83 PAGE FRMR\_BUFFER(2)=02H; FRMR\_BUFFER(2)=04H; FRMR\_BUFFER(2)=08H; /\* NO\_I\_FIELD\_ALLOWED \*/ /\* BUFF\_OVERRUN \*/ /\* SES\_ERR \*/ 76 77 78 79 3333 EMD-9 80 STATION\_STATE=FRMR\_S; IF (RCB AND 10H) <>0 THEN DO; TBF=1; 81 2 83 84 85 86 87 88 89 3344331 RTS=1; DO WHILE\_NOT SI; END; SI=0 END, END XMIT\_FRMR; 90 2 IN\_DISCONNECT\_STATE: PROCEDURE :/\* Called from SIU\_INT procedure \*/ 91 2 IF ((USER\_STATE=OPEN\_S) AND ((RCB AND OEFH)=SNRM)) THEN CALL SNRM\_RESPONSE; ELSE IF (RCB AND 10H) <> 0 THEN DO; TBL=0; 2 93 95 96 97 98 з 331 CALL XMIT\_UNNUMBERED(DM); END END IN\_DISCONNECT\_STATE; 99 2 IN\_FRMR\_STATE: PROCEDURE , /\* Called by SIU\_INT when a frame has been received when in the FRMR state \*/ 100 2 IF (RCB AND OEFH)=SNRM THEN DD, , CALL SNRM\_RESPONSE, TSS= SIU\_XMIT\_BUFFER(O), /\* Restore transmit buffer start address \*/ 102 333 103 END 105 2 ELSE IF (RCB AND OEFH)=DISC THEN DO, STATION\_STATE=DISCONNECT\_S; 107 333 108 TBS=. SIU\_XMIT\_BUFFER(0); IF (RCB AND 10H)<> 0 /\* Restore transmit buffer start address \*/ RCB AND 10... THEN DO; TBL=0; CALL XMIT\_UNNUMBERED(UA); 111 4443 112 113 114 END; 115 116 /\* Receive control byte is something other than DISC or SNRM \*/ IF (RCB AND 10H) $\diamondsuit$ 0 THEN DD, 3 ELSE DO, 118 119 TBF=1, 4 RTS=1:

| PL/M-51 | COMPI  | LER RUPI-4   | 4 Secondary               | Station [              | Driver 20-24:47 09/20/83                                                          | PAGE |
|---------|--------|--------------|---------------------------|------------------------|-----------------------------------------------------------------------------------|------|
| 121     | 5      |              | ENI                       | DO WHILE<br>END;<br>D; | E NOT SI                                                                          |      |
| 123     | 3      | END          | 1                         |                        |                                                                                   |      |
| 124     | 1      | END IN_FRMR_ | STATE:                    |                        |                                                                                   |      |
| 125     | 2      | COMMAND_DECO | DE: PROCEDUI              | RE,                    |                                                                                   |      |
| 126     | 2      |              | AND OEFH)=SI<br>CALL SNRM |                        | En                                                                                |      |
| 128     | 2      |              | (RCB AND OEI<br>THEN DO;  | FH)=DISC               |                                                                                   |      |
| 130     | з      |              |                           | STATION S              | STATE=DISCONNECT_S;                                                               |      |
|         | 3      |              |                           |                        | AND 10H)<>0                                                                       |      |
| 133     | 4      |              |                           | 1 MER                  | TBL=0                                                                             |      |
|         | 4      | •            |                           |                        | CALL XMIT_UNNUMBERED(UA);                                                         |      |
|         | 4      | ÷            |                           |                        | END;                                                                              |      |
|         | 3      |              | END;                      |                        |                                                                                   |      |
| 137     | 2      |              | (RCB AND OEI              | FH)=TEST               | · · · · · · · · · · · · · · · · · · ·                                             |      |
| 139     | Э      | 1            |                           |                        | 10H)>0 /* Respond if polled */                                                    |      |
| 141     | 4      |              |                           | THEN DO;               | IF (BOV=1)                                                                        |      |
|         | -      |              |                           |                        | THEN DO,                                                                          |      |
|         | 5<br>5 |              |                           |                        |                                                                                   |      |
|         | 5      |              |                           |                        | CALL XMIT_UNNUMBERED(TEST OR 10H);                                                |      |
|         | 5      |              |                           |                        | END,                                                                              |      |
|         |        |              |                           |                        | ELSE DO; /* If no BDV, send received I field back to primary */                   |      |
|         | 5      |              |                           |                        | TBL=RFL,                                                                          |      |
|         | 5      |              |                           |                        | TBS=RBS;                                                                          |      |
|         | 5      |              |                           |                        | CALL XMIT_UNNUMBERED(TEST OR 10H);                                                |      |
|         | 5<br>5 |              | -                         |                        | TBS=.SIU_XMIT_BUFFER(Q);                                                          |      |
|         |        |              |                           |                        | /* If an I frame was pending, set it up again */ '                                |      |
| 152     | 4      |              |                           | :                      | IF XMIT_BUFFER_EMPTY=0                                                            |      |
|         | -      |              |                           |                        | THEN (DO)                                                                         |      |
|         | 5      |              |                           |                        | TBL=I_FRAME_LENGTH,                                                               |      |
|         | 5      |              |                           |                        | TBF=1;                                                                            |      |
|         | 5      |              |                           |                        | END                                                                               |      |
|         | 4      |              |                           | END                    | );                                                                                |      |
|         | 3      |              | AM=                       | 1,                     |                                                                                   |      |
|         | 3      |              | END                       |                        |                                                                                   |      |
| 160     | 2      |              |                           | H) = 0 /*              | * Kicked out of the AUTD mode because<br>an I frame was received while RPB = 1 */ |      |
|         | _      |              | THEN DO;                  |                        | •                                                                                 |      |
|         | 3      |              |                           | = 1;                   |                                                                                   |      |
| 163     | 3      |              | IF                        |                        | FER_EMPTY = 1                                                                     |      |
| 165     | 3      |              | TBF                       | THEN TBL               | _ = C;<br>/* Send an AUTD mode response */                                        |      |
|         |        |              |                           |                        |                                                                                   |      |

| 166<br>167                                                                                                                                      | 3<br>3                          | RTS = 1; *******                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 168                                                                                                                                             | 2                               | ELSE CALL XMIT_FRMR(UNASSIGNED_C); /* Received an undefined or not implemented command */                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 169                                                                                                                                             | 1                               | END COMMAND_DECODE,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 170                                                                                                                                             | 2                               | SIU_INT PROCEDURE INTERRUPT 4,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 171                                                                                                                                             | 2                               | DECLARE I BYTE AUXILIARY;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 172                                                                                                                                             | 2                               | SI=0;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 173                                                                                                                                             | 2                               | IF STATION_STATE<> I_T_S /* Must be in NON-AUTO mode */<br>THEN DD;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 175                                                                                                                                             | з                               | IF RBE=0 /* Received a frame? Give response */<br>THEN DC;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 177                                                                                                                                             | 5                               | DO CASE STATION_STATE;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 78                                                                                                                                              | 5                               | CALL IN_DISCONNECT_STATE;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 79                                                                                                                                              | 5                               | CALL IN_FRMR_STATE;<br>END;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 81                                                                                                                                              | 4                               | RBE=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 82                                                                                                                                              | 4                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 183                                                                                                                                             | ġ.                              | RETURN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                 | 3                               | END                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 184                                                                                                                                             | 3                               | /* If the program reaches this point, STATION_STATE=I_T_S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 184                                                                                                                                             | 2                               | /* If the program reaches this point, STATION_STATE=I_T_S<br>which means the SIU either was, or still is in the AUTO MODE */<br>IF AM=O                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                 | -                               | <pre>/* If the program reaches this point, STATION_STATE=I_T_S which means the SIU either was, or stall is an the AUTO MODE */</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 185                                                                                                                                             | 2                               | /* If the program reaches this point, STATION_STATE=I_T_S<br>which means the SIU either was, or still is in the AUTO MODE */<br>IF AM=O<br>THEN DO;                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 85<br>87<br>89                                                                                                                                  | 2                               | <pre>/* If the program reaches this point, STATION_STATE=I_T_S which means the SIU either was, or still is in the AUTO MODE */ IF AM=0 THEN DO; IF (RCB AND OEFH)=DISC</pre>                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 185<br>187<br>187                                                                                                                               | 2<br>3<br>3                     | <pre>/* If the program reaches this point, STATION_STATE=I_T_S which means the SIU either was, or still is in the AUTO MODE */ IF AM=0 THEN DD; IF (RCB AND OEFH)=DISC THEN CALL COMMAND_DECODE; ELSE IF USER_STATE=CLOSED_S THEN DD; TBL=0;</pre>                                                                                                                                                                                                                                                                                                                                                     |
| 185<br>187<br>187<br>189                                                                                                                        | 2<br>3<br>3<br>4                | <pre>/* If the program reaches this point, STATION_STATE=I_T_S which means the SIU either was, or still is in the AUTO MODE */ IF AM=0 THEN DO; IF (RCB AND OEFH)=DISC THEN CALL COMMAND_DECODE; ELSE IF USER_STATE=CLOSED_S THEN CALL COMMAND_SERED(REG_DISC); CALL XHIT_UNNUMBERED(REG_DISC);</pre>                                                                                                                                                                                                                                                                                                  |
| .85<br>.87<br>.91<br>.92<br>.93                                                                                                                 | 2<br>3<br>3<br>4<br>4           | <pre>/* If the program reaches this point, STATION_STATE=I_T_S which means the SIU either was, or still is in the AUTO MDDE */ IF AM=0     THEN DO;     IF (RCB AND OEFH)=DISC         THEN CALL COMMAND_DECODE;         ELSE IF USER_STATE=CLOBED_S         TBL=0;         CALL XMIT_UNNUMBERED(REG_DISC);         END;</pre>                                                                                                                                                                                                                                                                         |
| 185<br>187<br>187                                                                                                                               | 2<br>3<br>3<br>4                | <pre>/* If the program reaches this point, STATION_STATE=I_T_S which means the SIU either was, or still is in the AUTO MODE */ IF AM=0 THEN DO; IF (RCB AND OEFH)=DISC THEN CALL COMMAND_DECODE; ELSE IF USER_STATE=CLOBED_S THEN CALL COMMAND_DECODE; ISL=0; CALL XMIT_UNNUMBERED(REG_DISC); ELSE IF SES=1</pre>                                                                                                                                                                                                                                                                                      |
| 185<br>187<br>187<br>191<br>192<br>193                                                                                                          | 2<br>3<br>3<br>4<br>4           | <pre>/* If the program reaches this point, STATION_STATE=I_T_S<br/>which means the SIU either was, or still is in the AUTO MODE */<br/>IF AM=0<br/>THEN DO;<br/>IF (RCB AND OEFH)=DISC<br/>THEN CALL COMMAND_DECODE;<br/>ELSE IF USER_STATE=CLOBED_S<br/>THEN CALL COMMAND_DECODE;<br/>ELSE IF SES=1<br/>THEN DO;<br/>ELSE IF SES=1<br/>THEN CALL XMIT_FRMR(SES_ERR);<br/>ELSE IF SU=1</pre>                                                                                                                                                                                                           |
| 85<br>87<br>91<br>92<br>93<br>94<br>96                                                                                                          | 2<br>3<br>3<br>4<br>4<br>4<br>3 | <pre>/* If the program reaches this point, STATION_STATE=I_T_S which means the SIU either was, or still is in the AUTO MODE */ IF AM=0 THEN DO; IF (RCB AND OEFH)=DISC THEN CALL COMMAND_DECODE; ELSE IF USER_STATE=CLOBED_S THEN CALL XMIT_UNNUMBERED(REG_DISC); ELSE IF SES=I THEN CALL XMIT_FRMR(SES_ERR); ELSE IF SOV=I THEN CALL XMIT_FRMR(SES_ERR); ELSE IF SOV=I THEN DD;/* DON'T SEND FRMR IF A TEST WAS RECEIVED*/ IF (RCB AND OEFH)=TEST</pre>                                                                                                                                               |
| 185<br>187<br>199<br>191<br>192<br>193<br>194<br>196                                                                                            | 233444433                       | <pre>/* If the program reaches this point, STATION_STATE=I_T_S which means the SIU either was. or still is in the AUTO MODE */ IF AM=0 THEN DO; IF (RCB AND OEFH)=DISC THEN CALL COMMAND_DECODE; ELSE IF USER_STATE=CLOBED_S THEN CALL COMMAND_DECODE; ELSE IF SES=1 THEN CALL XMIT_FRMR(SES_ERR), ELSE IF BOV=1 THEN CALL SUMMAND_DECODE; IF (RCB AND OEFH)=TEST THEN CALL COMMAND_DECODE;</pre>                                                                                                                                                                                                      |
| 85<br>87<br>89<br>91<br>92<br>93<br>94<br>96<br>98<br>00                                                                                        | 23344433444                     | <pre>/* If the program reaches this point, STATION_STATE=I_T_S which means the SIU either was, or still is in the AUTO MODE */ IF AM=0 THEN DO; IF (RCB AND OEFH)=DISC THEN CALL COMMAND_DECODE; ELSE IF USER_STATE=CLOSED_S THEN CALL COMMAND_DECODE; ELSE IF SES=I THEN CALL XMIT_FRMR(SES_ERR), ELSE IF BOV=I THEN CALL XMIT_FRMR(SES_ERR), ELSE IF BOV=I THEN CALL COMMAND_DECODE; ELSE CALL XMIT_FRMR(BUFF_OVERRUN); END; END;</pre>                                                                                                                                                              |
| 85<br>87<br>91<br>92<br>93<br>94<br>96<br>98<br>900                                                                                             | 2 3 3 4443 3 4 443              | <pre>/* If the program reaches this point, STATION_STATE=I_T_S which means the SIU either was, or still is in the AUTO MODE */ IF AM=0 THEN DO; IF (RCB AND OEFH)=DISC ELSE IF USER_STATE=CLOBED_S THEN CALL COMMAND_DECODE; ELSE IF SES=1 THEN CALL XMIT_UNNUMBERED(REG_DISC); ELSE IF SES=1 THEN CALL XMIT_FRMR(SES_ERR); ELSE IF BOV=1 THEN DD;/* DDN'T SEND FRMR IF A TEST WAS RECEIVED*/ IF (RCB AND OEFH)=TEST THEN CALL COMMAND_DECODE; ELSE CALL COMMAND_DECODE; ELSE CALL COMMAND_DECODE; ELSE CALL COMMAND_DECODE;</pre>                                                                     |
| 85<br>87<br>91<br>92<br>93<br>94<br>98<br>001<br>02<br>03                                                                                       | 2 3 3 4443 3 4 4493             | <pre>/* If the program reaches this point, STATION_STATE=I_T_S which means the SIU either was, or still is in the AUTO MODE */  IF AM=0 THEN DO; IF (RCB AND OEFH)=DISC THEN CALL COMMAND_DECODE; ELSE IF USER_STATE=CLOSED_S THEN DO; CALL XMIT_UNNUMBERED(REG_DISC); END; ELSE IF SES=I THEN CALL XMIT_FRMR(SES_ERR); ELSE IF BOV=1 THEN CALL XMIT_FRMR(SES_ERR); ELSE IF DO;/* DON'T SEND FRMR IF A TEST WAS RECEIVED*/ THEN CALL COMMAND_DECODE; ELSE CALL COMMAND_DECODE; ELSE CALL XMIT_FRMR(BUFF_OVERRUN); ELSE CALL XMIT_FRMR(BUFF_OVERRUN); ELSE CALL COMMAND_DECODE; RBC=1;</pre>            |
| 85<br>87<br>99<br>93<br>94<br>96<br>98<br>001<br>002<br>003                                                                                     | 2 3 3 4443 3 4 443              | <pre>/* If the program reaches this point, STATION_STATE=I_T_S which means the SIU either was. or still is in the AUTO MODE */ IF AM=0 THEN DO; IF (RCB AND OEFH)=DISC ELSE IF USER_STATE=CLOBED_S THEN CALL COMMAND_DECODE; ELSE IF SES=1 THEN CALL XMIT_UNNUMBERED(REG_DISC); ELSE IF SES=1 THEN CALL XMIT_FRMR(SES_ERR), ELSE IF BOV=1 THEN DD;/* DON'T SEND FRMR IF A TEST WAS RECEIVED*/ IF (RCB AND OEFH)=TEST THEN CALL COMMAND_DECODE; ELSE CALL COMMAND_DECODE; ELSE CALL COMMAND_DECODE; ELSE CALL COMMAND_DECODE;</pre>                                                                     |
| 85<br>87<br>89<br>91<br>92<br>93<br>94<br>96<br>98<br>001<br>002<br>004                                                                         | 2 3 3 4443 3 4 4493             | <pre>/* If the program reaches this point, STATION_STATE=I_T_S which means the SIU either was, or still is in the AUTO MODE */  IF AM=0 THEN DO; IF (RCB AND OEFH)=DISC THEN CALL COMMAND_DECODE; ELSE IF USER_STATE=CLOSED_S THEN DO; CALL XMIT_UNNUMBERED(REG_DISC); END; ELSE IF SES=I THEN CALL XMIT_FRMR(SES_ERR); ELSE IF BOV=1 THEN CALL XMIT_FRMR(SES_ERR); ELSE IF DO;/* DON'T SEND FRMR IF A TEST WAS RECEIVED*/ THEN CALL COMMAND_DECODE; ELSE CALL COMMAND_DECODE; ELSE CALL XMIT_FRMR(BUFF_OVERRUN); ELSE CALL XMIT_FRMR(BUFF_OVERRUN); ELSE CALL COMMAND_DECODE; RBC=1;</pre>            |
| 185<br>187<br>187<br>191<br>192<br>193<br>194                                                                                                   | 2 3 3 4443 3 4 44333            | <pre>/* If the program reaches this point, STATION_STATE=I_T_S which means the SIU either was, or still is in the AUTO MODE */ IF AM=0 THEN DO; IF (RCB AND OEFH)=DISC THEN CALL COMMAND_DECODE; ELSE IF USER_STATE=CLOSED_S THEN DO; CALL XMIT_UNNUMBERED(REG_DISC); END; ELSE IF SES=1 THEN CALL XMIT_FRMR(SES_ERR); ELSE IF SES=1 THEN DO; /* DON'T SEND FRMR IF A TEST WAS RECEIVED*/ IF (RCB AND OEFH)=TEST THEN CALL COMMAND_DECODE; ELSE CALL XMIT_FRMR(BUFF_OVERRUN); ELSE CALL XMIT_FRMR(BUFF_OVERRUN); ELSE CALL COMMAND_DECODE; RBC=1; END;</pre>                                           |
| 185<br>187<br>191<br>192<br>193<br>194<br>195<br>194<br>196<br>196<br>196<br>197<br>197<br>197<br>197<br>197<br>197<br>197<br>197<br>197<br>197 | 2 3 3 4 4 4 3 3 4 4 4 9 3 3 3   | <pre>/* If the program reaches this point, STATION_STATE=I_T_S which means the SIU either was. or still is in the AUTO MODE */  IF AM=0 THEN DD; IF (RCB AND OEFH)=DISC THEN CALL COMMAND_DECODE; ELSE IF USER_STATE=CLOBED_S TBL=0; CALL XMIT_UNNUMBERED(REG_DISC); ELSE IF SES=1 THEN CALL XMIT_FMR(SES_ERR). ELSE IF BOV=1 THEN DD;/* DON'T SEND FMMR IF A TEST WAS RECEIVED*/ IF (RCB AND OEFH)=TEST THEN CALL COMMAND_DECODE; ELSE CALL COMMAND_DECODE; ELSE CALL COMMAND_DECODE; RD; ELSE CALL COMMAND_DECODE; RD; ELSE CALL COMMAND_DECODE; RD; ELSE DD; /* MVST STILL BE IN AUTO MODE */</pre> |

PL/M-51 COMPILER RUPI-44 Secondary Station Driver

20-24:47 09/20/83 PAGE 7

| 210    | - 4    | RBP=1, /* RNR STATE */                      |
|--------|--------|---------------------------------------------|
| 211    | 4      | RBE=1; /* RE-ENABLE RECEIVER */             |
| 212    | 4      | CALL SIU_RECV(RFL),                         |
| 213    | 4      | RBP=0; /# RR STATE */                       |
| 214    | 4      | END                                         |
| 215    | з      | END                                         |
| 216    | 1      | END SIU_INT;                                |
| 217    | 1      | END MAIN\$MOD;                              |
| Softwa | are an | d application note written by Charles Yager |

WARNINGS 4 IS THE HIGHEST USED INTERRUPT

| MODULE INFORMATION:     | (  | STATIC+OVERI | AYABLE) |    |
|-------------------------|----|--------------|---------|----|
| CODE SIZE               | 18 | 028FH        | 655D    |    |
| CONSTANT SIZE           | =  | 0000H        | OD      |    |
| DIRECT VARIABLE SIZE    | =  | 3FH+02H      | 63D+    | 2D |
| INDIRECT VARIABLE SIZE  | -  | 3CH+00H      | 60D+    | OD |
| BIT SIZE                | 12 | 01H+00H      | 1D+     | OD |
| BIT-ADDRESSABLE SIZE    | =  | 00H+00H      | OD+     | OD |
| AUXILIARY VARIABLE SIZE | =  | 0006H        | 6D      |    |
| MAXIMUM STACK SIZE      | -  | 0017H        | 23D     |    |
| REGISTER-BANK(S) USED:  |    | 0 1 2/       |         |    |
| 460 LINES READ          |    | ,            |         |    |
| O PROGRAM ERROR(S)      |    |              |         |    |

END OF PL/M-51 COMPILATION

1 1 5 1 18 50-53 09/19/83 PAGE 1

.

ISIS-II PL/M-51 V1 O COMPILER INVOKED BY: :f2:plm51 :f2:unote src

| STITLE<br>Sdebug       | ('Application Modu | le Async/SDLC F | <pre>Protocol converter')</pre> |
|------------------------|--------------------|-----------------|---------------------------------|
| <pre>\$registert</pre> | ank (O)            |                 |                                 |
| user\$mod: c           |                    |                 |                                 |
| \$NOL IST              |                    |                 |                                 |
| DECLARE                | LIT                | LITERALLY       | 'LITERALLY',                    |
|                        | TRUE               | LIT             | OFFH',                          |
|                        | FALSE              | LIT             | 100H1                           |
|                        | FOREVER            | LIT             | WHILE 1',                       |
|                        | ESC                | LIT             | '1BH',                          |
|                        | LF                 | LIT             | 'OAH',                          |
|                        | CR                 | LIT             | 'ODH',                          |
|                        | 88                 | LIT             | (08H)                           |
|                        | BEL                | LIT             | '07H',                          |
|                        | EMPTY              | LIT             | '00H',                          |
|                        | INUSE              | LIT             | '01H',                          |
|                        | FULL               | LIT             | (02H),                          |
|                        | USER_STATE_CLOSED  | LIT             | (00H)                           |
|                        | LINK_DISCONNECTED  | LIT             | '01H',                          |
|                        | OVERFLOW           | LIT             | '02H',                          |
|                        | DATA_TRANSMITTED   | LIT             | 103H1                           |

/\* BUFFERS \*/

| BUFFER LENGTH           | т       | <b>'60'</b> , |           |        |
|-------------------------|---------|---------------|-----------|--------|
| SIU_XMIT_BUFFER (BUFFER | LENGTH) | BYTE          | EXTERNAL  | IDATA, |
| SIU RECV BUFFER (BUFFER | LENGTH) | BYTE          | EXTERNAL, |        |
| FIF0_T(256)             | BYTE    | AUXILIARY,    |           |        |
| IN_PTR_T                | BYTE '  | ·· AUXILIARY, |           |        |
| OUT_PTR_T               | BYTE    | AUXILIARY,    |           |        |
| BUFFER_STATUS_T         | BYTE    | AUXILIARY,    |           |        |
| F1F0_R(256)             | BYTE    | AUXILIARY,    |           |        |
| IN_PTR_R                | BYTE    | AUXILIARY,    |           |        |
| OUT_PTR_R               | BYTE    | AUXILIARY,    |           |        |
| BUFFER_STATUS_R         | BYTE    | AUXILIARY,    |           |        |

/\* Variables and Parameters \*/

| LENGTH              | BYTE | AUXILIARY, |
|---------------------|------|------------|
| CHAR                | BYTE | AUXILIARY, |
| I                   | BYTE | AUXILIARY, |
| USART_CMD           | BYTE | AUXILIARY, |
| DESTINATION ADDRESS | BYTE | AUXILIARY, |
| SEND_DATA           | BYTE | AUXILIARY, |
| RESULT              | BYTE | AUXILIARY, |
| ERR_MESSAGE_INDEX   | BYTE | AUXILIARY, |
| ERR_MESSAGE_PTR     | WORD | AUXILIARY  |

/\* Messages Sent to the Terminal \*/

PARITY(\*) BYTE CONSTANT(LF,CR,'Parity Error Detected',LF,CR,00H), FRAME(\*) BYTE CONSTANT(LF,CR,'Framing Error Detected',LF,CR,00H),

### I

PL/M-51 COMPILER

18.50.53 09/19/83 PAGE 2

| OVER_RUN(*) BYTE CONSTANT(LF,CR,'Overrun Error Detected',LF,CR,O),<br>LINK(*) BYTE CONSTANT(LF,CR,'Umable to Get Online',LF,CR,OOH),<br>DEST_ADDR(*) BYTE CONSTANT(CR,LF,LF,<br>'Enter the debtination address', BS, BS, O),                  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D_ADDR_ACK(*) BYTE CONSTANT(CR,LF,LF,<br>'The new destination address is ',0),                                                                                                                                                                |
| STAT_ADDR(*) BYTE CONSTANT(CR,LF,LF,<br>'Enter the station address:',B5,B5,O),                                                                                                                                                                |
| S_ADDR_ACK(*) BYTE CONSTANT(CR,LF,LF,<br>'The new station address is ',0),                                                                                                                                                                    |
| ADDR_ACK_FIN(*) BYTE CONSTANT('H', CR, LF, LF, 0),                                                                                                                                                                                            |
| SION_DN(*) BYTE CONSTANT(CR, LF,LF,<br>'(\/) RUFI-44 Secondary Station', CR, LF,<br>'\/', CR, LF, LF,<br>'1 - Set the Station Address',LF,CR,<br>'2 - Set the Destination Address',CR,LF,<br>'3 - 90 Dnline',CR,LF,<br>'4 - 90 Dfline',CR,LF, |
|                                                                                                                                                                                                                                               |

'5 - Return to terminal mode', CR, LF, LF, Enter option: \_', BS, O),

Application Module. Async/SDLC Protocol converter

FIN(\*) BYTE CONSTANT(CR, LF, LF, 0);

/\* Characters Received From the Terminal \*/

HEX\_TÁBLE(17) BYTE CONSTANT('0123456789ABCDEF',BEL), MENU\_CHAR(6) BYTE CONSTANT('12345',BEL),

/\* Flags and Bits \*/

| XMIT_BUFFER_EMPTY   | BIT    | EXTERNAL, /* Semaphore for RUPI SIOU Transmit Buffer */ |
|---------------------|--------|---------------------------------------------------------|
| STOP_BIT            | BIT    | AT(147) REG. /* Terminal parameters */                  |
| ECHO                | BIT    | AT(084H) REG.                                           |
| WAIT                | BIT,   | /* Timeout flag */                                      |
| ERROR_FLAQ          | BIT,   | /* Error message Flag */                                |
| /* Perihèral Addres | ses #/ |                                                         |
| USART_STATUS        | BYTE   | AT(0801H) AUXILIARY,                                    |
| USART_DATA          | Byte   | AT(0800H) AUXILIARY,                                    |
| TIMER_CONTROL       | Byte   | AT(1003H) AUXILIARY,                                    |
| TIMER_O             | Byte   | AT(1000H) AUXILIARY,                                    |
| TIMER_1             | Byte   | AT(1001H) AUXILIARY,                                    |
| TIMER_2             | Byte   | AT(1002H) AUXILIARY;                                    |

/\* External Procedures \*/

19-60

| 6<br>7         | 2<br>1      | POWER_ON_D' PROCEDURE EXTERNAL;<br>END POWER_ON_D;                                                           |
|----------------|-------------|--------------------------------------------------------------------------------------------------------------|
| 8<br>9         | 2<br>1      | CLOSE <sup>,</sup> procedure external using 2;<br>End Close,                                                 |
| 10<br>11       | 2<br>1      | OPEN PROCEDURE EXTERNAL USING 2;<br>END OPEN;                                                                |
| 12<br>13<br>14 | 2<br>2<br>1 | TRANSMIT' PROCEDURE (XMIT_BUFFER_LENGTH) BYTE EXTERNAL,<br>DECLARE XMIT_BUFFER_LENGTH BYTE,<br>END TRANSMIT; |
|                |             | /* Local Procedures */                                                                                       |
|                |             |                                                                                                              |
| 15             | 2           | TIMER_0_INT PROCEDURE INTERRUPT 1 USING 1;                                                                   |
| 16             | 2           | WAIT=0,                                                                                                      |
| 17             | 1           | END TIMER_O_INT;                                                                                             |
| 18             | 2           | POWER_ON PROCEDURE USING O                                                                                   |
| 19             | 5           | DECLARE TEMP BYTE AUXILIARY;                                                                                 |
| 20             | 2           | SMD=54H; /* Using DPLL; NRZI, PFS, TIMER 1, @ 62.5 Kbps */                                                   |
| 21             | 2           | TMOD=21H; /* Timer O 16 bit, Timer 1 auto reload */                                                          |
| 22             | 2           | TH1=OFFH;                                                                                                    |
| 23             | 2           | TCDN=40H;                                                                                                    |
|                |             |                                                                                                              |
| 24             | 2           | TIMER_CONTROL=37H;   /* Initialize USART's system clock; 8254 */                                             |
| 25             | 2           | TIMER_O=O4H,                                                                                                 |
| 26             | 2           | TIMER_O=OOH,                                                                                                 |
| 27             | 2           | TIMER_CONTROL=77H; /* Initialize TxC, RxC */                                                                 |
|                |             | /* Definition for dip switch tied to P1 O to P1.6                                                            |
|                |             |                                                                                                              |

з 2 1 Bit Rate 300 1200 2400 4800 9600 19200 on on on off off on on off off on on on off on off on off 4 Stop bit on off 1 2 Parity 6 5 off odd off even on on off off on off on off

,

19-61

| ,                |                    |                     |           |
|------------------|--------------------|---------------------|-----------|
| PL/M-51 COMPILER | Application Module | Asunc/SDLC Protocol | converter |

18: 50: 53 09/19/83 PAGE 4

|          |   |          | <b>F</b> -1-  | 7                  |                  |                     |               |
|----------|---|----------|---------------|--------------------|------------------|---------------------|---------------|
|          |   |          | Echo          | '                  |                  |                     |               |
|          |   |          | on            | on                 |                  |                     |               |
|          |   |          | off           | off                | */               |                     |               |
| 28       | 2 |          | TEMP=P1 AND C | )7H; /* Rea        | the dip switch   | h to determine the  | bit rate #/   |
| 29       | 2 |          | IF TEMP>5     |                    |                  |                     |               |
|          | - |          | THEN TEMP     |                    |                  |                     |               |
| 31       | 3 | /* 300 * | DO CASE TEMP; |                    |                  |                     |               |
| 32       | 4 | /- 000 - | DO            |                    |                  |                     | 1             |
| 33       | 4 |          |               | 1=83H;             |                  |                     |               |
| 34<br>35 | 4 |          | TIMER<br>END; | 1=20H,             |                  | 2.5                 |               |
| 35       | 4 |          | END           |                    |                  |                     |               |
| 36       | 4 | /* 1200  | */ DO;        |                    |                  |                     |               |
| 37       | 4 |          |               | _1=20H.            |                  |                     |               |
| 38<br>39 | 4 |          | TIMER<br>END; | 1=05H;             |                  |                     |               |
| 37       | - |          | END;          | `                  |                  |                     |               |
| 40       | 4 | /* 2400  |               |                    | '                |                     |               |
| 41       | 4 |          |               | _1=60H;            |                  |                     |               |
| 42<br>43 | 4 |          | END;          | 1=02H;             |                  |                     |               |
|          | • |          | 21407         |                    |                  |                     | ,             |
| 44       | 4 | /* 4800  |               |                    |                  |                     |               |
| 45<br>46 | 4 |          |               | 1=30H;             |                  |                     |               |
| 47       | 4 |          | END;          | 1=01H;             |                  |                     |               |
|          | • |          |               |                    |                  |                     |               |
| 48       | 4 | /* 9600  |               |                    |                  |                     |               |
| 49<br>50 | 4 |          |               | l_1=65H;<br>l_1=0; |                  |                     |               |
| 51       | 4 |          | END;          | _1-0,              |                  |                     |               |
|          |   |          |               |                    |                  |                     |               |
| 52<br>53 | 4 | /* 19200 |               | 1-000              |                  |                     |               |
| 54       | 4 |          |               | 1=33H;<br>1=0,     |                  |                     |               |
| 55       | 4 |          | END;          |                    |                  |                     |               |
| 56       | з |          | END;          |                    |                  |                     | 1             |
| 57       | 2 |          | USART STATUS- | 0: /# Sc4+.        |                  | eset for 8251A #/   |               |
| .58      | 2 |          | USART_STATUS= |                    |                  |                     |               |
| 59       | 2 |          | USART_STATUS= | :0;                |                  | · · · ·             |               |
| 60       | 2 |          | USART_STATUS= | 40H)               |                  |                     |               |
| 61       | 2 |          | TEMP=OAH;     | /* Deter           | mine the parit   | y and # of stop bi  | ts */         |
| 62       | 2 |          | TEMP=TEMP OR  | (P1 AND 30H)       |                  |                     |               |
| 63       | 2 |          | IF STOP_BIT=1 |                    |                  |                     |               |
| 65       | 2 |          | THEN TEMP     | TEMP OR OCO        | )H)              |                     |               |
|          | - |          |               |                    |                  |                     |               |
| 66       | 2 |          | USART_STATUS= |                    | SART Mode Word   |                     |               |
| 67       | 2 |          | USART_STATUS, | USART_CMD=2        | 27H; /#USART Com | mand Word RTS, RxE. | DTR, TxEN=1+/ |
| 68       | 2 |          | STAD=OFFH;    |                    |                  |                     |               |
|          |   |          |               |                    |                  | ,                   |               |
|          |   |          |               |                    |                  |                     |               |

#### 19-62

5

| PL/M-5    | COMPI | LER Application Module <sup>.</sup> Async/SDLC Protocol converter                                              | 18. 50: 53 | 09/19/83 | PAGE |
|-----------|-------|----------------------------------------------------------------------------------------------------------------|------------|----------|------|
|           |       |                                                                                                                |            |          |      |
| 69        | 2     | SEND_DATA=0; /# Intialize Flags #/                                                                             |            |          |      |
| 70        | 2     | IN_PTR_T, OUT_PTR_T, IN_PTR_R, OUT_PTR_R = 0,/*Initialize FIFO PTRs*/                                          |            |          |      |
| 71        | 2     | BUFFER_STATUS_T, BUFFER_STATUS_R= EMPTY;                                                                       |            |          |      |
| 72        | 2     | CALL POWER_ON_D;                                                                                               |            |          |      |
| 73        | 2     | IP=01H; /* USART's RxRdy is the highest priority */                                                            |            |          |      |
| 74        | 2     | /* Both external interrupts are level triggered*/<br>IE=93H; /* Enable USART RxRdy, SI; and Timer O interrupts |            |          |      |
| 75        | 2     | ERROR_FLAQ=0;                                                                                                  |            |          |      |
| 76        | 1     | END POWER_ON;                                                                                                  |            |          |      |
| 77        | 2     | FIFO_R_IN: PROCEDURE (CHAR) USING 1;                                                                           |            |          |      |
| 78        | 2     | DECLARE CHAR BYTE;                                                                                             |            |          |      |
| 79        | 2     | FIFO_R(IN_PTR_R)=CHAR;                                                                                         |            |          |      |
| 80        | 2     | IN_PTR_R=IN_PTR_R+1;                                                                                           |            |          |      |
| 81        | 2     | IF BUFFER_STATUS_R=EMPTY<br>THEN DO:                                                                           |            |          |      |
| 83        | 3     | EA=O,                                                                                                          |            |          |      |
| 84<br>85  | 3     | BUFFER_STATUS_R=INUSE;<br>EX1=1;                                                                               |            |          |      |
| 86        | 3     | EX1=1; /* Enable USART's TxD interrupt */<br>EA=1;                                                             |            |          |      |
| 87        | 3     | END;                                                                                                           |            |          |      |
| 88        | 2     | ELSE IF ((BUFFER_STATUS_R=INUSE) AND (IN_PTR_R=OUT_PTR_R))<br>THEN BUFFER_STATUS_R=FULL;                       |            |          |      |
| 90        | 1     | END FIFO_R_IN;                                                                                                 |            |          |      |
| 91        | 2     | FIFO_R_OUT: PROCEDURE BYTE USING 1;                                                                            |            |          |      |
| 92        | 5     | DECLARE CHAR BYTE AUXILIARY,                                                                                   |            | ,        |      |
| 93        | 2     | CHAR=FIFO_R(OUT_PTR_R),                                                                                        |            |          |      |
| 94        | 2     | OUT_PTR_R=OUT_PTR_R=1;                                                                                         |            |          |      |
| 95        | 2     | IF OUT_PTR_R=IN_PTR_R<br>THEN DO:                                                                              |            |          |      |
| 97        | 3     | EX1=0, /* Shut off TxD interrupt */                                                                            |            |          |      |
| 98        | Э     | BUFFER_STATUS_R=EMPTY;                                                                                         |            |          |      |
| 99<br>100 | 3,    | END;<br>ELSE IF ((BUFFER_STATUS_R≒FULL) AND (OUT_PTR_R-20≖IN_PTR_R))                                           |            |          |      |
|           |       | THEN BUFFER_STATUS_R=INUSE;                                                                                    |            |          |      |
| 102       | 2     | RETURN CHAR;                                                                                                   |            |          |      |
| 103       | 1.    | END FIFO_R_OUT                                                                                                 |            |          |      |
|           | _     |                                                                                                                |            |          |      |

104 2 USART\_XMIT\_INT: PROCEDURE INTERRUPT 2 USING 1;

# inteľ

|        |      | 4 · · ·                                                                                      |
|--------|------|----------------------------------------------------------------------------------------------|
| PL/M-5 | COMP | ILER Application Module Async/BDLC Protocol converter 18.50.53 09/19/83 PAGE 6               |
| 105    | 2    | DECLARE                                                                                      |
|        |      | MESSAGE BASED ERR_MESSAGE_PTR(1) BYTE CONSTANT,                                              |
| 106    | 2    | IF ERROR_FLAG<br>THEN DO:                                                                    |
| 108    | 3    | IF MESSAGE(ERR_MESSAGE_INDEX)<>O /* Then continue to send the message */<br>THEN DO:         |
| 110    | 4    | USART_DATA = MESSAGE(ERR_MESSAGE_INDEX);                                                     |
| 111    | 4    | ERR MESSAGE INDEX=ERR MESSAGE_INDEX+1;                                                       |
| 112    | 4    |                                                                                              |
| 113    | 4 .  | ELSE DO; /* If message is done reset ERROR_FLAG and shut off interrupt if FIFO is empty */   |
| 114    | 4    | ERROR_FLAG=0;                                                                                |
| 115    | 4    | IF BUFFER_STATUS_R = EMPTY                                                                   |
|        |      | THEN EX1=0;                                                                                  |
| 117    | 4    | END:                                                                                         |
| 118    | 3    | END                                                                                          |
| 117    | 2    | ELSE VSART_DATA=FIFO_R_OUT;                                                                  |
| 120    | 1    | END USART_XMIT_INT;                                                                          |
| 121    | 2    | SIU_RECV. PROCEDURE (LENGTH) FUBLIC USING 1,                                                 |
| 122    | 2    | DECLARE LENGTH BYTE,<br>I byte Auxiliary;                                                    |
|        | _    |                                                                                              |
| 123    | 3    | DO I=O TO LENGTH-1;                                                                          |
| 124    | 4    | DO WHILE BUFFER_STATUS_R=FULL:/* Check to see if fifo is full */                             |
| 125    | 4    | END;                                                                                         |
| 126    | 3    | CALL FIFD_R_IN(SIU_RECV_BUFFER(I));                                                          |
| 127    | з    | END;                                                                                         |
| 128    | 1    | END SIU_RECV;                                                                                |
| 129    | 2    | FIFO_T_IN: PROCEDURE (CHAR) USING 2;                                                         |
| 130    | 2    | DECLARE CHAR BYTE;                                                                           |
| 131    | 2    | FIFO_T(IN_PTR_T)=CHAR,                                                                       |
| 132    | 2    | IN PTR T=IN PTR_T+1;                                                                         |
| 133    | 2    | IF CHAR=LF                                                                                   |
|        | -    | THEN SEND_DATA=SEND_DATA+1;                                                                  |
| 135    | 2    | IF BUFFER_STATUS_T=EMPTY                                                                     |
| 137    | 2    | THEN BUFFER_STATUS_T=INUSE;<br>ELSE IF (1BUFFER_STATUS_T=INUSE) AND (IN_PTR_T+20=OUT_PTR_T)) |
|        | _    | THEN DO; /* Stop reception using CTS */                                                      |
| 139    | э    | USART_STATUS, USART_CMD=USART_CMD AND NOT(20H);                                              |
| 140    | 3    | BUFFER_STATUS_T=FULL;                                                                        |
| 141    | 3    | IF SEND_DATA=0                                                                               |
| • • •  | -    | THEN SEND_DATA=1;/*If the buffer is full and no LF                                           |
|        |      | has been received then send data */                                                          |
| 143    | з    | END,                                                                                         |
| 144    | 1    | END FIFO_T_IN;                                                                               |
|        | •    |                                                                                              |
|        |      |                                                                                              |

| PL/M-51 | COMPI  | LER Application Module: Async/SDLC Protocol converter                     | 18 <sup>.</sup> 50, 53 | 09/19/83 | PAGE | 7 |
|---------|--------|---------------------------------------------------------------------------|------------------------|----------|------|---|
| 145     | 2      | FIFD_T_OUT: PROCEDURE BYTE ,                                              |                        |          |      |   |
| 146     | 2      | DECLARE CHAR BYTE AUXILIARY,                                              |                        |          |      | • |
| 147     | 2      | CHAR=FIFO_T(OUT_PTR_T);                                                   |                        |          |      |   |
|         | 2      | OUT_PTR_T=OUT_PTR_T+1;                                                    |                        |          |      |   |
|         | 2      | IF OUT_PTR_T=IN_PTR_T /* Then FIFO_T is empty */<br>THEN DO;              |                        |          |      |   |
|         | 3      |                                                                           |                        |          |      |   |
|         | 3<br>3 | BUFFER_STATUS_T=EMPTY;                                                    |                        |          |      |   |
|         | 3      | SEND_DATA=0;<br>EA=1;                                                     |                        |          |      |   |
|         | 3      | END)                                                                      |                        |          |      |   |
|         | 2      | ELSE IF ((BUFFER_STATUS_T=FULL) AND (OUT_PTR_T-80=IN_PTR_T))<br>THEN DD:  |                        |          |      |   |
| 158     | з      | USART_STATUS, USART_CMD=USART CMD DR 20H,                                 |                        |          |      |   |
|         | 3      | BUFFER_STATUS_T=INUSE;                                                    |                        |          |      |   |
|         | 3      |                                                                           |                        |          |      |   |
| 161     | 2      | IF (CHAR=LF AND SEND_DATA>0) THEN SEND_DATA=SEND_DATA=1;                  |                        |          |      |   |
| 163     | 2 '    | RETURN, CHAR;                                                             |                        |          |      |   |
| 164     | 1      | END FIFO_T_OUT;                                                           |                        |          |      |   |
| 165     | 2      | ERROR: PROCEDURE (STATUS) USING 2;                                        |                        |          |      |   |
| 166     | 2      | DECLARE STATUS BYTE:                                                      |                        |          |      |   |
| 167     | 2      | IF (STATUS AND OBH)<>0<br>THEN ERR_MEBSAGE_PTR=. PARITY;                  |                        |          |      |   |
| 169     | 2      | ELSE IF (STATUS AND TOH)<>0                                               |                        |          |      |   |
| 171     | 2      | THEN ERR_MESSAGE_PTR=.OVER_RUN;<br>ELSÉ IF (STATUS ÁND 20H)<>0            |                        |          |      |   |
| 171     | •      | THEN ERR_MESBAGE_PTR=. FRAME;                                             |                        |          |      |   |
| 173     | 2      | USART_STATUS=(USART_CMD OR 10H); /* Reset error flags on USART */         |                        |          |      |   |
| 174     | 2      | ERR_MESSAGE_INDEX = 0;                                                    |                        |          |      |   |
| 175     | 2      | ERROR_FLAG=1;                                                             |                        |          |      |   |
| 176     | 2      | EX1=1; /# Turn on Tx Interrupt #/                                         |                        |          |      |   |
| 177     | 1      | END ERROR;                                                                |                        |          |      |   |
| 178     | 2      | LINK_DISC: PROCEDURE ;                                                    |                        |          |      |   |
|         |        | /# This procedure sends the message 'Unable to Get Online' to the termina | 1 */                   |          |      |   |
| 179     | 2      | DECLARE MESSAGE_PTR WORD AUXILIARY,                                       |                        |          |      |   |
|         |        | MESSAGE BASED MESSAGE_PTR(1) BYTE CONSTANT,                               |                        |          |      |   |
|         |        | J BYTE AUXILIARY,<br>Exi_store bit;                                       |                        |          |      |   |
|         | 2      | EX1_STORE=EX1;                                                            |                        |          |      |   |
|         | 2      | EX1=0,                                                                    |                        |          |      |   |
|         | 2      | MESSAGE_PTR=. LINK,                                                       |                        |          |      |   |
|         | 2      |                                                                           |                        |          |      |   |
| 194     | 3      | DO WHILE (MESSAGE(J)<>0);                                                 |                        |          |      |   |

.

intel

12.3

PAGE 8

| PL/M-      | 51 COMP | ILER Application Module: Async/SDLC Protocol converter 18:50:53 09/19/83 |
|------------|---------|--------------------------------------------------------------------------|
| 185        | 4       | DD WHILE (USART_STATUS AND 01H)=0; /* Wait for TxRDY on USART */         |
| 186        | 4       | END;                                                                     |
| 187        | 3       | USART_DATA=MESSAGE(J);                                                   |
| 188        | 3       | ر میں ان ان ان ان ان ان ان ان ان ان ان ان ان                             |
| 187        | 3       | END;                                                                     |
| 190        | 2       | EX1=EX1_STORE; /* Restore async transmit interrupt */                    |
| 191        | 1       |                                                                          |
| 171        | •       | END LINK_DISC:                                                           |
| 192        | 2       | CO: PROCEDURE (CHAR) USING 2;                                            |
| 193        | 2       | DECLARE CHAR BYTE;                                                       |
| 194        | Э       | DD WHILE (USART_STATUS AND 01H) = 0;                                     |
| 195        | з       | END                                                                      |
| 196        | 2       | USART_DATA=CHAR;                                                         |
| 197        | 1       | END CO;                                                                  |
| 198<br>199 | 2       | CI. PROCEDURE BYTE USING 2:                                              |
|            | 3       | DO WHILE (USART_STATUS AND 02H) = 0;                                     |
| 200        | 3       | END,                                                                     |
| 201<br>202 | 2       | RETURN USART_DATA;<br>END CI;                                            |
| đVđ        | 1       |                                                                          |
| 203 `      | \$      | GET_MEX: PROCEDURE BYTE USING 2;                                         |
| 204        | 2       | DECLARE CHAR BYTE AUXILIARY.<br>I byte Auxiliary.                        |
| 205        | 2       | LO: CHAR=CI;                                                             |
| 206        | з       | DC I=0 TC 15;                                                            |
| 207        | 3       | IF CHAR=HEX_TABLE(I)<br>THEN GOTO L1;                                    |
| 209        | 3       |                                                                          |
| 210        | 2       | L1. CALL CD(HEX_TABLE(I));                                               |
| 211        | 2       | IF I=16<br>THEN GOTO LO;                                                 |
| 213        | 2       | RETURN 1:                                                                |
| 214        | 1       | END GET_HEX;                                                             |
| 215        | 2       | DUTPUT_MESSAGE: PROCEDURE (MESSAGE_PTR) USING 2.                         |
| 216        | 2       | DECLARE MESSAGE_PTR WORD,                                                |
|            |         | MESSAGE BASED MESSAGE_PTR(1) BYTE CONSTANT,<br>I BYTE AUXILIARY,         |
| 217        | 2       | 1=0;                                                                     |
|            |         |                                                                          |
| 218        | 3       | DO WHILE MESSAGE(I) <> 0;                                                |
| 219        | Э       | CALL CO(MESSAGE(I)),                                                     |
| 220        | Э       | I=I+1;                                                                   |

| PL/M-51    | COMPIL | ER Application Module Async/SDLC Protocol converter                                         |
|------------|--------|---------------------------------------------------------------------------------------------|
| 221        | з      | END                                                                                         |
| 222        | 1      | END OUTPUT_MEBSAQE;                                                                         |
| 223        | 2      | MENU PROCEDURE USING 2;                                                                     |
| 224        | 2      | DECLARE I BYTE AUXILIARY,<br>CHAR BYTE AUXILIARY,<br>STATION_ADDRESS BYTE AUXILIARY;        |
| 225        | 2      | START:<br>CALL DUTPUT_MESSAGE(.SIGN_DN);                                                    |
| 226        | 2      | MO: CHAR=CI; /* Read a character */                                                         |
| 227<br>228 | 3      | DO I=O TO 4;<br>If Char=Menu_Char(I)<br>Ther goto M1,                                       |
| 230        | 3      | END;                                                                                        |
| 231<br>232 | 2      | M1 CALL CO(MENU_CHAR(I));<br>IF I=5<br>Then Goto Mo;                                        |
| 234        | з      | DO CASE I,                                                                                  |
| 235<br>236 | 4<br>4 | DO;<br>CALL OUTPUT_MESSAGE(.STAT_ADDR);                                                     |
| 237        | 4      | STATION_ADDRESS=SHL(GET_HEX,4),                                                             |
| 238        | 4      | STATION_ADDRESS=(STATION_ADDRESS OR GET_HEX);                                               |
| 239        | 4      | STAD=STATION_ADDRESS;                                                                       |
| 240        | 4      | CALL OUTPUT_MESSAGE( S_ADDR_ACK),                                                           |
| 241<br>242 | 4<br>4 | CALL CO(HEX_TABLE(SHR(STATION_ADDRESS,4))),<br>CALL CO(HEX_TABLE(OFH AND STATION_ADDRESS)), |
| 243<br>244 | 4<br>4 | CALL OUTPUT_MESSAGE(.ADDR_ACK_FIN),<br>END;                                                 |
| 245        | 4      | DO,                                                                                         |
| 246        | 4      | CALL OUTPUT_MESSAGE(.DEST_ADDR),                                                            |
| 247        | 4      | DESTINATION_ADDRESS=SHL(GET_HEX,4);                                                         |
| 248        | 4      | DESTINATION_ADDRESS=(DESTINATION_ADDRESS OR GET_HEX ),                                      |
| 247        | 4      | CALL OUTPUT_MESSAGE( D_ADDR_ACK),                                                           |

18.50 53 09/19/83 PAGE 9

| PL/M-S     | 51 COM | PILER Application Module: Async/SDLC Protocol converter                                             | 18 50 53 09/19/83        | PAGE 10 |
|------------|--------|-----------------------------------------------------------------------------------------------------|--------------------------|---------|
| 250<br>251 | 4<br>4 | CALL CD(HEX_TABLE(SHR(DESTINATION_ADDRESS,4)));<br>CALL CD(HEX_TABLE(OFH AND DESTINATION_ADDRESS)); | 1 <b>*</b>               | ,       |
| 252<br>253 | 4<br>4 | <ul> <li>CALL OUTPUT_MESSAGE(.ADDR_ACK_FIN);<br/>END;</li> </ul>                                    |                          |         |
| 254        | 4      | DO;                                                                                                 |                          |         |
| 255        | 4      | CALL OUTPUT_MESSAGE(.FIN);                                                                          |                          |         |
| 256        | 4      | CALL OPEN;                                                                                          |                          |         |
| 257        | 4      | END;                                                                                                |                          |         |
| 258        | 4      | DO,                                                                                                 |                          |         |
| 259        | 4      | CALL OUTPUT_MESSAGE( FIN);                                                                          |                          |         |
| 260        | 4      | CALL CLOSE;                                                                                         |                          |         |
| 261        | 4      | END,                                                                                                |                          |         |
| 262        | 3      | CALL OUTPUT_MESSAGE( FIN),                                                                          | t                        |         |
| 263        | з      | END, /* DO CASE */                                                                                  | ×                        |         |
| 264        | 1      | END MENU,                                                                                           |                          |         |
| 265        | 2      | USART_RECV_INT PROCEDURE INTERRUPT O UBING 2                                                        |                          |         |
| 266        | 2      | DECLARE CHAR BYTE AUXILIARY,<br>Status byte Auxiliary,                                              |                          |         |
| 267        | 2      | CHAR=USART_DATA:                                                                                    |                          |         |
| 268        | 2      | STATUS=USART_STATUS AND 38H,                                                                        |                          |         |
| 267        | 2      | IF STATUS<>0                                                                                        |                          |         |
| 271        | 2      | THEN CALL ERROR(STATUS);<br>ELSE IF CHAR=ESC                                                        | *                        |         |
|            | -      | THEN CALL MENU,                                                                                     |                          |         |
| 273        | з      | ELSE DO;                                                                                            |                          |         |
| 274<br>275 | 3<br>3 | CALL FIFO_T_IN(CHAR),<br>IF ECHO=0                                                                  |                          |         |
| 213        | 3      | THEN CALL CD(CHAR),                                                                                 |                          |         |
| ·277       | з'     | END,                                                                                                |                          |         |
| 278        | 1      | END USART_RECV_INT,                                                                                 | ,                        |         |
| 279        | 1      | BEGIN<br>CALL POWER_ON,                                                                             | 3                        |         |
| 280        | 2      | DO FOREVER;                                                                                         |                          |         |
| 281        | 2      | IF SEND_DATA>O<br>THEN DO;                                                                          |                          |         |
| 283        | 4,     | DD WHILE NOT(XMIT_BUFFER_EMPTY)/ /*Wait until SIU_XM]<br>is empty */                                | (T_BUFFer                |         |
| 284        | 4      | END,                                                                                                |                          |         |
| 285        | э      | LENGTH, CHAR =1.                                                                                    |                          |         |
| 286        | з      | SIU_XMIT_BUFFER(0)=DESTINATION_ADDRESS;                                                             |                          |         |
|            |        |                                                                                                     | (BUFFER_STATUS_T<>EMPTY) | );      |

,

| PL/M-5 | 1 COMF | ILER Application Module: Async/SDLC Protocol converter 18.50-53 09/                                                                                                             | 19/83 PAQE |
|--------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| 288    | 4      | CHAR=FIFO_T_OUT;                                                                                                                                                                |            |
| 289    | 4      | SIU_XMIT_BUFFER(LENGTH)=CHAR;                                                                                                                                                   |            |
| 290    | 4      | LENGTH=LENGTH+1;                                                                                                                                                                |            |
| 291    | 4      | END                                                                                                                                                                             |            |
|        |        | /* If the line entered at the terminal is greater than BUFFER_LENOTH char, send the<br>first BUFFER_LENOTH char, then send the rest, since the SIU buffer is only BUFFER_LENOTH | bytes #/   |
| 292    | 3      | L1 I=0, /* Use I to count the number of unsuccesful                                                                                                                             |            |
|        |        | transmits */                                                                                                                                                                    |            |
| 293    | з      | RETRY RESULT=TRANSMIT(LENGTH); /* Send the message */                                                                                                                           |            |
| 294    | з      | IF RESULT<>DATA_TRANSMITTED                                                                                                                                                     |            |
|        |        | THEN DO;                                                                                                                                                                        |            |
|        |        | /# Wait 50 msec for link to connect then try again #/                                                                                                                           |            |
| 296    | 4      | WAIT=1;                                                                                                                                                                         |            |
| 297    | 4      | THO=3CH;                                                                                                                                                                        |            |
| 298    | 4      |                                                                                                                                                                                 |            |
| 299    | 4      | TRO=1;                                                                                                                                                                          |            |
| 300    | 5      | DO WHILE WAIT;                                                                                                                                                                  |            |
| 301    | 5      | END                                                                                                                                                                             |            |
| 302    | 4      |                                                                                                                                                                                 |            |
| 303    | 7      | I=I+1;                                                                                                                                                                          |            |
| 303    | 5      | IF I>100 THEN DD; /* Wait 5 sec to get on line else                                                                                                                             |            |
| 304    | 3      | if 17100 then buy it want 5 set to get on the ease<br>send error message to terminal                                                                                            |            |
|        |        |                                                                                                                                                                                 |            |
|        | -      | and try again +/                                                                                                                                                                |            |
| 306    | 5      | CALL LINK_DISC,                                                                                                                                                                 |            |
| 307    | 5      | GOTO L1,                                                                                                                                                                        |            |
| 308    | 5      | END,                                                                                                                                                                            | × .        |
| 309    | 4      | QOTO RETRY;                                                                                                                                                                     |            |
| 310    | 4      | END                                                                                                                                                                             |            |
| 311    | 3      | END;                                                                                                                                                                            |            |
| 312    | 2      | END,                                                                                                                                                                            |            |
| 313    | 1      | END USER\$MOD;                                                                                                                                                                  |            |
|        |        |                                                                                                                                                                                 |            |

11

WARNINGS 2 IS THE HIGHEST USED INTERRUPT

| MODULE INFORMATION      | (STATIC+OVERLAYABLE) |   |
|-------------------------|----------------------|---|
| CODE SIZE               | = 06B2H 1714D        |   |
| CONSTANT SIZE           | = 01CFH 463D         |   |
| DIRECT VARIABLE SIZE    | = 00H+05H 0D+ 5      | D |
| INDIRECT VARIABLE SIZE  | = 00H+00H 0D+ 0      | D |
| BIT SIZE                | = 02H+01H 2D+ 1      | D |
| BIT-ADDRESSABLE SIZE    | = 00H+00H 0D+ 0      | D |
| AUXILIARY VARIABLE SIZE | = 021FH 543D         |   |
| MAXIMUM STACK SIZE      | = 0028H 40D          |   |
| REGISTER-BANK(S) USED   | 012                  |   |
| 713 LINES READ          |                      |   |
| O PROGRAM ERROR(S)      |                      |   |

END OF PL/M-51 COMPILATION

| nteľ                     |                                |                                  |                          |                                           |                     |          | 4<br>1<br>1 | 1<br>  |
|--------------------------|--------------------------------|----------------------------------|--------------------------|-------------------------------------------|---------------------|----------|-------------|--------|
|                          |                                | ,                                |                          |                                           |                     |          |             |        |
| /M-31 COMP               | PILER R                        | UPI-44 Primary                   | Station                  | Х                                         |                     | 20 47 13 | 09/26/83    | PAGE 1 |
| IS-II PL/M<br>MPILER INV |                                | F2 PLM51 F2                      | PNOTE SRC                |                                           | -                   |          |             |        |
|                          | \$TITLE<br>\$DEBUG<br>\$REGIST | ('RUPI-44<br>ERBANK (0)          | Primary Stati            | on')                                      |                     | *        |             |        |
| 1 1                      | MAINSMO                        |                                  |                          |                                           |                     |          |             |        |
|                          |                                |                                  |                          | are not listed, but<br>( f2 REG44 DCL) */ | this is the stateme | nt       |             |        |
|                          | \$NOLIST                       |                                  |                          |                                           |                     |          |             |        |
| 51                       | DECLARE                        |                                  | LITERALLY                | 'LITERALLY',                              |                     |          |             |        |
|                          |                                | TRUE<br>FALSE                    | LIT<br>LIT               | 'OFFH',<br>'OOH',                         |                     |          |             |        |
|                          |                                | FOREVER                          | LIT                      | WHILE 1',                                 | 4.5                 |          |             |        |
|                          | /* SDLC                        | COMMANDS AND R                   | ESPONSES */              |                                           | ,                   |          |             | 4      |
| 6 1                      | DECLARE                        | SNRM                             |                          | '93H',                                    |                     |          |             |        |
|                          | •                              | UA<br>DISC                       | LIT                      | (73H),<br>(53H),                          |                     |          | -           |        |
|                          |                                | DISC                             | LIT<br>LIT               | '1FH',                                    |                     |          |             |        |
|                          |                                | FRMR                             | LIT                      | '97H',                                    |                     |          |             |        |
|                          |                                | REQ_DISC                         |                          | 153H1,<br>133H1,                          |                     |          |             |        |
|                          |                                | TEST                             | LIT                      | '0F3H',                                   |                     |          |             |        |
|                          |                                | RR                               | LIT                      | (11H),                                    |                     |          |             |        |
|                          |                                | RNR ·                            | LIT                      | '15H',                                    |                     |          |             |        |
| ,                        |                                | /* REM                           | IOTE STATION E           | UFFER STATUS */                           |                     |          |             |        |
|                          |                                | BUFFER_READY<br>BUFFER_NOT_REA   | LIT<br>DY LIT            | '0',<br>'1',                              |                     |          |             |        |
|                          |                                | /* STA                           | TION STATES *            |                                           |                     |          | ;           |        |
|                          |                                | DISCONNECT_S                     | LIT                      | 'OOH', /* LOGICALLY                       | DISCONNECTED STATE* | /        |             |        |
|                          |                                | GO_TO_DISC<br>I_T_S              | LIT<br>LIT               | '01H',<br>'02H', /* INFORMATIO            | TRANCEER STATE #/   |          |             |        |
|                          |                                | *_1_0                            | <b>L</b> 11              |                                           | INHIGHER JIHTE W    |          |             |        |
|                          |                                | /* PARAMETERS                    |                          |                                           |                     |          |             |        |
|                          |                                | T_I_FRAME<br>T_RR                | LIT                      | '00H',<br>'01H',                          |                     |          |             |        |
| ,                        |                                | T_RNR                            | LIT                      | '02H',                                    |                     |          |             |        |
|                          |                                | /* SECONDARY S                   | TATION IDENTI            | FICATION */                               |                     |          |             |        |
|                          |                                |                                  |                          |                                           |                     |          |             |        |
|                          |                                | NUMBER_OF_STAT<br>SECONDARY_ADDR | IUNS LIT<br>ESSES(NUMBER | (2',<br>OF STATIONS)                      |                     |          |             |        |
|                          |                                |                                  | BYTE                     | CONSTANT (55H, 43H),                      |                     |          |             |        |

|            |         |                                              |                                       | х.                                                |
|------------|---------|----------------------------------------------|---------------------------------------|---------------------------------------------------|
| PL/M-1     | 51 COMP | ILER RUPI-44 Primary Stati                   | en                                    | 20:47                                             |
|            |         | /* Remote S                                  | Station                               | Database */                                       |
|            |         | RSD (NUMBER_OF_STAT)                         | -                                     | 81/C TI /05                                       |
|            |         | (STATION_ADDRESS                             | BYTE,                                 | RUCIURE                                           |
|            |         | STATION STATE                                | BYTE.                                 |                                                   |
|            |         | NS                                           | BYTE.                                 |                                                   |
|            |         | NR                                           | BYTE.                                 |                                                   |
|            |         | BUFFER_STATUS                                | BYTE.                                 | /# The status of the secondary stations buffer #/ |
|            |         | INFO_LENGTH                                  | BYTE,                                 |                                                   |
|            |         | DATA(64)                                     | BYTE)                                 | AUXILIARY,                                        |
|            |         | /+ VARIABLE                                  | S */                                  |                                                   |
|            |         | STATION_NUMBER                               | BVTE                                  | AUXILIARY,                                        |
|            |         | RECV_FIELD_LENGTH                            | BYTE                                  | AUXILIARY,                                        |
|            |         | WAIT                                         | BIT,                                  |                                                   |
|            |         | /* BUFFERS                                   |                                       |                                                   |
|            |         | SIU_XMIT_BUFFER(64)                          |                                       | TE IDATA,                                         |
|            |         | SIU_RECV_BUFFER(64)                          |                                       | TE:                                               |
| 7<br>8     | 2       | POWER_ON: PROCEDURE ;<br>Declare I byte aux  | ILIARY,                               |                                                   |
| ` <b>9</b> | 2       |                                              |                                       |                                                   |
| 10         | 2       | TBS=. SIU_XMIT_BUFFE<br>RBS=. SIU_RECV_BUFFE |                                       |                                                   |
| 11         | 2       |                                              |                                       | eive buffer #/                                    |
| 12         | 2       |                                              |                                       | SIU's receiver */                                 |
|            | -       |                                              | · · · · · · · · · · · · · · · · · · · |                                                   |
| 13         | 3       | DO I= O TO NUMBER_O                          | F_STATI                               | ONS-1, ~                                          |
| 14         | з       | RSD(I). STATION                              | ADDRESS                               | SECONDARY_ADDRESSES(I)                            |
| 15         | Э       | RSD(1). STATION                              | STATE=D                               | ISCONNECT_S;                                      |
| 16         | 3       |                                              |                                       | UFFER_NOT_READY,                                  |
| 17         | 3       | RSD(I) INFO_LEN                              | ICTH=0;                               |                                                   |
| 18         | 3       | END;                                         |                                       |                                                   |
| 19         | 2       | SMD=54H; /* Using D                          | PLL, NR                               | ZI, PFS, TIMER 1, 8 62.5 Kbps +/                  |
| 20         | 5       | TMOD=21H;                                    |                                       |                                                   |
| 21         | 2       | TH1=OFFH,                                    |                                       |                                                   |
| 55         | 2       |                                              | mer () f                              | or receive time out interrupt #/                  |
| 23         | 2       | IE=82H,                                      |                                       |                                                   |
| 24         | 1       | END POWER_ON;                                |                                       |                                                   |
| 25         | 2       | XMIT PROCEDURE (CONTROL BY                   | TE).                                  |                                                   |

25 2 XMIT PROCEDURE (CONTROL\_BYTE),

26 2 DECLARE CONTROL\_BYTE BYTE, TCB=CONTROL\_BYTE, TBF=1;

27 28 22

.

, ·

20-47 13 09/26/83 PAGE 2

.

| PL/M-S   | 51 COMF | ILER RUPI-44 Primary Station               | ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ı' ` <b>2</b>                         | 20**47,*13* 09/26/<br>·               | 83" PAGE 3 |
|----------|---------|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|---------------------------------------|------------|
| 29       | 2       | RTS=1,                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                       |                                       |            |
| 30       | 3       | DO WHILE NOT SI,                           | 5 m a 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | \$                                    |                                       |            |
| 31<br>32 | 3       | END,<br>SI=0,                              | 10 C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                       |                                       |            |
|          | -       |                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 |                                       |            |
| 33       | 1       | END XMIT,                                  | ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | هي .                                  | · · · · ·                             |            |
| 34       | 2       | TIMER_O_INT PROCEDURE INTERRUPT 1 USING 1, | 14 S. F.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 3.<br>, 11                            | •                                     |            |
| 35<br>36 | 2<br>1  | WAIT=O,<br>END TIMER_O_INT,                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | , "                                   | <i>.</i>                              |            |
|          | -       |                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                       |                                       |            |
| 37       | 2       | a Framer<br>If∵there<br>200 msec           | eturns true if ther<br>received within 200<br>was'a frame receiv<br>then time_out retu                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ) msec.<br>ed.within://               | ί,                                    |            |
| 38       | 2       | DECLARE I BYTE AUXILIARY,                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                       |                                       |            |
| 39       | з       | DO I=O TO 3,                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                       |                                       |            |
| 40       | з       | WAIT=1,                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | · ·                                   |                                       |            |
| 41       | з       | THO=3CH,                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                       |                                       |            |
| 42<br>43 | 3<br>3  | TL0=0AFH,<br>TR0=1,                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                       | 4, , ,                                |            |
| 44       | 4       | DO WHILE WAIT,                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                       | ··· · ·                               |            |
| 45       | 4       | IF SI=1                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                       | 1 <b></b>                             | 1 2        |
| 47       | 4       | THEN GOTO T_01,<br>END,                    | ×                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                       |                                       |            |
| 48       | з       | END,                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 2 1 1                                 |                                       |            |
| 49       | 2       | RETURN TRUE,                               | e de la compañía de la compañía de la compañía de la compañía de la compañía de la compañía de la compañía de l                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                       | , , , , , , , , , , , , , , , , , , , |            |
| 50       | 2       | T_01                                       | *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | and a set of                          |                                       |            |
| 51       | 2       | SI≖O,<br>RETURN FALSE,                     | و مر الاند ال                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                       |                                       |            |
| 52       | 1       | END TIME_OUT,                              | and the second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second sec | с тукум<br>К                          |                                       |            |
| 53       | 2       | SEND_DISC PROCEDURE,                       | · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                       |                                       |            |
|          |         | -                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                       |                                       |            |
| 54<br>55 | 2       | TBL=0,<br>CALL XMIT(DISC),                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                       | <b>1</b> -                            |            |
| 56       | 2       | IF TIME_OUT=FALSE                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | •                                     | **                                    |            |
| 57       | з       | THEN IF RCB=UA OR RCB=DM<br>THEN DO,       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                       | 2, 11                                 |            |
| 59       | 3       | RSD(STATION_NUMBE                          | ER) BUFFER STATUS=E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | UFFER NOT RE                          | EADY,                                 |            |
| 60       | 3       | RSD (STATION_NUMBE                         | ER) STATION_STATE=D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                       |                                       |            |
| 61<br>62 | 3<br>2  | END,<br>RBE=1,                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                       | 1. gen - 1. h                         |            |
| 63       | 1       | END SEND_DISC,                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                       |                                       |            |
|          |         |                                            | \$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                       |                                       | ,          |
| 64       | 2       | SEND_SNRM PROCEDURE,                       | ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                       |                                       |            |
| 65       | 2       | TBL=O,                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1                                     |                                       |            |

| PL/M-S   | 51 COMPI | LER RUPI-44 Primary Station                                                                                                                                                                          | 20 47 1 | 13 04 | 9/26/83 | PAGE |
|----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------|---------|------|
| 66       | 2        | CALL XMIT(SNRM),                                                                                                                                                                                     |         |       |         |      |
| 67       | 2        | IF (TIME_OUT=FALSE) AND (RCB=UA)<br>THEN DO,                                                                                                                                                         |         |       |         |      |
| 69       | з        | RSD(STATION_NUMBER) STATION_STATE=I_T_S,                                                                                                                                                             |         |       |         |      |
| 70       | ă        | RSD(STATION_NUMBER) NS=0,                                                                                                                                                                            |         |       |         |      |
| 71       | 3        | RSD(STATION_NUMBER) NR≖O,                                                                                                                                                                            |         |       |         |      |
| 72       | з        | END;                                                                                                                                                                                                 |         |       |         |      |
| 73       | 2        | RBE=1;                                                                                                                                                                                               |         |       |         |      |
| 74       | 1        | END SEND_SNRM;                                                                                                                                                                                       |         |       |         |      |
| 75       | 2        | CHECK_NS PROCEDURE BYTE,                                                                                                                                                                             |         |       |         |      |
|          |          | /* Check the Ns Field of the received frame $\  \  If Nr(P)=Ns(S)$ return true */                                                                                                                    |         |       |         |      |
| 76       | 2        | IF (RSD(STATION_NUMBER) NR=(SHR(RCB,1) AND 07H))<br>THEN RETURN TRUE,                                                                                                                                |         |       |         | ,    |
| 78       | 2        | ELSE RETURN FALSE;                                                                                                                                                                                   |         |       |         |      |
| 79       | 1        | END CHECK_NS,                                                                                                                                                                                        |         |       |         |      |
| 80       | 2        | CHECK_NR PROCEDURE BYTE,                                                                                                                                                                             |         |       |         |      |
|          |          | /* Check the Nr field of the received frame If Ns(P)+1=Nr(S) then the frame<br>has been acknowledged, else if Ns(P)=Nr(S) then the frame has not been<br>acknowledged, else reset the secondary */   |         |       |         |      |
| 81       | 5        | IF (((RSD(STATION_NUMBER) NS + 1) AND 07H) = SHR(RCB,5))<br>THEN DD,                                                                                                                                 |         |       |         |      |
| 83       | 3        | RSD(STATION_NUMBER) NS=((RSD(STATION_NUMBER) NS+1) AND 07H),                                                                                                                                         |         |       |         |      |
| 84       | 3        | RSD(STATION_NUMBER) INFO_LENGTH=0,                                                                                                                                                                   |         |       |         |      |
| 85       | з        | END,                                                                                                                                                                                                 |         |       |         |      |
| 86       | 2        | ELSE IF (RSD(STATION_NUMBER) NS <> SHR(RCB,5))<br>THEN RETURN FALSE,                                                                                                                                 |         |       |         |      |
| 88       | 2        | RETURN TRUE,                                                                                                                                                                                         |         |       |         |      |
| 89       | 1        | END CHECK_NR,                                                                                                                                                                                        |         |       |         |      |
| 90       | 2        | RECEIVE PROCEDURE                                                                                                                                                                                    |         |       |         |      |
| 91       | 2        | DECLARE I BYTE AUXILIARY,                                                                                                                                                                            |         |       |         |      |
| 92       | 2        | RSD(STATION_NUMBER) BUFFER_STATUS=BUFFER_READY,                                                                                                                                                      |         |       |         |      |
|          |          | /* If an RNR was received buffer_status will be changed in the supervisory<br>frame decode section futher down in this procedure, any other response<br>means the remote stations buffer is ready */ |         |       |         |      |
| 93       | 2        | IF (RCB AND 01H)=0<br>THEN DD, /* I Frame Received */                                                                                                                                                |         |       |         |      |
| 95       | Э        | IF (CHECK_NS=TRUE AND BOV=0 AND CHECK_NR=TRUE)<br>THEN DD;                                                                                                                                           | ,       |       |         |      |
| 97<br>98 | 4        | RSD(STATION_NUMBER) NR=((RSD(STATION_NUMBER)<br>RBP=1,                                                                                                                                               | NR+1) A | ND 07 | н),     |      |
| . 3      | •        |                                                                                                                                                                                                      |         |       |         |      |

| P1 /M      | i COMPI | ILER RUPI-44 Primary Station 2                                              | 0.47 13  | 09/26/83   | PAGE |
|------------|---------|-----------------------------------------------------------------------------|----------|------------|------|
| 10/11/0    |         |                                                                             | • •, 10  | 07720700   |      |
| 99         | 4       | RECV_FIELD_LENGTH=RFL-1,                                                    |          |            |      |
| 100        | 4.      |                                                                             | 1        |            |      |
| 101        | з       | ELSE RSD(STATION_NUMBER) STATION_STATE=GO_TO_DISC;                          |          |            |      |
| 102        | 3       | END;                                                                        |          |            |      |
| 103        | 2       | ELSE IF (RCB AND O3H)=01H                                                   |          |            |      |
| 105        | з       | THEN DD, /* Supervisory frame received */<br>IF CHECK_NR=FALSE              |          |            |      |
| 105        | 3       | THEN RSD(STATION_NUMBER). STATION_STATE=QO_TO_DISC,                         |          |            |      |
|            |         |                                                                             | ,        |            |      |
| 107        | з       | ELSE IF ((RCB AND OFH)=05H) /* then RNR */                                  |          |            |      |
| 109        | з       | THEN RSD(STATION_NUMBER) BUFFER_STATUS=BUFFER_N<br>END,                     | UT_READY | •          |      |
| 107        | 5       |                                                                             |          |            |      |
| 110        | з       | ELSE DO, /* Unnumbered frame or unknown frame received */                   |          |            |      |
| 111        | 3       | IF RCB=FRMR                                                                 |          |            |      |
|            |         | THEN DD, /* If FRMR was received check Nr for an<br>acknowledged I frame */ |          |            |      |
| 113        | 4       | RCB=SIU_RECV_BUFFER(1);                                                     |          |            | 1    |
| 114        | 4       | I=CHECK_NR;                                                                 | ,        |            |      |
| 115        | 4       | END,                                                                        |          |            |      |
| 116        | 3       | RSD(STATION_NUMBER) STATION_STATE=GO_TO_DISC,                               |          |            |      |
| 117        | з       | END)                                                                        |          |            |      |
| 118        | 2       | RBE=1,                                                                      |          |            |      |
|            |         |                                                                             |          |            |      |
| 119        | 1       | END RECEIVE,                                                                |          |            |      |
|            |         |                                                                             |          |            |      |
| 120        | 2       | XMIT_I_T_S PROCEDURE (TEMP),                                                |          |            |      |
|            |         | ANIT_I_T_A FROMEDORE (TENF)                                                 |          |            |      |
| 121        | 2       | DECLARE TEMP BYTE,                                                          |          |            |      |
| 122        | 2       | IF TEMP=T_I_FRAME                                                           |          |            |      |
|            |         | THEN DO, /* Transmit I frame */                                             |          |            |      |
|            |         | /* Transfer the station buffer into internal ram */                         |          |            |      |
| 124        | 4       | DO TEMP#0 TO RSD(STATION_NUMBER). INFO_LENGTH-1,                            |          |            |      |
| 125        | 4       | SIU_AMIT_BUFFER(TEMP)=RSD(STATION_NUMBER) DATA(TEMP),                       |          |            |      |
| 126        | 4       | END)                                                                        |          |            |      |
|            |         | /* Build the I frame control field */                                       |          |            |      |
|            |         |                                                                             |          |            |      |
| 127        | 3       | TEMP=(SHL(RSD(STATION_NUMBER) NR,5) OR SHL(RSD(STATION_NUMB                 | ER) NS,1 | ) OR 10H), |      |
| 128<br>129 | 3       | TBL=RSD(STATION_NUMBER).INFO_LENGTH,                                        |          |            |      |
| 130        | 3       | CALL XMIT(TEMP),<br>IF TIME OUT=FALSE                                       |          |            |      |
|            | -       | THEN CALL RECEIVE,                                                          |          |            |      |
| 132        | 3       | END,                                                                        |          |            |      |
| 133        | 2       |                                                                             |          |            |      |
| 133        | 3       | ELSE DO, /* Transmit RR or RNR*/<br>IF TEMP=T_RR                            |          |            |      |
| 104        | 5       |                                                                             |          |            |      |
| 136        | з       | ELSE TEMP=RNR;                                                              |          |            |      |
|            |         |                                                                             |          |            |      |

| PL/M-      | 51 CO  | MPILER RUPI-44 Primary Station                                                                                                            | 20 47 13 | 09/26/83 | PAGE | 6 |
|------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------|----------|----------|------|---|
| 137        | з      | TENG-/OUI (BOD/OTATION NUMBED) NO S) OB TENG                                                                                              |          |          |      |   |
| 138        | 3      | TEMP=(SHL(RSD(STATION_NUMBER) NR,5) OR TEMP),<br>TBL=0;                                                                                   |          |          |      |   |
| 139        |        | CALL XMIT(TEMP),                                                                                                                          |          |          |      |   |
| 140        | 3      | IF TIME OUT-FALSE                                                                                                                         |          |          |      |   |
|            |        | THE CALL RECEIVE,                                                                                                                         |          |          |      |   |
| 142        | з      | END,                                                                                                                                      |          |          |      |   |
| 143        | 1      | END XMIT_I_T_S;                                                                                                                           |          |          |      |   |
|            | -      |                                                                                                                                           |          |          |      |   |
| 144        | 2      | BUFFER_TRANSFER PROCEDURE,                                                                                                                |          |          |      |   |
| 145        | 2      | DECLARE I BYTE AUXILIARY,<br>J BYTE AUXILIARY;                                                                                            |          |          |      |   |
| 146        | з      | DO I=0 TO NUMBER OF STATIONS-1,                                                                                                           |          |          |      |   |
| 140        | 3      | IF RSD(I) STATION_ADDRESS=SIU_RECV_BUFFER(0)                                                                                              |          |          |      |   |
| 14/        | 3      | THEN GOTO T1;                                                                                                                             |          |          |      |   |
| 149        | з      | END,                                                                                                                                      |          |          |      |   |
|            | 0      |                                                                                                                                           |          |          |      |   |
| 150        | 2      | T1 IF I=NUMBER_OF_STATIONS /* If the addressed station does not exits,<br>then discard the data */                                        |          |          |      |   |
|            | _      | THEN DO,                                                                                                                                  |          |          |      |   |
| 152        | 3      | RBP=0.                                                                                                                                    |          |          |      |   |
| 153<br>154 | 3<br>3 | RETURN;<br>END;                                                                                                                           |          |          |      |   |
| 154        | 2      | ELSE IF RSD(I) INFO_LENGTH=0                                                                                                              |          |          |      |   |
|            |        | THEN DO,                                                                                                                                  |          |          |      |   |
| 157        | 3      | RSD(I), INFO_LENGTH=RECV_FIELD_LENGTH,                                                                                                    |          |          |      |   |
| 158<br>159 | 4<br>4 | DO J=1 TO RECV_FIELD_LENGTH,                                                                                                              |          |          |      |   |
| 160        | 4      | RSD(I) DATA(J-1)≖SIU_RECV_BUFFER(J),<br>END,                                                                                              |          |          |      |   |
| 161        | 3      | RBP=0;                                                                                                                                    |          |          |      |   |
| 162        | 3      |                                                                                                                                           |          |          |      |   |
| IUE        | 5      |                                                                                                                                           |          |          |      |   |
| 163        | 1      | END BUFFER_TRANSFER                                                                                                                       | ,        |          |      |   |
| 164        | 1      | BEGIN<br>CALL POWER_ON,                                                                                                                   |          |          |      |   |
| 165        | 2      | DO FOREVER;                                                                                                                               |          |          |      |   |
| 166        | з      | DO STATION_NUMBER=0 TO NUMBER_OF_STATIONS-1,                                                                                              |          |          |      |   |
| 167        | з      | STAD=RSD(STATION_NUMBER) STATION_ADDRESS,                                                                                                 |          |          |      |   |
| 168        | 3      | IF RSD(STATION_NÜMBER) STATION_STATE = DISCONNECT_S<br>THEN CALL SEND_SNRM,                                                               | -        |          |      |   |
| 170        | з      | ELSE IF RSD(STATION_NUMBER) STATION_STATE = 00_T0_DISC<br>THEN CALL SEND_DISC,                                                            |          |          |      |   |
| 172        | з      | ELSE IF ((RSD(STATION_NUMBER) INFO_LENGTH>0) AND<br>(RSD(STATION_NUMBER) BUFFER_STATUS=BUFFER_READY))<br>THEN CALL XNIT_I_T_S(T_I_FRAME), |          |          |      |   |
| 174        | з      | ELSE IF RBP=0<br>THEN CALL XMIT_I_T_S(T_RR),                                                                                              |          |          |      |   |
| 176        | з      | ELSE CALL XMIT_I_T_S(T_RNR),                                                                                                              |          |          |      |   |
| 177        | 3      | IF RBP=1<br>Then Call Buffer_transfer,                                                                                                    |          |          |      |   |
|            | 1      |                                                                                                                                           |          |          |      |   |

PL/M-51 COMPILER RUPI-44 Primary Station 20 47 13 09/26/83 PAGE 7

179 END, з 180 2 END, 181 END MAIN\$MOD, 1

WARNINGS 1 IS THE HIGHEST USED INTERRUPT

| MODULE INFORMATION         | (STATIC+OVERL | AYABLE) |
|----------------------------|---------------|---------|
| CODE SIZE                  | = 053DH       | 1341D   |
| CONSTANT SIZE              | = 0002H       | 2D      |
| DIRECT VARIABLE SIZE       | = 40H+02H     | 64D+ 2D |
| INDIRECT VARIABLE SIZE     | = 40H+00H     | 64D+ OD |
| BIT SIZE                   | = 01H+00H     | 1D+ OD  |
| BIT-ADDRESSABLE SIZE       | = 00H+00H     | OD+ OD  |
| AUXILIARY VARIABLE SIZE    | = 0093H       | 147D    |
| MAXIMUM STACK SIZE         | = 0019H       | 25D     |
| REGISTER-BANK(S) USED.     | 0 1           |         |
| 456 LINES READ             |               |         |
| 0 PROGRAM ERROR(S)         |               |         |
| END OF PL/M-51 COMPILATION |               |         |

۰ ۱

· · ·

. .

# **RUPI™** Data Sheets

20

en en en proposition en la sector de la carde d'Arabeiro de la Regentra de Regentra de Regentra de Regentra de 

### 8044AH/8344AH HIGH PERFORMANCE 8-BIT MICROCONTROLLER WITH ON-CHIP SERIAL COMMUNICATION CONTROLLER

- **8044AH CPU/SIU with Factory Mask Programmable ROM**
- 8344AH An 8044AH used with External Program Memory
- 8744H An 8044AH with User Programmable/Erasable EPROM

#### 8051 MICROCONTROLLER CORE

- Optimized for Real Time Control 12 MHz Clock, Priority Interrupts, 32 Programmable I/O lines, Two 16-bit Timer/Counters
- Boolean Processor
- 4K x 8 RQM, 192 x 8 RAM
- 64K Accessible External Program Memory
- 64K Accessible External Data Memory

#### SERIAL INTERFACE UNIT (SIU)

- Serial Communication Processor that Operates Concurrently to CPU
- 2.4 Mbps Maximum Data Rate
- 375 Kbps using On-Chip Phase Locked Loop
- Communication Software in Silicon:
   Complete Data Link Functions
   Automatic Station Responses
- Operates as an SDLC Primary or Secondary Station

**4**  $\mu$ s Multiply and Divide

The RUPI-44 family integrates a high performance 8-bit Microcontroller, the Intel 8051 Core, with an intelligent/high performance HDLC/SDLC serial communication controller, called the Serial Interface Unit (SIU). See Figure 1. This dual architecture allows complex control and high speed data communication functions to be realized cost effectively.

Specifically, the 8044's Microcontroller features: 4K byte On-Chip program memory space; 32 I/O lines; two 16-bit timer/event counters; a 5-source; 2-level interrupt structure; a full duplex serial channel; a Boolean processor; and on-chip oscillator and clock circuitry. Standard TTL and most byte-oriented MCS-80 and MCS-85 peripherals can be used for I/O and memory expansion.

The Serial Interface Unit (SIU) manages the interface to a high speed serial link. The SIU offloads the On-Chip 8051 Microcontroller of communication tasks, thereby freeing the CPU to concentrate on real time control tasks.

The RUPI-44 family consists of the 8044, 8744, and 8344. All three devices are identical except in respect of on-chip program memory. The 8044 contains 4K bytes of mask-programmable ROM. User programmable EPROM replaces ROM in the 8744. The 8344 addresses all program memory externally.

The RUPI-44 devices are fabricated with Intel's reliable +5 volt, silicon-gate HMOSII technology and packaged in a 40-pin DIP.

The 8344 is available in two versions: C8344H and P8344AH. Refer to the 8744 data sheet for the C8344H.



### 8044's Dual Controller Architecture

#### Table 1. RUPI™ -44 Family Pin Description

#### VSS 🦾

Circuit ground potential.

#### VCC

+5V power supply during operation and program verification.

#### PORT 0

Port 0 is an 8-bit open drain bidirectional I/O port. It is also the multiplexed low-order address and data bus when using external memory. It is used for data output during program verification. Port 0 can sink/source eight LS TTL loads.

#### PORT 1

Port 1 is an 8-bit quasi-bidirectional I/O port. It is used for the low-order address byte during program verification. Port 1 can sink/source four LS TTL loads.

In non-loop mode two of the I/O lines serve alternate functions:

-RTS (P1.6). Request-to-Send output. A low indicates that the RUPI-44 is ready to transmit.

--CTS (P1.7) Clear-to-Send input. A low indicates that a receiving station is ready to receive.

#### PORT 2

Port 2 is an 8-bit quasi-bidirection I/O port. It also emits the high-order address byte when accessing external memory. It is used for the high-order address and the control signals during program verification. Port 2 can sink/source four LS TTL loads.

#### PORT 3

Port 3 is an 8-bit quasi-bidirectional I/O port. It also contains the interrupt, timer, serial port and RD and WR pins that are used by various options. The output latch corresponding to a secondary function must be programmed to a one (1) for that function to operate. Port 3 can sink/source four LS TTL loads.

In addition to I/O, some of the pins also serve alternate functions as follows:

- —I/O RxD (P3.0). In point-to-point or multipoint configurations, this pin controls the direction of pin P3.1. Serves as Receive Data input in loop and diagnostic modes.
- —DATA TxD (P3.1) In point-to-point or multipoint configurations, this pin functions as data input/output. In loop mode, it serves as transmit pin. A '0' written to this pin enables diagnostic mode.
- INT0 (P3.2). Interrupt 0 input or gate control input for counter 0.
- -- INT1 (P3.3). Interrupt 1 input or gate control input for counter 1.
- -TO(P3.4). Input to counter 0.

- -SCLK T1 (P3.5). In addition to I/O, this pin provides input to counter 1 or serves as SCLK (serial clock) input. -WR (P3.6). The write control signal latches the data byte from Port 0 into the External Data Memory.
- RD (P3.7). The read control signal enables External Data Memory to Port 0.

#### RST

A high on this pin for two machine cycles while the oscillator is running resets the device. A small external pulldown resistor ( $\approx$ 8.2KΩ) from RST to V<sub>SS</sub> permits power-on reset when a capacitor ( $\approx$ 10µt) is also connected from this pin to V<sub>CC</sub>.

#### ALE/PROG

Provides Address Latch Enable output used for latching the address into external memory during normal operation. It is activitated every six oscillator periods except during an external data memory access. It also receives the program pulse input for programming the EPROM version.

#### PSEN

The Program Store Enable output is a control signal that enables the external Program Memory to the bus during external fetch operations. It is activated every six oscillator periods, except during external data memory accesses. Remains high during internal program execution.

#### EA/VPP

When held at a TTL high level, the RUPI-44 executes instructions from the internal ROM when the PC is less than 4096. When held at a TTL low level, the RUPI-44 fetches all instructions from external Program Memory. The pin also receives the 21V EPROM programming supply voltage on the 8744.

#### XTAL 1

Input to the oscillator's high gain amplifier. Required when a crystal is used. Connect to VSS when external source is used on XTAL 2.

#### XTAL 2

Output from the oscillator's amplifier. Input to the internal timing circuitry. A crystal or external source can be used.



Figure 4. Block Diagram

#### Functional Description General

The 8044 integrates the powerful 8051 microcontroller with an intelligent Serial Communication Controller to provide a single-chip solution which will efficiently implement a distributed processing or distributed control system. The microcontroller is a self-sufficient unit containing ROM, RAM, ALU, and its own peripherals. The 8044's architecture and instruction set are identical to the 8051's. The 8044 replaces the 8051's serial interface with an intelligent SDLC/HDLC Serial Interface Unit (SIU). 64 more bytes of RAM have been added to the 8051 RAM array. The SIU can communicate at bit rates up to 2.4 M bps. The SIU works concurrently with the Microcontroller so that there is no throughput loss in either unit. Since the SIU possesses its own intelligence, the CPU is off-loaded from many of the communications tasks. thus dedicating more of its computing power to controlling local peripherals or some external process.

#### The Microcontroller

The microcontroller is a stand-alone highperformance single-chip computer intended for use in sophisticated real-time application such as instrumentation, industrial control, and intelligent computer peripherals.

The major features of the microcontroller are:

- 8-bit CPU
- on-chip oscillator
- 4K bytes of ROM
- 192 bytes of RAM
- 32 I/O lines
- 64K address space for external Data Memory
- 64K address space for external Program Memory
- two fully programmable 16-bit timer/counters
- a five-source interrupt structure with two priority levels
- bit addressability for Boolean processing
- 1 μsec instruction cycle time for 60% of the instructions 2 μsec instruction cycle time for 40% of the instructions
- 4 μsec cycle time for 8 by 8 bit unsigned Multiply/Divide

#### **Internal Data Memory**

Functionally the Internal Data Memory is the most flexible of the address spaces. The Internal Data Memory space is subdivided into a 256-byte Internal Data RAM address space and a 128-byte Special Function Register address space as shown in Figure 5. The Internal Data RAM address space is 0 to 255. Four 8-Register Banks occupy locations 0 through 31. The stack can be located anywhere in the Internal Data RAM address space. In addition, 128 bit locations of the on-chip RAM are accessible through Direct Addressing. These bits reside in Internal Data RAM at byte locations 32 through 47. Currently locations 0 through 191 of the Internal Data RAM address space are filled with on-chip RAM.



Figure 5. Internal Data Memory Address Space

#### Parallel I/O

The 8044 has 32 general-purpose I/O lines which are arranged into four groups of eight lines. Each group is called a port. Hence there are four ports; Port 0, Port 1, Port 2, and Port 3. Up to five lines from 1 and Port 2 are dedicated to supporting the serial channel when the SIU is invoked. Due to the nature of the serial port, two of Port 3's I/O lines (P3.0 and P3.1) do not have latched outputs. This is true whether or not the serial channel is used.

#### Table 1. MCS®-51 Instruction Set Description

| <b></b> |               |                                                |            |               | <b>г</b> |                  |        |
|---------|---------------|------------------------------------------------|------------|---------------|----------|------------------|--------|
| ARITH   | METIC OPERA   | TIONS                                          |            |               |          | LOGIC            |        |
| Mnemo   | nic           | Description                                    | Byte       | Cyc           |          | Mnemo            | nic    |
| ADD     | A,Rn          | Add register to                                |            |               |          | ORL              | A,@R   |
| 1       |               | Accumulator                                    | 1          | 1             |          |                  |        |
| ADD     | A, direct     | Add direct byte to                             |            |               |          | ORL              | A,#da  |
|         |               | Accumulator                                    | 2          | 1             |          |                  |        |
| ADD     | A,@Ri         | Add indirect RAM to                            |            |               |          | ORL              | direct |
|         | •             | Accumulator                                    | 1          | 1             |          | 0.54             |        |
| ADD     | A,#data       | Add immediate data to                          | <b>o</b> ′ |               |          | ORL              | direct |
|         | A D =         | Accumulator                                    | 2          | 1             |          | XRL              | 4 D.   |
| ADDC    | A,Rn          | Add register to                                | 1          | 1             |          | XHL              | A,Rn   |
| ADDC    | A.direct      | Accumulator with Carry<br>Add direct byte to A | 1          | · 1           |          | XRL <sup>,</sup> | A,dire |
| 1000    | A, direct     | with Carry flag                                | 2          | 1             |          |                  | A,une  |
| ADDC    | A,@Ri         | Add indirect RAM to A                          | 2          | '             |          | XRL              | A,@R   |
| 1.000   | , i e i i     | with Carry flag                                | 1          | 1             |          |                  |        |
| ADDC    | A.#data       | Add immediate data to                          | •          | ·             |          | XRL              | A,#da  |
|         |               | A with Carry flag                              | 2          | 1             |          |                  |        |
| SUBB    | A,Rn          | Subtract register from A                       |            |               |          | XRL              | direct |
| l       |               | with Borrow                                    | 1          | 1             |          |                  |        |
| SUBB    | A,direct      | Subtract direct byte                           |            |               |          | XRL              | direct |
| 1       |               | from A with Borrow                             | 2          | 1             |          |                  |        |
| SUBB    | A,@Ri         | Subtract indirect RAM                          |            |               |          | CLR              | А      |
| 1       |               | from A with Borrow                             | 1          | 1             |          | CPL              | А      |
| SUBB    | A,#data       | Subtract immed data                            |            |               |          |                  |        |
|         |               | from A with Borrow                             | 2          | 1             |          | RL               | A      |
| INC     | A             | Increment Accumulator                          | 1          | 1.            |          | RLC              | А      |
| INC     | Rn            | Increment register                             | 1          | 1             |          | ~~               |        |
| INC     | direct        | Increment direct byte                          | 2          | 1             |          | RR               | A      |
| INC     | @Ri           | Increment indirect RAM                         | 1          | 1             |          | RRC              | •      |
| INC     | DPTR<br>A     | Increment Data Pointer                         | 1          | 2             |          | RAC              | A      |
| DEC     | Rn            | Decrement Accumulator<br>Decrement register    | 1          | 1             |          | SWAP             | А      |
| DEC     | direct        | Decrement direct byte                          | 2          | 1             |          | SWAP             | A      |
| DEC     | @Ri           | Decrement indirect                             | 2          | '             |          |                  |        |
|         | (a) II        | RAM                                            | 1          | ` <b>'</b> 1. |          | DATA T           | RANS   |
| MUL     | AB            | Multiply A & B                                 | 1          | 4             |          |                  |        |
| DIV     | AB            | Divide A by B                                  | 1          | 4             |          | Mnemo            |        |
| DA      | A             | Decimal Adjust                                 | •          |               |          | MOV              | A,Rn   |
|         |               | Accumulator                                    | 1          | 1             |          | моу              | A duro |
|         |               |                                                |            |               |          | NOV              | A,dıre |
| LOGIC   | AL OPERATIO   | NS                                             |            |               |          | моу              | A,@R   |
| Mnemo   | nic           | Destination                                    | Byte       | Cyc           |          |                  | പ,അ    |
| ANL     | A,Rn          | AND register to                                | -          |               |          | моу              | A,#da  |
|         |               | Accumulator                                    | 1          | 1             |          |                  | ,      |
| ANL     | A,direct      | AND direct byte to                             |            |               |          | MOV              | Rn,A   |
|         |               | Accumulator                                    | 2          | 1             |          | -                |        |
| ANL     | A,@Ri         | AND indirect RAM to                            |            |               |          | MOV              | Rn,di  |
| 1       |               | Accumulator                                    | 1          | 1             |          |                  |        |
| ANL     | A,#data       | AND immediate data to                          |            |               |          | MOV              | Rn,#d  |
| 1       |               | Accumulator                                    | 2          | 1             |          |                  |        |
| ANL     | direct,A      | AND Accumulator to                             | ~          | _             |          | MOV              | direct |
|         | dura at #dat- | direct byte                                    | 2          | 1             |          |                  |        |
| ANL     | dırect,#data  | AND immediate data to                          | ~          | ~             |          | MOV              | direct |
| ORL     | A.Rn          | direct byte                                    | 3          | 2             |          | моу              | diract |
| UNL     | A,DU          | OR register to                                 | 1          | 1             |          | NOV              | direct |
| ORL     | A, direct     | Accumulator<br>OR direct byte to               | I.         | 1             |          | моу              | direct |
| UNL     | 7,011-601     | Accumulator                                    | 2          | 1             |          |                  | unect  |
| L       |               |                                                |            |               | L        |                  |        |
|         |               |                                                |            |               |          |                  |        |

,

| LOGICAL OPERATIONS (CONTINUED)        |                |                                             |          |       |  |  |  |  |
|---------------------------------------|----------------|---------------------------------------------|----------|-------|--|--|--|--|
| Mnemoni                               | ic             | Destination                                 | Byte     | Cvc   |  |  |  |  |
|                                       | A,@Ri          | OR indirect RAM to                          | - • • •  | - 4 - |  |  |  |  |
|                                       |                | Accumulator                                 | 1        | 1     |  |  |  |  |
| ORL A                                 | A,#data        | OR immediate data to                        |          |       |  |  |  |  |
|                                       |                | Accumulator                                 | 2        | 1     |  |  |  |  |
| ORL c                                 | firect,A       | OR Accumulator to                           |          |       |  |  |  |  |
|                                       |                | direct byte                                 | 2        | 1     |  |  |  |  |
| ORL c                                 | lirect;#data   | OR immediate data to                        |          |       |  |  |  |  |
|                                       | ,              | direct byte                                 | 3        | 2     |  |  |  |  |
| XRL A                                 | A,Rn           | Exclusive-OR register to                    |          |       |  |  |  |  |
|                                       |                | Accumulator                                 | 1        | 1     |  |  |  |  |
| XRL A                                 | A, direct      | Exclusive-OR direct                         |          |       |  |  |  |  |
|                                       | ·              | byte to Accumulator                         | 2        | 1     |  |  |  |  |
| XRL A                                 | A,@Ri          | Exclusive-OR indirect                       |          |       |  |  |  |  |
|                                       |                | RAM to A                                    | 1        | 1     |  |  |  |  |
| XRL A                                 | A,#data        | Exclusive-OR                                | •        |       |  |  |  |  |
| VDI                                   |                | immediate data to A                         | 2        | 1     |  |  |  |  |
| XRL c                                 | firect,A       | Exclusive-OR Accumu-                        | <u> </u> |       |  |  |  |  |
|                                       |                | lator to direct byte                        | 2        | 1     |  |  |  |  |
| XRL c                                 | direct,#data   | Exclusive-OR im-                            | 0        | ~     |  |  |  |  |
| CLR A                                 |                | mediate data to direct<br>Clear Accumulator | 3<br>1   | 2     |  |  |  |  |
|                                       | À .            |                                             |          |       |  |  |  |  |
| UPL A                                 | • /            | Complement<br>Accumulator                   | 1        | 1     |  |  |  |  |
| RL A                                  | <b>`</b>       | Rotate Accumulator Left                     |          | 1     |  |  |  |  |
| RLC A                                 |                | Rotate A Left through                       | 1        | · · · |  |  |  |  |
|                                       | 7              | the Carry flag                              | 1        | 1     |  |  |  |  |
| RR A                                  | <b>`</b>       | Rotate Accumulator                          | '        | '     |  |  |  |  |
| , , , , , , , , , , , , , , , , , , , | <b>`</b>       | Right                                       | 1        | 1     |  |  |  |  |
| RRC A                                 | 2              | Rotate A Right through                      | •        | '     |  |  |  |  |
| /                                     | •              | Carry flag                                  | 1        | 1     |  |  |  |  |
| SWAP A                                | 4              | Swap nibbles within the                     |          | •     |  |  |  |  |
|                                       |                | Accumulator                                 | 1        | 1     |  |  |  |  |
|                                       |                |                                             |          |       |  |  |  |  |
| DATA TR                               | ANSFER         |                                             |          |       |  |  |  |  |
| Mnemoni                               | ic             | Description                                 | Byte     | Cyc   |  |  |  |  |
| MOV A                                 | A.Rn           | Move register to                            | •        |       |  |  |  |  |
|                                       |                | Accumulator                                 | 1        | 1     |  |  |  |  |
| MOV A                                 | A, direct      | Move direct byte to                         |          |       |  |  |  |  |
|                                       |                | Accumulator                                 | 2        | 1     |  |  |  |  |
| MOV A                                 | A,@Ri          | Move indirect RAM to                        |          |       |  |  |  |  |
|                                       |                | Accumulator                                 | 1        | 1     |  |  |  |  |
| MOV A                                 | A,#data        | Mov immediate data to                       |          |       |  |  |  |  |
|                                       |                | Accumulator                                 | 2        | 1 -   |  |  |  |  |
| MOV F                                 | Rn,A           | Move Accumulator to                         |          |       |  |  |  |  |
|                                       |                | register                                    | 1        | 1     |  |  |  |  |
| MOV F                                 | Rn,direct      | Move direct byte to                         |          |       |  |  |  |  |
|                                       |                | register                                    | 2        | 2     |  |  |  |  |
| MOV F                                 | Rn,#data       | Move immediate data to                      |          |       |  |  |  |  |
|                                       |                | register                                    | 2        | 1     |  |  |  |  |
| MOV d                                 | lirect,A       | Move Accumulator to                         | ~        | _     |  |  |  |  |
|                                       | Para A Da      | direct byte                                 | 2        | 1     |  |  |  |  |
| MOV d                                 | lirect,Rn      | Move register to direct                     | ~        | ~     |  |  |  |  |
| MOV                                   |                | byte                                        | 2        | 2     |  |  |  |  |
| MOV d                                 | direct, direct | Move direct byte to                         | 3        | 2     |  |  |  |  |
|                                       |                | direct                                      | 3        | ~     |  |  |  |  |
| MOV                                   | direct @Pi     | Move indirect PAM to                        |          |       |  |  |  |  |
| MOV d                                 | lirect,@Ri     | Move indirect RAM to<br>direct byte         | 2        | 2     |  |  |  |  |

| DATAT      | RANSFER (CO     |                               |           | <u> </u> |
|------------|-----------------|-------------------------------|-----------|----------|
|            |                 |                               |           |          |
| Mnemo      |                 | Description                   | Byte      | Cýc      |
| MOV        | direct,#data    | Move immediate data to        | •         |          |
|            | 0 <b>D</b> : 4  | direct byte                   | 3         | 2        |
| MOV        | @Ri,A           | Move Accumulator to           |           |          |
| MOV        | OD: direct      | indirect RAM                  | 1         | 1        |
| MOV        | @Ri,direct      | Move direct byte to           | ~         |          |
|            |                 | Indirect RAM                  | 2         | 2        |
| MOV        | @Ri,#data       | Move immediate data to        | ~         |          |
| 101        |                 | indirect RAM                  | 2         | 1        |
| MOV        | DPTR,#data16    | Load Data Pointer with        | ~         |          |
| MOVO       |                 | a 16-bit constant             | 3         | 2        |
| MOVC       | A,@A+DPTR       | Move Code byte relative       |           | _        |
|            | A @A (DO        | to DPTR to A                  | 1         | 2        |
| MOVC       | A,@A+PC         | Move Code byte relative       |           |          |
|            |                 | to PC to A                    | 1         | 2        |
| MOVX       | A,@HI           | Move External RAM (8-         |           |          |
| 1000       |                 | bit addr) to A                | 1         | 2        |
| MOAX       | A;@DPTR         | Move External RAM (16-        |           |          |
|            |                 | bit addr) to A                | 1         | 2        |
| MOVX       | @HI,A           | Move A to External RAM        |           |          |
|            |                 | (8-bit addr)                  | 1         | 2        |
| MOAX       | @DPTR,A         | Move A to External RAM        |           |          |
|            |                 | (16-bit addr)                 | 1         | 2        |
| PUSH       | direct          | Push direct byte onto         | _         |          |
|            |                 | stack                         | 2         | 2        |
| POP        | direct          | Pop direct byte from          |           |          |
|            |                 | stack                         | 2         | 2        |
| хсн        | A,Rn            | Exchange register with        |           |          |
|            |                 | Accumulator                   | 1         | 1        |
| хсн        | A,direct        | Exchange direct byte          |           |          |
|            |                 | with Accumulator              | 2         | 1        |
| хсн        | A,@Rı           | Exchange indirect RAM         |           |          |
|            |                 | with A                        | <u>`1</u> | 1        |
| XCHD       | A,@Rı           | Exchange low-order            |           |          |
|            |                 | Digit ind RAM w A             | 1         | 1        |
| BOOLE      |                 | MANIPULATION                  |           |          |
|            |                 |                               | <b>D</b>  | ~        |
| Mnemo      |                 | Description                   | Byte      |          |
| CLR        | C               | Clear Carry flag              | 1         | 1        |
| CLR        | bit             | Clear direct bit              | 2         | 1        |
| SETB       | C               | Set Carry flag                | 1         | 1        |
| SETB       | bit             | Set direct Bit                | 2         | 1        |
| CPL        | C               | Complement Carry flag         | 1         | 1        |
| CPL        | bit             | Complement direct bit         | 2         | 1        |
| ANL        | C,bit           | AND direct bit to Carry       |           |          |
|            |                 | flag                          | 2         | 2        |
| ANL        | C,/bit          | AND complement of             |           |          |
| ·          |                 | direct bit to Carry           | 2         | 2        |
| ORL        | C/bit           | OR direct bit to Carry        | ,         |          |
|            |                 | flag                          | 2         | 2        |
|            | C,/bit          | OR complement of              |           |          |
| ORL        |                 | direct bit to Carry           | 2         | 2        |
|            |                 |                               |           |          |
| ORL<br>MOV | C,/bit          | Move direct bit to Carry      |           | 1        |
| MOV        |                 | Move direct bit to Carry flag | 2         | 1.       |
|            | C,/bit<br>bit,C | Move direct bit to Carry      | _         | 1        |
| MOV        |                 | Move direct bit to Carry flag | 2<br>2    | 1<br>2   |

| Table | 1. | (Cont.) |  |
|-------|----|---------|--|
|       |    |         |  |

|               |                                                                         | HINE CONTROL                                                                             | _                         | _            |
|---------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------|---------------------------|--------------|
| Mnemo         |                                                                         | Description                                                                              | Byte                      | Cyc          |
| ACALL         | addr11                                                                  | Absolute Subroutine                                                                      | -                         |              |
|               | •                                                                       | Call                                                                                     | 2                         | 2            |
| LCALL         | addr16                                                                  | Long Subroutine Call                                                                     | 3                         | 2            |
| RET           |                                                                         | Return from subroutine                                                                   | 1                         | 2            |
| RETI          |                                                                         | Return from interrupt                                                                    | 1                         | 2            |
| AJMP          | addr11                                                                  | Absolute Jump                                                                            | 2                         | 2            |
| LJMP          | addr16                                                                  | Long Jump                                                                                | 3                         | 2            |
| SJMP          | rel                                                                     | Short Jump (relative                                                                     |                           |              |
|               |                                                                         | addr)                                                                                    | 2                         | 2            |
| JMP           | @A+DPTR                                                                 | Jump indirect relative to                                                                |                           |              |
|               | 0                                                                       | the DPTR                                                                                 | 1                         | 2            |
| JZ            | rel                                                                     | Jump if Accumulator is                                                                   |                           |              |
|               |                                                                         | Zero                                                                                     | 2                         | 2            |
| JNZ           | rel                                                                     | Jump if Accumulator is                                                                   | -                         | -            |
|               |                                                                         | Not Zero                                                                                 | 2                         | 2            |
| JC            | rel                                                                     | Jump if Carry flag is set                                                                | 2                         | 2            |
| JNC           | rel                                                                     | Jump if No Carry flag                                                                    | 2                         | 2            |
| JB            | bit,rel                                                                 | Jump if direct Bit set                                                                   | 2<br>3.                   | 2            |
| JNB           |                                                                         | Jump if direct Bit Not                                                                   | 3                         | 2            |
| JIND          | bit,rel                                                                 |                                                                                          | ~                         | ~            |
| 100           | la la val                                                               | set                                                                                      | 3                         | 2            |
| JBC           | bit,rel                                                                 | Jump if direct Bit is set                                                                | •                         | ~            |
| 0.00          | A                                                                       | & Clear bit                                                                              | 3                         | 2            |
| CJNE          | A, direct, rel                                                          | Compare direct to A &                                                                    |                           | -            |
|               |                                                                         | Jump if Not Equal                                                                        | 3                         | 2            |
| CJNE          | A,#data,rel                                                             | Comp, immed, to A &                                                                      |                           |              |
|               |                                                                         | Jump if Not Equal                                                                        | 3                         | 2            |
| CJNE          | Rn,#data,rel                                                            | Comp, immed, to reg &                                                                    |                           |              |
|               |                                                                         | Jump if Not Equal                                                                        | 3                         | 2            |
| CJNE          | @Ri,#data,rel                                                           | Comp, immed, to ind, &                                                                   |                           |              |
|               |                                                                         | Jump if Not Equal                                                                        | 3                         | 2            |
| DJNZ          | Rn,rel                                                                  | Decrement register &                                                                     |                           |              |
|               |                                                                         | Jump if Not Zero                                                                         | 2                         | 2            |
| DJNZ          | direct, rel                                                             | Decrement direct &                                                                       |                           |              |
|               |                                                                         | Jump if Not Zero                                                                         | 3                         | 2            |
| NOP           |                                                                         | No operation                                                                             | 1                         | 1            |
|               |                                                                         | No operation                                                                             | '                         | •            |
|               | n data addressi                                                         |                                                                                          |                           |              |
| Rn            | -Working reg                                                            | gister R0-R7                                                                             |                           |              |
| direct        |                                                                         | RAM locations, any I/O                                                                   | port,                     |              |
| @P:           |                                                                         | tatus register                                                                           |                           | by           |
| @Ri           | register R0                                                             | ernal RAM location addre                                                                 | 5560                      | IJУ          |
| #data         |                                                                         | ant included in instruction                                                              | n                         |              |
| #data16       |                                                                         | ant included as bytes 2 8                                                                |                           |              |
|               | instruction                                                             |                                                                                          |                           |              |
| bit           |                                                                         | e flags, any I/O pin, cont                                                               | rol or                    |              |
|               | status bit                                                              |                                                                                          |                           |              |
|               |                                                                         | ressing modes:                                                                           |                           |              |
| addr16        |                                                                         | address for LCALL & LJ                                                                   |                           | ay           |
|               |                                                                         | e within the 64-K program                                                                | m                         |              |
|               | memory ad                                                               | dress space                                                                              |                           |              |
|               |                                                                         | address for ACALL & AJ                                                                   |                           | III D        |
| Addr11        |                                                                         | ame 2-K page of program                                                                  |                           |              |
| Addr11        |                                                                         |                                                                                          | win a                     |              |
| Addr11        | memory as                                                               | the first byte of the follow                                                             | ving                      |              |
|               | memory as<br>instruction                                                | the first byte of the follow                                                             | -                         | n Զ-         |
| Addr11<br>rel | memory as<br>instruction<br>—SJMP and a                                 | the first byte of the follow<br>all conditional jumps incl                               | ude a                     |              |
|               | memory as<br>instruction<br>—SJMP and a<br>bit offset by                | the first byte of the follow<br>all conditional jumps incl<br>ite, Range is +127–128 byt | ude a<br>es rel           | ativ         |
| rel           | memory as<br>instruction<br>—SJMP and a<br>bit offset by<br>to first by | the first byte of the follow<br>all conditional jumps incl<br>ite, Range is +127–128 byt | ude a<br>es rel<br>nstrue | ativ<br>ctio |

Port 0 and Port 2 also have an alternate dedicated function. When placed in the external access mode, Port 0 and Port 2 become the means by which the 8044 communicates with external program memory. Port 0 and Port 2 are also the means by which the 8044 communicates with external data memory. Peripherals can be memory mapped into the address space and controlled by the 8044.

#### **Timer/Counters**

The 8044 contains two 16-bit counters which can be used for measuring time intervals, measuring pulse widths, counting events, generating precise periodic interrupt requests, and clocking the serial communications. Internally the Timers are clocked at 1/12 of the crystal frequency, which is the instruction cycle time. Externally the counters can run up to 500 KHz.

#### Interrupt System

External events and the real-time driven on-chip peripherals require service by the CPU asynchronous to the execution of any particular section of code. To tie the asynchronous activities of these functions to normal program execution, a sophisticated multiple-source, two priority level, nested interrupt system is provided. Interrupt response latency ranges from 3  $\mu$ sec to 7  $\mu$ sec when using a 12 MHz clock.

All five interrupt sources can be mapped into one of the two priority levels. Each interrupt source can be enabled or disabled individually or the entire interrupt system can be enabled or disabled. The five interrupt sources are: Serial Interface Unit, Timer 1, Timer 2, and two external interrupts. The external interrupts can be either level or edge triggered.

#### Serial Interface Unit (SIU)

The Serial Interface Unit is used for HDLC/SDLC communications. It handles Zero Bit Insertion/Deletion, Flags, automatic address recognition, and a 16-bit cyclic redundancy check. In addition it implements in hardware a subset of the SDLC protocol such that it responds to many SDLC frames without CPU intervention. In certain applications it is advantageous to have the CPU control the reception or transmission of every single frame. For this reason the SIU has two modes of operation: "AUTO" and "FLEXIBLE" (or "NON-AUTO"). It is in the AUTO mode that the SIU responds to SDLC frames without CPU intervention; whereas, in the FLEXIBLE mode the reception or transmission of every single frame will be under CPU control.

There are three control registers and eight parameter registers that are used to operate the serial interface. These registers are shown in Figure 5 and Figure 6. The control registers set the modes of operation and provide status information. The eight parameter registers buffer the station address, receive and transmit control bytes, and point to the on-chip transmit and receive buffers.

Data to be received or transmitted by the SIU must be buffered anywhere within the 192 bytes of onchip RAM. Transmit and receive buffers are not allowed to "wrap around" in RAM; a "buffer end" is generated after address 191 is reached.

#### AUTO Mode

In the AUTO mode the SIU implements in hardware a subset of the SDLC protocol such that it responds to many SDLC frames without CPU intervention. All AUTO mode responses to the primary station will conform to IBM's SDLC definition. The advantages of the AUTO mode are that less software is required to implement a secondary station, and the hardware generated response to polls is much faster than doing it in software. However, the Auto mode can not be used at a primary station.

To transmit in the AUTO mode the CPU must load the Transmit Information Buffer, Transmit Buffer Start register, Transmit Buffer Length register, and set the Transmit Buffer Full bit. The SIU automatically responds to a poll by transmitting an information frame with the P/F bit in the control field set. When the SIU receives a positive acknowledgement from the primary station, it automatically increments the Ns field in the NSNR register and interrupts the CPU. A negative acknowledgement would cause the SIU to retransmit the frame.

To receive in the AUTO mode, the CPU loads the Receive Buffer Start register, the Receive Buffer Length register, clears the Receive Buffer Protect bit, and sets the Receive Buffer Empty bit. If the SIU is polled in this state, and the TBF bit indicates that the Transmit Buffer is empty, an automatic RR response will be generated. When a valid information frame is received the SIU will automatically increment Nr in the NSNR register and interrupt the CPU.

While in the AUTO mode the SIU can recognize and respond to the following commands without CPU intervention: I (Information), RR (Receive Ready), RNR (Receive Not Ready), REJ (Reject), and UP (Unnumbered Poll). The SIU can generate intel

| in the second second second second second second second second second second second second second second second                           | SYMBOLIC                                            | , <b>*</b>                                                                                              | BYTE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | · •                                                                                                                                                                                                                                                                                                                                                   |
|-------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|---------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| REGISTER NAMES                                                                                                                            | ADDRESS                                             | BIT ADDRESS                                                                                             | ADDRESS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | · · ·                                                                                                                                                                                                                                                                                                                                                 |
| , · · · · · · · · · · · · · · · · · · ·                                                                                                   |                                                     | · · · · · · · · · · · · · · · · · · ·                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 4                                                                                                                                                                                                                                                                                                                                                     |
| B. BEOLOTER                                                                                                                               |                                                     | 247 through 240                                                                                         | 240 (F0H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| B REGISTER<br>ACCUMULATOR                                                                                                                 | BACC                                                | 231 through 224                                                                                         | 2240 (F0H)<br>224 (E0H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                       |
| *THREE BYTE FIFO                                                                                                                          | FIFO                                                | 231 unough 224                                                                                          | 223 (DFH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                           | FIFO                                                | · · · · ·                                                                                               | 222 (DEH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                           | FIFO                                                | · · · ·                                                                                                 | 221 (DDH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| TRANSMIT BUFFER START                                                                                                                     | TBS                                                 |                                                                                                         | 220 (DCH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ,                                                                                                                                                                                                                                                                                                                                                     |
| TRANSMIT BUFFER LENGTH                                                                                                                    | TBL                                                 |                                                                                                         | 219 (DBH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| TRANSMIT CONTROL BYTE                                                                                                                     | TCB ·                                               |                                                                                                         | 218 (DAH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| ' SIU STATE COUNTER                                                                                                                       | SIUST                                               |                                                                                                         | 217 (D9H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| SEND COUNT RECEIVE COUNT                                                                                                                  | NSNR                                                | 223 through 216                                                                                         | 216 (D8H)<br>208 (D0H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                       |
| PROGRAM STATUS WORD                                                                                                                       | PSW                                                 | 215 through 208                                                                                         | 207 (CFH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| *DMA COUNT                                                                                                                                | DMA CNT                                             |                                                                                                         | 206 (CEH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| STATION ADDRESS<br>RECEIVE FIELD LENGTH                                                                                                   | STAD                                                |                                                                                                         | 205 (CDH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| RECEIVE BUFFER START                                                                                                                      | RBS                                                 | ·                                                                                                       | 204 (CCH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| RECEIVE BUFFER LENGTH                                                                                                                     | RBL                                                 |                                                                                                         | 203 (CBH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | SFR'S CONTAINING                                                                                                                                                                                                                                                                                                                                      |
| RECEIVE CONTROL BYTE                                                                                                                      | RCB                                                 | -                                                                                                       | 202 (CAH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | DIRECT ADDRESSABLE BITS                                                                                                                                                                                                                                                                                                                               |
| SERIAL MODE                                                                                                                               | SMD                                                 | 1                                                                                                       | 201 (C9H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| STATUS REGISTER                                                                                                                           | STS                                                 | 207 through 200                                                                                         | 200 (C8H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| INTERRUPT PRIORITY CONTROL                                                                                                                | IP                                                  | 191 through 184                                                                                         | 184 (B8H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| PORT 3                                                                                                                                    | P3                                                  | 183 through 176                                                                                         | 176 (B0H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| INTERRUPT ENABLE CONTROL                                                                                                                  | IE                                                  | 175 through 168                                                                                         | 168 (A8H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| PORT 2                                                                                                                                    | P2                                                  | 167 through 160                                                                                         | 160 (A0H)<br>144 (90H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                       |
| PORT 1                                                                                                                                    | P1                                                  | 151 through 144                                                                                         | 144 (90H)<br>141 (8DH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                       |
| TIMER HIGH 1                                                                                                                              | TH1                                                 |                                                                                                         | 140 (8CH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| TIMER HIGH 0<br>TIMER LOW 1                                                                                                               | THO<br>TL1                                          |                                                                                                         | 139 (8BH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| TIMER LOW I                                                                                                                               | TLO                                                 |                                                                                                         | 138 (8AH)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| TIMER MODE                                                                                                                                | TMOD                                                |                                                                                                         | 137 (89H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| TIMER CONTROL                                                                                                                             | TCON                                                | 143 through 136                                                                                         | 136 (88H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| DATA POINTER HIGH                                                                                                                         | DPH                                                 |                                                                                                         | 131 (83H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| DATA POINTER LOW                                                                                                                          | DPL                                                 |                                                                                                         | 130 (82H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1                                                                                                                                                                                                                                                                                                                                                     |
| STACK POINTER                                                                                                                             | SP                                                  |                                                                                                         | 129 (81H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| PORT 0                                                                                                                                    | PO                                                  |                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                       |
| ,<br>,                                                                                                                                    | · · ·                                               | 135 through 128                                                                                         | 128 (80H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| *ICE Support Hardware registers. Ur<br>is no need for the CPU to access the                                                               | nder normal operat                                  |                                                                                                         | 128 (80H)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                       |
| *ICE Support Hardware registers. Ur                                                                                                       | nder normal operat<br>ese registers.                | ung conditions there                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                       |
| *ICE Support Hardware registers. Ur                                                                                                       | nder normal operat<br>ese registers.                |                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                       |
| •ICE Support Hardware registers. Ur<br>is no need for the CPU to access th                                                                | nder normal operat<br>ese registers.<br>Figure 5. N | ung conditions there                                                                                    | unction re                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                       |
| •ICE Support Hardware registers. Ur<br>is no need for the CPU to access th                                                                | nder normal operat<br>ese registers.<br>Figure 5. N | ung conditions there                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | egisters                                                                                                                                                                                                                                                                                                                                              |
| •ICE Support Hardware registers. Ur<br>is no need for the CPU to access th                                                                | nder normal operat<br>ese registers.<br>Figure 5. N | ung conditions there                                                                                    | unction re                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <b>Pgisters</b>                                                                                                                                                                                                                                                                                                                                       |
| •ICE Support Hardware registers. Ur<br>is no need for the CPU to access th                                                                | nder normal operat<br>ese registers.<br>Figure 5. N | ung conditions there                                                                                    | unction re                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | OFRAME CHECK SEQUENCE                                                                                                                                                                                                                                                                                                                                 |
| •ICE Support Hardware registers. Ur<br>is no need for the CPU to access th                                                                | nder normal operat<br>ese registers.<br>Figure 5. N | ung conditions there                                                                                    | INFCS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | PGISTERS<br>O FRAME CHECK SEQUENCE<br>ON-BUFFERED<br>ON-BUFFERED<br>RE-FRAME SYNC                                                                                                                                                                                                                                                                     |
| •ICE Support Hardware registers. Ur<br>is no need for the CPU to access th                                                                | nder normal operat<br>ese registers.<br>Figure 5. N | ung conditions there                                                                                    | Unction re                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | D FRAME CHECK SEQUENCE<br>ON-BUFFERED<br>RE-FRAME SYNC<br>DOP                                                                                                                                                                                                                                                                                         |
| •ICE Support Hardware registers. Ur<br>is no need for the CPU to access th                                                                | nder normal operat<br>ese registers.<br>Figure 5. N | ung conditions there                                                                                    | unction re                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <b>PGISTERS</b><br>O FRAME CHECK SEQUENCE<br>ON-BUFFERED<br>RE-FRAME EYNC<br>DOP<br>ON RETURN TO ZERO INVERTED                                                                                                                                                                                                                                        |
| •ICE Support Hardware registers. Ur<br>is no need for the CPU to access th                                                                | nder normal operat<br>ese registers.<br>Figure 5. N | ung conditions there                                                                                    | unction re                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | D FRAME CHECK SEQUENCE<br>ON-BUFFERED<br>RE-FRAME SYNC<br>DOP                                                                                                                                                                                                                                                                                         |
| •ICE Support Hardware registers. Ur<br>is no need for the CPU to access th                                                                | nder normal operat<br>ese registers.<br>Figure 5. N | ung conditions there                                                                                    | unction re                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <b>PGISTERS</b><br>O FRAME CHECK SEQUENCE<br>ON-BUFFERED<br>RE-FRAME EYNC<br>DOP<br>ON RETURN TO ZERO INVERTED                                                                                                                                                                                                                                        |
| *ICE Support Hardware registers. Ur<br>is no need for the CPU to access the<br>RIAL MODE REGISTER (SMD)                                   | Figure 5. N                                         | ung conditions there                                                                                    | unction re                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <b>PGISTERS</b><br>O FRAME CHECK SEQUENCE<br>ON-BUFFERED<br>RE-FRAME EYNC<br>DOP<br>ON RETURN TO ZERO INVERTED                                                                                                                                                                                                                                        |
| •ICE Support Hardware registers. Ur<br>is no need for the CPU to access th                                                                | Figure 5. N                                         | Ing conditions there                                                                                    | INFCS<br>NFCS<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Pgisters<br>O FRAME CHECK SEQUENCE<br>ON-BUFFERED<br>RE-FRAME SYNC<br>DOP<br>ON RETURN TO ZERO INVERTED<br>ELECT CLOCK MODE                                                                                                                                                                                                                           |
| *ICE Support Hardware registers. Ur<br>is no need for the CPU to access the<br>RIAL MODE REGISTER (SMD)                                   | Figure 5. N                                         | Ing conditions there                                                                                    | INFCS<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <b>Pgisters</b><br>O FRAME CHECK SEQUENCE<br>ON-BUFFERED<br>RE-FRAME SYNC<br>DOP<br>ON RETURN TO ZERO INVERTED<br>ELECT CLOCK MODE<br>ECEIVE BUFFER PROTECT                                                                                                                                                                                           |
| *ICE Support Hardware registers. Ur<br>is no need for the CPU to access the<br>RIAL MODE REGISTER (SMD)                                   | Figure 5. N                                         | Ing conditions there                                                                                    | INFCS<br>NFCS<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | D FRAME CHECK SEQUENCE<br>ON-BUFFERED<br>RE-FRAME SYNC<br>OOP<br>ON RETURN TO ZERO INVERTED<br>ELECT CLOCK MODE<br>ELECT CLOCK MODE                                                                                                                                                                                                                   |
| *ICE Support Hardware registers. Ur<br>is no need for the CPU to access the<br>RIAL MODE REGISTER (SMD)                                   | Figure 5. N                                         | Ing conditions there                                                                                    | INFCS<br>NFCS<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | PGISTERS<br>O FRAME CHECK SEQUENCE<br>ON-BUFFERED<br>RE-FRAME SYNC<br>DOP<br>ON RETURN TO ZERO INVERTED<br>ELECT CLOCK MODE<br>ECEIVE BUFFER PROTECT<br>UTO MODE/ADDRESSED MODE<br>PTIONAL POLL BIT                                                                                                                                                   |
| *ICE Support Hardware registers. Ur<br>is no need for the CPU to access the<br>RIAL MODE REGISTER (SMD)                                   | Figure 5. N                                         | Ing conditions there                                                                                    | INFCS N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | D FRAME CHECK SEQUENCE<br>ON-BUFFERED<br>RE-FRAME SYNC<br>DOP<br>ON RETURN TO ZERO INVERTED<br>ELECT CLOCK MODE<br>ECEIVE BUFFER PROTECT<br>UTO MODE/ADDRESSED MODE<br>PTIONAL POLL BIT<br>ECEIVE INFORMATION BUFFER OVERRU                                                                                                                           |
| *ICE Support Hardware registers. Ur<br>is no need for the CPU to access the<br>RIAL MODE REGISTER (SMD)                                   | Figure 5. N                                         | Ing conditions there                                                                                    | INFCS<br>NFCS<br>N<br>U<br>U<br>U<br>U<br>U<br>U<br>U<br>U<br>U<br>U<br>U<br>U<br>U<br>U<br>U<br>U<br>U<br>U                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | D FRAME CHECK SEQUENCE<br>ON-BUFFERED<br>RE-FRAME SYNC<br>DOP<br>ON RETURN TO ZERO INVERTED<br>ELECT CLOCK MODE<br>ECEIVE BUFFER PROTECT<br>UTO MODE/ADDRESSED MODE<br>PTIONAL POLL BIT<br>ECEIVE INFORMATION BUFFER OVERRU<br>ERIAL INTERFACE UNIT INTERRUPT                                                                                         |
| *ICE Support Hardware registers. Ur<br>is no need for the CPU to access the<br>RIAL MODE REGISTER (SMD)                                   | Figure 5. N                                         | Ing conditions there                                                                                    | INFCS<br>NFCS<br>NN<br>NN<br>NN<br>NN<br>NN<br>NN<br>NN<br>NN<br>NN<br>NN<br>NN<br>NN<br>NN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | PGISTERS<br>O FRAME CHECK SEQUENCE<br>ON-BUFFERED<br>RE-FRAME SYNC<br>DOP<br>ON RETURN TO ZERO INVERTED<br>ELECT CLOCK MODE<br>ECEIVE BUFFER PROTECT<br>UTO MODE/ADDRESSED MODE<br>PTIONAL POLL BIT<br>ECEIVE INFORMATION BUFFER OVERRU<br>ERIAL INTERFACE UNIT INTERRUPT<br>EQUEST TO SEND                                                           |
| *ICE Support Hardware registers. Ur<br>is no need for the CPU to access the<br>RIAL MODE REGISTER (SMD)                                   | Figure 5. N                                         | Ing conditions there                                                                                    | Infcs         N           NFCS         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N | PGISTERS                                                                                                                                                                                                                                                                                                                                              |
| *ICE Support Hardware registers. Ur<br>is no need for the CPU to access the<br>RIAL MODE REGISTER (SMD)                                   | Figure 5. N                                         | Ing conditions there                                                                                    | Infcs         N           NFCS         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N | PGISTERS<br>O FRAME CHECK SEQUENCE<br>ON-BUFFERED<br>RE-FRAME SYNC<br>DOP<br>ON RETURN TO ZERO INVERTED<br>ELECT CLOCK MODE<br>ECEIVE BUFFER PROTECT<br>UTO MODE/ADDRESSED MODE<br>PTIONAL POLL BIT<br>ECEIVE INFORMATION BUFFER OVERRU<br>ERIAL INTERFACE UNIT INTERRUPT<br>EQUEST TO SEND                                                           |
| •ICE Support Hardware registers. Ur<br>is no need for the CPU to access the<br>RIAL MODE REGISTER (SMD) SCM2<br>STATUS REGISTER (STS) TBF | Figure 5. N                                         | Ing conditions there                                                                                    | Infcs         N           NFCS         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N           N         N | PGISTERS                                                                                                                                                                                                                                                                                                                                              |
| *ICE Support Hardware registers. Ur<br>is no need for the CPU to access the<br>RIAL MODE REGISTER (SMD) SCM2<br>STATUS REGISTER (STS) TBF | Inder normal operatese registers.                   | Ing conditions there                                                                                    | INFCS<br>NFCS<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | PGISTERS<br>OFRAME CHECK SEQUENCE<br>ON-BUFFERED<br>RE-FRAME EYNC<br>DOP<br>ON RETURN TO ZERO INVERTED<br>ELECT CLOCK MODE<br>ELECT CLOCK MODE<br>ECEIVE BUFFER PROTECT<br>UTO MODE/ADDRESSED MODE<br>PTIONAL POLL BIT<br>ECEIVE INFORMATION BUFFER OVERRU<br>ERIAL INTERFACE UNIT INTERRUPT<br>EQUEST TO SEND<br>ECEIVE BUFFER EMPTY                 |
| *ICE Support Hardware registers. Ur<br>is no need for the CPU to access the<br>RIAL MODE REGISTER (SMD) SCM2<br>STATUS REGISTER (STS) TBF | Inder normal operatese registers.                   | Ing conditions there                                                                                    | INFCS<br>NFCS<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | PGISTERS                                                                                                                                                                                                                                                                                                                                              |
| *ICE Support Hardware registers. Ur<br>is no need for the CPU to access the<br>RIAL MODE REGISTER (SMD) SCM2<br>STATUS REGISTER (STS) TBF | Inder normal operatese registers.                   | Ing conditions there                                                                                    | INFCS         N           INFCS         N           INFCS         N           INFCS         N           INFCS         N           INFCS         N           INFCS         N           INFCS         N           INFCS         N           INFCS         N           INFCS         N           INFCS         N           INFCS         N           INFCS         N           INFCS         N           INFCS         N           INFCS         N           INFCS         N                                                                                                                                                                                                                                                                                                | D FRAME CHECK SEQUENCE<br>ON-BUFFERED<br>RE-FRAME SYNC<br>DOP<br>ON RETURN TO ZERO INVERTED<br>ELECT CLOCK MODE<br>ECEIVE BUFFER PROTECT<br>UTO MODE/ADDRESSED MODE<br>PTIONAL POLL BIT<br>ECEIVE INFORMATION BUFFER OVERRU<br>ENAL INTERFACE UNT INTERRUPT<br>EQUEST TO SEND<br>ECEIVE BUFFER EMPTY<br>RANSMIT BUFFER FULL<br>EQUENCE ERROR RECEIVED |
| *ICE Support Hardware registers. Ur<br>is no need for the CPU to access the<br>RIAL MODE REGISTER (SMD) SCM2<br>STATUS REGISTER (STS) TBF | Inder normal operatese registers.                   | Ing conditions there  Iapping of Special F NRZI LOOP PFS NB SI BOV OPB AM SI BOV OPB AM SES NR2 NR1 NR0 | INFCS<br>NI<br>NI<br>NI<br>NI<br>NI<br>NI<br>NI<br>NI<br>NI<br>NI<br>NI<br>NI<br>NI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | PGISTERS                                                                                                                                                                                                                                                                                                                                              |
| *ICE Support Hardware registers. Ur<br>is no need for the CPU to access the<br>RIAL MODE REGISTER (SMD) SCM2<br>STATUS REGISTER (STS) TBF | Inder normal operatese registers.                   | Ing conditions there                                                                                    | INFCS<br>NFCS<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N<br>N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | D FRAME CHECK SEQUENCE<br>ON-BUFFERED<br>RE-FRAME SYNC<br>DOP<br>ON RETURN TO ZERO INVERTED<br>ELECT CLOCK MODE<br>ECEIVE BUFFER PROTECT<br>UTO MODE/ADDRESSED MODE<br>PTIONAL POLL BIT<br>ECEIVE INFORMATION BUFFER OVERRU<br>ENAL INTERFACE UNT INTERRUPT<br>EQUEST TO SEND<br>ECEIVE BUFFER EMPTY<br>RANSMIT BUFFER FULL<br>EQUENCE ERROR RECEIVED |

### Figure 6. Serial Interface Unit Control registers

the following responses without CPU intervention: I (Information), RR (Receive Ready), and RNR (Receive Not Ready).

When the Receive Buffer Empty bit (RBE) indicates that the Receive Buffer is empty, the receiver is enabled, and when the RBE bit indicates that the Receive Buffer is full, the receiver is disabled. Assuming that the Receive Buffer is empty, the SIU will respond to a poll with an I frame if the Transmit Buffer is full. If the Transmit Buffer is empty, the SIU will respond to a poll with a RR command if the Receive Buffer Protect bit (RBP) is cleared, or an RNR command if RBP is set.

#### FLEXIBLE (or NON-AUTO) Mode

In the FLEXIBLE mode all communications are under control of the CPU. It is the CPU's task to encode and decode control fields, manage acknowledgements, and adhere to the requirements of the HDLC/SDLC protocols. The 8044 can be used as a primary or a secondary station in this mode.

To receive a frame in the FLEXIBLE mode, the CPU must load the Receive Buffer Start register, the Receive Buffer Length register, clear the Receive Buffer Protect bit, and set the Receive Buffer Empty bit. If a valid opening flag is received and the address field matches the byte in the Station Address register or the address field contains a broadcast address, the 8044 loads the control field in the receive control byte register, and loads the I field in the receive buffer. If there is no CRC error, the SIU interrupts the CPU, indicating a frame has just been received. If there is a CRC error, no interrupt occurs. The Receive Field Length register provides the number of bytes that were received in the information field.

To transmit a frame, the CPU must load the transmit information buffer, the Transmit Buffer Start register, the Transmit Buffer Length register, the Transmit Control Byte, and set the TBF and the RFS bit. The SIU, unsolicited by an HDLC/SDLC frame, will transmit the entire information frame, and interrupt the CPU, indicating the completion of transmission. For supervisory frames or unnumbered frames, the transmit buffer length would be 0.

#### CRC

The FCS register is initially set to all 1's prior to calculating the FCS field. The SIU will not interrupt the CPU if a CRC error occurs (in both AUTO and FLEXIBLE modes). The CRC error is cleared upon receiving of an opening flag.

#### **Frame Format Options**

In addition to the standard SDLC frame format, the 8044 will support the frames displayed in Figure 7. The standard SDLC frame is shown at the top of this figure. For the remaining frames the information field will incorporate the control or address bytes and the frame check sequences; therefore these fields will be stored in the Transmit and Receive buffers. For example, in the non-buffered mode the third byte is treated as the beginning of the information field. In the nonaddressed mode, the information field begins after the opening flag. The mode bits to set the frame format options are found in the Serial Mode register and the Status register.

#### EXTENDED ADDRESSING

To realize an extended control field or an extended address field using the HDLC protocol, the FLEXI-BLE mode must be used. For an extended control field, the SIU is programmed to be in the non-buffered mode. The extended control field will be the first and second bytes in the Receive and Transmit Buffers. For extended addressing the SIU is placed in the nonaddressed mode. In this mode the CPU must implement the address recognition for received frames. The addressing field will be the initial bytes in the Transmit and Receive buffers followed by the control field.

The SIU can transmit and receive only frames which are multiples of 8 bits. For frames received with other than 8-bit multiples, a CRC error will cause the SIU to reject the frame.

#### SDLC Loop Networks

The SIU can be used in a ADLC loop as a secondary or primary station. When the SIU is placed in the Loop mode it receives the data on pin 10 and transmits the data one bit time delayed on pin 11. It can also recognize the Go ahead signal and change it into a flag when it is ready to transmit. As a secondary station the SIU can be used in the AUTO or FLEXIBLE modes. As a primary station the FLEXIBLE mode is used; however, additional hardware is required for generating the Go Ahead bit pattern. In the Loop mode the maximum data rate is 1 Mbps clocked or 375 Kbps self-clocked.

#### SDLC Multidrop Networks

The SIU can be used in a SDLC non-loop configuration as a secondary or primary station. When the SIU is placed in the non-loop mode, data is received and transmitted on pin 11, and pin 10 drives a tri-state buffer. In non-loop mode, modem interface pins, RTS and CTS, become available.

#### ADVANCE INFORMATION

| RAME OPTION                                                                            | NFCS             | NB.          | AM                    | FRAME FORMAT                                                                                                                                                                                                                        | · · · ·                                  |
|----------------------------------------------------------------------------------------|------------------|--------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|
| itenderd SDLC<br>ION-AUTO Mode                                                         | 0                | Ó            | 0                     | FIAC I FCS F                                                                                                                                                                                                                        |                                          |
| itendard SDLC                                                                          | 0                | 0            | <b>1</b>              | F A C F                                                                                                                                                                                                                             | ه<br>کودن<br>به می ه                     |
| Ion-Buffered Mode                                                                      | 0                | 1            | <b>1</b>              | F A I FCS F                                                                                                                                                                                                                         | че.<br>К.                                |
| Ion-Addressed Mode                                                                     | ò                | <b>]</b> 1,  | <b>0</b>              | F I FCS F                                                                                                                                                                                                                           | · · · ·                                  |
| IO FCS Field<br>ION-AUTO Mode                                                          | 1,               | <u>,</u> 0 , | · 0                   | F A C E F                                                                                                                                                                                                                           |                                          |
| IO FCS Field<br>NUTO Mode                                                              | 1                | o            | 1                     | F A C I F                                                                                                                                                                                                                           | , .                                      |
| lo FCS Field<br>Ion-Buffered Mode<br>ION-AUTO Mode                                     | 1                | 1            | 1                     |                                                                                                                                                                                                                                     | 1 (1, 1)<br>1 (1, 1)                     |
| lo FCS Field<br>Ion-Addressed Mode<br>ION-AUTO Mode                                    | 1                | 1,           | 0                     | F. I F                                                                                                                                                                                                                              | a ta ta ta                               |
| fode Bits:<br>AM — "AUTO" Mode<br>NB — Non-Buffered<br>NFCS — No FCS Field             | Mode             | d Mode       |                       | n an an 16 an 26 an 26 an 27 an 28 an 28 an 28 an 28 an 28 an 28 an 28 an 28 an 28 an 28 an 28 an 28 an 28 an 2<br>An 28 an 2 | د ر <sup>سر</sup> فر<br>به در فرج        |
| Key to Abbreviations:<br>F = Flag (01111110)<br>A = Address Field<br>C = Control Field | a<br>Alfred a ca |              | informati<br>Frame Cl | on Field<br>seck Sequence                                                                                                                                                                                                           | an an an an an an an an an an an an an a |

Figure 7. Frame Format Options

#### **Data Clocking Options**

The 8044's serial port can operate in an externally clocked or self clocked system. A clocked system provides to the 8044 a clock synchronization to the data. A self-clocked system uses the 8044's on-chip Digital Phase Locked Loop (DPLL) to recover the clock from the data, and clock this data into the Serial Receive Shift Register.

In this mode, a clock synchronized with the data is externally fed into the 8044. This clock may be generated from an External Phase Locked Loop, or possibly supplied along with the data. The 8044 can transmit and receive data in this mode at rates up to 2.4 Mbps.

This self clocked mode allows data transfer without a common system data clock. An on-chip Digital Phase Locked Loop is employed to recover the data clock which is encoded in the data stream. The DPLL will converge to the nominal bit center within eight bit transitions, worst case. The DPLL requires a reference clock of either 16 times (16x) or 32 times (32x) the data rate. This reference clock may be externally applied or internally generated. When internally generated either the 8044's internal logic clock (crystal frequency divided by two) or the timer 1 overflow is used as the reference clock. Using the internal timer 1 clock the data reates can vary from 244 to 62.5 Kbps. Using the internal logic clock at a 16x sampling rate, receive data can either be 187.5 Kbps, or 375 Kbps. When the reference clock for the DPLL is externally applied the data rates can vary from 0 to 375 Kbps at a 16x sampling rate.

To aid in a Phase Locked Loop capture, the SIU has a NRZI (Non Return to Zero Inverted) data encoding and decoding option. Additionally the SIU has a preframe sync option that transmits two bytes of alternating 1's and 0's to ensure that the receive station DPLL will be synchronized with the data by the time it receives the opening flag.

#### **Control and Status Registers**

There are three SIU Control and Status Registers:

Serial Mode Register (SMD)

Status/Command Register (STS)

Send/Receive Count Register (NSNR)

The SMD, STS, and NSNR registers are all cleared by system reset. This assures that the SIU will power up in an idle state (neither receiving nor transmitting).

These registers and their bit assignments are described below.

#### SMD: Serial Mode Register (byte-addressable)

| Bit: 7 | 6    | 5    | 4    | 3    | 2   | 1  | 0    |  |
|--------|------|------|------|------|-----|----|------|--|
| SCM2   | SCM1 | SCM0 | NRZI | LOOP | PFS | NB | NFCS |  |

The Serial Mode Register (Address C9H) selects the operational modes of the SIU. The 8044 CPU can both read and write SMD. The SIU can read SMD but cannot write to it. To prevent conflict between CPU and SIU access to SMD, the CPU should write SMD only when the Request To Send (RTS) and Receive Buffer Empty (RBE) bits (in the STS register) are both false (0). Normally, SMD is accessed only during initialization.

The individual bits of the Serial Mode Register are as follows:

| Bit # | Name | Description                                                                                                                                                                                                                                                      |
|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SMD.0 | NFCS | No FCS field in the SDLC frame.                                                                                                                                                                                                                                  |
| SMD.1 | NB   | Non-Buffered mode. No control field in the SDLC frame.                                                                                                                                                                                                           |
| SMD.2 | PFS  | Pre-Frame Sync mode. In this<br>mode, the 8044 transmits two bytes<br>before the first flag of a frame, for<br>DPLL synchronization. If NRZI is<br>enabled, 00H is sent; otherwise,<br>55H is sent. In either case, 16 pre-<br>frame transitions are guaranteed. |
| SMD.3 | LOOP | Loop configuration.                                                                                                                                                                                                                                              |
| SMD.4 | NRZI | NRZI coding option.                                                                                                                                                                                                                                              |
| SMD.5 | SCM0 | Select Clock Mode — Bit 0                                                                                                                                                                                                                                        |
| SMD.6 | SCM1 | Select Clock Mode — Bit 1                                                                                                                                                                                                                                        |
| SMD.7 | SCM2 | Select Clock Mode — Bit 2                                                                                                                                                                                                                                        |
|       |      |                                                                                                                                                                                                                                                                  |

The SCM bits decode as follows:

| SCM          | ,                            | Data Rate   |       |   |
|--------------|------------------------------|-------------|-------|---|
| <u>2 1 0</u> | Clock Mode                   | (Bits/sec)* |       |   |
| 0 0 0        | Externally clocked           | 0-2.4M**    | STS.5 | R |
| 0 0 1        | Reserved                     |             |       |   |
| 0 1 0        | Self clocked, timer overflow | 244-62.5K   |       |   |
| 0 1 1        | Reserved                     |             |       |   |
| 100          | Self clocked, external 16x   | 0-375K      | 4     |   |

| SCM |   | 1 |                              | Data Rate   |
|-----|---|---|------------------------------|-------------|
| 2   | 1 | 0 | Clock Mode                   | (Bits/sec)* |
| 1   | 0 | 1 | Self clocked, external 32x   | 0-187.5K    |
| 1   | 1 | 0 | Self clocked, internal fixed | 375K        |
| 1   | 1 | 1 | Self clocked, internal fixed | 187.5k      |

\*Based on a 12 Mhz crystal frequency

\*\*0-1M bps in loop configuration

STS: Status/Command Register (bit-addressable)

| Bit: | 7   | 6   | 5   | 4  | 3   | 2   | 1  | 0   |
|------|-----|-----|-----|----|-----|-----|----|-----|
|      | TBF | RBE | RTS | SI | BOV | OPB | AM | RBP |

The Status/Command Register (Address C8H) provides operational control of the SIU by the 8044 CPU, and enables the SIU to post status information for the CPU's access. The SIU can read STS, and can alter certain bits, as indicated below. The CPU can both read and write STS asynchronously. However, 2-cycle instructions that access STS during both cycles ('JBC/B, REL' and 'MOV /B,C.') should not be used; since the SIU may write to STS between the two CPU accesses.

The individual bits of the Status/Command Register are as follows:

| Bit # | Name | Description                                                                                                                                                                                                         |
|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| STS.0 | RBP  | Receive Buffer Protect. Inhibits<br>writing of data into the receive buff-<br>er. In AUTO mode, RBP forces an<br>RNR response instead of an RR.                                                                     |
| STS.1 | АМ   | AUTO Mode/Addressed Mode. Se-<br>lects AUTO mode where AUTO<br>mode is allowed. If NB is true,<br>(=1), the AM bit selects the ad-<br>dressed mode. AM may be cleared<br>by the SIU.                                |
| STS.2 | OPB  | Optional Poll Bit. Determines<br>whether the SIU will generate an<br>AUTO response to an optional poll<br>(UP with $P=0$ ). OPB may be set or<br>cleared by the SIU.                                                |
| STS.3 | BOV  | Receive Buffer Overrun. BOV may be set or cleared by the SIU.                                                                                                                                                       |
| STS.4 | SI   | SIU Interrupt. This is one of the five interrupt sources to the CPU. The vector location $= 23H$ . SI may be set by the SIU. It should be cleared by the CPU before returning from an interrupt routine.            |
| STS.5 | RTS  | Request To Send. Indicates that the<br>8044 is ready to transmit or is trans-<br>mitting. RTS may be read or writ-<br>ten by the CPU. RTS may be read<br>by the SIU, and in AUTO mode<br>may be written by the SIU. |

- STS.6 RBE Receive Buffer Empty. RBE can be thought of as Receive Enable. RBE is set to one by the CPU when it is ready to receive a frame, or has just read the buffer, and to zero by the SIU when a frame has been received.
- STS.7 TBF Transmit Buffer Full. Written by the CPU to indicate that it has filled the transmit buffer. TBF may be cleared by the SIU.

#### NSNR: Send/Receive Count Register (bitaddressable)

| Bit: | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |
|------|-----|-----|-----|-----|-----|-----|-----|-----|--|
|      | NS2 | NS1 | NS0 | SES | NR2 | NR1 | NR0 | SER |  |

The Send/Receive Count Register (Address D8H) contains the transmit and receive sequence numbers, plus tally error indications. The SIU can both read and write NSNR. The 8044 CPU can both read and write NSNR asynchronously. However, 2-cycle instructions that access NSNR during both cycles (JBC /B, REL', and 'MOV /B,C') should not be used, since the SIU may write to NSNR between the two 8044 CPU accesses.

The individual bits of the Send/Receive Count Register are as follows:

| Bit #  | Name | Description                                                                  |
|--------|------|------------------------------------------------------------------------------|
| NSNR.0 | SER  | Receive Sequence Error:<br>NS (P) $\neq$ NR (S)                              |
| NSNR.1 | NR0  | Receive Sequence Counter—Bit 0                                               |
| NSNR.2 | NR1  | Receive Sequence Counter-Bit 1                                               |
| NSNR.3 | NR2  | Receive Sequence Counter-Bit 2                                               |
| NSNR.4 | SES  | Send Sequence Error:<br>NR (P) $\neq$ NS (S) and<br>NR (P) $\neq$ NS (S) + 1 |
| NSNR.5 | NS0  | Send Sequence Counter — Bit 0                                                |
| NSNR.6 | NS1  | Send Sequence Counter — Bit 1                                                |
| NSNR.7 | NS2  | Send Sequence Counter — Bit 2                                                |

#### **Parameter Registers**

There are eight parameter registers that are used in connection with SIU operation. All eight registers may be read or written by the 8044 CPU. RFL and RCB are normally loaded by the SIU.

The eight parameter registers are as follows:

### STAD: Station Address Register (byte-addressable)

The Station Address register (Address CEH) contains the station address. To prevent access conflict, the CPU should access STAD only when the SIU is idle (RTS=0 and RBE=0). Normally, STAD is accessed only during initialization.

### TBS: Transmit Buffer Start Address Register (byte-addressable)

The Transmit Buffer Start address register (Address DCH) points to the location in on-chip RAM for the beginning of the I-field of the frame to be transmitted. The CPU should access TBS only when the SIU is not transmitting a frame (when TBF=0).

# TBL: Transmit Buffer Length Register (byte-addressable)

The Transmit Buffer Length register (Address DBH) contains the length (in bytes) of the I-field to be transmitted. A blank I-field (TBL=0) is valid. The CPU should access TBL only when the SIU is not transmitting a frame (when TBF=0).

NOTE: The transmit and recieve buffers are not allowed to "wrap around" in the on-chip RAM. A "buffer end" is automatically generated if address 191 (BFH) is reached.

# TCB: Transmit Control Byte Register (byte-addressable)

The Transmit Control Byte register (Address DAH) contains the byte which is to be placed in the control field of the transmitted frame, during NON-AUTO mode transmission. The CPU should access TCB only when the SIU is not transmitting a frame (when TBF=0). The N<sub>S</sub> and N<sub>R</sub> counters are not used in the NON-AUTO mode.

# RBS: Receive Buffer Start Address Register (byte-addressable)

The Receive Buffer Start address register (Address CCH) points to the location in on-chip RAM where the beginning of the I-field of the frame being received is to be stored. The CPU should write RBS only when the SIU is not receiving a frame (when RBE=0).

# RBL: Receive Buffer Length Register (byte-addressable)

The Receive Buffer Length register (Address CBH) contains the length (in bytes) of the area in on-chip

RAM allocated for the received I-field. RBL=0 is valid. The CPU should write RBL only when RBE=0.

### RFL: Receive Field Length Register (byte-addressable)

The Received Field Length register (Address CDH) contains the length (in bytes) of the received I -field that has just been loaded into on-chip RAM. RFL is loaded by the SIU. RFL=0 is valid. RFL should be accessed by the CPU only when RBE=0.

# RCB: Receive Control Byte Register (byte-addressable)

The Received Control Byte register (Address CAH) contains the control field of the frame that has just been received. RCB is loaded by the SIU. The CPU can only read RCB, and should only access RCB when RBE=0.

#### **ICE Support Registers**

The 8044 In-Circuit Emulator (ICE-44) allows the user to exercise the 8044 application system and monitor the execution of instructions in real time.

The emulator operates with Intel's Intellec<sup>®</sup> development system. The development system interfaces with the user's 8044 system through an in-cable buffer box. The cable terminates in a 8044 pin-compatible plug, which fits into the 8044 socket in the user's system. With the emulator plug in place, the user can excercise his system in real time while collecting up to 255 instruction cycles of real-time data. In addition, he can single-step the program.

Static RAM is available (in the in-cable buffer box) to emulate the 8044 internal and external program memory and external data memory. The designer can display and alter the contents of the replacement memory in the buffer box, the internal data memory, and the internal 8044 registers, including the SFRs.

#### SIUST: SIU State Counter (byte-addressable)

The SIU State Counter (Address D9H) reflects the state of the internal logic which is under SIU control. Therefore, care must be taken not to write into this register. This register provides a useful means for debugging 8044 receiver problem.

#### **ABSOLUTE MAXIMUM RATINGS\***

| Ambient Temperature Under Bias       |
|--------------------------------------|
| Storage Temperature 65°C to + 150°C  |
| Voltage on Any Pin With              |
| Respect to Ground (Vss) 0.5V to + 7V |
| Power Dissipation 2 Watts            |

\*Notice: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

### **DC CHARACTERISTICS** (TA = 0 °C to 70 °C, VCC = $5V \pm 10\%$ , VSS = 0V)

| Symbol           | Parameter                                                 | Min   | Тур | Max       | Units    | Test Conditions             |
|------------------|-----------------------------------------------------------|-------|-----|-----------|----------|-----------------------------|
| VIL              | Input Low Voltage                                         | - 0.5 |     | 0.8       | v        |                             |
| VIH              | Input High Voltage<br>(Except RST/VPD and XTAL2)          | 2 0   |     | VCC + 0 5 | <b>V</b> |                             |
| VIH1             | Input High Voltage To<br>RST/VPD For Reset, XTAL2         | 2 5   |     |           | V        | XTAL1 to VSS                |
| VOL              | Output Low Voltage<br>Ports 1, 2, 3 (Note 1)              |       |     | 0.45      | V.       | IOL = 1 6mA                 |
| VOL1             | Output Low V <u>oltag</u> e<br>Port 0 ALE, ∖PSEN (Note 1) |       |     | 0 45      | v        | IOL = 3.2mA                 |
| VOH              | Outpt High Voltage<br>Ports 1, 2, 3                       | 24    |     |           | v        | IOH = −80µA                 |
| VOH1             | Output High Voltage<br>Port 0, ALE, \PSEN                 | 2.4   |     | <i>i</i>  | V        | 10H = - 400µA               |
| IIL <sup>'</sup> | Logical 0 Input Current<br>Ports 1, 2, 3                  |       |     | - 800     | μΑ       | XTAL1 at VSS<br>VIL = 0.45V |
| IIH1<br>,        | Input High Current.T0<br>RST/VPD For Reset                |       |     | 500       | μΑ       | Vin = VCC - 1.5V            |
| ILI ,            | Input Leakage Current<br>To Port 0, ∖EA                   |       |     | 10        | μΑ       | 0.45V < Vin < VCC           |
| ICC              | Power Supply Current                                      |       | 125 | 200       | mA       | TA = 25 °C                  |
| CIO              | Capacitance of I/O Buffer                                 |       | T.  | 10        | pF       | fc = 1MHz                   |
| IIL2             | Logical 0 Input Current<br>XTAL 2                         |       |     | -3.5      | mA       | XTAL1 = VSS<br>VIL = 0.45V  |

Note 1: VOL is degraded when the RUPI-44 rapidly discharges external capacitance. This A.C. noise is most pronounced during emission of address data. When using external memory, locate the latch or buffer as close to the RUPI-44 as possible.

| Datum      | Emitting<br>Ports | Degraded<br>I/O Lines | VOL<br>(peak)<br>(max) | Ň |
|------------|-------------------|-----------------------|------------------------|---|
| Address    | P2, P0            | P1, P3                | .8V                    |   |
| Write Data | P0                | P1, P3, ALE           | .8V                    |   |

#### A.C. CHARACTERISTICS (TA 0 °C to 70 °C, VCC = 5V ± 10% VSS = OV, CL for Port 0, ALE and PSEN Outputs = 100pF; CL for All Other Outputs = d0 pF)

#### **Program Memory**

|                          | 12 MHz Clock                 |     |     | Variable Clock<br>1/TCLCL = 1.2 MHz to 12 MHz |           |            |       |
|--------------------------|------------------------------|-----|-----|-----------------------------------------------|-----------|------------|-------|
| Symbol                   | Parameter                    | Min | Max | Units                                         | Min       | Max        | Units |
| TLHLL                    | ALE Pulse Width              | 127 |     | ns                                            | 2TCLCL-40 |            | ns    |
| TAVLL                    | Address Setup to ALE         | 43  |     | ns                                            | TCLCL-40  |            | ns    |
| TLLAX'                   | Address Hold After ALE       | 48  |     | ns                                            | TCLCL-35  |            | ns    |
| TLLIV                    | ALE To Valid Instr In        |     | 233 | ns                                            | ι.        | 4TCLCL-100 | ns    |
| TLLPL                    | ALE TO PSEN                  | 58  |     | ns                                            | TCLCL-25  | ·          | ns    |
| TPLPH                    | PSEN Pulse Width             | 215 |     | ns                                            | 3TCLCL-35 |            | ns    |
| TPLIV                    | PSEN To Valid Instr In       |     | 125 | ns                                            |           | 3TCLCL-125 | ns    |
| TPXIX                    | Input Instr Hold After PSEN  | 0   |     | ns                                            | 0         |            | ns    |
| <b>TPXIZ<sup>2</sup></b> | Input Instr Float After PSEN |     | 63  | ns                                            |           | TCLCL-20   | ns .  |
| TPXAV <sup>2</sup>       | Address Valid After PSEN     | 75  | 1   | ns                                            | TCLCL-8   |            | ns    |
| TAVIV                    | Address To Valid Instr In    |     | 302 | ns                                            |           | 5TCLCL-115 | ns    |
| TAZPL                    | Address Float To PSEN        | -25 |     | ns                                            | -25       | · · ·      | ns    |

#### Notes:

1. TLLAX for access to program memory is different from TLLAX for data memory.

 Interfacing RUPI-44 devices with float times up to 75ns is permissible. This limited bus contention will not cause any damage to Port 0 drivers.

#### External Data Memory

|        |                             | 12 MHz Clock |     |       | Variable Clock<br>1/TCLCL = 1.2 MHz to 12 MHz |             |       |
|--------|-----------------------------|--------------|-----|-------|-----------------------------------------------|-------------|-------|
| Symbol | Parameter                   | Min          | Max | Units | Min                                           | Max         | Units |
| TRLRH  | RD Pulse Width              | 400          |     | rs    | 6TCLCL-100                                    |             | ns    |
| TWLWH  | WR Pulse Width              | 400          |     | ns    | 6TCLCL-100                                    |             | ns    |
| TLLAX' | Address Hold After ALE      | 48           |     | ns    | TCLCL-35                                      |             |       |
| TRLDV  | RD To Valid Data In         |              | 250 | ns    |                                               | 5TCLCL-165  | ns    |
| TRHDX  | Data Hold After RD          | 0            |     | ns    | 0                                             |             | ns    |
| TRHDZ  | Data Float After RD         |              | 97  | ns    |                                               | 2TCLCL-70   | ns    |
| TLLDV  | ALE To Valid Data In        |              | 517 | ns    |                                               | 8TCLCL-150  | ns    |
| TAVDV  | Address To Valid Data In    |              | 585 | ns    | 1                                             | 9TCLCL-165  | . ns  |
| TLLWL  | ALE To WR or RD             | 200          | 300 | ns    | 3TCLCL-50                                     | 3TCLCL + 50 | ns    |
| TAVWL  | Address To WR or RD         | 203          |     | ns    | 4TCLCL-130                                    |             | ns    |
| TWHLH  | WR or RD High To ALE High   | 43           | 123 | ns    | TCLCL-40                                      | TCLCL + 40  | ns    |
| TDVWX  | Data Valid To WR Transition | 33           |     | ns    | TCLCL-50                                      |             | ns    |
| TQVWH  | Data Setup Before WR        | 433          | -   | ns    | 7TCLCL-150                                    | 1           | ns    |
| TWHQX  | Data Hold After WR          | 33           |     | ns    | TCLCL-50                                      |             | ns    |
| TRLAZ  | Address Float After RD      |              | 0   | ns    |                                               | 0           | ns    |

Note 1. TLLAX for access to program memory is different from TLLAX for access data memory

#### Serial Interface

| Symbol | Parameter       | Min | Max | Units | . * |
|--------|-----------------|-----|-----|-------|-----|
| TDCY   | Data Clock      | 420 |     | ns    |     |
| TDCL   | Data Clock Low  | 180 |     | ns    |     |
| тосн   | Data Clock High | 100 |     | ns    |     |

#### ADVANCE INFORMATION



|      | · · · · · · · · · · · · · · · · · · · |    |     |    |                                       |
|------|---------------------------------------|----|-----|----|---------------------------------------|
| tTD  | Transmit Data Delay                   |    | 180 | ns |                                       |
| tDSS | Data Setup Time                       | 40 |     | ns | · · · · · · · · · · · · · · · · · · · |
| tDHS | Data Hold Time                        | 40 |     | ns |                                       |
|      |                                       |    | ,   |    |                                       |

#### WAVEFORMS

#### Memory Access





,

#### SERIAL I/O WAVEFORMS



#### AC TESTING INPUT, OUTPUT, FLOAT WAVEFORMS

and a second second second second second second second second second second second second second second second





AC testing inputs are driven at 2 4V for a logic "1" and 0 45V for a logic "0 " Timing measurements are made at 2 0V for a logic "1" and 0 8V for a logic "0 "

#### EXTERNAL CLOCK DRIVE XTAL2



|        |                   | Variable Clock<br>Freq = 1.2 MHz to 12 MHz |             |      |
|--------|-------------------|--------------------------------------------|-------------|------|
| Symbol | Parameter         | Min                                        | Max         | Unit |
| TCLCL  | Oscillator Period | 83.3                                       | 287.5       | ns   |
| TCHCX  | High Time         | 20                                         | TCLCL-TCLCX | ns   |
| TCLCX  | Low Time          | 20                                         | TCLCL-TCHCX | ns   |
| TCLCH  | Rise Time         |                                            | 20          | ns   |
| TCHCL  | Fall Time         |                                            | 20          | ns   |

# intel

**CLOCK WAVEFORMS** STATE 6 STATE 1 STATE 2 STATE 3 STATE 4 STATE 5 STATE 4 STATE 5 INTERNAL CLOCK P1 | P2 | P1 P2 P1 P2 P1 P2 P1 P2 P1 P2 P1 P1 | P2 P2 XTAL 2 ALE THESE SIGNALS ARE NOT ACTIVATED DURING THE EXTERNAL PROGRAM MEMORY FETCH EXECUTION OF A MOVX INSTRUCTION PSEN PCL OUT PCL OUT PCL OUT PO DATA DATA DATA SAMPLED SAMPLED SAMPLED FLOAT-FLOAT FLOAT INDICATES ADDRESS TRANSIONS P2(EXT) READ CYCLE RD 00H IS EMITTED PCL OUT (IF PROGRAM MEMORY IS EXTERNAL) DURING THIS PERIOD DPL OR RI DATA PO FLOAT OUT P2 INDICATES DPH OR P2 SFR TO PCH TRANSITIONS WRITE CYCLE WR PCL OUT(EVEN IF PROGRAM MEMORY IS INTERNAL) DPL OR BI P0 OUT DATA OUT PCL OUT (IF PROGRAM MEMORY IS EXTERNAL) **P**2 INDICATES DPH OR P2 SFR TO PCH TRANSITIONS PORT OPERATION OLD DATA NEW DATA MOV PORT, SRC P0 PINS SAMPLED MOV DEST. PO PO PINS SAMPLED MOV DEST, PORT (P1, P2, P3) (INCLUDES INTO, INT1, TO, T1) P1, P2, P3 P1, P2, P3 PINS SAMPLED PINS SAMPLED SERIAL PORT SHIFT CLOCK TXD (MODE 0) RXD SAMPLED RXD SAMPLED

This diagram indicates when signals are clocked internally. The time it takes the signals to propagate to the pins, however, ranges from 25 to 125 ns. This propagation delay is dependent on variables such as temperature and pin loading. Propagation also varies from output to output and component to component. Typically though,  $(T_A = 25^\circ C, fully loaded)$  RD and WR propagation delays are approximately 50 ns. The other signals are typically 85 ns. Propagation delays are incorporated in the AC specifications.

#### 20-19

# intel

### 8744H HIGH PERFORMANCE 8-BIT MICROCONTROLLER WITH On-CHIP SERIAL COMMUNICATION CONTROLLER

#### 8051 MICROCONTROLLER CORE

- Optimized for Real Time Control
   12 MHz Clock, Priority Interrupts,
   32 Programmable I/O lines,
   Two 16-bit Timer/Counters
- Boolean Processor
- **4K x 8 EPROM, 192 x 8 RAM**
- 64K Accessible External Program Memory
- 64K Accessible External Data Memory
- 4 µs Multiply and Divide

#### SERIAL INTERFACE UNIT (SIU)

- Serial Communication Processor that, Operates Concurrently to CPU
- 2.4 Mbps Maximum Data Rate
- 375 Kbps using On-Chip Phase Locked Loop
- Communication Software in Silicon:
   Complete Data Link Functions
   Automatic Station Responses
- Operates as an SDLC Primary or Secondary Station

The RUPI-44 family integrates a high performance 8-bit Microcontroller, the Intel 8051 Core, with an intelligent/high performance HDLC/SDLC serial communication controller, called the Serial Interface Unit (SIU). See Figure 1. This dual architecture allows complex control and high speed data communication functions to be realized cost effectively.

Specifically, the 8044's Microcontroller features: 4K byte On-Chip program memory space; 32 I/O lines; two 16-bit timer/event counters; a 5-source; 2-level interrupt structure; a full duplex serial channel; a Boolean processor; and on-chip oscillator and clock circuitry. Standard TTL and most byte-oriented MCS-80 and MCS-85 peripherals can be used for I/O and memory expansion.

The Serial Interface Unit (SIU) manages the interface to a high speed serial link. The SIU offloads the On-Chip 8051 Microcontroller of communication tasks, thereby freeing the CPU to concentrate on real time control tasks.

The RUPI-44 family consists of the 8044, 8744, and 8344. All three devices are identical except in respect of on-chip program memory. The 8044 contains 4K bytes of mask-programmable ROM. User programmable EPROM replaces ROM in the 8744. The 8344 addresses all program memory externally.

The RUPI-44 devices are fabricated with Intel's reliable +5 volt, silicon-gate HMOSII technology and packaged in a 40-pin DIP

The 8744H is available in a hermetically sealed, ceramic, 40-lead dual in-line package which includes a window that allows for EPROM erasure when exposed to ultraviolet light (See Erasure Characteristics). During normal operation, ambient light may adversely affect the functionality of the chip. Therefore, applications which expose the 8744H to ambient light may require an opaque label over the window.



#### Figure 1. Dual Controller Architecture

Intel Corporation Assumes No Responsibility for the Use of Any Circuitry Other Than Circuitry Embodied in an Intel Product No Other Circuit Patent Licenses are Implied • INTEL CORPORATION, 1982

#### Table 1. RUPI<sup>™</sup> -44 Family Pin Description

#### vss

Circuit ground potential.

#### VCC

+5V power supply during operation and program verification.

#### PORT 0

Port 0 is an 8-bit open drain bidirectional I/O port. It is also the multiplexed low-order address and data bus when using external memory. It is used for data output during program verification. Port 0 can sink/source eight LS TTL loads.

#### PORT 1

Port 1 is an 8-bit quasi-bidirectional I/O port. It is used for the low-order address byte during program verification. Port 1 can sink/source four LS TTL loads.

In non-loop mode two of the I/O lines serve alternate functions:  $\dot{\phantom{a}}$ 

- -RTS (P1.6). Request-to-Send output. A low indicates that the RUPI-44 is ready to transmit.
- —CTS (P1.7) Clear-to-Send input. A low indicates that a receiving station is ready to receive.

#### PORT 2

Port 2 is an 8-bit quasi-bidirection I/O port. It also emits the high-order address byte when accessing, external memory. It is used for the high-order address and the control signals during program verification. Port 2 can sink/source four LS TTL loads.

#### PORT 3

Port 3 is an 8-bit quasi-bidirectional I/O port. It also contains the interrupt, timer, serial port and RD and WR pins that are used by various options. The output latch corresponding to a secondary function must be programmed to a one (1) for that function to operate. Port 3 can sink/source LS TTL loads.

In addition to I/O, some of the pins also serve alternate functions as follows:

- I/O RxD (P3.0). In point-to-point or multipoint configurations, this pin controls the direction of pin P3.1. Serves as Receive Data input in loop and diagnostic modes.
- -DATA TxD (P3.1) In point-to-point or multipoint configurations, this pin functions as data input/output. In loop mode, it serves as transmit pin. A '0' written to this pin enables diagnostic mode.
- INTO (P3.2). Interrupt 0 input or gate control input for counter 0.
- —INT1 (P3.3). Interrupt 1 input or gate control input for counter 1.
- -TO(P3.4). Input to counter 0.

- SCLK T1 (P3.5). In addition to I/O, this pin provides input to counter 1 or serves as SCLK (serial clock) input.
   WR (P3.6). The write control signal latches the data byte from Port 0 into the External Data Memory.
- -RD (P3.7). The read control signal enables External Data Memory to Port 0.

#### RST

A high on this pin for two machine cycles while the oscillator is running resets the device. A small external pulldown resistor ( $\approx$ 8.2k $\Omega$ ) from RST to V<sub>SS</sub> permits power-on reset when a capacitor ( $\approx$ 10 $\mu$ f) is also connected from this pin to V<sub>CC</sub>.

#### ALE/PROG

Provides Address Latch Enable output used for latching the address into external memory during normal operation. It is activitated every six oscillator periods except during an external data memory access. It also receives the program pulse input for programming the EPROM version.

#### PSEN

The Program Store Enable output is a control signal that enables the external Program Memory to the bus during external fetch operations. It is activated every six oscillator periods, except during external data memory accesses. Remains high during internal program execution.

#### EA/VPP

When held at a TTL high level, the RUPI-44 executes instructions from the internal ROM when the PC is less than 4096. When held at a TTL low level, the RUPI-44 fetches all instructions from external Program Memory. The pin also receives the 21V EPROM programming supply voltage on the 8744.

#### XTAL 1

Input to the oscillator's high gain amplifier. Required when a crystal is used. Connect to VSS when external source is used on XTAL 2.

#### XTAL 2

Output from the oscillator's amplifier. Input to the internal timing circuitry. A crystal or external source can be used.



Figure 2.





Figure 4. Block Diagram

#### **ABSOLUTE MAXIMUM RATINGS\***

| Ambient Temperature Under Bias 0°C to 70°C |
|--------------------------------------------|
| Storage Temperature65°C to +150°C          |
| Voltage On Any Pin to V <sub>SS</sub>      |
| (Except V <sub>PP</sub> )                  |
| Voltage from Vpp to VSS                    |
| Power Dissipation 2 W                      |
|                                            |

\*NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

١

| Symbol            | Parameter                                                       | Min  | Max                   | Unit   | Test Conditions                                   |
|-------------------|-----------------------------------------------------------------|------|-----------------------|--------|---------------------------------------------------|
| VIL               | Input Low Voltage (except EA)                                   | -0.5 | 0.8                   | V      |                                                   |
| VIL1              | Input Low Voltage to EA                                         | 0    | 0.8                   | ٧      |                                                   |
| VIH               | Input High Voltage (Except XTAL2, RST)                          | 2.0  | V <sub>CC</sub> + 0.5 | V      |                                                   |
| VIH1              | Input High Voltage to XTAL2, RST                                | 2.5  | V <sub>CC</sub> + 0.5 | V      | XTAL1 = V <sub>SS</sub>                           |
| VOL.              | Output Low Voltage Ports 1, 2, 3 (Note 1)                       |      | 0.45                  | V.     | IOL = 1.6mA                                       |
| VOL1              | Output Low Voltage Port 0, ALE, PSEN<br>(Note 1)                |      | 0.60<br>0.45          | V<br>V | IOL = 3.2mA<br>IOL = 2.4mA                        |
| VOH               | Output High Voltage Ports 1, 2, 3                               | 2.4  |                       | V      | IOH = -80µA                                       |
| VOH1              | Output High Voltage Port 0 (in External<br>Bus Mode), ALE, PSEN | 2.4  |                       | V      | IOH = -400µA                                      |
| IIL               | Logical 0 Input Current P1, P2, P3                              |      | 500                   | μA     | Vin = 0.45V                                       |
| IIL1              | Logical 0 Input Current to EA/VPP                               |      | -15                   | mA     | Vin = 0.45V                                       |
| IIL2              | Logical 0 Input Current to XTAL2 .                              |      | -3.5                  | mA     | $XTAL1 = V_{SS}$ Vin = 0.45V                      |
| ILI               | Input Leakage Current to Port 0                                 |      | 100                   | μA     | 0.45 < Vin < V <sub>CC</sub>                      |
| IIH               | Logical Input Current to EA/VPP                                 |      | 500                   | μA     | Vin = 2.4V                                        |
| IIH1 <sup>×</sup> | Input Current to RST/VPD to activate reset                      |      | 500                   | μA     | Vin < (V <sub>CC</sub> - 1.5V)                    |
| ICC               | Power Supply Current                                            |      | 270                   | mA     | All outputs disconnected,<br>EA = V <sub>CC</sub> |
| CIO               | Capacitance of I/O Buffers                                      |      | 10                    | pF     | fc = 1 MHz T <sub>A</sub> = 25°C                  |

AC CHARACTERISTICS (T<sub>A</sub> = 0°C to 70°C, V<sub>CC</sub> = 4.5V to 5.5V, V<sub>SS</sub> = 0V, Load Capacitance for Port 0, ALE, and  $\overrightarrow{PSEN}$  = 100 pF; Load Capacitance for all other outputs = 80 pF).

|        |                              |       | 44H<br>Hz Osc | Variable  |                |                 |
|--------|------------------------------|-------|---------------|-----------|----------------|-----------------|
| Symbol | Parameter                    | Min   | Max           | Min       | Max            | Units           |
| TCLCL  | Oscillator Period            |       |               | 83.3      | 285.7          | ns              |
| TLHLL  | . ALE Pulse Width            | , 127 |               | 2TCLCL-40 |                | ns              |
| TAVLL  | Address Valid to ALE         | 53    |               | TCLCL-40  |                | ns              |
| TLLAX  | Address Hold after ALE       | 48    |               | TCLCL-35  |                | ns              |
| TLLIV  | ALE to Valid Instr In        |       | 183           |           | 4TCLCL-150     | ns              |
| TLLPL  | ALE to PSEN                  | 58,   | 3             | TCLCL-25  |                | ns <sup>,</sup> |
| TPLPH  | PSEN Pulse Width             | 190   |               | 3TCLCL-60 | х.             | ns              |
| TPLIV  | PSEN to Valid Instr In       | 1     | 100           | ,         | · 3TCLCL-150 - | ns              |
| ΤΡΧΙΧ  | Input Instr Hold after PSEN  | 0     |               | 0         |                | ns              |
| TPXIZ  | Input Instr Float after PSEN |       | 63            |           | TCLCL-20       | ns              |
| TPXAV  | PSEN to Address Valid        | 75    |               | TCLCL-8   | ć.             | ns              |
| ΤΑΥΙΥ  | Address to Valid Instr In    | 1.    | 267           |           | 5TCLCL-150     | ns              |
| TAZPL  | Address Float to PSEN        | -25   |               | -25       |                | ns              |

#### **EXTERNAL PROGRAM MEMORY CHARACTERISTICS**

#### EXTERNAL DATA MEMORY CHARACTERISTICS

|        |                             | 8744H<br>12 MHz Osc |     | Variable Oscillator |            | ŕ     |
|--------|-----------------------------|---------------------|-----|---------------------|------------|-------|
| Symbol | Parameter                   | Min                 | Max | Min                 | Max        | Units |
| TRLRH  | RD Pulse Width              | 400                 |     | 6TCLCL-100          | ×          | ns .  |
| TWLWH  | WR Pulse Width              | 400                 |     | 6TCLCL-100          | _          | ns    |
| TLLAX  | Address Hold After ALE      | 48                  |     | TCLCL-35            |            | ns    |
| TRLDV  | RD to Valid Data In         |                     | 252 |                     | 5TCLCL-165 | ns    |
| TRHDX  | Data Hold after RD          | 0                   |     | 0                   |            | ns    |
| TRHDZ  | Data Float after RD         |                     | 97  |                     | 2TCLCL-70  | ns    |
| TLLDV  | ALE to Valid Data In        |                     | 517 |                     | 8TCLCL-150 | ns    |
| TAVDV  | Address to Valid Data In    |                     | 585 |                     | 9TCLCL-165 | ns    |
| TLLWL  | ALE to WR or RD             | 200                 | 300 | 3TCLCL-50           | 3TCLCL+50  | ns    |
| TAVWL  | Address to WR or RD         | 203                 |     | 4TCLCL-130          |            | ns    |
| TQVWX  | Data Valid to WR Transition | 13                  |     | TCLCL-70            |            | ns    |
| ΤΩνωΗ  | Data Setup to WR High       | 433                 | Í   | 7TCLCL-150          |            | ns    |
| TWHQX  | Data Held after WR          | 33                  | [   | TCLCL-50            |            | ns    |
| TRLAZ  | RD Low to Address Float     | <u> </u>            | 25  |                     | 25         | ns    |
| TWHLH  | RD or WR High to ALE High   | 33                  | 133 | TCLCL-50            | TCLCL+50   | ns    |

r

#### AC TESTING INPUT, OUTPUT, FLOAT WAVEFORMS



AC testing inputs are driven at 2.4V for a logic 1 and 0.45V for a logic 0

Timing measurements are made at 2.0V for a logic 1 and 0.8V for a logic 0

For timing purposes, the float state is defined as the point at which a PO pin sinks 3.2mA or sources 400µA at the voltage test levels

# 

#### SERIAL I/O WAVEFORMS

#### Serial Interface

| Symbol | Parameter       | Min | Max | Units |     |
|--------|-----------------|-----|-----|-------|-----|
| TDCY   | Data Clock      | 420 |     | ns    |     |
| TDCL   | Data Clock Low  | 180 | ,   | ns    |     |
| TDCH   | Data Clock High | 100 | ,   | ns    | 4 4 |

| TTD  | Transmit Data Delay |    | 180 | ns | S. 1 |  |
|------|---------------------|----|-----|----|------|--|
| TDSS | Data Setup Time     | 40 |     | ns |      |  |
| TDHS | Data Hold Time      | 40 |     | ns |      |  |

#### Memory Access



NOTE: VOL is degraded when the 8744H rapidly discharges external capacitance. This AC noise is most pronounced during emission of address data. When using external memory, locate the latch or buffer as close to the 8744H as possible.

| Datum      | Emitting<br>Ports | Degraded<br>I/O Lines | VOL<br>(peak)<br>(max) |
|------------|-------------------|-----------------------|------------------------|
| Address    | P2, P0            | P1, P3                | 0.8V                   |
| Write Data | P0                | P1, P3, ALE           | 0.8V                   |

#### **EXTERNAL CLOCK DRIVE CHARACTERISTICS (XTAL2)**

| Symbol | Parameter                | Min  | Max   | Units |
|--------|--------------------------|------|-------|-------|
| TCLCL  | Oscillator Period: 8751H | 83.3 | 285.7 | ns    |
| тснсх  | High Time                | 20   |       | ns    |
| TCLCX  | Low Time                 | 20   |       | ns    |
| TCLCH  | Rise Time                |      | 20    | ns    |
| TCHCL  | Fall Time                |      | 20    | ns    |



CLOCK WAVEFORMS



This diagram indicates when signals are clocked internally. The time it takes the signals to propagate to the pins, however, ranges from 25 to 125 ns. This propagation delay is dependent on variables such as temperature and pin loading. Propagation also varies from output to output and component to component Typically though,  $(T_A = 25^{\circ}C)$ , fully loaded) RD and WR propagation delays are approximately 50 ns. The other signals are typically 85 ns. Propagation delays are incorporated in the AC specifications

#### 8744H EPROM CHARACTERISTICS

#### **Erasure Characteristics**

Erasure of the 8744H Program Memory begins to occur when the chip is exposed to light with wavelengths shorter than approximately 4,000 Ångstroms. Since sunlight and fluorescent lighting have wavelengths in this range, constant exposure to these light sources over an extended period of time (about 1 week in sunlight, or 3 years in room-level fluorescent lighting) could cause unintentional erasure. If an application subjects the 8744H to this type of exposure, it is suggested that an opaque label be placed over the window.

The recommended erasure procedure is exposure to ultraviolet light (at 2537 Ångstroms) to an integrated dose of at least 15 W-sec/cm<sup>2</sup> rating for 20 to 30 minutes, at a distance of about 1 inch, should be sufficient.

Erasure leaves the array in an all 1s state.

#### Programming the EPROM

To be programmed, the 8744H must be running with a 4 to 6 MHz oscillator. (The reason the oscillator needs to be running is that the internal bus is being used to transfer address and program data to appropriate registers.) The address of an EPROM location to be programmed is applied to Port 1 and pins P2.0-P2.3 of Port 2, while the data byte is applied to Port 0. Pins P2.4-P2.6 and PSEN should be held low, and P2.7 and RST high. (These are all TTL levels except RST, which requires 2.5V for high.) EA/VPP is held normally high, and is pulsed to +21V. While EA/VPP is at 21V, the ALE/PROG pin, which is normally being held high, is pulsed low for 50 msec. Then EA/VPP is returned to high. This is illustrated in Figure 3. Detailed timing specifications are provided in the EPROM Programming and Verification Characteristics section of this data sheet.

#### **Program Memory Security**

The program memory security feature is developed around a "security bit" in the 8744H EPROM array. Once this "hidden bit" is programmed, electrical access to the contents of the entire program memory array becomes impossible. Activation of this feature is accomplished by programming the 8744H as described in "Programming the EPROM" with the exception that P2.6 is held at a TTL high rather than a TTL low. In addition, Port 1 and P2.0-P2.3 may be in any state. Figure 4 illustrates the security bit programming configuration. Deactivating the security feature, which again allows programmability of the EPROM, is accomplished by exposing the EPROM to ultraviolet light. This exposure, as described in "Erasure Characteristics." erases the entire EPROM array. Therefore, attempted retrieval of "protected code" results in its destruction.

#### **Program Verification**

Program Memory may be read only when the "security feature" has not been activated. Refer to Figure 5 for Program Verification setup. To read the Program Memory, the following procedure can be used. The unit must be running with a 4 to 6 MHz oscillator. The address of a Program Memory location to be read is applied to Port 1 and pins P2.0-P2.3 of Port 2. Pins P2.4-P2.6 and PSEN are held at TTL low, while the ALE/PROG, RST, and EA/VPP pins are held at TTL high. (These are all TTL levels except RST, which requires 2.5V for high.) Port 0 will be the data output lines. P2.7 can be used as a read strobe. While P2.7 is held high, the Port 0 pins float. When P2.7 is strobed low, the contents of the addressed location will appear at Port 0. External pullups (e.g., 10K) are required on Port 0 during program verification.

INT









20-30



Figure 5. Program Verification Configuration

# EPROM PROGRAMMING, SECURITY BIT PROGRAMMING AND VERIFICATION CHARACTERISTICS (TA = $21^{\circ}$ C to $27^{\circ}$ C, V<sub>CC</sub> = 4.5V to 5.5V, V<sub>SS</sub> = 0V)

| Symbol  | Parameter                  | Min     | Max     | Units |
|---------|----------------------------|---------|---------|-------|
| VPP     | Programming Supply Voltage | 20.5    | , 21.5  | V     |
| IPP     | Programming Current        |         | 30      | mA    |
| 1/TCLCL | Oscillator Frequency       | 4       | 6       | MHz   |
| TAVGL   | Address Setup to PROG      | 48TCLCL |         |       |
| TGHAX   | Address Hold after PROG    | 48TCLCL |         |       |
| TDVGL   | Data Setup to PROG         | 48TCLCL |         |       |
| TGHDX   | Data Hold after PROG       | 48TCLCL |         |       |
| TEHSH   | ENABLE High to VPP         | 48TCLCL |         |       |
| TSHGL   | VPP Setup to PROG          | 10      |         | μsec  |
| TGHSL   | VPP Hold after PROG        | 10      |         | μsec  |
| TGLGH   | PROG Width                 | 45      | 55      | msec  |
| TAVQV   | Address to Data Valid      |         | 48TCLCL |       |
| TELQV   | ENABLE to Data Valid       |         | 48TCLCL |       |
| TEHQZ   | Data Float after ENABLE    | 0       | 48TCLCL |       |

# EPROM PROGRAMMING, SECURITY BIT PROGRAMMING AND VERIFICATION WAVEFORMS



# **RUPI™** Article Reprints

21

ARTICLE REPRINT

AR-307

NOVEMBER 1983



ORDER NUMBER 230876-001

© INTEL CORPORATION

# intel

#### SUMMARY

The 8044 offers a lower cost and higher performance solution to networking microcontrollers than conventional solutions. The system cost is lowered by integrating an entire microcomputer with an intelligent HDLC/SDLC communication processor onto a single chip. The higher performance is realized by integrating two processors running concurrently on one chip; the powerful 8051 microcontroller and the Serial Interface Unit. The 8051 microcontroller is substantially off-loaded from the communication tasks when using the AUTO mode. In the AUTO mode the SIU handles many of the data link functions in hardware. The advantages of the AUTO mode are: less software is required to implement a secondary station data link, the 8051 CPU is offloaded, and the turn-around time is reduced, thus increasing the network throughput. Currently the 8044 is the only microcontroller with a sophisticated communications processor on-chip. In the future there will be more microcontrollers available following this trend.

#### INTRODUCTION

Today microcontrollers are being designed into virtually every type of equipment. For the household, they are turning up in refrigerators, thermostats, burglar alarms, sprinklers, and even water softeners. At work they are found in laboratory instruments, copiers, elevators, hospital equipment, and telephones. In addition, a lot of microcomputer equipment contains more than one microcontroller. Applications using multiple microcontrollers as well, as the office and home, are now faced with the same requirements that laboratory instruments were faced with 12 years ago - they need to connect them together and have them communicate. This need was satisfied in the laboratory with the IEEE-488 General Purpose Instrumentation Bus (GPIB). However, GPIB does not meet the current design objectives for networking microcontrollers.

Today there are many communications schemes and protocols available; some of the popular ones are GPIB, Async, HDLC/SDLC, and Ethernet. Common design objectives of today's networks are: low cost, reliable, efficient throughput, and expandable. In examining available solutions, GPIB does not meet these design objectives; first, the cable is too expensive (parallel communications), second, it can only be used over a limited distance (20 meters), and third, it can only handle a limited number of stations. For general networking, serial communications is preferable because of lower cable costs and higher reliability (fewer connections). While Ethernet provides very high performance, it is more of a system backbone rather than a microcontroller interconnect. Async, on the other hand, is inexpensive but it is not an efficient protocol for data block or file transfers. Even with some new modifications such as a 9 bit protocol for addressing, important functions such as acknowledgements, error checking/recovery, and data transparency are not standardized nor supported by available data comm chips.

SDLC, Synchronous Data Link Control, meets the requirements for communications link design. The physical medium can be used on two or four wire twisted pair with inexpensive transceivers and connectors. It can also be interfaced through modems, which allows it to be used on broadband networks, leased or switched telephone lines. VLSI controllers have been available from a number of vendors for years; higher performance and more user friendly SDLC controllers continue to appear. SDLC has also been designed to be very reliable. A 16 bit CRC checks the integrity of the received data, while frame numbering and acknowledgements are also built in. Using SDLC, up to 254 stations can be uniquely addressed. while HDLC addressing is unlimited. If an RS-422 only requires a single +5 volt power supply.

What will the end user pay for the added value provided by communications? The cost of the communications hardware is not the only additional cost. There will be performance degradation in the main application because the microcontroller now has additional tasks to perform. There are two extremes to the cost of adding communication capability. One could spend very little by adding an I/O port and have the CPU handle everything from the baud rate to the protocol. Of course the main application would be idle while the CPU was communicating. The other extreme would be to add another microcontroller to the system dedicated to communications. This communications processor could interface to the main CPU through a high speed parallel link or dual port RAM. This approach would maintain system performance, but it would be costly.

#### Adding HDLC/SDLC Networking Capability

Figure 1 shows a microcomputer system with a conventional HDLC/SDLC communications solution. The additional hardware needed to realize the conventional design is: an HDLC/SDLC communication chip, additional ROM for the communication software, part of an interrupt controller, a baud rate generator, a phase locked loop, NRZI encoded/decoder, and a cable driver locked loop are used when the transmitter does not send the clock on a separate line from the data (i.e. over telephone lines, or two wire cable). the NRZI encoder/decoder is used in HDLC/SDLC to combine the clock into the data line. A phase locked loop is used to recover the clock from the data line.

The majority of the available communication chips provide a limited number of data link control functions. Most of them will handle Zero Bit Insertion/Deletion (ZBI/D), Flags, Aborts, Automatic



Figure 1. Conventional microcontroller networking solution

address recognition, and CRC generation and checking. It is the CPU's responsibility to manage link access, command recognition and response, acknowledgements and error recovery. Handling these tasks can take a lot of CPU time. In addition, servicing the transmission and reception of data bytes can also be very time consuming depending on the method used.

Using a DMA controller can increase the overall system performance, since it can transfer a block of data in fewer clock cycles than a CPU. In addition, the CPU and the DMA controller can multiplex their access to the bus so that both can be running at virtually the same time. However, both the DMA controller and the CPU are sharing the same bus, therefore, neither one get to utlize 100% of the bus bandwidth. Microcontrollers available today do not support DMA, therefore, they would have to use interrupts, since polling is unacceptable in a multitasking environment.

In an interrupt driven, the CPU has overhead in addition to servicing the interrupt. During each interrupt request the CPU has to save all of the important registers, transfer a byte, update pointers and counters, then restore all of its registers. At low bit rates this overhead may be insignificant. However, the percentage of overhead increases linearly with the bit rate. At high bit rates this overhead would consume all of the CPU's time. There is another nuisance factor associated with interrupt driven systems, interrupt latency. Too much interrupt latency will cause data to be lost from underrun and overrun errors.

The additional hardware necessary to implement the communications solution, as shown in Figure 1, would

require 1 LSI chip and about 10 TTL chips. The cost of CPU throughput degradation can be even greater. The percentage of time the CPU has to spend servicing the communication tasks can be anywhere from 10-100%, depending on the serial bit rate. These high costs will prevent consumer acceptance of networking microcomputer equipment.

A Highly Integrated, High Performance Solution The 8044 reduces the cost of networking microcontrollers without compromising performance. It contains all of the hardware components necessary to implement a microcomputer system with communications capability, plus it reduces the CPU and software overhead of implementing HDLC/SDLC. Figure 2 shows a functional block diagram of the 8044.

The 8044 integrates the powerful 8051 microcontroller with an intelligent Serial Interface Unit to provide a single chip solution which efficiently implements a distributed processing or distributed control system. The microcontroller is a self sufficient unit containing ROM, RAM, ALU and its own peripherals. The 8044's architecture and instruction set are identical to the 8051's. The Serial Interface Unit (SIU) uses bit synchronous HDLC/SDLC protocol and can communicate at bit rates up to 2.4 Mbps, externally clocked, or up to 375 Kbps using the on-chip digital phase locked loop. The SIU contains its own processor, which operates concurrently with the microcontroller.

The CPU and the SIU, in the 8044, interface through 192 bytes of dual port RAM. There is no hardware arbitration in the dual port RAM. Both processor's memory access cycles are interlaced; each processor has access every other clock cycle. Therefore, there



Figure 2. 8044 single chip microcontroller networking solution

is no throughput loss in either processor as a result of the dual port RAM, and execution times are deterministic. Since this has always been the method for memory access on the 8051 microcontroller, 8051 programs have the same execution time in the 8044.

By integrating all of the communication hardware onto the 8051 microcontroller, the hardware cost of the system is reduced. Now several chips have been integrated into a single chip. This means that the system power is reduced, P.C. board space is reduced, inventory and assembly is reduced, and reliability is improved. The improvement in reliability is a result of fewer chips and interconnections on the P.C. board.

As mentioned before, there can be two extremes in a design which adds communications to the microcomputer system. The 8044 solution uses the high end extreme. The SIU on the 8044 contains its own processor which communicates with the 8051 processor through dual port RAM and control/status registers. While the SIU is not a totally independent communications processor, it substantially offloads the 8051 processor from the communication tasks.

The DMA on the 8044 is dedicated to the SIU. It cannot access external RAM. By having a DMA controller in the SIU, the 8051 CPU is offloaded. As a result of the dual port RAM design, the DMA does not share the running at full speed while the frames are being transmitted or received. Also, the nuisance of overrun and underrun errors is totally eliminated since the dedicated DMA controller is guaranteed to meet the maximum data rates. Having a dedicated DMA controller means that the serial channel interrupt can be the lowest priority, thus allowing the CPU to have higher priority real time interrupts.

Figure 3 shows a comparison between the conventional and the 8044 solution on the percentage of time the CPU must spend sending data. This diagram was derived by assuming a 64 byte information frame is being transmitted repeatedly. The conventional solution is interrupt driven, and each interrupt service routine is assumed to take about 15 instructions with a 1 µsec instruction cycle time. At 533 Kbps, an interrupt would occur every 15 usec. Thus, the CPU becomes completely dedicated to servicing the serial communications. The conventional design could not support bit rates higher than this because of underruns and overruns. For the 8044 to repeatedly send 64 byte frames, it simply has to reinitialize the DMA controller. As a result, the 8044 can support bit rates up to 2.4 Mbps.

Some of the other communications tasks the CPU has to perform, such as link access, command recognition/response, and acknowledgements, are performed automatically by the SIU in a mode called "AUTO." The combination of the dedicated DMA controller and the AUTO mode, substantially offload





the CPU, thus allowing it to devote more of its power to other tasks.

#### 8044's Auto Mode

In the AUTO mode the SIU implements in hardware a subset of the SDLC protocol such that it responds to many SDLC commands without CPU intervention. All AUTO mode responses to the primary station conform to IBM's SDLC definition. In the AUTO mode the 8044 can only be a secondary station operating in SDLC specified "Normal Response Mode." Normal Response Mode means that the secondary station can not transmit unless it is polled by the primary station. The SIU in the AUTO mode can recognize and respond to the following SDLC commands without CPU intervention: I (Information), RR (Receive Ready), RNR (Receive Not Ready), REJ (Reject), and for loop mode UP (Unnumbered Poll). The SIU can generate the following responses without CPU intervention: I, RR, and RNR. In addition. the SIU manages Ns and Nr in the control field. If it detects an error in either Ns or Nr, it interrupts the CPU for error recovery.

How does the SIU know what responses to send to the primary? It uses two status bits which are set by the CPU. The two bits are TBF (Transmit Buffer Full) and RBP (Receive Buffer Protect). TBF indicates that the CPU wants to send data, and RBP indicates that the receive data buffer is full. Table 1 shows the responses the SIU will send based on these two status bits. This is an innovative approach to communication design. The CPU in the 8044 with one instruction can directly set a bit which communicates to the primary what its transmit and receive buffering status is.

When the CPU wants to send a frame, it loads the transmit buffer with the data, loads the starting address and the count of the data into the SIU, then sets TBF to transmit the frame. The SIU waits for the primary station to poll it with a RR command. After the SIU is polled, it automatically sends the information frame to the primary with the proper control field. The SIU then waits for a positive acknowledgement from the primary before incrementing the Ns field and interrupting the CPU for more data. If a negative acknowledgement is received, the SIU automatically retransmits the frame.

When the 8044 is ready to receive information, the CPU loads the receive buffer starting address and the buffer length into the SIU, then enables the receiver. When a valid information frame with the correct address and CRC is received, the SIU will increment the Nr field, disable the receiver and interrupt the CPU indicating that a good I frame has been received. The CPU then sets RBP, reenables the receiver and processes the received data. By enabling the receiver with RBP set, the SIU will automatically respond to polls with a Receive Not Ready, thus keeping the link moving rather than timing out the primary from a disabled receiver, or interrupting the CPU with another poll before it has processed the data. After the data has been processed, the CPU clears RBP, returning to the Receive Ready responses:

| Table 1. S                                      | Table 1. SIU's automatic responses in auto mode |                         |  |  |  |
|-------------------------------------------------|-------------------------------------------------|-------------------------|--|--|--|
|                                                 | STATUS BITS                                     |                         |  |  |  |
| un a staring the line<br>an internet <b>TBF</b> | RBP                                             |                         |  |  |  |
| ` <b>0</b>                                      | 0                                               | (RR) Receive ready      |  |  |  |
| 0                                               | 1                                               | (RNR) Receive not ready |  |  |  |
| 1                                               | 0                                               | (I) Information         |  |  |  |
| 1                                               | 1                                               | (I) Information         |  |  |  |
|                                                 | ,                                               |                         |  |  |  |

SDLC communications can be broken up into four states: Logical Disconnect State, Initialization State, Frame Reject State, and Information Transfer State. Data can only be transferred in the Information Transfer State. More than 90% of the time a station will be in the Information Transfer State, which is where the SIU can run autonomously. In the other states, where error recovery, online/offline, and initialization takes place, the CPU manages the protocol. In the Information Transfer State there are three common events which occur as illustrated in Figure 4, they are: 1) the primary polls the secondary and the secondary is ready to receive but has nothing to send, 2) the primary sends the secondary information, and 3) the secondary sends information to the primary. Figures 5, 6, and 7 compare the functions the conventional design and the 8044 must execute in order to respond to the primary for the cases in Figure 4.



Figure 4. SDLC commands and responses in the information transfer state



Figure 5. Primary polls secondary, secondary has nothing to send



Figure 6. Primary polls secondary, secondary sends information frame

# intel

# AR-307



# Figure 7. Primary sends information frame to secondary

Using case 1 as an example, the conventional design first gets receive interrupts bringing the data from the SDLC comm chip into memory. The CPU must then decode the command in the control field and determine the response. In addition, it must check the Nr field for any pending acknowledgements. The CPU loads the transmit buffer with the appropriate address and control field, then transmits the frame. When the 8044 receives this frame in AUTO mode, the CPU never gets an interrupt because the SIU handles the entire frame reception and response automatically.

In SDLC networks, when there is no information transfers, case 1 is the activity on the line. Typically this is 80% of the network traffic. The CPU in the conventional design would constantly be getting interrupts and servicing the communications tasks, even when it has nothing to send or receive. On the other hand, the 8044 CPU would only get involved in communicating when it has data to send or receive.

Having the SIU implement a subset of the SDLC protocol in hardware not only offloads the CPU, but it also improves the throughput on the network. The most critical parameter for calculating throughput on any high speed network is the station turnaround time; the time it takes a station to respond after receiving a frame. Since the 8044 handles all of the commands and responses of the Information Transfer State in hardware, the turnaround time is much faster than handling it in software, hence a higher throughput.

#### 8044's Flexible Mode

In the "NON-AUTO" mode or Flexible mode, the SIU does not recognize or respond to any commands, nor does it manage acknowledgements, which means the CPU must handle link access, command recognition/response, acknowledgements and error recovery by itself. The Flexible mode allows the 8044 to have extended address fields and extended control fields, thus providing HDLC support. In the Flexible mode the 8044 can operate as a primary station, since it can transmit without being polled.

# Front End Communications Processor

The 8044 can also be used as an intelligent HDLC/SDLC front end for a microporcessor, capable of extensively off-loading link control functions for

the microporcessor. In some applications the 8044 can even be used for communications preprocessing, in addition to data link control. For this type of design the 8044 would communicate to the Host CPU through a FIFO, or dual port RAM. A block diagram of this design is given in Figure 8. A tightly coupled interface between the 8044 and the Host CPU would be established. The Host CPU would give the 8044 high level commands and data which the 8044 would convert to HDLC/SDLC. This particular type of design would be most appropriate for a primary Station which is normally a micro, mini, or mainframe computer. Sophisticated secondary stations could also take advantage of this design.

Since the 8044 has ROM on chip, all the communications software is non-volatile. The 8044 primary station could down-line-load software to 8044 secondary stations. Once down-line-loading is implemented, software updates to the primary and secondary stations could be done very inexpensively. The only things which would remain fixed in ROM are the HDLC/SDLC communications software and the software interface to the HOST.



Figure 8. 8044 front end processor

# **Design Considerations**

22

•

· · ·

1

# Designing Microcontroller Systems for Electrically Noisy Environments

# Contents

| SYMPTOMS OF NOISE PROBLEMS                                                                                                             | 22-2                         |
|----------------------------------------------------------------------------------------------------------------------------------------|------------------------------|
| TYPES AND SOURCES OF ELECTRICAL NOIS<br>Supply Line Transients<br>EMP and RFI<br>ESD<br>Ground Noise                                   | 22-2<br>22-2<br>22-3         |
| "RADIATED" AND "CONDUCTED" NOISE                                                                                                       |                              |
| SIMULATING THE ENVIRONMENT                                                                                                             |                              |
|                                                                                                                                        | 66°7                         |
| TYPES OF FAILURES AND FAILURE<br>MECHANISMS                                                                                            | 22-4                         |
| THE GAME PLAN                                                                                                                          | 22-5                         |
| CURRENT LOOPS                                                                                                                          | 22-5                         |
| SHIELDING                                                                                                                              | 22-6<br>22-6<br>22-6<br>22-9 |
| GROUNDS                                                                                                                                | 22-10<br>22-11<br>22-12      |
| POWER SUPPLY DISTRIBUTION AND<br>DECOUPLING<br>Selecting the Value of the Decoupling Cap<br>The Case for On-Board Voltage Regulation . | 22-15                        |
| RECOVERING GRACEFULLY FROM A SOFTU                                                                                                     |                              |
| SPECIAL PROBLEM AREAS         ESD.         The Automotive Environment                                                                  | 22-18<br>22-18<br>22-19      |
| PARTING THOUGHTS                                                                                                                       | 22-21                        |
| REFERENCES.                                                                                                                            | 22-22                        |

Digital circuits are often thought of as being immune to noise problems, but really they're not. Noises in digital systems produce software upsets: program jumps to apparently random locations in memory. Noise-induced glitches in the signal lines can cause such problems, but the supply voltage is more sensitive to glitches than the signal lines.

Severe noise conditions, those involving electrostatic discharges, or as found in automotive environments, can do permanent damage to the hardware. Electrostatic discharges can blow a crater in the silicon. In the automotive environment, in ordinary operation, the "12V" power line can show + and -400V transients.

This Application Note describes some electrical noises and noise environments. Design considerations, along the lines of PCB layout, power supply distribution and decoupling, and shielding and grounding techniques, that may help minimize noise susceptibility are reviewed. Special attention is given to the automotive and ESD environments.

# **Symptoms of Noise Problems**

Noise problems are not usually encountered during the development phase of a microcontroller system. This is because benches rarely simulate the system's intended environment. Noise problems tend not to show up until the system is installed and operating in its intended environment. Then, after a few minutes or hours of normal operation the system finds itself someplace out in left field. Inputs are ignored and outputs are gibberish. The system may respond to a reset, or it may have to be turned off physically and then back on again, at which point it commences operating as though nothing had happened. There may be an obvious cause, such as an electrostatic discharge from somebody's finger to a keyboard or the upset occurs every time a copier machine is turned on or off. Or there may be no obvious cause, and nothing the operator can do will make the upset repeat itself. But a few minutes, or a few hours, or a few days later it happens again.

One symptom of electrical noise problems is randomness, both in the occurrence of the problem and in what the system does in its failure. All operational upsets that occur at seemingly random intervals are not necessarily caused by noise in the system. Marginal VCC, inadequate decoupling, rarely encountered software conditions, or timing coincidences can produce upsets that seem to occur randomly. On the other hand, some noise sources can produce upsets downright periodically. Nevertheless, the more difficult it is to characterize an upset as to cause and effect, the more likely it is to be a noise problem.

# Types and Sources of Electrical Noise

The name given to electrical noises other than those that are inherent in the circuit components (such as thermal noise) is EMI: electromagnetic interference. Motors, power switches, fluorescent lights, electrostatic discharges, etc., are sources of EMI. There is a veritable alphabet soup of EMI types, and these are briefly described below.

## SUPPLY LINE TRANSIENTS

Anything that switches heavy current loads onto or off of AC or DC power lines will cause large transients in these power lines. Switching an electric typewriter on or off, for example, can put a 1000V spike onto the AC power lines.

The basic mechanism behind supply line transients is shown in Figure 1. The battery represents any power source, AC or DC. The coils represent the line inductance between the power source and the switchable loads R1 and R2. If both loads are drawing current, the line current flowing through the line inductance establishes a magnetic field of some value. Then, when one of the loads is switched off, the field due to that component of the line current collapses, generating transient voltages, v = L(di/dt), which try to maintain the current at its original level. That's called an "inductive kick." Because of contact bounce, transients are generated whether the switch is being opened or closed, but they're worse when the switch is being opened.

An inductive kick of one type or another is involved in most line transients, including those found in the automotive environment. Other mechanisms for line transients exist, involving noise pickup on the lines. The noise voltages are then conducted to a susceptible circuit right along with the power.

## **EMP AND RFI**

Anything that produces arcs or sparks will radiate electromagnetic pulses (EMP) or radio-frequency interference (RFI).



Figure 1. Supply Line Transients

Spark discharges have probably caused more software upsets in digital equipment than any other single noise source. The upsetting mechanism is the EMP produced by the spark. The EMP induces transients in the circuit, which are what actually cause the upset.

Arcs and sparks occur in automotive ignition systems, electric motors, switches, static discharges, etc. Electric motors that have commutator bars produce an arc as the brushes pass from one bar to the next. DC motors and the "universal" (AC/DC) motors that are used to power hand tools are the kinds that have commutator bars. In switches, the same inductive kick that puts transients on the supply lines will cause an opening or closing switch to throw a spark.

### ESD

Electrostatic discharge (ESD) is the spark that occurs when a person picks up a static charge from walking across a carpet, and then discharges it into a keyboard, or whatever else can be touched. Walking across a carpet in a dry climate, a person can accumulate a static voltage of 35kV. The current pulse from an electrostatic discharge has an extremely fast risetime — typically, 4A/nsec. Figure 2 shows ESD waveforms that have been observed by some investigators of ESD phenomena.

It is enlightening to calculate the L(di/dt) voltage required to drive an ESD current pulse through a couple of inches of straight wire. Two inches of straight wire has about 50nH of inductance. That's not very much, but using 50nH for L and 4A/nsec for di/dt gives an L(di/dt) drop of about 200V. Recent observations by W.M. King suggest even faster risetimes (Figure 2B) and the occurrence of multiple discharges during a single discharge event.

Obviously, ESD-sensitivity needs to be considered in the design of equipment that is going to be subjected to it, such as office equipment.

## **GROUND NOISE**

Currents in ground lines are another source of noise. These can be 60Hz currents from the power lines, or RF hash, or crosstalk from other signals that are sharing this particular wire as a signal return line. Noise in the ground lines is often referred to as a "ground loop" problem. The basic concept of the ground loop is shown in Figure 3. The problem is that true earth-ground is not really at the same potential in all locations. If the two ends of a wire are earth-grounded at different locations, the voltage difference between the two "ground" points can drive significant currents (several amperes) through the wire. Consider the wire to be part of a loop which contains, in addition to the wire, a voltage source that represents the difference in potential between the two ground points, and you have the classical "ground loop." By extension, the term is used to refer to any unwanted (and often unexpected) currents in a ground line.

# "Radiated" and "Conducted" Noise

Radiated noise is noise that arrives at the victim circuit in the form of electromagnetic radiation, such as EMP and RFI. It causes trouble by inducing extraneous voltages in the circuit. Conducted noise is noise that arrives at the victim circuit already in the form of an extraneous voltage, typically via the AC or DC power lines.

One defends against radiated noise by care in designing layouts and the use of effective shielding techniques. One defends against conducted noise with filters and suppres-



Figure 2. Waveforms of Electrostatic Discharge Currents From a Hand-Held Metallic Object

sors, although layouts and grounding techniques are important here, too.

# Simulating the Environment

Addressing noise problems after the design of a system has been completed is an expensive proposition. The ill will generated by failures in the field is not cheap either. It's cheaper in the long run to invest a little time and money in learning about noise and noise simulation equipment, so that controlled tests can be made on the bench as the design is developing.

Simulating the intended noise environment is a two-step process: First you have to recognize what the noise environment is, that is, you have to know what kinds of electrical noises are present, and which of them are going to cause trouble. Don't ignore this first step, because it's important. If you invest in an induction coil spark generator just because your application is automotive, you'll be straining at the gnat and swallowing the camel. Spark plug noise is the least of your worries in that environment.

The second step is to generate the electrical noise in a controlled manner. This is usually more difficult than first imagined; one first imagines the simulation in terms of a waveform generator and a few spare parts, and then finds that a wideband power amplifier with a 200V dynamic range is also required. A good source of information on who supplies what noise-simulating equipment is the 1981 "ITEM" Directory and Design Guide (reference 6).

## **Types of Failures and Failure Mechanisms**

A major problem that EMI can cause in digital systems is intermittent operational malfunction. These software upsets occur when the system is in operation at the time an EMI source is activated, and are usually characterized by a loss of information or a jump in the execution of the program to some random location in memory. The person who has to iron out such problems is tempted to say the program counter went crazy. There is usually no damage to the hardware, and normal operation can resume as soon as the EMI has passed or the source is de-activated. Resuming normal operation usually requires manual or automatic reset, and possibly re-entering of lost information.

Electrostatic discharges from operating personnel can cause not only software upsets, but also permanent ("hard") damage to the system. For this to happen the system doesn't even have to be in operation. Sometimes the permanent damage is latent, meaning the initial damage may be marginal and require further aggravation through operating stress and time before permanent failure takes place. Sometimes too the damage is hidden.

One ESD-related failure mechanism that has been identified has to do with the bias voltage on the substrate of the chip. On some CPU chips the substrate is held at -2.5V by a phase-shift oscillator working into a capacitor/diode clamping circuit. This is called a "charge pump" in chip-design circles. If the substrate wanders too far in either direction, program read errors are noted. Some designs have been known to allow electrostatic discharge currents to flow directly into port pins of an 8048. The resulting damage to the oxide causes an increase in leakage current, which loads down the charge pump, reducing the substrate voltage to a marginal or unacceptable level. The system is then unreliable or completely inoperative until the CPU chip is replaced. But if the CPU chip was subjected to a discharge spark once, it will eventually happen again.

Chips that have a grounded substrate, such as the 8748, can sometimes sustain some oxide damage without actually becoming inoperative. In this case the damage is present, and the increased leakage current is noted; however, since the substrate voltage retains its design value, the damage is largely hidden.



Figure 3. What a Ground Loop Is

It must therefore be recognized that connecting port pins unprotected to a keyboard or to anything else that is subject to electrostatic discharges, makes an extremely dangerous configuration. It doesn't make any difference what CPU chip is being used, or who makes it. If it connects unprotected to a keyboard, it will eventually be destroyed. Designing for an ESD-environment will be discussed further on.

We might note here that MOS chips are not the only components that are susceptible to permanent ESD damage. Bipolar and linear chips can also be damaged in this way. PN junctions are subject to a hard failure mechanism called thermal secondary breakdown, in which a current spike, such as from an electrostatic discharge, causes microscopically localized spots in the junction to approach melt temperatures. Low power TTL chips are subject to this type of damage, as are op-amps. Op-amps, in addition, often carry on-chip MOS capacitors which are directly across an external pin combination, and these are susceptible to dielectric breakdown.

We return now to the subject of software upsets. Noise transients can upset the chip through any pin, even an output pin, because every pin on the chip connects to the substrate through a pn junction. However, the most vulnerable pin is probably the VCC line, since it has direct access to all parts of the chip: every register, gate, flip-flop and buffer.

The menu of possible upset mechanisms is quite lengthy. A transient on the substrate at the wrong time will generally cause a program read error. A false level at a control input can cause an extraneous or misdirected opcode fetch. A disturbance on the supply line can flip a bit in the program counter or instruction register. A short interruption or reversal of polarity on the supply line can actually turn the processor off, but not long enough for the power-up reset capacitor to discharge. Thus when the transient ends, the chip starts up again without a reset.

A common failure mode is for the processor to lock itself into a tight loop. Here it may be executing the data in a table, or the program counter may have jumped a notch, so that the processor is now executing operands instead of opcodes, or it may be trying to fetch opcodes from a nonexistent external program memory.

It should be emphasized that mechanisms for upsets have to do with the arrival of noise-induced transients at the pins of the chips, rather than with the generation of noise pulses within the chip itself, that is, it's not the chip that is picking up noise, it's the circuit.

# The Game Plan

Prevention is usually cheaper than suppression, so first we'll consider some preventive methods that might help to minimize the generation of noise voltages in the circuit. These methods involve grounding, shielding, and wiring techniques that are directed toward the mechanisms by which noise voltages are generated in the circuit. We'll also discuss methods of decoupling. Then we'll look at some schemes for making a graceful recovery from upsets that occur in spite of preventive measures. Lastly, we'll take another look at two special problem areas: electrostatic discharges and the automotive environment.

# **Current Loops**

The first thing most people learn about electricity is that current won't flow unless it can flow in a closed loop. This simple fact is sometimes temporarily forgotten by the overworked engineer who has spent the past several years mastering the intricacies of the DO loop, the timing loop, the feedback loop, and maybe even the ground loop. The simple current loop probably owes its apparent demise to the invention of the ground symbol. By a stroke of the pen one avoids having to draw the return paths of most of the current loops in the circuit. Then "ground" turns into an infinite current sink, so that any current that flows into it is gone and forgotten. Forgotten it may be, but it's not gone. It must return to its source, so that its path will by all the laws of nature form a closed loop.

The physical geometry of a given current loop is the key to why it generates EMI, why it's susceptible to EMI, and how to shield it. Specifically, it's the area of the loop that matters.

Any flow of current generates a magnetic field whose intensity varies inversely to the distance from the wire that carries the current. Two parallel wires conducting currents +1 and -1 (as in signal feed and return lines) would generate a nonzero magnetic field near the wires. where the distance from a given point to one wire is noticeably different from the distance to the other wire, but farther away (relative to the wire spacing), where the distances from a given point to either wire are about the same, the fields from both wires tend to cancel out. Thus, maintaining proximity between feed and return paths is an important way to minimize their interference with other signals. The way to maintain their proximity is essentially to minimize their loop area. And, because the mutual inductance from current loop A to current loop B is the same as the mutual inductance from current loop B to current loop A, a circuit that doesn't radiate interference doesn't receive it either.

Thus, from the standpoint of reducing both generation of EMI and susceptibility to EMI, the hard rule is to keep loop areas small. To say that loop areas should be minimized is the same as saying the circuit inductance should

be minimized. Inductance is by definition the constant of proportionality between current and the magnetic field it produces:  $\phi = LI$ . Holding the feed and return wires close together so as to promote field cancellation can be described either as minimizing the loop area or as minimizing L. It's the same thing.

# Shielding

There are three basic kinds of shields: shielding against capacitive coupling, shielding against inductive coupling, and RF shielding. Capacitive coupling is electric field coupling, so shielding against it amounts to shielding against electric fields. As will be seen, this is relatively easy. Inductive coupling is magnetic field coupling, so shielding against it is shielding against magnetic fields. This is a little more difficult. Strangely enough, this type of shielding does not in general involve the use of magnetic materials. RF shielding, the classical "metallic barrier" against all sorts of electromagnetic fields, is what most people picture when they think about shielding. Its effectiveness depends partly on the selection of the shielding material, but mostly, as it turns out, on the treatment of its seams and the geometry of its openings.

### SHIELDING AGAINST CAPACITIVE COUPLING

Capacitive coupling involves the passage of interfering signals through mutual or stray capacitances that aren't shown on the circuit diagram, but which the experienced engineer knows are there. Capacitive coupling to one's body is what would cause an unstable oscillator to change its frequency when the person reaches his hand over the circuit, for example. More importantly, in a digital system it causes crosstalk in multi-wire cables.

The way to block capacitive coupling is to enclose the circuit or conductor you want to protect in a metal shield. That's called an electrostatic or Faraday shield. If coverage is 100%, the shield does not have to be grounded, but it usually is, to ensure that circuit-to-shield capacitances go to signal reference ground rather than act as feedback and crosstalk elements. Besides, from a mechanical point of view, grounding it is almost inevitable.

A grounded Faraday shield can be used to break capacitive coupling between a noisy circuit and a victim circuit, as shown in Figure 4. Figure 4A shows two circuits capacitively coupled through the stray capacitance between them. In Figure 4B the stray capacitance is intercepted by a grounded Faraday shield, so that interference currents are shunted to ground. For example, a grounded plane can be inserted between PCBs (printed circuit boards) to eliminate most of the capacitive coupling between them.

Another application of the Faraday shield is in the elec-

trostatically shielded transformer. Here, a conducting foil is laid between the primary and secondary coils so as to intercept the capacitive coupling between them. If a system is being upset by AC line transients, this type of transformer may provide the fix. To be effective in this application, the shield must be connected to the greenwire ground.

### SHIELDING AGAINST INDUCTIVE COUPLING

With inductive coupling, the physical mechanism involved is a magnetic flux density B from some external interference source that links with a current loop in the victim circuit, and generates a voltage in the loop in accordance with Lenz's law: v = -NA(dB/dt), where in this case N = 1 and A is the area of the current loop in the victim circuit.

There are two aspects to defending a circuit against inductive pickup. One aspect is to try to minimize the offensive fields at their source. This is done by minimizing the area of the current loop at the source so as to promote field cancellation, as described in the section on current loops. The other aspect is to minimize the inductive pickup in the victim circuit by minimizing the area of that current loop, since, from Lenz's law, the induced voltage is proportional to this area. So the two aspects really involve the same corrective action: minimize the areas of the current loops. In other words, minimizing the offensiveness of a circuit inherently minimizes its susceptibility.



Figure 4. Use of Faraday Shield



Figure 5. External to the Shield,  $\phi=0$ 

Shielding against inductive coupling means nothing more nor less than controlling the dimensions of the current loops in the circuit. We must look at four examples of this type of "shielding": the coaxial cable, the twisted pair, the ground plane, and the gridded-ground PCB layout.

**The Coaxial Cable** — Figure 5 shows a coaxial cable carrying a current I from a signal source to a receiving load. The shield carries the same current as the center conductor. Outside the shield, the magnetic field produced by +I flowing in the center conductor is cancelled by the field produced by –I flowing in the shield. To the extent that the cable is ideal in producing zero external magnetic field, it is immune to inductive pickup from external sources. The cable adds effectively zero area to the loop. This is true only if the shield carries the same current as the center conductor.

In the real world, both the signal source and the receiving load are likely to have one end connected to a common signal ground. In that case, should the cable be grounded at one end, both ends, or neither end? The answer is that it should be grounded at both ends. Figure 6A shows the situation when the cable shield is grounded at only one end. In that case the current loop runs down the center conductor of the cable, then back through the common ground connection. The loop area is not well defined. The shield not only does not carry the same current as the center conductor, but it doesn't carry any current at all. There is no field cancellation at all. The shield has no effect whatsoever on either the generation of EMI or susceptibility to EMI. (It is, however, still effective as an electrostatic shield, or at least it would be if the shield coverage were 100%.)

Figure 6B shows the situation when the cable is grounded at both ends. Does the shield carry all of the return current, or only a portion of it on account of the shunting effect of the common ground connection? The answer to that question depends on the frequency content of the signal. In general, the current loop will follow the path of least impedance. At low frequencies, 0Hz to several kHz, where the inductive reactance is insignificant, the current will follow the path of least resistance. Above a few kHz, where inductive reactance predominates, the current will follow the path of least inductance. The path of least





inductance is the path of minimum loop area. Hence, for higher frequencies the shield carries virtually the same current as the center conductor, and is therefore effective against both generation and reception of EMI.

Note that we have now introduced the famous "ground loop" problem, as shown in Figure 7A. Fortunately, a digital system has some built-in immunity to moderate ground loop noise. In a noisy environment, however, one can break the ground loop, and still maintain the shielding effectiveness of the coaxial cable, by inserting an optical coupler, as shown in Figure 7B. What the optical coupler does, basically, is allow us to re-define the signal source as being ungrounded, so that that end of the cable need not be grounded, and still lets the shield carry the same current as the center conductor. Obviously, if the signal source weren't grounded in the first place, the optical coupler wouldn't be needed.

**The Twisted Pair** — A cheaper way to minimize loop area is to run the feed and return wires right next to each other. This isn't as effective as a coaxial cable in minimizing loop area. An ideal coaxial cable adds zero area to the loop, whereas merely keeping the feed and return wires next to each other is bound to add a finite area.

However, two things work to make this cheaper method almost as good as a coaxial cable. First, real coaxial cables are not ideal. If the shield current isn't evenly distributed around the center conductor at every cross-





section of the cable (it isn't), then field cancellation external to the shield is incomplete. If field cancellation is incomplete, then the effective area added to the loop by the cable isn't zero. Second, in the cheaper method the feed and return wires can be twisted together. This not only maintains their proximity, but the noise picked up in one twist tends to cancel out the noise picked up in the next twist down the line. Thus the "twisted pair" turns out to be about as good a shield against inductive coupling as coaxial cable is.

The twisted pair does not, however, provide electrostatic shielding (i.e., shielding against capacitive coupling). Another operational difference between them is that the coaxial cable works better at higher frequencies. This is primarily because the twisted pair adds more capacitive loading to the signal source than the coaxial cable does. The twisted pair is normally considered useful up to only about 1MHz, as opposed to near a GHz for the coaxial cable.

The Ground Plane — The best way to minimize loop areas when many current loops are involved is to use a ground plane. A ground plane is a conducting surface that is to serve as a return conductor for all the current loops in the circuit. Normally, it would be one or more layers of a multilayer PCB. All ground points in the circuit go not to a grounded trace on the PCB, but directly to the ground plane. This leaves each current loop in the circuit free to complete itself in whatever configuration yields minimum loop area (for frequencies wherein the ground path impedance is primarily inductive).

Thus, if the feed path for a given signal zigzags its way across the PCB, the return path for this signal is free to zigzag right along beneath it on the ground plane, in such a configuration as to minimize the energy stored in the magnetic field produced by this current loop. Minimal magnetic flux means minimal effective loop area and minimal susceptibility to inductive coupling.

**The Gridded-Ground PCB Layout** — The next best thing to a ground plane is to lay out the ground traces on a PCB in the form of a grid structure, as shown in Figure 8. Laying horizontal traces on one side of the board and vertical traces on the other side allows the passage of signal and power traces. Wherever vertical and horizontal ground traces cross, they must be connected by a feed-through.

Have we not created here a network of "ground loops"? Yes, in the literal sense of the word, but loops in the ground layout on a PCB are not to be feared. Such inoffensive little loops have never caused as much noise pickup as their avoidance has. Trying to avoid innocent little loops in the ground layout, PCB designers have forced current loops into geometries that could swallow a whale. That is exactly the wrong thing to do.

The gridded ground structure works almost as well as the ground plane, as far as minimizing loop area is concerned. For a given current loop, the primary return path may have to zig once in a while where its feed path zags,



Figure 8. PCB with Gridded Ground

but you still get a mathematically optimal distribution of currents in the grid structure, such that the current loop produces less magnetic flux than if the return path were restrained to follow any single given ground trace. The key to attaining minimum loop areas for all the current loops together is to let the ground currents distribute themselves around the entire area of the board as freely as possible. They want to minimize their own magnetic field. Just let them.

### **RF SHIELDING**

A time-varying electric field generates a time-varying magnetic field, and vice versa. Far from the source of a time-varying EM field, the ratio of the amplitudes of the electric and magnetic fields is always 377 ohms. Up close to the source of the fields, however, this ratio can be quite different, and dependent on the nature of the source. Where the ratio is near 377 ohms is called the far field, and where the ratio is significantly different from 377 ohms is called the near field. The ratio itself is called the wave impedance, E/H.

The near field goes out about 1/6 of a wavelength from the source. At 1MHz this is about 150 feet, and at 10MHz it's about 15 feet. That means if an EMI source is in the same room with the victim circuit, it's likely to be a near field problem. The reason this matters is that in the near field an RF interference problem could be almost entirely due to E-field coupling or H-field coupling, and that could influence the choice of an RF shield or whether an RF shield will help at all.

In the near field of a whip antenna, the E/H ratio is higher than 377 ohms, which means it's mainly an E-field generator. A wire-wrap post can be a whip antenna. Interference from a whip antenna would be by electric field coupling, which is basically capacitive coupling. Methods to protect a circuit from capacitive coupling, such as a Faraday shield, would be effective against RF interference from a whip antenna. A gridded-ground structure would be less effective.

In the near field of a loop antenna, the E/H ratio is lower than 377 ohms, which means it's mainly an H-field generator. Any current loop is a loop antenna. Interference from a loop antenna would be by magnetic field coupling, which is basically the same as inductive coupling. Methods to protect a circuit from inductive coupling, such as a gridded-ground structure, would be effective against RF interference from a loop antenna. A Faraday shield would be less effective.

A more difficult case of RF interference, near field or far field, may require a genuine metallic RF shield. The idea' behind RF shielding is that time-varying EMI fields induce currents in the shielding material. The induced currents dissipate energy in two ways: I<sup>2</sup>R losses in the shielding material and radiation losses as they re-radiate their own EM fields. The energy for both of these mechanisms is drawn from the impinging EMI fields. Hence the EMI is weakened as it penetrates the shield.

More formally, the  $I^2R$  losses are referred to as absorption loss, and the re-radiation is called reflection loss. As it turns out, absorption loss is the primary shielding mechanism for H-fields, and reflection loss is the primary shielding mechanism for E-fields. Reflection loss, being a surface phenomenon, is pretty much independent of the thickness of the shielding material. Both loss mechanisms, however, are dependent on the frequency ( $\omega$ ) of the impinging EMI field, and on the permeability ( $\mu$ ) and conductivity ( $\sigma$ ) of the shielding material. These loss mechanisms vary approximately as follows:

reflection loss to an E-field (in dB)  $\sim \log \frac{\sigma}{\omega \mu}$ 

absorption loss to an H-field (in dB) ~  $t\sqrt{\omega\sigma\mu}$ 

where t is the thickness of the shielding material.

The first expression indicates that E-field shielding is more effective if the shield material is highly conductive, and less effective if the shield is ferromagnetic, and that low-frequency fields are easier to block than highfrequency fields. This is shown in Figure 9.



Figure 9. E-Field Shielding



Figure 10. H-Field Shielding

Copper and aluminum both have the same permeability, but copper is slightly more conductive, and so provides slightly greater reflection loss to an E-field. Steel is less effective for two reasons. First, it has a somewhat elevated permeability due to its iron content, and, second, as tends to be the case with magnetic materials, it is less conductive.

On the other hand, according to the expression for absorption loss to an H-field, H-field shielding is more effective at higher frequencies and with shield material that has both high conductivity and high permeability. In practice, however, selecting steel for its high permeability involves some compromise in conductivity. But the increase in permeability more than makes up for the decrease in conductivity, as can be seen in Figure 10. This figure also shows the effect of shield thickness.

A composite of E-field and H-field shielding is shown in Figure 11. However, this type of data is meaningful only in the far field. In the near field the EMI could be 90% H-field, in which case the reflection loss is irrelevant. It would be advisable then to beef up the absorption loss, at the expense of reflection loss, by choosing steel. A better conductor than steel might be less expensive, but quite ineffective.

A different shielding mechanism that can be taken advantage of for low frequency magnetic fields is the ability of a high permeability material such as mumetal to divert the field by presenting a very low reluctance path to the magnetic flux. Above a few kHz, however, the permeability of such materials is the same as steel.

In actual fact the selection of a shielding material turns out to be less important than the presence of seams, joints and holes in the physical structure of the enclosure. The shielding mechanisms are related to the induction of currents in the shield material, but the currents must be



Figure 11. E- and H-Field Shielding

allowed to flow freely. If they have to detour around slots and holes, as shown in Figure 12, the shield loses much of its effectiveness.

As can be seen in Figure 12, the severity of the detour has less to do with the area of the hole than it does with the geometry of the hole. Comparing Figure 12C with 12D shows that a long narrow discontinuity such as a seam can cause more RF leakage than a line of holes with larger total area. A person who is responsible for designing or selecting rack or chassis enclosures for an EMI environment needs to be familiar with the techniques that are available for maintaining electrical continuity across seams. Information on these techniques is available in the references.

# Grounds

There are two kinds of grounds: earth-ground and signal ground. The earth is not an equipotential surface, so earth ground potential varies. That and its other electrical properties are not conducive to its use as a return conductor in a circuit. However, circuits are often connected to earth ground for protection against shock hazards. The other kind of ground, signal ground, is an arbitrarily selected reference node in a circuit—the node with respect to which other node voltages in the circuit are measured.

## SAFETY GROUND

The standard 3-wire single-phase AC power distribution system is represented in Figure 13. The white wire is earth-grounded at the service entrance. If a load circuit has a metal enclosure or chassis, and if the black wire develops a short to the enclosure, there will be a shock hazard to operating personnel, unless the enclosure itself is earth-grounded. If the enclosure is earth-grounded, a





short results in a blown fuse rather than a "hot" enclosure. The earth-ground connection to the enclosure is called a safety ground. The advantage of the 3-wire power system is that it distributes a safety ground along with the power.

Note that the safety-ground wire carries no current, except in case of a fault, so that at least for low frequencies it's at earth-ground potential along its entire length. The white wire, on the other hand, may be several volts off ground, due to the IR drop along its length.





# SIGNAL GROUND

Signal ground is a single point in a circuit that is designated to be the reference node for the circuit. Commonly, wires that connect to this single point are also referred to as "signal ground." In some circles "power supply common" or PSC is the preferred terminology for these conductors. In any case, the manner in which these wires connect to the actual reference point is the basis of distinction among three kinds of signal-ground wiring methods: series, parallel, and multipoint. These methods are shown in Figure 14.

The series connection is pretty common because it's simple and economical. It's the noisiest of the three, however, due to common ground impedance coupling between the circuits. When several circuits share a ground wire, currents from one circuit, flowing through the finite impedance of the common ground line, cause variations in the ground potential of the other circuits. Given that the currents in a digital system tend to be spiked, and that the common impedance is mainly inductive reactance, the variations could be bad enough to cause bit errors in high current or particularly noisy situations.

The parallel connection eliminates common ground impedance problems, but uses a lot of wire. Other disadvantages are that the impedance of the individual ground lines can be very high, and the ground lines themselves can become sources of EMI. In the multipoint system, ground impedance is minimized by using a ground plane with the various circuits connected to it by very short ground leads. This type of connection would be used mainly in RF circuits above 10MHz.

# PRACTICAL GROUNDING

A combination of series and parallel ground-wiring methods can be used to trade off economic and the various electrical considerations. The idea is to run series connections for circuits that have similar noise properties, and connect them at a single reference point, as in the parallel method, as shown in Figure 15.

In Figure 15, "noisy signal ground" connects to things like motors and relays. Hardware ground is the safety ground connection to chassis, racks, and cabinets. It's a mistake to use the hardware ground as a return path for signal currents because it's fairly noisy (for example, it's the hardware ground that receives an ESD spark) and tends to have high resistance due to joints and seams.







Figure 15. Parallel Connection of Series Grounds

Screws and bolts don't always make good electrical connections because of galvanic action, corrosion, and dirt. These kinds of connections may work well at first, and then cause mysterious maladies as the system ages.

Figure 16 illustrates a grounding system for a 9-track digital tape recorder, showing an application of the series/ parallel ground-wiring method.

Figure 17 shows a similar separation of grounds at the PCB level. Currents in multiplexed LED displays tend to put a lot of noise on the ground and supply lines because of the constant switching and changing involved in the scanning process. The segment driver ground is relatively quiet, since it doesn't conduct the LED currents. The digit driver ground is noisier, and should be provided with a separate path to the PCB ground terminal, even if the PCB ground layout is gridded. The LED feed and return current paths should be laid out on opposite sides of the board like parallel flat conductors.

Figure 18 shows right and wrong ways to make ground connections in racks. Note that the safety ground connections from panel to rack are made through ground straps, not panel screws. Rack 1 correctly connects signal ground to rack ground only at the single reference point. Rack 2 incorrectly connects signal ground to rack ground at two points, creating a ground loop around points 1, 2, 3, 4, 1.

Breaking the "electronics ground" connection to point 1 eliminates the ground loop, but leaves signal ground in rack 2 sharing a ground impedance with the relatively noisy hardware ground to the reference point; in fact, it may end up using hardware ground as a return path for signal and power supply currents. This will probably cause more problems than the ground loop.

### **BRAIDED CABLE**

Ground impedance problems can be virtually eliminated by using braided cable. The reduction in impedance is due to skin effect: At higher frequencies the current tends to flow along the surface of a conductor rather than uni-



Figure 16. Ground System in a 9-Track Digital Recorder



Figure 17. Separate Ground for Multiplexed LED Display



# Figure 18. Electronic Circuits Mounted in Equipment Racks Should Have Separate Ground Connections. Rack 1 Shows Correct Grounding, Rack 2 Shows Incorrect Grounding

formly through its bulk. While this effect tends to increase the impedance of a given conductor, it also indicates the way to minimize impedance, and that is to manipulate the shape of the cross-section so as to provide more surface area. For its bulk, braided cable is almost pure surface.

# **Power Supply Distribution and Decoupling**

The main consideration for power supply distribution lines is, as for signal lines, to minimize the areas of the current loops. But the power supply lines take on an importance that no signal line has when one considers the fact that these lines have access to every PC board in the system. The very extensiveness of the supply current loops makes it difficult to keep loop areas small. And, a noise glitch on a supply line is a glitch delivered to every board in the system.

The power supply provides low-frequency current to the load, but the inductance of the board-to-board and chipto-chip distribution network makes it difficult for the power supply to maintain VCC specs on the chip while providing the current spikes that a digital system requires. In addition, the power supply current loop is a very large one, which means there will be a lot of noise pick-up. Figure 19A shows a load circuit trying to draw current spikes from a supply voltage through the line impedance. To the VCC waveform shown in that figure should be added the inductive pick-up associated with a large loop area.

Adding a decoupling capacitor solves two problems: The capacitor acts as a nearby source of charge to supply the current spikes through a smaller line impedance, and it

defines a much smaller loop area for the higher frequency components of EMI. This is illustrated in Figure 19B, which shows the capacitor supplying the current spike, during which VCC drops from 5V by the amount indicated in the figure. Between current spikes the capacitor recovers through the line impedance.

One should resist the temptation to add a resistor or an inductor to the decoupler so as to form a genuine RC or LC low-pass filter because that slows down the speed with which the decoupler cap can be refreshed. Good filtering and good decoupling are not necessarily the same thing.

The current loop for the higher frequency currents, then, is defined by the decoupling cap and the load circuit, rather than by the power supply and the load circuit. For the decoupling cap to be able to provide the current spikes required by the load, the inductance of this current loop must be kept small, which is the same as saying the loop area must be kept small. This is also the requirement for minimizing inductive pick-up in the loop.

There are two kinds of decoupling caps: board decouplers and chip decouplers. A board decoupler will normally be a 10 to  $100\mu$ f electrolytic capacitor placed near to where the power supply enters the PC board, but its placement is relatively non-critical. The purpose of the board decoupler is to refresh the charge on the chip decouplers. The chip decouplers are what actually provide the current spikes to the chips. A chip decoupler will normally be a 0.1 to  $1\mu$ f ceramic capacitor placed near the chip and connected to the chip by traces that minimize the area of the loop formed by the cap and the chip. If a chip decoupler is not properly placed on the board, it will be ineffective as a decoupler and will serve only to increase



Figure 19. What a Decoupling Capacitor Does

the cost of the board. Good and bad placement of decoupling capacitors are illustrated in Figure 20.

Power distribution traces on the PC board need to be laid out so as to obtain minimal area (minimal inductance) in the loops formed by each chip and its decoupler, and by the chip decouplers and the board decoupler. One way to accomplish this goal is to use a power plane. A power plane is the same as a ground plane, but at VCC potential. More economically, a power grid similar to the ground grid previously discussed (Figure 8) can be used. Actually, if the chip decoupling loops are small, other aspects of the power layout are less critical. In other words, power planes and power gridding aren't needed, but power traces *should* be laid in the closest possible proximity to ground traces, preferably so that



Figure 20. Placement of Decoupling Capacitors

each power trace is on the direct opposite side of the board from a ground trace.

Special-purpose power supply distribution buses which mount on the PCB are available. The buses use a parallel flat conductor configuration, one conductor being a VCC line and the other a ground line. Used in conjunction with a gridded ground layout, they not only provide a low-inductance distribution system, but can themselves form part of the ground grid, thus facilitating the PCB layout. The buses are available with and without enhanced bus capacitance, under the names Mini/Bus<sup>®</sup> and Q/PAC<sup>®</sup> from Rogers Corp. (5750 E. McKellips, Mesa, AZ 85205).

# SELECTING THE VALUE OF THE DECOUPLING CAP

The effectiveness of the decoupling cap has a lot to do with the way the power and ground traces connect this capacitor to the chip. In fact, the area formed by this loop is more important than the value of the capacitance. Then, given that the area of this loop is indeed minimal, it can generally be said that the larger the value of the decoupling cap, the more effective it is, if the cap has a mica, ceramic, glass, or polystyrene dielectric.

It's often said, and not altogether accurately, that the chip decoupler shouldn't have too large a value. There are two reasons for this statement. One is that some capacitors, because of the nature of their dielectrics, tend to become inductive or lossy at higher frequencies. This is true of electrolytic capacitors, but mica, glass, ceramic, and polystyrene dielectrics work well to several hundred MHz. The other reason cited for not using too large a capacitance has to do with lead inductance.

The capacitor with its lead inductance forms a series LC circuit. Below the frequency of series resonance, the net impedance of the combination is capacitive. Above that frequency, the net impedance is inductive. Thus a decoupling capacitor is capacitive only below the frequency of series resonance. This frequency is given by

$$f_0 = \frac{1}{2\pi\sqrt{LC}}$$

where C is the decoupling capacitance and L is the lead inductance between the capacitor and the chip. On a PC board this inductance is determined by the layout, and is the same whether the capacitor dropped into the PCB holes is  $0.001\mu f$  or  $1\mu f$ . Thus, increasing the capacitance lowers the series resonant frequency. In fact, according to the resonant frequency formula, increasing C by a factor of 100 lowers the resonant frequency by a factor of 10.

Figures quoted on the series resonant frequency of a 0.01µf capacitor run from 10 to 15MHz, depending on the lead length. If these numbers were accurate, a  $1\mu f$ capacitor in the same position on the board would have a resonant frequency of 1.0 to 1.5MHz, and as a decoupler would do more harm than good. However, the numbers are based on a presumed inductance of a given length of wire (the lead length). It should be noted that a "length of wire" has no inductance at all, strictly speaking. Only a complete current loop has inductance, and the inductance depends on the geometry of the loop. Figures quoted on the inductance of a length of wire are based on a presumably "very large" loop area, such that the magnetic field produced by the return current has no cancellation effect on the field produced by the current in the given length of wire. Such a loop geometry is not and should not be the case with the decoupling loop.

Figure 21 shows VCC waveforms, measured between pins 40 and 20 (VCC and VSS) of an 8751 CPU, for several conditions of decoupling on a PC board that has a decoupling loop area slightly larger than necessary. These photographs show the effects of increasing the decoupling capacitance and decreasing the area of the decoupling loop. The indications are that a  $1\mu f$  capacitor is better than a  $0.1\mu f$  capacitor, which in turn is better than nothing, and that the board should have been laid out with more attention paid to the area of the decoupling loop.

Figure 21E was obtained using a special-purpose experimental capacitor designed by Rogers Corp. 'Q-Pac Division, Mesa, AZ) for use as a decoupler. It con. sts of two parallel plates, the length of a 40-pin DIP, separated by a ceramic dielectric. Sandwiched between the CPU chip and the PCB (or between the CPU socket and the PCB), it makes connection to pins 40 and 20, forming a leadless decoupling capacitor. It is obviously a configuration of minimal inductance. Unfortunately, the particular sample tested had only  $0.07\mu f$  of capacitance and so was unable to prevent the 1MHz ripple as effectively as the configuration of Figure 21D. It seems apparent, though, that with more capacitance this part will alleviate a lot of decoupling problems.

# THE CASE FOR ON-BOARD VOLTAGE REGULATION

To complicate matters, supply line glitches aren't always picked up in the distribution networks, but can come from the power supply circuit itself. In that case, a welldesigned distribution network faithfully delivers the glitch throughout the system. The VCC glitch in Figure 22 was found to be coming from within a bench power supply in response to the EMP produced by an induction coil spark generator that was being used at Intel during a study of noise sensitivity. The VCC glitch is about 400mV high and some  $20\mu$ sec in duration. Normal board decoupling techniques were ineffective in removing it, but adding an on-board voltage regulator chip did the job.

Thus, a good case can be made in favor of using a voltage regulator chip on each PCB, instead of doing all the voltage regulation at the supply circuit. This eases requirements on the heat-sinking at the supply circuit, and alleviates much of the distribution and board decoupling headaches. However, it also brings in the possibility that different boards would be operating at slightly different VCC levels due to tolerance in the regulator chips; this then leads to slightly different logic levels from board to board. The implications of that may vary from nothing to latch-up, depending on what kinds of chips are on the boards, and how they react to an input "high" that is perhaps 0.4V higher than local VCC.

# Recovering Gracefully from a Software Upset

Even when one follows all the best guidelines for designing for a noisy environment, it's always possible for a noise transient to occur which exceeds the circuit's immunity level. In that case, one can strive at least for a graceful recovery.

Graceful recovery schemes involve additional hardware and/or software which is supposed to return the system to a normal operating mode after a software upset has occurred. Two decisions have to be made: How to recognize when an upset has occurred, and what to do about it.

If the designer knows what kinds and combinations of



Figure 21. Noise on V<sub>CC</sub> Line





outputs can legally be generated by the system, he can use gates to recognize and flag the occurrence of an illegal state of affairs. The flag can then trigger a jump to a recovery routine which then may check or re-initialize data, perhaps output an error message, or generate a simple reset.

The most reliable scheme is to use a so-called watchdog circuit. Here the CPU is programmed to generate a periodic signal as long as the system is executing instructions in an expected manner. The periodic signal is then used to hold off a circuit that will trigger a jump to a recovery routine. The periodic signal needs to be AC-coupled to the trigger circuit so that a "stuck-at" fault won't continue to hold off the trigger. Then, if the processor locks up someplace, the periodic signal is lost and the watchdog triggers a reset.

In practice, it may be convenient to drive the watchdog circuit with a signal which is being generated anyway by the system. One needs to be careful, however, that an upset does in fact discontinue that signal. Specifically, for example, one could use one of the digit drive signals going to a multiplexed display. But display scanning is often handled in response to a timer-interrupt, which may continue operating even though the main program is in a failure mode. Even so, with a little extra software, the signal can be used to control the watchdog (see reference 8 on this).

Simpler schemes can work well for simpler systems. For example, if a CPU isn't doing anything but scanning and decoding a keyboard, there's little to lose and much to gain by simply resetting it periodically with an astable multivibrator. It only takes about  $13\mu$ sec (at 6MHz) to reset an 8048 if the clock oscillator is already running.

A zero-cost measure is simply to fill all unused program memory with NOPs and JMPs to a recovery routine. The effectiveness of this method is increased by writing the program in segments that are separated by NOPs and JMPs. It's still possible, of course, to get hung up in a data table or something. But you get a lot of protection, for the cost.

Further discussion of graceful recovery schemes can be found in reference 13.

# **Special Problem Areas**

**ESD** MOS chips have some built-in protection against a static charge build-up on the pins, as would occur during normal handling, but there's no protection against the kinds of current levels and rise times that occur in a genuine electrostatic spark. These kinds of discharges can blow a crater in the silicon.

It must be recognized that connecting CPU pins unprotected to a keyboard or to anything else that is subject to electrostatic discharges makes an extremely fragile configuration. Buffering them is the very least one can do. But buffering doesn't completely solve the problem, because then the buffer chips will sustain the damage (even TTL); therefore, one might consider mounting the buffer chips in sockets for ease of replacement.

Transient suppressors, such as the TranZorbs<sup>®</sup> made by General Semiconductor Industries (Tempe, AZ), may in the long run provide the cheapest protection if their "zero inductance" structure is used. The structure and circuit application are shown in Figure 23.

The suppressor element is a pn junction that operates like a Zener diode. Back-to-back units are available for AC operation. The element is more or less an open circuit at normal system voltage (the standoff voltage rating for the device), and conducts like a Zener diode at the clamping voltage.

The lead inductance in the conventional transient suppressor package makes the conventional package essen-



Figure 23. "Zero-inductance" Structure and Use in Circuit

tially useless for protection against ESD pulses, owing to the fast rise of these pulses. The "zero inductance" units are available singly in a 4-pin DIP, and in arrays of four to a 16-pin DIP for PCB level protection. In that application they should be mounted in close proximity to the chips they protect.

In addition, metal enclosures or frames or parts that can receive an ESD spark should be connected by braided cable to the green-wire ground. Because of the ground impedance, ESD current shouldn't be allowed to flow through any signal ground, even if the chips are protected by transient suppressors. A 35kV ESD spark can always spare a few hundred volts to drive a fast current pulse down a signal ground line if it can't find a braided cable to follow. Think how delighted your 8048 will be to find its VSS pin about 250V higher than VCC for a few 10s of nanoseconds.

### THE AUTOMOTIVE ENVIRONMENT

The automobile presents an extremely hostile environment for electronic systems. There are several parts to it:

- 1. Temperature extremes from -40°C to +125°C (under the hood) or +85°C (in the passenger compartment)
- 2. Electromagnetic pulses from the ignition system
- 3. Supply line transients that will knock your socks off

One needs to take a long, careful look at the temperature extremes. The allowable storage temperature range for most Intel MOS chips is  $-65^{\circ}$ C to  $+150^{\circ}$ C, although some chips have a maximum storage temperature rating of  $+125^{\circ}$ C. In operation (or "under bias," as the data sheets say) the allowable ambient temperature range depends on the product grade, as follows:

|            | Ambient Temperature |      |  |
|------------|---------------------|------|--|
| Grade      | <sup>,</sup> min.   | max. |  |
| Commercial | 0                   | 70   |  |
| Industrial | -40                 | +85  |  |
| Automotive | -40                 | +110 |  |
| Military   | -55                 | +125 |  |

The different product grades are actually the same chip, but tested according to different standards. Thus, a given commercial-grade chip might actually pass military temperature requirements, but not have been tested for it. (Of course, there are other differences in grading requirements having to do with packaging, burn-in, traceability, etc.)

In any case, it's apparent that commercial-grade chips can't be used safely in automotive applications, not even in the passenger compartment. Industrial-grade chips can be used in the passenger compartment, and automotive or military chips are required in under-the-hood applications.

Ignition noise, CB radios, and that sort of thing are probably the least of your worries. In a poorly designed system, or in one that has not been adequately tested for the automotive environment, this type of EMI might cause a few software upsets, but not destroy chips.

The major problem, and the one that seems to come as the biggest surprise to most people, is the line transients. Regrettably, the 12V battery is not actually the source of power when the car is running. The charging system is, and it's not very clean. The only time the battery is the real source of power is when the car is first being started, and in that condition the battery terminals may be delivering about 5 or 6V. Below is a brief description of the major idiosyncracies of the "12V" automotive power line.





- An abrupt reduction in the alternator load causes a positive voltage transient called "load dump." In a load dump transient the line voltage rises to 20 or 30V in a few msec, then decays exponentially with a time constant of about 100msec, as shown in Figure 24. Much higher peak voltages and longer decay times have also been reported. The worst case load dump is caused by disconnecting a low battery from the alternator circuit while the alternator is running. Normally this would happen intermittently when the battery terminal connections are defective.
- When the ignition is turned off, as the field excitation decays, the line voltage can go to between -40 and -100V for 100 msec or more.
- Miscellaneous solenoid switching transients, such as the one shown in Figure 25, can drive the line to + or -200 to 400V for several µsec.

• Mutual coupling between unshielded wires in long harnesses can induce 100 and 200V transients in unprotected circuits.

What all this adds up to is that people in the business of building systems for automotive applications need a comprehensive testing program. An SAE guideline which describes the automotive environment is available to designers: SAE J1211, "Recommended Environmental Practices for Electronic Equipment Design," *1980 SAE Handbook*, Part 1, pp. 22.80–22.96.

Some suggestions for protecting circuitry are shown in Figure 26. A transient suppressor is placed in front of the regulator chip to protect it. Since the rise times in these transients are not like those in ESD pulses, lead inductance is less critical and conventional devices can be used. The regulator itself is pretty much of a necessity, since a load dump transient is simply not going to be removed



Figure 25. Transient Created by De-energizing an Air Conditioning Clutch Solenoid



Figure 26. Use of Transient Suppressors in Automotive Applications

by any conventional LC or RC filter.

Special I/O interfacing is also required, because of the need for high tolerance to voltage transients, input noise, input/output isolation, etc. In addition, switches that are being monitored or driven by these buffers are usually referenced to chassis ground instead of signal ground, and in a car there can be many volts difference between the two. I/O interfacing is discussed in reference 2.

# **Parting Thoughts**

The main sources of information for this Application Note were the references by Ott and by White. Reference 5 is probably the finest treatment currently available on the subject. The other references provided specific information as cited in the text.

Courses and seminars on the subject of electromagnetic interference are given regularly throughout the year. Information on these can be obtained from:

IEEE Electromagnetic Compatibility Society EMC Education Committee 345 East 47th Street New York, NY 10017 Phone: (212) 752-6800

Don White Consultants, Inc. International Training Centre P.O. Box D Gainesville, VA 22065 Phone: (703) 347-0030 The EMC Education committee has available a video tape: "Introduction to EMC — A Video Training Tape," by Henry Ott. Don White Consultants offers a series of training courses on many different aspects of electromagnetic compatibility. Most organizations that sponsor EMC courses also offer in-plant presentations.

intel

APPLICATION NOTE

**AP-155** 

June 1983



Order Number: 230659-001

12 38 2 1. 2 3

191

# Oscillators for Microcontrollers

# CONTENTS

# 

Å

# FEEDBACK OSCILLATORS

| Loop Gain                         | 22-25 |
|-----------------------------------|-------|
| How Feedback Oscillators Work     | 22-26 |
| The Positive Reactance Oscillator | 22-26 |

# QUARTZ CRYSTALS

| Crystal Parameters               | 22-27 |
|----------------------------------|-------|
| equivalent circuit               | 22-27 |
| load capacitance                 | 22-27 |
| "series" vs. "parallel" crystals | 22-28 |
| equivalent series resistance     | 22-28 |
| frequency tolerance              |       |
| drive level                      |       |
| DAMO DECONATORO                  |       |
|                                  | 00 00 |

# CERAMIC RESONATORS ...... 22-29

# OSCILLATOR DESIGN CONSIDERATIONS

| On-Chip Oscillators               |       |
|-----------------------------------|-------|
| crystal specifications            | 22-30 |
| oscillation frequency             | 22-30 |
| selection of CX1 and CX2          | 22-31 |
| placement of components           | 22-31 |
| clocking other chips              | 22-31 |
| External Oscillators              | 22-31 |
| gate oscillators vs. discrete     |       |
| devices                           | 22-33 |
| fundamental vs. overtone          |       |
| operation                         | 22-33 |
| "series" vs. "parallel" operation | 22-33 |

# MORE ABOUT USING THE "ON-CHIP" OSCILLATORS

| Oscillator Calculations      | 22-34 |
|------------------------------|-------|
| Start-Up Characteristics     | 22-35 |
| Steady-State Characteristics | 22-37 |
| Pin Capacitance              | 22-38 |
| MCS®-51 Oscillator           | 22-39 |
| MCS®-48 Oscillator           |       |
| Pre-Production Tests         | 22-42 |
| troubleshooting oscillator   |       |
| problems                     | 22-43 |

# **APPENDIX I**

|             | Ceramic Resonator | 22-46 |  |
|-------------|-------------------|-------|--|
| APPENDIX II |                   |       |  |

Oscillator Analysis Program ...... 22-48

# INTRODUCTION

Intel's microcontroller families (MCS®-48, MCS-51, and iACX-96) contain a circuit that is commonly referred to as the ''on-chip oscillator''. The on-chip circuitry is not itself an oscillator, of course, but an amplifier that is suitable for use as the amplifier part of a feedback oscillator. The data sheets and Microcontroller Handbook show how the on-chip amplifier and several offchip components can be used to design a working oscillator. With proper selection of off-chip components, these oscillator circuits will perform better than almost any other type of clock oscillator, and by almost any criterion of excellence. The suggested circuits are simple, economical, stable, and reliable.

We offer assistance to our customers in selecting suitable off-chip components to work with the on-chip oscillator circuitry. It should be noted, however, that Intel cannot assume the responsibility of writing specifications for the off-chip components of the complete oscillator circuit, nor of guaranteeing the performance of the finished design in production, anymore than a transistor manufacturer, whose data sheets show a number of suggested amplifier circuits, can assume responsibility for the operation, in production, of any of them.

We are often asked why we don't publish a list of required crystal or ceramic resonator specifications, and recommend values for the other off-chip components. This has been done in the past, but sometimes with consequences that were not intended.

Suppose we suggest a maximum crystal resistance of 30 ohms for some given frequency. Then your crystal supplier tells you the 30-ohm crystals are going to cost twice as much as 50-ohm crystals. Fearing that Intel will not "guarantee operation" with 50-ohm crystals, you order the expensive ones. In fact, Intel guarantees only what is embodied within an Intel product. Besides, there is no reason why 50-ohm crystals couldn't be used, if the other off-chip components are suitably adjusted.

Should we recommend values for the other off-chip components? Should we do it for 50-ohm crystals or 30-ohm crystals? With respect to what should we optimize their selection? Should we minimize start-up time or maximize frequency stability? In many applications, neither start-up time nor frequency stability are particularly critical, and our "recommendations" are only restricting your system to unnecessary tolerances. It all depends on the application.

Although we will neither "specify" nor "recommend" specific off-chip components, we do offer assistance in these tasks. Intel applications engineers are available to provide whatever technical assistance may be needed or desired by our customers in designing with Intel products.

This Application Note is intended to provide such assis-

tance in the design of oscillator circuits for microcontroller systems. Its purpose is to describe in a practical manner how oscillators work, how crystals and ceramic resonators work (and thus how to spec them), and what the on-chip amplifier looks like electronically and what its operating characteristics are. A BASIC program is provided in Appendix II to assist the designer in determining the effects of changing individual parameters. Suggestions are provided for establishing a pre-production test program.

# FEEDBACK OSCILLATORS

# Loop Gain

Figure 1 shows an amplifier whose output line goes into some passive network. If the input signal to the amplifier is  $v_1$ , then the output signal from the amplifier is  $v_2 = Av_1$  and the output signal from the passive network is  $v_3 = \beta v_2 = \beta A v_1$ . Thus  $\beta A$  is the overall gain from terminal 1 to terminal 3.



Figure 1 — Factors in Loop Gain

Now connect terminal 1 to terminal 3, so that the signal path forms a loop: 1 to 2 to 3, which is also 1. Now we have a feedback loop, and the gain factor  $\beta A$  is called the *loop gain*.

Gain factors are complex numbers. That means they have a magnitude and a phase angle, both of which vary with frequency. When writing a complex number, one must specify both quantities, magnitude and angle. A number whose magnitude is 3, and whose angle is 45 degrees is commonly written this way:  $3/45^{\circ}$ . The number 1 is, in complex number notation,  $1/0^{\circ}$ , while -1 is  $1/180^{\circ}$ .

By closing the feedback loop in Figure 0, we force the equality

$$v_1 = \beta A v_1$$

This equation has two solutions:

1) 
$$v_1 = 0;$$
  
2)  $\beta A = 1/0^{\circ}$ 

In a given circuit, either or both of the above solutions may be in effect. In the first solution the circuit is quiescent (no output signal). If you're trying to make an oscillator, a no-signal condition is unacceptable. There are ways to guarantee that the second solution is the one that will be in effect, and that the quiescent condition will be excluded.

## **How Feedback Oscillators Work**

A feedback oscillator amplifies its own noise and feeds it back to itself in exactly the right phase, at the oscillation frequency, to build up and reinforce the desired oscillations. Its ability to do that depends on its loop gain. First, oscillations can occur only at the frequency for which the loop gain has a phase angle of 0 degrees. Second, build-up of oscillations will occur only if the loop gain exceeds 1 at that frequency. Build-up continues until nonlinearities in the circuit reduce the average value of the loop gain to exactly 1.

Start-up characteristics depend on the small-signal properties of the circuit, specifically, the small-signal loop gain. Steady-state characteristics of the oscillator depend on the large-signal properties of the circuit, such as the transfer curve (output voltage vs. input voltage) of the amplifier, and the clamping effect of the input protection devices. These things will be discussed more fully further on. First we will look at the basic operation of a particular oscillator.

### The Positive Reactance Oscillator

Figure 2 shows the configuration of the positive reactance oscillator. The inverting amplifier, working into the impedance of the feedback network, produces an output signal that is nominally 180 degrees out of phase with its input. The feedback network must provide an additional 180 degrees phase shift, such that the overall loop gain has zero (or 360) degrees phase shift at the oscillation frequency.





In order for the loop gain to have zero phase angle it is necessary that the feedback element  $Z_f$  have a positive reactance. That is, it must be inductive. Then, the frequency at which the phase angle is zero is approximately the frequency at which

$$X_f = \frac{+1}{\omega C}$$

where  $X_f$  is the reactance of  $Z_f$  (the total  $Z_f$  being  $R_f$  +  $jX_f$ , and C is the series combination of  $C_{X1}$  and  $C_{X2}$ .

$$C = \frac{C_{X1}C_{X2}}{C_{X1} + C_{X2}}$$

In other words, Z<sub>f</sub> and C form a parallel resonant circuit.

If  $Z_f$  is an inductor, then  $X_f = \omega L$ , and the frequency at which the loop gain has zero phase is the frequency at which

$$\omega L = \frac{1}{\omega C}$$

or

$$\omega = \frac{1}{\sqrt{\text{LC}}}$$

Normally,  $Z_r$  is not an inductor, but it must still have a positive reactance in order for the circuit to oscillate. There are some piezoelectric devices on the market that show a positive reactance, and provide a more stable oscillation frequency than an inductor will. Quartz crystals can be used where the oscillation frequency is critical, and lower cost ceramic resonators can be used where the frequency is less critical.

When the feedback element is a piezoelectric device, this circuit configuration is called a Pierce oscillator. The advantage of piezoelectric resonators lies in their property of providing a wide range of positive reactance values over a very narrow range of frequencies. The reactance will equal  $1/\omega C$  at some frequency within this range, so the oscillation frequency will be within the same range. Typically, the width of this range is only .3% of the nominal frequency of a quartz crystal, and about 3% of the nominal frequency of a ceramic resonator. With relatively little design effort, frequency accuracies of .03% or better can be obtained with quartz crystals, and .3% or better with ceramic resonators.

# QUARTZ CRYSTALS

The crystal resonator is a thin slice of quartz sandwiched between two electrodes. Electrically, the device looks pretty much like a 5 or 6 pF capacitor, except that over certain ranges of frequencies the crystal has a positive (i.e., inductive) reactance.

The ranges of positive reactance originate in the piezoelectric property of quartz: Squeezing the crystal generates an internal E-field. The effect is reversible: Applying an E-field causes a mechanical deflection. Applying an AC E-field causes the crystal to vibrate. At certain vibrational frequencies there is a mechanical resonance. As the E-field frequency approaches a frequency of mechanical resonance, the measured reactance of the crystal becomes positive, as shown in Figure 3.



Figure 3 — Crystal Reactance vs. Frequency

Typically there are several ranges of frequencies wherein the reactance of the crystal is positive. Each range corresponds to a different mode of vibration in the crystal. The main resonances are the so-called fundamental response and the third and fifth overtone responses.

The overtone responses shouldn't be confused with the harmonics of the fundamental. They're not harmonics, but different vibrational modes. They're not in general at exact integer multiples of the fundamental frequency. There will also be "spurious" responses, occurring typically a few hundred KHz above each main response.

To assure that an oscillator starts in the desired mode on power-up, something must be done to suppress the loop gain in the undesired frequency ranges. The crystal itself provides some protection against unwanted modes of oscillation; too much resistance in that mode, for example. Additionally, junction capacitances in the amplifying devices tend to reduce the gain at higher frequencies, and thus may discriminate against unwanted modes. In some cases a circuit fix is necessary, such as inserting a trap, a phase shifter, or ferrite beads to kill oscillations in unwanted modes.

# **Crystal Parameters**

### **Equivalent Circuit**

Figure 4 shows an equivalent circuit that is used to represent the crystal for circuit analysis.

The  $R_1$ - $L_1$ - $C_1$  branch is called the motional arm of the crystal. The values of these parameters derive from the mechanical properties of the crystal and are constant for a given mode of vibration. Typical values for various nominal frequencies are shown in Table 1.



Figure 4 — Quartz Crystal: Symbol and Equivalent Circuit

 $C_0$  is called the shunt capacitance of the crystal. This is the capacitance of the crystal's electrodes and the mechanical holder. If one were to measure the reactance of the crystal at a frequency far removed from a resonance frequency, it is the reactance of this capacitance that would be measured. It's normally 3 to 7 pF.

Table 1 — Typical Crystal Parameters

| frequency<br>MHz | R <sub>1</sub><br>ohms | · L <sub>1</sub><br>mH | C <sub>1</sub><br>pF | C₀<br>pF |
|------------------|------------------------|------------------------|----------------------|----------|
| ,2,              | 100                    | 520                    | .012                 | 4        |
| 4.608            | 36                     | 117                    | .010                 | 2.9      |
| 11.25            | 19                     | 8.38                   | .024                 | 5.4      |

The series resonant frequency of the crystal is the frequency at which  $L_1$  and  $C_1$  are in resonance. This frequency is given by

$$f_s = \frac{1}{2\pi \sqrt{L_1 C_1}}$$

At this frequency the impedance of the crystal is  $R_1$  in parallel with the reactance of  $C_0$ . For most purposes, this impedance is taken to be just  $R_1$ , since the reactance of  $C_0$  is so much larger than  $R_1$ .

### Load Capacitance

A crystal oscillator circuit such as the one shown in Figure 2 (redrawn in Figure 5) operates at the frequency for which the crystal is antiresonant (ie, parallelresonant) with the total capacitance across the crystal terminals external to the crystal. This total capacitance external to the crystal is called the load capacitance.

As shown in Figure 5, the load capacitance is given by

$$C_{L} = \frac{C_{X1} C_{X2}}{C_{X1} + C_{X2}} + C_{stray}$$

The crystal manufacturer needs to know the value of  $C_L$  in order to adjust the crystal to the specified frequency.



Figure 5 — Load Capacitance

The adjustment involves putting the crystal in *series* with the specified  $C_L$ , and then "trimming" the crystal to obtain resonance of the series combination of the crystal and  $C_L$  at the specified frequency. Because of the high Q of the crystal, the resonant frequency of the series combination of the crystal and  $C_L$  is the same as the antiresonant frequency of the *parallel* combination of the crystal and  $C_L$ . This frequency is given by

$$f_{a} = \frac{1}{2 \pi \sqrt{L_{1}C_{1} (C_{L} + C_{0})/(C_{1} + C_{L} + C_{0})}}$$

These frequency formulas are derived (in Appendix I) from the equivalent circuit of the crystal, using the assumptions that the Q of the crystal is extremely high, and that the circuit external to the crystal has no effect on the frequency other than to provide the load capacitance  $C_L$ . The latter assumption is not precisely true, but it is close enough for present purposes.

# "Series" vs. "Parallel" Crystals

There is no such thing as a "series cut" crystal as opposed to a "parallel cut" crystal. There are different cuts of crystal, having to do with the parameters of its motional arm in various frequency ranges, but there is no special cut for series or parallel operation.

An oscillator is series resonant if the oscillation frequency is  $f_s$  of the crystal. To operate the crystal at  $f_s$ , the amplifier has to be noninverting. When buying a crystal for such an oscillator, one does not specify a load capacitance. Rather, one specifies the loading condition as "series."

If a "series" crystal is put into an oscillator that has an inverting amplifier, it will oscillate in parallel resonance with the load capacitance presented to the crystal by the oscillator circuit, at a frequency slightly above  $f_{\rm s}.$  In fact, at approximately

$$f_a = f_s \left( 1 + \frac{C_1}{2 (C_L + C_0)} \right)$$

This frequency would typically be about 0.02% above  $\mathbf{f}_{\mathrm{s}}.$ 

# **Equivalent Series Resistance**

The "series resistance" often listed on quartz crystal data sheets is the real part of the crystal impedance at the crystal's calibration frequency. This will be R1 if the calibration frequency is the series resonant frequency of the crystal. If the crystal is calibrated for parallel resonance with a load capacitance CL, the equivalent series resistance will be

$$ESR = R_1 (1 + \frac{C_0}{C_L})^2$$

The crystal manufacturer measures this resistance at the calibration frequency during the same operation in which the crystal is adjusted to the calibration frequency.

# **Frequency Tolerance**

Frequency tolerance as discussed here is not a requirement on the crystal, but on the complete oscillator. There are two types of frequency tolerances on oscillators: frequency *accuracy* and frequency *stability*. Frequency accuracy refers to the oscillator's ability to run at an exact specified frequency. Frequency stability refers to the constancy of the oscillation frequency.

Frequency accuracy requires mainly that the oscillator circuit present to the crystal the same load capacitance that it was adjusted for. Frequency stability requires mainly that the load capacitance be constant.

In most digital applications the accuracy and stability requirements on the oscillator are so wide that it makes very little difference what load capacitance the crystal was adjusted to, or what load capacitance the circuit actually presents to the crystal. For example, if a crystal was calibrated to a load capacitance of 25 pF, and is used in a circuit whose actual load capacitance is 50 pF, the frequency error on that account would be less than 0.01%.

In a positive reactance oscillator, the crystal only needs to be in the intended response mode for the oscillator to satisfy a 0.5% or better frequency tolerance. That's because for any load capacitance the oscillation frequency is certain to be between the crystal's resonant and antiresonant frequencies.

Phase shifts that take place within the amplifier part of the oscillator will also affect frequency accuracy and stability. These phase shifts can normally be modeled as an "output capacitance" that, in the positive reactance oscillator, parallels  $C_{X2}$ . The predictability and constancy of this output capacitance over temperature and device sample will be the limiting factor in determining the tolerances that the circuit is capable of holding.

### **Drive Level**

Drive level refers to the power dissipation in the crystal. There are two reasons for specifying it. One is that the parameters in the equivalent circuit are somewhat dependent on the drive level at which the crystal is calibrated. The other is that if the application circuit exceeds the test drive level by too much, the crystal may be damaged. Note that the terms "test drive level" and "rated drive level" both refer to the drive level at which the crystal is calibrated. Normally, in a microcontroller system, neither the frequency tolerances nor the power levels justify much concern for this specification. Some crystal manufacturers don't even require it for micro-processor crystals.

In a positive reactance oscillator, if one assumes the peak voltage across the crystal to be something in the neighborhood of  $V_{CC}$ , the power dissipation can be approximated as

$$P = 2R_1[\pi f (C_L + C_0) V_{CC}]^2$$

This formula is derived in Appendix I. In a 5V system, P rarely evaluates to more than a milliwatt. Crystals with a standard 1 or 2 mW drive level rating can be used in most digital systems.





# **CERAMIC RESONATORS**

Ceramic resonators operate on the same basic principles as a quartz crystal. Like quartz crystals, they are piezoelectric, have a reactance versus frequency curve similar to a crystal's, and an equivalent circuit that looks just like a crystal's (with different parameter values, however).

The frequency tolerance of a ceramic resonator is about two orders of magnitude wider than a crystal's, but the ceramic is somewhat cheaper than a crystal. It may be noted for comparison that quartz crystals with relaxed tolerances cost about twice as much as ceramic resonators. For purposes of clocking a microcontroller, the frequency tolerance is often relatively noncritical, and the economic consideration becomes the dominant factor.

Figure 6 shows a graph of impedance magnitude versus frequency for a 3.58MHz ceramic resonator. (Note that Figure 6 is a graph of  $|Z_f|$  versus frequency, whereas Figure 3 is a graph of  $X_f$  versus frequency.) A number of spurious responses are apparent in Figure 6. The manufacturers state that spurious responses are more prevalent in the lower frequency resonators (kHz range) than in the higher frequency units (MHz range). For our purposes only the MHz range ceramics need to be considered.





Figure 7 shows the symbol and equivalent circuit for the ceramic resonator, both of which are the same as for the crystal. The parameters have different values, however, as listed in Table 2.

Table 2 — Typical Ceramic Parameters

| frequency<br>MHz | R <sub>1</sub><br>ohms | L <sub>1</sub><br>mH | C <sub>1</sub><br>pF | C₀<br>pF |
|------------------|------------------------|----------------------|----------------------|----------|
| 3.58             | 7                      | .113                 | 19.6                 | 140      |
| 6.0              | 8                      | .094                 | 8.3                  | 60       |
| 8.0              | 7                      | .092                 | 4.6                  | 40       |
| 11.0             | 10                     | .057                 | 3.9                  | 30       |

Note that the motional arm of the ceramic resonator tends to have less resistance than the quartz crystal and also a vastly reduced  $L_1/C_1$  ratio. This results in the motional arm having a Q (given by  $(1/R_1) \sqrt{L_1/C_1}$ ) that is typically two orders of magnitude lower than that of a quartz crystal. The lower Q makes for a faster startup of the oscillator and for a less closely controlled frequency (meaning that circuitry external to the resonator will have more influence on the frequency than with a quartz crystal).

Another major difference is that the shunt capacitance of the ceramic resonator is an order of magnitude higher than  $C_0$  of the quartz crystal and more dependent on the frequency of the resonator.

The implications of these differences are not all obvious, but some will be indicated in the section on Oscillator Calculations.

### Specifications for Ceramic Resonators

Ceramic resonators are easier to specify than quartz crystals. All the vendor wants to know is the desired frequency and the chip you want it to work with. They'll supply the resonators, a circuit diagram showing the positions and values of other external components that may be required and a guarantee that the circuit will work properly at the specified frequency.

# **OSCILLATOR DESIGN CONSIDERATIONS**

Designers of microcontroller systems have a number of options to choose from for clocking the system. The main decision is whether to use the ''on-chip'' oscillator or an external oscillator. If the choice is to use the onchip oscillator, what kinds of external components are needed to make it operate as advertised? If the choice is to use an external oscillator, what type of oscillator should it be?

The decisions have to be based on both economic and technical requirements. In this section we'll discuss some of the factors that should be considered.





# **On-Chip Oscillators**

In most cases, the on-chip amplifier with the appropriate external components provides the most economical solution to the clocking problem. Exceptions may arise in severe environments when frequency tolerances are tighter than about 0.01%.

The external components that need to be added are a positive reactance (normally a crystal or ceramic resonator) and the two capacitors  $C_{\chi_1}$  and  $C_{\chi_2}$ , as shown in Figure 8.

# **Crystal Specifications**

Specifications for an appropriate crystal are not very critical, unless the frequency is. *Any* fundamental-mode crystal of medium or better quality can be used.

We are often asked what maximum crystal resistance should be specified. The best answer to this question is the lower the better, but use what's available. The crystal resistance will have some effect on start-up time and steady-state amplitude, but not so much that it can't be compensated for by appropriate selection of the capacitances  $C_{\rm X1}$  and  $C_{\rm X2}$ .

Similar questions are asked about specifications of load capacitance and shunt capacitance. The best advice we can give is to understand what these parameters mean and how they affect the operation of the circuit (that being the purpose of this Application Note), and then decide for yourself if such specifications are meaningful in your application or not. Normally, they're not, unless your frequency tolerances are tighter than about 0.1%.

Part of the problem is that crystal manufacturers are accustomed to talking "ppm" tolerances with radio engineers and simply won't take your order until you've filled out their list of specifications. It will help if you define your actual frequency tolerance requirements, both for yourself and to the crystal manufacturer. Don't pay for 0.003% crystals if your actual frequency tolerance is 1%.

## **Oscillation Frequency**

The oscillation frequency is determined 99.5% by the crystal and up to about 0.5% by the circuit external to the crystal. The on-chip amplifier has little effect on the frequency, which is as it should be, since the amplifier parameters are temperature and process dependent.

The influence of the on-chip amplifier on the frequency is by means of its input and output (pin-to-ground) capacitances, which parallel  $C_{X1}$  and  $C_{X2}$ , and the XTAL1to-XTAL2 (pin-to-pin) capacitance, which parallels the crystal. The input and pin-to-pin capacitances are about 7 pF each. Internal phase deviations from the nominal 180° can be modeled as an output capacitance of 25 to 30 pF. These deviations from the ideal have less effect in the positive reactance oscillator (with the inverting amplifier) than in a comparable series resonant oscillator (with the noninverting amplifier) for two reasons: first, the effect of the output capacitance is lessened, if not swamped, by the off-chip capacitor; secondly, the positive reactance oscillator is less sensitive, frequencywise, to such phase errors.

# Selection of C<sub>x1</sub> and C<sub>x2</sub>

Optimal values for the capacitors  $C_{X1}$  and  $C_{X2}$  depend on whether a quartz crystal or ceramic resonator is being used, and also on application-specific requirements on start-up time and frequency tolerance.

Start-up time is sometimes more critical in microcontroller systems than frequency stability, because of various reset and initialization requirements.

Less commonly, accuracy of the oscillator frequency is also critical, for example, when the oscillator is being used as a time base. As a general rule, fast start-up and stable frequency tend to pull the oscillator design in opposite directions.

Considerations of both start-up time and frequency stability over temperature suggest that  $C_{X1}$  and  $C_{X2}$  should be about equal and at least 20 pF. (But they don't *have* to be either.) Increasing the value of these capacitances above some 40 or 50 pF improves frequency stability. It also tends to increase the start-up time. There is a maximum value (several hundred pF, depending on the value of  $R_1$  of the quartz or ceramic resonator) above which the oscillator won't start up at all.

If the on-chip amplifier is a simple inverter, such as in the 8051, the user can select values for  $C_{X1}$  and  $C_{X2}$ between some 20 and 100 pF, depending on whether start-up time or frequency stability is the more critical parameter in a specific application. If the on-chip amplifier is a Schmitt Trigger, such as in the 8048, smaller values of  $C_{X1}$  must be used (5 to 30 pF), in order to prevent the oscillator from running in a relaxation mode.

Later sections in this Application Note will discuss the effects of varying  $C_{X1}$  and  $C_{X2}$  (as well as other parameters), and will have more to say on their selection.

### **Placement of Components**

Noise glitches arriving at the XTAL1 or XTAL2 pins at the wrong time can cause a miscount in the internal clock-generating circuitry. These kinds of glitches can be produced through capacitive coupling between the oscillator components and PCB traces carrying digital signals with fast rise and fall times. For this reason, the oscillator components should be mounted close to the chip and have short, direct traces to the XTAL1, XTAL2, and VSS pins.

#### **Clocking Other Chips**

There are times when it would be desirable to use the on-chip oscillator to clock other chips in the system.



# Figure 9 — Using the On-Chip Oscillator to Drive Other Chips

This can be done if an appropriate buffer is used. A TTL buffer puts too much load on the on-chip amplifier for reliable start-up. A CMOS buffer (such as the 74HC04) can be used, if it's fast enough and if its VIH and VIL specs are compatible with the available signal amplitudes. Circuits such as shown in Figure 9 might also be considered for these types of applications.

Clock-related signals are available at the TO pin in the MCS-48 products, at ALE in the MCS-48 and MCS-51 lines, and the iACX-96 controllers provide a CLKOUT signal.

# **External Oscillators**

When technical requirements dictate the use of an external oscillator, the external drive requirements for the microcontroller, as published in the data sheet, must be carefully noted. The logic levels are not in general TTLcompatible. And each controller has its idiosyncracies in this regard. The 8048, for example, requires that both XTAL1 and XTAL2 be driven. The 8051 *can* be driven that way, but the data sheet suggest the simpler method of grounding XTAL1 and driving XTAL2. For this method, the driving source must be capable of sinking some current when XTAL2 is being driven low.

For the external oscillator itself, there are basically two choices: ready-made and home-grown.



## Figure 10 — Pre-packaged Oscillator Data\*

Prepackaged oscillators are available from most crystal manufacturers, and have the advantage that the system designer can treat the oscillator as a black box whose performance is guaranteed by people who carry many years of experience in designing and building oscillators. Figure 10 shows a typical data sheet for some prepackaged oscillators. Oscillators are also available with complementary outputs.

If the oscillator is to drive the microcontroller directly, one will want to make a careful comparison between the external drive requirements in the microcontroller data sheet and the oscillator's output logic levels and test conditions.

If oscillator stability is less critical than cost, the user

\*Reprinted with the permission of © Midland-Ross Corporation 1982

may prefer to go with an in-house design. Not without some precautions, however.

It's easy to design oscillators that work. Almost all of them do work, even if the designer isn't too clear on why. The key point here is that *almost* all of them work. The problems begin when the system goes into production, and marginal units commence malfunctioning in the field. Most digital designers, after all, are not very adept at designing oscillators for production.

Oscillator design is somewhat of a black art, with the quality of the finished product being very dependent on the designer's experience and intuition. For that reason the most important consideration in any design is to have an adequate preproduction test program. Preproduction tests are discussed later in this Application Note. Here we will discuss some of the design options and take a look at some commonly used configurations.

#### **Gate Oscillators versus Discrete Devices**

Digital systems designers are understandably reluctant to get involved with discrete devices and their peculiarities (biasing techniques, etc.). Besides, the component count for these circuits tends to be quite a bit higher than what a digital designer is used to seeing for that amount of functionality. Nevertheless, if there are unusual requirements on the accuracy and stability of the clock frequency, it should be noted that discrete device oscillators can be tailored to suit the exact needs of the application and perfected to a level that would be difficult for a gate oscillator to approach.

In most cases, when an external oscillator is needed, the designer tends to rely on some form of a gate oscillator. A TTL inverter with a resistor connecting the output to the input makes a suitable inverting amplifier. The resistor holds the inverter in the transition region between logical high and low, so that at least for start-up purposes the inverter is a linear amplifier.

The feedback resistance has to be quite low, however, since it must conduct current sourced by the input pin without allowing the DC input voltage to get too far above the DC output voltage. For biasing purposes, the feedback resistance should not exceed a few k-ohms.





But shunting the crystal with such a low resistance does not encourage start-up.

Consequently, the configuration in Figure 11A might be suggested. By breaking  $R_f$  into two parts and AC-grounding the midpoint, one achieves the DC feedback required to hold the inverter in its active region, but without the negative signal feedback that is in effect telling the circuit *not* to oscillate. However, this biasing scheme will increase the start-up time, and relaxation-type oscillations are also possible.

A CMOS inverter, such as the 74HC04, might work better in this application, since a larger  $R_f$  can be used to hold the inverter in its linear region.

Logic gates tend to have a fairly low output resistance, which destabilizes the oscillator. For that reason a resistor Rx is often added to the feedback network, as shown in Figure 11 A and B. At higher frequencies a 20 or 30 pF capacitor is sometimes used in the Rx position, to compensate for some of the internal propagation delay.

Reference 1 contains an excellent discussion of gate oscillators, and a number of design examples.

#### **Fundamental versus Overtone Operation**

It's easier to design an oscillator circuit to operate in the resonator's fundamental response mode than to design one for overtone operation. A quartz crystal whose fundamental response mode covers the desired frequency can be obtained up to some 30 MHz. For frequencies above that, the crystal might be used in an overtone mode.

Several problems arise in the design of an overtone oscillator. One is to stop the circuit from oscillating in the fundamental mode, which is what it would really rather do, for a number of reasons, involving both the amplifying device and the crystal. An additional problem with overtone operation is an increased tendency to spurious oscillations. That is because the  $R_1$  of various spurious modes is likely to be about the same as  $R_1$  of the intended overtone response. It may be necessary, as suggested in reference 1, to specify a "spurious-tomain-response" resistance ratio to avoid the possibility of trouble.

Overtone oscillators are not to be taken lightly. One would be well advised to consult with an engineer who is knowledgeable in the subject during the design phase of such a circuit.

#### Series versus Parallel Operation

Series resonant oscillators use noninverting amplifiers. To make a noninverting amplifier out of logic gates requires that two inverters be used, as shown in Figure 12.

This type of circuit tends to be inaccurate and unstable

in frequency over variations in temperature and VCC. It has a tendency to oscillate at overtones, and to oscillate through  $C_0$  of the crystal or some stray capacitance rather than as controlled by the mechanical resonance of the crystal.

The demon in series resonant oscillators is the phase shift in the amplifier. The series resonant oscillator wants more than just a "noninverting" amplifier — it wants a zero phase-shift amplifier. Multistage noninverting amplifiers tend to have a considerably lagging phase shift, such that the crystal reactance must be capacitive in order to bring the total phase shift around the feedback loop back up to 0. In this mode, a "12 MHz" crystal may be running at 8 or 9 MHz. One can put a capacitor in series with the crystal to relieve the crystal of having to produce all of the required phase shift, and bring the oscillation frequency closer to fs. However, to further complicate the situation, the amplifier's phase shift is strongly dependent on frequency, temperature, VCC, and device sample.



## Figure 12 — "Series Resonant" Gate Oscillator

Positive reactance oscillators ("parallel resonant") use inverting amplifiers. A single logic inverter can be used for the amplifier, as in Figure 11. The amplifier's phase shift is less critical, compared to the series resonant circuit, and since only one inverter is involved there's less phase error anyway. The oscillation frequency is effectively bounded by the resonant and antiresonant frequencies of the crystal itself. In addition, the feedback network includes capacitors that parallel the input and output terminals of the amplifier, thus reducing the effect of unpredictable capacitances at these points.

# MORE ABOUT USING THE "ON-CHIP" OSCILLATORS

In this section we will describe the on-chip inverters on selected microcontrollers in some detail, and discuss criteria for selecting components to work with them. Future data sheets will supplement this discussion with updates and information pertinent to the use of each chip's oscillator circuitry.

## **Oscillator Calculations**

Oscillator design, though aided by theory, is still largely an empirical exercise. The circuit is inherently nonlinear, and the normal analysis parameters vary with instantaneous voltage. In addition, when dealing with the on-chip circuitry, we have FETs being used as resistors, resistors being used as interconnects, distributed delays, input protection devices, parasitic junctions, and processing variations.

Consequently, oscillator calculations are never very precise. They can be useful, however, if they will at least indicate the effects of *variations* in the circuit parameters on start-up time, oscillation frequency, and steady-state amplitude. Start-up rime, for example, can be taken as an indication of start-up reliability. If preproduction tests indicate a possible start-up problem, a relatively inexperienced designer can at least be made aware of what





parameter may be causing the marginality, and what direction to go in to fix it.

The analysis used here is mathematically straightforward but algebraically intractable. That means it's relatively easy to understand and program into a computer, but it will not yield a neat formula that gives, say, steady-state amplitude as a function of this or that list of parameters. A listing of a BASIC program that implements the analysis will be found in Appendix II.

When the circuit is first powered up, and before the oscillations have commenced (and if the oscillations *fail* to commence), the oscillator can be treated as a small signal linear amplifier with feedback. In that case, standard small-signal analysis techniques can be used to determine start-up characteristics. The circuit model used in this analysis is shown in Figure 13.

The circuit approximates that there are no highfrequency effects within the amplifier itself, such that its high-frequency behavior is dominated by the load impedance  $Z_L$ . This is a reasonable approximation for single-stage amplifiers of the type used in 8051-type devices. Then the gain of the amplifier as a function of frequency is

$$A = \frac{A_v Z_L}{Z_L + R_0}$$



Figure 14 — Loop Gain versus Frequency (4.608 MHz Crystal)

The gain of the feedback network is

$$\beta = \frac{Z_1}{Z_1 + Z_f}$$

And the loop gain is

1

$$BA = \frac{1}{Z_1 + Z_f} \cdot \frac{A_v Z_L}{Z_L + R_0}$$

The impedances  $Z_L$ ,  $Z_f$ , and  $Z_i$  are defined in Figure 13B.

Figure 14 shows the way the loop gain thus calculated (using typical 8051-type parameters and a 4.608 MHz crystal) varies with frequency. The frequency of interest is the one for which the phase of the loop gain is zero. The accepted criterion for start-up is that the magnitude of the loop gain must exceed unity at this frequency. This is the frequency at which the circuit is in resonance. It corresponds very closely with the antiresonant frequency of the motional arm of the crystal in parallel with  $C_1$ .

Figure 15 shows the way the loop gain varies with frequency when the parameters of a 3.58MHz ceramic resonator are used in place of a crystal (the amplifier parameters being typical 8051, as in Figure 14). Note the different frequency scales.





#### Start-Up Characteristics

It is common, in studies of feedback systems, to examine the behavior of the closed loop gain as a function of complex frequency  $s = \sigma + j\omega$ ; specifically, to determine the location of its poles in the complex plane. A pole is a point on the complex plane where the gain function goes to infinity. Knowledge of its location can be used to predict the response of the system to an input disturbance.

The way that the response function depends on the location of the poles is shown in Figure 16. Poles in the left half plane cause the response function to take the form of a damped sinusoid. Poles in the right half plane cause the response function to take the form of an exponentially growing sinusoid. In general,

$$v(t) \sim e^{at}sin(\omega t + \Theta)$$

where a is the real part of the pole frequency. Thus if the pole is in the right half plane, a is positive and the sinusoid grows. If the pole is in the left half plane, a is negative and the sinusoid is damped.

The same type of analysis can usefully be applied to oscillators. In this case, however, rather than trying to ensure that the poles are in the left half plane, we would seek to ensure that they're in the *right* half plane. An



Figure 16 — Do You Know Where Your Poles are Tonight?

exponentially growing sinusoid is exactly what is wanted from an oscillator that has just been powered up.

The gain function of interest in oscillators is  $1/(1-\beta A)$ . Its poles are at the complex frequencies where  $\beta A = 1 / \underline{0}^{\circ}$ , because that value of  $\beta A$  causes the gain function to go to infinity. The oscillator will start up if the real part of the pole frequency is positive. More importantly, the *rate* at which it starts up is indicated by how *much* greater than 0 the real part of the pole frequency is.



Figure 17 — Oscillator Start-Up (4.608 MHz Crystal from Standard Crystal Corp.)

The circuit in Figure 13B can be used to find the pole frequencies of the oscillator gain function. All that needs to be done is evaluate the impedances at complex frequencies  $\sigma + j\omega$  rather than just at  $\omega$ , and find the value of  $\sigma + j\omega$  for which  $\beta A = 1 \ \underline{0}^{\circ}$ . The larger that value of  $\sigma$  is, the faster the oscillator will start up.

Of course, other things besides pole frequencies, things like the VCC rise time, are at work in determining the start-up time. But to the extent that the pole frequencies





do affect start-up time, we can obtain results like those in Figures 17 and 18.

To obtain these figures, the pole frequencies were computed for various values of capacitance  $C_X$  from XTAL1 and XTAL2 to ground (thus  $C_{X1} = C_{X2} = C_X$ ). Then a "time constant" for start-up was calculated as  $T_s = \frac{1}{\sigma}$  where  $\sigma$  is the real part of the pole frequency

(rad/sec), and this time constant is plotted versus  $C_X$ .

A short time constant means faster start-up. A long time constant means slow start-up. Observations of actual start-ups are shown in the figures. Figure 17 is for a typical 8051 with a 4.608 MHz crystal supplied by Standard Crystal Corp., and Figure 18 is for a typical 8051 with a 3.58MHz ceramic resonator supplied by NTK Technical Ceramics, Ltd.

It can be seen in Figure 17 that, for this crystal, values of  $C_x$  between 30 and 50 pF minimize start-up time, but that the exact value in this range is not particularly important, even if the start-up time itself is critical.

As previously mentioned, start-up time can be taken as an indication of start-up reliability. Start-up problems are normally associated with  $C_{X1}$  and  $C_{X2}$  being too small or too large for a given resonator. If the parameters of the resonator are known, curves such as in Figure 17 or 18 can be generated to define acceptable ranges of values for these capacitors.

As the oscillations grow in amplitude, they reach a level at which they undergo severe clipping within the amplifier, in effect reducing the amplifier gain. As the amplifier gain decreases, the poles move towards the j $\omega$  axis. In steady-state, the poles are on the j $\omega$  axis and the amplitude of the oscillations is constant.

#### **Steady-State Characteristics**

Steady-state analysis is greatly complicated by the fact that we are dealing with large signals and nonlinear circuit response. The circuit parameters vary with instantaneous voltage, and a number of clamping and clipping mechanisms come into play. Analyses that take all these things into account are too complicated to be of general use, and analyses that don't take them into account are too inaccurate to justify the effort.

There is a steady-state analysis in Appendix II that takes some of the complications into account and ignores others. Figure 19 shows the way the steady-state amplitudes thus calculated (using tpical 8051 parameters and a 4.608 MHz crystal) vary with equal bulk capacitance placed from XTAL1 and XTAL2 to ground. Experimental results are shown for comparison.

The waveform at XTAL1 is a fairly clean sinusoid. Its negative peak is normally somewhat below zero, at a level which is determined mainly by the input protection circuitry at XTAL1.



#### Figure 19 — Calculated and Experimental Steady-State Amplitudes vs. Bulk Capacitance from XTAL1 and XTAL2 to ground.

The input protection circuitry consists of an ohmic resistor and an enhancement-mode FET with the gate and source connected to ground (VSS), as shown in Figure 20 for the 8051, and in Figure 21 for the 8048. Its function is to limit the positive voltage at the gate of the input FET to the avalanche voltage of the drain junction. If the input pin is driven below VSS, the drain and source of the protection FET interchange roles, so its gate is connected to what is now the drain. In this condition the device resembles a diode with the anode connected to VSS.

There is a parasitic pn junction between the ohmic resistor and the substrate. In the ROM parts (8051, 8048, etc.) the substrate is held at approximately -3V by the on-chip back-bias generator. In the EPROM parts (8751, 8748, etc.) the substrate is connected to VSS.

The effect of the input protection circuitry on the oscillator is that if the XTAL1 signal goes negative, its negative peak is clamped to  $-V_{DS}$  of the protection FET in the ROM parts, and to about -.5V in the EPROM parts. These negative voltages on XTAL1 are in this application self-limiting and nondestructive. The clamping action does, however, raise the DC level at XTAL1, which in turn tends to reduce the positive peak at XTAL2. The waveform at XTAL2 resembles a sinusoid riding on a DC level, and whose negative peaks are clipped off at zero.

Since it's normally the XTAL2 signal that drives the internal clocking circuitry, the question naturally arises as to how large this signal must be to reliably do its job. In fact, the XTAL2 signal doesn't have to meet the same VIH and VIL specifications that an external driver would have to. That's because as long as the oscillator is working, the on-chip amplifier is driving itself through its own 0-to-1 transition region, which is very nearly the same as the 0-to-1 transition region in the internal buffer that follows the oscillator. If some processing variations move the transition level higher or lower, the on-chip amplifier tends to compensate for it by the fact that its own transition level is correspondingly higher or lower. (In the 8096, it's the XTAL1 signal that drives the internal clocking circuitry, but the same concept applies.)

The main concern about the XTAL2 signal amplitude is as an indication of the general health of the oscillator. An amplitude of less than about 2.5V peak-to-peak indicates that start-up problems could develop in some units (with low gain) with some crystals (with high  $R_1$ ). The remedy is to either adjust the values (of  $C_{X1}$  and/or  $C_{X2}$  or use a crystal with a lower  $R_1$ .

The amplitudes at XTAL1 and XTAL2 can be adjusted by changing the ratio of the capacitors from XTAL1 and XTAL2 to ground. Increasing the XTAL2 capacitance, for example, decreases the amplitude at XTAL2 and increases the amplitude at XTAL1 by about the same amount. Decreasing both caps increases both amplitudes.

#### Pin Capacitance

Internal pin-to-ground and pin-to-pin capacitances at XTAL1 and XTAL2 will have some effect on the oscillator. These capacitances are normally taken to be in the range of 5 to 10 pF, but they are extremely difficult to evaluate. Any measurement of one such capacitance will necessarily include effects from the others. One advantage of the positive reactance oscillator is that the pin-to-ground capacitances are paralleled by external bulk capacitors, so a precise determination of their value is unnecessary. We would suggest that there is little justification for more precision than to assign them a value of 7 pF (XTAL1-to-ground and XTAL1-to-XTAL2). This value is probably not in error by more than 3 or 4 pF.

The XTAL2-to-ground capacitance is not entirely "pin capacitance," but more like an "equivalent output capacitance" of some 25 to 30 pF, having to include the effect of internal phase delays. This value will vary to some extent with temperature, processing, and frequency.

#### MC5®-51 Oscillator

The on-chip amplifier on the HMOS MCS-51 family is shown in Figure 20. The drain load and feedback "resistors" are seen to be field-effect transistors. The drain load FET,  $R_D$ , is typically equivalent to about 1k to 3k-ohms. As an amplifier, the low frequency voltage gain is normally between -10 and -20, and the output resistance is effectively  $R_D$ .

The 8051 oscillator is normally used with equal bulk capacitors placed externally from XTAL1 to ground and from XTAL2 to ground. To determine a reasonable value of capacitance to use in these positions, given a crystal or ceramic resonator of known parameters, one can use the BASIC analysis in Appendix II to generate curves such as in Figures 17 and 18. This procedure will define a range of values that will minimize start-up time. We don't suggest that smaller values be used than those which minimize start-up time. Larger values than those can be used in applications where increased frequency stability is desired, at some sacrifice in start-up time.



Figure 20 — MCS®-51 Oscillator Amplifier

Standard Crystal Corp. (reference 8) studied the use of their crystals with the MCS-51 family using skew samples supplied by Intel. They suggest putting 30 pF capacitors from XTAL1 and XTAL2 to ground, if the crystal is specified as described in reference 8. They noted that in that configuration and with crystals thus specified, the frequency accuracy was  $\pm 0.01\%$  and the frequency stability was  $\pm 0.005\%$ , and that a frequency accuracy of  $\pm 0.005\%$  could be obtained by substituting a 25 pF fixed cap in parallel with a 5-20 pF trimmer for one of the 30 pF caps.

MCS-51 skew samples have also been supplied to a number of ceramic resonator manufacturers for characterization with their products. These companies should be contacted for application information on their products. In general, however, ceramics tend to want somewhat larger values for  $C_{X1}$  and  $C_{X2}$  than quartz crystals do. As shown in Figure 18, they start up a lot faster that way.

In some applications the actual frequency tolerance required is only 1% or so, the user being concerned mainly that the circuit *will* oscillate. In that case,  $C_{X1}$  and  $C_{X2}$ can be selected rather freely in the range of 20 to 80 pF.

As you can see, "best" values for these components and their tolerances are strongly dependent on the application and its requirements. In any case, their suitability should be verified by environmental testing before the design is submitted to production.

#### MCS®-48 Oscillator

The NMOS and HMOS MCS-48 oscillator is shown in Figure 21. It differs from the 8051 in that its inverting amplifier is a Schmitt Trigger. This configuration was



Figure 21 — MCS®-48 Oscillator Amplifier

chosen to prevent crosstalk from the TO pin, which is adjacent to the XTAL1 pin.

All Schmitt Trigger circuits exhibit a hysteresis effect, as shown in Figure 22. The hysteresis is what makes it less sensitive to noise. The same hysteresis allows any Schmitt Trigger to be used as a relaxation oscillator. All you have to do is connect a resistor from output to input, and a capacitor from input to ground, and the circuit oscillates in a relaxation mode as follows.

If the Schmitt Trigger output is at a logic high, the capacitor commences charging through the feedback resistor. When the capacitor voltage reaches the upper trigger point (UTP), the Schmitt Trigger output switches to a logic low and the capacitor commences discharging



### Figure 22 — Schmitt Trigger Characteristic

through the same resistor. When the capacitor voltage reaches the lower trigger point (LTP), the Schmitt Trigger output switches to a logic high again, and the sequence repeats. The oscillation frequency is determined by the RC time constant and the hysteresis voltage, UTP-LTP.

The 8048 can oscillate in this mode. It has an internal feedback resistor. All that's needed is an external capacitor from XTAL1 to ground. In fact, if a smaller external feedback resistor is added, an 8048 system could be designed to run in this mode. *Do it at your own risk!* This mode of operation is not tested, specified, documented, or encouraged in any way by Intel for the 8048. Future steppings of the device might have a different type of inverting amplifier (one more like the 8051). The CHMOS members of the MCS-48 family do not use a Schmitt Trigger as the inverting amplifier.

Relaxation oscillations in the 8048 must be avoided, and this is the major objective in selecting the off-chip components needed to complete the oscillator circuit.

When an 8048 is powered up, if VCC has a short rise time, the relaxation mode starts first. The frequency is normally about 50kHz. The resonator mode builds more slowly, but it eventually takes over and dominates the operation of the circuit. This is shown in Figure 23A.

Due to processing variations, some units seem to have a harder time coming out of the relaxation mode, particularly at low temperatures. In some cases the resonator oscillations may fail entirely, and leave the device in the relaxation mode. Most units will stick in the relaxation mode at any temperature if  $C_{X1}$  is larger than about 50 pF. Therefore,  $C_{X1}$  should be chosen with some care, particularly if the system must operate at lower temperatures. One method that has proven effective in all units to -40 C is to put 5 pF from XTAL1 to ground and 20 pF from XTAL2 to ground. Unfortunately, while this method does discourage the relaxation mode, it is not an optimal choice for the resonator mode. For one thing, it does not swamp the pin capacitance. Also, it makes for a rather high signal level at XTAL1 (8 or 9 volts peak-to-peak).

The question arises as to whether that level of signal at XTAL1 might damage the chip. Not to worry. The negative peaks are self-limiting and nondestructive. The positive peaks could conceivably damage the oxide, but in fact, NMOS chips (eg, 8048) and HMOS chips (eg, 8048H) are tested to a much higher voltage than that. The technology trend, of course, is to thinner oxides, as the devices shrink in size. For an extra margin of safety, the HMOS II chips (eg, 8048AH) have an internal diode clamp at XTAL1 to VCC.

In reality,  $C_{X1}$  doesn't have to be quite so small to avoid relaxation oscillations, if the minimum operating temperature is not -40 C. For less severe temperature requirements, values of capacitance selected in much the same way as for an 8051 can be used. The circuit should be tested, however, at the system's lowest temperature limit.

Additional security against relaxation oscillations can be obtained by putting a 1M-ohm (or larger) resistor from XTAL1 to VCC. Pulling up the XTAL1 pin this way seems to discourage relaxation oscillations as effectively as any other method (Figure 23B).

Another thing that discourages relaxation oscillations is low VCC. The resonator mode, on the other hand, is much less sensitive to VCC. Thus if VCC comes up relatively slowly (several milliseconds rise time), the resonator mode is normally up and running before the relaxation mode starts (in fact, before VCC has even reached operating specs). This is shown in Figure 23C.

A secondary effect of the hysteresis is a shift in the oscillation frequency. At low frequencies, the output signal from an inverter without hysteresis leads (or lags) the input by 180 degrees. The hysteresis in a Schmitt Trigger, however, causes the output to lead the input by less than 180 degrees (or lag by more than 180 degrees), by an amount that depends on the signal amplitude, as shown in Figure 24. At higher frequencies, there are additional phase shifts due to the various reactances in the circuit, but the phase shift due to the hysteresis is still present. Since the total phase shift in the oscillator's loop gain is necessarily 0 or 360 degrees, it is apparent that as the oscillations build up, the frequency has to change to allow the reactances to compensate for the hysteresis. In normal operation, this additional phase shift due to hysteresis does not exceed a few degrees, and the resulting frequency shift is negligible.

Kyocera, a ceramic resonator manufacturer, studied the

use of some of their resonators (at 6.0MHz, 8.0MHz, and 11.0MHz) with the 8049H. Their conclusion as to the value of capacitance to use at XTAL1 and XTAL2 was that 33 pF is appropriate at all three frequencies. One should probably follow the manufacturer's rec-

ommendations in this matter, since they will guarantee operation.

Whether one should accept these recommendations and guarantees without further testing is, however, another



Figure 23 — Relaxation Oscillations in the 8048



### Figure 24 — Amplitude — Dependent Phase Shift in Schmitt Trigger

matter. Not all users have found the recommendations to be without occasional problems. If you run into difficulties using their recommendations, both Intel and the ceramic resonator manufacturer want to know about it. It is to their interest, and ours, that such problems be resolved.

## **Preproduction Tests**

An oscillator design should never be considered ready for production until it has proven its ability to function acceptably well under worst-case environmental conditions and with parameters at their worst-case tolerance limits. Unexpected temperature effects in parts that may already be near their tolerance limits can prevent startup of an oscillator that works perfectly well on the bench. For example, designers often overlook temperature effects in ceramic capacitors. (Some ceramics are down to 50% of their room-temperature values at  $-20^{\circ}$ C and  $+60^{\circ}$  C.) The problem here isn't just one of



Figure 25 — Oscillator Test Circuit and Software

frequency stability, but also involves start-up time and steady-state amplitude. There may also be temperature effects in the resonator and amplifier.

It will be helpful to build a test jig that will allow the oscillator circuit to be tested independently of the rest of the system. Both start-up and steady-state characteristics should be tested. Figure 25 shows the circuit that was used to obtain the oscillator start-up photographs in this Application Note. This circuit or a modified version of it would make a convenient test vehicle. The oscillator and its relevant components can be physically separated from the control circuitry, and placed in a temperature chamber.

Start-up should be observed under a variety of conditions, including low VCC and using slow and fast VCC rise times. The oscillator should not be reluctant to start up even when VCC is below its spec value for the rest of the chip. (The rest of the chip may not function, but the oscillator should work.) It should also be verified that start-up occurs when the resonator has more than its upper tolerance limit of series resistance. (Put some resistance in series with the resonator for this test.) The bulk capacitors from XTAL1 and XTAL2 to ground should also be varied to their tolerance limits.

The same circuit, with appropriate changes in the software to lengthen the "on" time, can be used to test the steady-state characteristics of the oscillator, specifically the frequency, frequency stability, and amplitudes at XTAL1 and XTAL2.

As previously noted, the voltage swings at these pins are not critical, but they should be checked at the system's temperature limits to ensure that they are in good health. Observing these signals necessarily changes them somewhat. Observing the signal at XTAL2 requires that the capacitor at that pin be reduced to account for





the oscilloscope probe capacitance. Observing the signal at XTAL1 requires the same consideration, plus a blocking capacitor (switch the oscilloscope input to AC), so as to not disturb the DC level at that pin. Alternatively, a MOSFET buffer such as the one shown in Figure 26 can be used. It should be verified by direct measurement that the ground clip on the scope probe is ohmically connected to the scope chassis (probes are incredibly fragile in this respect), and the observations should be made with the ground clip on the VSS pin, or very close to it. If the probe shield isn't operational and in use, the observations are worthless.

Frequency checks should be made with only the oscillator circuitry connected to XTAL1 and XTAL2. The ALE frequency can be counted, and the oscillator frequency derived from that. In systems where the frequency tolerance is only "nominal," the frequency should still be checked to ascertain that the oscillator isn't running in a spurious resonance or relaxation mode. Switching VCC off and on again repeatedly will help reveal a tendency to go into unwanted modes of oscillation.

The operation of the oscillator should then be verified under actual system running conditions. By this stage one will be able to have some confidence that the basic selection of components for the oscillator itself is suitable, so if the oscillator appears to malfunction in the system the fault is not in the selection of these components.

#### **Troubleshooting Oscillator Problems**

The first thing to consider in case of difficulty is that between the test jig and the actual application there may be significant differences in stray capacitances, particularly if the actual application is on a multi-layer board.

Noise glitches, that aren't present in the test jig but are in the application board, are another possibility. Capacitive coupling between the oscillator circuitry and other signals has already been mentioned as a source of miscounts in the internal clocking circuitry. Inductive coupling is also possible, if there are strong currents nearby. These problems are a function of the PCB layout.

Surrounding the oscillator components with "quiet" traces (VCC and ground, for example) will alleviate capacitive coupling to signals that have fast transition times. To minimize inductive coupling, the PCB layout should minimize the areas of the loops formed by the oscillator components. These are the loops that should be checked:

XTAL1 through the resonator to XTAL2; XTAL1 through CX1 to the VSS pin; XTAL2 through CX2 to the VSS pin. It is not unusual to find that the grounded ends of  $C_{X1}$ and  $C_{X2}$  eventually connect up to the VSS pin only after looping around the farthest ends of the board. Not good. Finally, it should not be overlooked that software problems sometimes imitate the symptoms of a slow-starting oscillator or incorrect frequency. Never underestimate the perversity of a software problem.

#### REFERENCES

1. Frerking, M. E., Crystal Oscillator Design and Temperature Compensation, Van Nostrand Reinhold, 1978.

2. Bottom, V., "The Crystal Unit as a Circuit Component," Ch. 7, *Introduction to Quartz Crystal Unit Design*, Van Nostrand Reinhold, 1982.

3. Parzen, B., Design of Crystal and Other Harmonic Oscillators, John Wiley & Sons, 1983.

4. Holmbeck, J. D., "Frequency Tolerance Limitations with Logic Gate Clock Oscillators," *31st Annual Frequency Control Symposium*, June, 1977.

5. Roberge, J. K., "Nonlinear Systems," Ch. 6, *Operational Amplifiers: Theory and Practice*, Wiley, 1975.

6. Eaton, S. S., *Timekeeping Advances Through COS/MOS Technology*, RCA Application Note ICAN-6086.

7. Eaton, S. S. Micropower Crystal-Controlled Oscillator Design Using RCA COS/MOS Inverters, RCA Application Note ICAN-6539.

8. Fisher, J. B., Crystal Specifications for the Intel 8031/8051/8751 Microcontrollers, Standard Crystal Corp. Design Data Note #2F.

9. Murata Mfg. Co., Ltd., Ceramic Resonator "Ceralock" Application Manual.

10. Kyoto Ceramic Co., Ltd., Adaptability Test Between Intel 8049H and Kyocera Ceramic Resonators.

11. Kyoto Ceramic Co., Ltd., *Technical Data on Ceramic Resonator Model KBR-6.0M*, *KBR-8.0M*, *KBR-11.0M Application for 8051 (Intel)*.

12. NTK Technical Ceramic Division, NGK Spark Plug Co., Ltd., NTKK Ceramic Resonator Manual.

and a start of the second second second second second second second second second second second second second s Second second second second second second second second second second second second second second second second

.

| APPENDIX        | I | <br>22 |
|-----------------|---|--------|
| <b>APPENDIX</b> |   | <br>24 |

# APPENDIX I QUARTZ AND CERAMIC RESONATOR FORMULAS

Based on the equivalent circuit of the crystal, the impedance of the crystal is

$$Z_{\text{XTAL}} = \frac{(R_1 + j\omega L_1 + 1/j\omega C_1)(1/j\omega C_0)}{R_1 + j\omega L_1 + 1/j\omega C_1 + 1/j\omega C_1}$$

After some algebraic manipulation, this calculation can be written in the form

$$Z_{\text{XTAL}} = \frac{1}{j\omega(C_1 + C_0)} \cdot \frac{1 - \omega^2 L_1 C_1 + j\omega R_1 C_1}{1 - \omega^2 L_1 C_T + j\omega R_1 C_T}$$

where  $C_T$  is the capacitance of  $C_1$  in series with  $C_0$ :

$$C_{T} = \frac{C_1 C_0}{C_1 + C_0}$$

The impedance of the crystal in parallel with an external load capacitance  $C_L$  is the same expression, but with  $C_0 + C_L$  substituted for  $C_0$ :

$$Z_{\text{XTAL } \| \text{CL}} = \frac{1}{j\omega(C_1 + C_0 + C_L)} \cdot \frac{1 - \omega^2 L_1 C_1 + j\omega R_1 C_1}{1 - \omega^2 L_1 C_T' + j\omega R_1 C_T'}$$

where  $C'_{T}$  is the capacitance of  $C_{1}$  in series with  $(C_{0}+C_{L})$ :

$$C'_{T} = \frac{C_{1}(C_{0} + C_{L})}{C_{1} + C_{0} + C_{L}}$$

The impedance of the crystal in *series* with the load capacitance is

$$Z_{\text{XTAL}+\text{CL}} = Z_{\text{XTAL}} + \frac{1}{j\omega\text{C}_{\text{L}}}$$
  
=  $\frac{\text{C}_{\text{L}} + \text{C}_{1} + \text{C}_{0}}{j\omega\text{C}_{\text{L}}(\text{C}_{1} + \text{C}_{0})} \cdot \frac{1 - \omega^{2}\text{L}_{1}\text{C}_{\text{T}}' + j\omega\text{R}_{1}\text{C}_{\text{T}}'}{1 - \omega^{2}\text{L}_{1}\text{C}_{\text{T}} + j\omega\text{R}_{1}\text{C}_{\text{T}}'}$ 

where  $C_T$  and  $C'_T$  are as defined above.

The phase angles of these impedances are readily obtained from the impedance expressions themselves:

$$\Theta_{\text{XTAL}} = \arctan \frac{\omega R_1 C_1}{1 - \omega^2 L_1 C_1}$$
$$-\arctan \frac{\omega R_1 C_T}{1 - \omega^2 L_1 C_T} - \frac{\pi}{2}$$
$$\Theta_{\text{XTAL} \parallel C_L} = \arctan \frac{\omega R_1 C_1}{1 - \omega^2 L_1 C_1}$$
$$-\arctan \frac{\omega R_1 C_T}{1 - \omega^2 L_1 C_T} - \frac{\pi}{2}$$

$$\Theta_{\text{XTAL}+\text{CL}} = \arctan \frac{\omega R_1 C_1'}{1 - \omega^2 L_1 C_1'} - \arctan \frac{\omega R_1 C_T}{1 - \omega^2 L_1 C_T} - \frac{\pi}{2}$$

The resonant ("series resonant") frequency is the frequency at which the phase angle is zero and the impedance is low. The antiresonant ("parallel resonant") frequency is the frequency at which the phase angle is zero and the impedance is high.

Each of the above  $\Theta$ -expressions contains two arctan functions. Setting the denominator of the argument of the first arctan function to zero gives (approximately) the "series resonant" frequency for that configuration. Setting the denominator of the argument of the second arctan function to zero gives (approximately) the "parallel resonant" frequency for that configuration.

For example, the resonant frequency of the crystal is the frequency at which

Thus,

or

$$1 - \omega^2 L_1 C_1 = 0$$
$$\omega_s = \frac{1}{\sqrt{L_1 C_1}}$$
$$f_s = \frac{1}{2\pi\sqrt{L_1 C_1}}$$

It will be noted that the series resonant frequency of the "XTAL+CL" configuration (crystal in series with CL) is the same as the parallel resonant frequency of the "XTAL  $\parallel$  CL" configuration (crystal in parallel with C<sub>L</sub>). This is the frequency at which

 $1 - \omega^2 L_1 C_T' = 0$ 

Thus,

or

$$\begin{split} \omega_{a} &= \frac{1}{\sqrt{L_{1}C_{T}'}} \\ f_{a} &= \frac{1}{2\pi\sqrt{L_{1}C_{T}'}} \end{split}$$

This fact is used by crystal manufacturers in the process of calibrating a crystal to a specified load capacitance.

By subtracting the resonant frequency of the crystal from its antiresonant frequency, one can calculate the range of frequencies over which the crystal reactance is positive:

$$f_{a} - f_{s} = f_{s} \left( \sqrt{1 + C_{1}/C_{0}} - 1 \right)$$
$$= f_{s} \left( \frac{C_{1}}{2C_{0}} \right)$$

Given typical values for  $C_1$  and  $C_0$ , this range can hardly exceed 0.5% of fs. Unless the inverting amplifier in the positive reactance oscillator is doing something very strange indeed, the oscillation frequency is bound to be accurate to that percentage whether the crystal was calibrated for series operation or to any unspecified load capacitance.

#### Equivalent Series Resistance

ESR is the real part of  $Z_{XTAL}$  at the oscillation frequency. The oscillation frequency is the parallel resonant frequency of the "XTAL || CL" configuration (which is the same as the series resonant frequency of the "XTAL+CL" configuration). Substituting this frequency into the  $Z_{XTAL}$  expression yields, after some algebraic manipulation,

$$ESR = \frac{R_{1} \left(\frac{C_{0} + C_{L}}{C_{L}}\right)^{2}}{1 + \omega^{2} C_{1}^{2} \left(\frac{C_{0} + C_{L}}{C_{L}}\right)^{2}}$$
$$\cong R_{1} \left(1 + \frac{C_{0}}{C_{L}}\right)^{2}$$

#### **Drive Level**

The power dissipated by the crystal is  $I_1^2R_1$ , where  $I_1$  is the RMS current in the motional arm of the crystal. This current is given by  $V_x/|Z_1|$ , where  $V_x$  is the RMS voltage across the crystal, and  $|Z_1|$  is the magnitude of the impedance of the motional arm. At the oscillation frequency, the motional arm is a positive (inductive) reactance in parallel resonance with  $(C_0 + C_L)$ . Therefore  $|Z_1|$  is approximately equal to the magnitude of the reactance of  $(C_0 + C_L)$ :

$$|Z_1| = \frac{1}{2\pi f(C_0 + C_L)}$$

where f is the oscillation frequency. Then,

$$\mathbf{P} = \mathbf{I}_{1}^{2}\mathbf{R}_{1} = \left(\frac{\mathbf{V}_{\mathbf{x}}}{|\mathbf{Z}_{1}|}\right)^{2}\mathbf{R}_{1}$$
$$= [2\pi f(\mathbf{C}_{0} + \mathbf{C}_{1})\mathbf{V}_{\mathbf{x}}]^{2}\mathbf{R}_{1}$$

The waveform of the voltage across the crystal (XTAL1 to XTAL2) is approximately sinusoidal. If its peak value is VCC, then  $V_x$  is VCC/ $\sqrt{2}$ . Therefore,

$$P = 2R_{1}[\pi f(C_{0} + C_{L})V_{CC}]^{2}$$

# APPENDIX II OSCILLATOR ANALYSIS PROGRAM

The program is written in BASIC. BASIC is excruciatingly slow, but it has some advantages. For one thing, more people know BASIC than FORTRAN. In addition, a BASIC program is easy to develop, modify, and "fiddle around" with. Another important advantage is that a BASIC program can run on practically any small computer system.

Its slowness is a problem, however. For example, the routine which calculates the "start-up time constant" discussed in the text may take several hours to complete. A person who finds this program useful may prefer to convert it to FORTRAN, if the facilities are available.

#### Limitations of the Program

The program was developed with specific reference to 8051-type oscillator circuitry. That means the on-chip amplifier is a simple inverter, and not a Schmitt Trigger. The 8096, the 80C51, the 80C48 and 80C49 all have simple inverters. The 8096 oscillator is almost identical to the 8051, differing mainly in the input protection circuitry. The CHMOS amplifiers have somewhat different parameters (higher gain, for example), and different transition levels than the 8051.

The MCS-48 family is specifically included in the program only to the extent that the input-output curve used in the steady-state analysis is that of a Schmitt Trigger, if the user identifies the device under analysis as an MCS-48 device. The analysis does not include the voltage dependent phase shift of the Schmitt Trigger.

The clamping action of the input protection circuitry is important in determining the steady-state amplitudes. The steady-state routine accounts for it by setting the negative peak of the XTAL1 signal at a level which depends on the amplitude of the XTAL1 signal in accordance with experimental observations. It's an exercise in curve-fitting. A user may find a different type of curve works better. Later steppings of the chips may behave differently in this respect, having somewhat different types of input protection circuitry. It should be noted that the analysis ignores a number of important items, such as high-frequency effects in the on-chip circuitry. These effects are difficult to predict, and are no doubt dependent on temperature, frequency, and device sample. However, they can be simulated to a reasonable degree by adding an "output capacitance" of about 20 pF to the circuit model (ie, in parallel with CX2), as described below.

#### Notes on Using the Program

The program asks the user to input values for various circuit parameters. First the crystal (or ceramic resonator) parameters are asked for. These are R1, L1, C1, and C0. The manufacturer can supply these values for selected samples. To obtain any kind of correlation between calculation and experiment, the values of these parameters must be known for the specific sample in the test circuit. The value that should be entered for C0 is the C0 of the crystal itself plus an estimated 7 pF to account for the XTAL1-to-XTAL2 pin capacitance, plus any other stray capacitance paralleling the crystal that the user may feel is significant enough to be included.

Then the program asks for the values of the XTAL1-toground and XTAL2-to-ground capacitances. For CXTAL1, enter the value of the externally connected bulk capacitor plus an estimated 7 pF for pin capacitance. For CXTAL2, enter the value of the externally connected bulk capacitor plus an estimated 7 pF for pin capacitance plus about 20 pF to simulate high-frequency roll-off and phase shifts in the on-chip circuitry.

Next the program asks for values for the small-signal parameters of the on-chip amplifier. Typically, for the 8051/8751,

| Amplifier Gain Magnitude | =  | 15         |
|--------------------------|----|------------|
| Feedback Resistance      | == | 2300k-ohms |
| Output Resistance        | =  | 2k-ohms    |

The same values can be used for MCS-48 (NMOS and HMOS) devices, but they are difficult to verify, because the Schmitt Trigger does not lend itself to small-signal measurements.

```
100 DEFDBL C. D. F. G. L. P. R. S. X
                                                                    APRTI 8. 1983
200 REM
400 REM
                              FUNCTIONS
500 REM
ADD REM
700 REM
800 REM FNZM(R,X) = MAGNITUDE OF A COMPLEX NUMBER, {R+JX;
900 \text{ DEF ENZM}(R, X) = SOR(R^2+X^2)
1000 REM
1100 REM FNZP(R, X) = ANGLE OF A COMPLEX NUMBER
                                                 TE ROO
1200 REM
                   = 180/PI#ARCTAN(X/R)
                   = 180/PI*ARCTAN(X/R) + 180
                                                 IF R<O AND X>O
1300 REM
                   = 180/PI*ARCTAN(X/R) - 180
                                                 IF R.O AND XCO
1400 REM
1500 DEF FNZP(R,X) = 180/PI*ATN(X/R) - (SGN(R)-1)*SGN(X)*90
1600 REM
1700 REM
            INDUCTIVE IMPEDANCE AT COMPLEX FREQUENCY S+ (F (HZ)
                Z = 2*PI*S*L + J2*PI*F*L
= FNRL(S,L) + JFNXL(F,L)
1800 REM
1900 REM
2000 DEF FNRL(SL,LL) = 2#*PI*SL*LL
2100 DEF FNXL(FL,LL) = 2#*PI*FL*LL
2200 REM
2300 REM
            CAPACITIVE IMPEDANCE AT COMPLEX FREQUENCY S+JF (HZ)
2400 REM
                 Z = 1/[2*PI*(S+_{j}F)*C]
2500 REM
                   = S/[2*PI*(S`2+F`2)*C] + j(-F)/[2*PI*(S`2+F^2)C]
                   = FNRC(S, F, C) + JFNXC(S, F, C)
2600 REM
2700 DEF FNRC(SC,FC,CC) = SC/(2#*PI*(SC 2+FC^2)*CC)
2800 DEF FNXC(SC,FC,CC) = -FC/(2#*PI*(SC`2+FC`2)*CC)
2900 REM
3000 REM
            RATIO OF TWO COMPLEX NUMBERS
3100 REM
                 RA+ j XA
                           RA*RB+XA*XB
                                              XA*RB-RA*XB
3200 REM
                 -----
                         ----
                           + J -----
                             RB^2+XB^2
                                              RB'2+XB^2
3300 REM
                 RB+JX3
3400 REM = FNRR(RA, XA, RB, XB) + JFNRR(RA, XA, RB, XB)
3500 DEF FNRR(RA, XA, RB, XB) = (RA*RB+XA*XB)/(RB 2+XB 2)
3600 DEF FNXR(RA, XA, RB, XB) = (XA*RB-XB*RA)/(RB 2+XB 2)
3700 REM
3800 REM
            PRODUCT OF TWO COMPLEX NUMBERS
                (RA+JXA)*(RB+JXB) = RA*RB-XA*XB + J(XA*RB+RA*XB)
3900 REM
                                    = FNRM(RA, XA, RB, XB) + JFNXM(RA, XA, RB, XB)
4000 REM
4100 DEF FNRM(RA, XA, RB, XB) = RA*RB - XA*XB
4200 DEF
         FNXM(RA, XA, RB, XB) = RA*XB + RB*XA
4300 REM
4400 REM
4500 REM
            PARALLEL IMPEDANCES
4600 REM
                                    (RA+JXA)*(RB+JXB)
           (RA+JXA)!!(RB+JXB) =
4700 REM
4800 REM
                                     RA+RB + (XA+XB)
4900 REM
5000 REM
              RA*(RB`2+XB^2)+RB*(RA`2+XA 2)
                                                   XA*(RB`2+XB'2)+XB*(RA^2+XA^2)
5100 REM
5200 REM
                  (RA+RB) 2 + (XA+XB) 2
                                                        (RA+RB)'2 + (XA+XB)^2
5300 REM
5400 REM
           = FNRP(RA, XA, RB, XB) + JFNXP(RA, XA, RB, XB)
5500 DEF FNRP(RA,XA,RB,XB) = (RA*(RB 2+XB 2) + RB*(RA^2+XA^2))/((RA+RB)^2 + (XA+XB)^2)
5600 DEF FNXP(RA,XA,RB,XB) = (XA*(RB 2+XB^2) + XB*(RA^2+XA^2))/((RA+RB)^2 + (XA+XB)^2).
5700 REM
5900 REM
6000 REM
                       BEGIN COMPUTATIONS
6100 REM
6200 LET PI = 3 141592654#
6300 REM
6400 REM
                    DEFINE CIRCUIT PARAMETERS
6500 GOSUB 14500
6600 REM
6700 REM
          ESTABLISH NOMINAL RESONANT AND ANTIRESONANT CRYSTAL FREQUENCIES
6800 FS = FIX(1/(2*PI<SQR(L1*C1)))
6900 FA = FIX(1/(2*PI*EOR(L1*C1*C0/(C1+C0))))
7000 PRINT
7100 PRINT "XTAL IS SERIES RESONANT AT ", FS, " HZ"
7200 PRINT "
                 PARALLEL RESONANT AT ", FA, " HZ"
7300 PRINT
7400 PRINT "SELECT 1 LIST PARAMETERS"
7500 PRINT "
7600 PRINT "
                    2 CIRCUIT ANALYSIS"
                    3 OSCILLATION FREQUENCY"
7700 PRINT "
                    4 START-UP TIME CONSTANT"
7800 PRINT "
                   5 STEADY-STATE ANALYSIS"
```

7900 PRINT 8000 INPUT N 8100 IF N=1 THEN PRINT ELSE 8600 8200 REM ----- LIST PARAMETERS -----8300 REM -----8400 GOSUB 17100 8500 GOTO 6800 8600 IF N=2 THEN PRINT ELSE 9400 8700 REM 8800 REM ------ CIRCUIT ANALYSIS -----8900 PRINT " FREQUENCY S+JF TYPE (S), (F) ' 9000 INPUT SQ. FQ 9100 GOSUB 20200 9200 GOSUB 26600 9300 GOTO 6800 9400 IF N=3 THEN 10300 ELSE 11000 9500 REM 9600 REM ------ OSCILLATION FREQUENCY ------9700 CL = CX\*CY/(CX+CY) + CO 9800 FQ = FIX(1/(2\*PI\*SQR(L1\*C1\*CL/(C1+CL)))) 7700 SG = 0 10000 DF = FIX(10^INT(LOG(FA-FS)/LOG(10)-2)+.5) 10100 DS = 0 10200 RETURN 10300 GOSUB 9700 10400 GDSUB 30300 10500 PRINT 10600 PRINT 10700 PRINT "FREQUENCY AT WHICH LOOP GAIN HAS ZERO PHASE ANGLE " 10800 GOSUB 26600 10900 GOTO 6800 11000 IF N=4 THEN PRINT ELSE 12200 11100 REM 11200 REM --------- START-UP TIME CONSTANT -----11300 PRINT "THIS WILL TAKE SOME TIME . 11400 GOSUB 9700 11500 GOSUB 37700 11600 PRINT 11700 PRINT 11800 PRINT "FREQUENCY AT WHICH LOOP GAIN = 1 AT O DEGRELS " 11700 GOSUB 26600 12000 PRINT · PRINT "THIS YIELDS A START-UP TIME CONSTANT OF ", CSNG(1000000!/(2\*PI\*SQ)), " MICROSECS" 12100 GOTO 6800 12200 IF N=5 THEN PRINT ELSE 7300 12300 REM 12400 REM ------ STEADY-STATE ANALYSIS ------12500 PRINT "STEADY-STATE ANALYSIS" 12600 PRINT 12700 PRINT "SELECT 1 8031/8051" 12800 PRINT " 2 8751" 12900 PRINT " 8035/8039/8040/8048/8049" з 13000 PRINT " 4 8748/8749 13100 INPUT IC% 13200 IF IC%(1 OR IC%)4 THEN 12600 4 8748/8749" 13300 GOSUB 46900 13400 GOTO 7300 13500 REM SUBROUTINE BELOW DEFINES INPUT-OUTPUT CURVE OF OSCILLATOR CKT 13600 IF IC%>2 AND VD=5 AND VI 12 THEN RETURN 13700 VD = -10\*VI + 15 13800 IF V0>5 THEN V0 = 5 13900 IF VO< 2 THEN VD = 2 14000 IF IC%>2 AND VO>2 THEN VO = 5 14100 RETURN 14200 REM 14400 REM 14500 REM DEFINE CIRCUIT PARAMETERS 14600 REM 14700 INPUT " R1 (OHMS)",R1 14800 INPUT " L1 (HENRY)",L1 14900 INPUT " C1 (PF)",X 15000 C1 = X\*1E-12 15100 INPUT " C0 (PF)", X 15200 CO = X+1E-12 15300 INPUT " CXTAL1 (PF)", X 15400 CX = X\*1E-12 15500 INPUT " CXTAL2 (PF)", X 15600 CY = X+1E-12

```
15700 INPUT " GAIN FACTOR MAGNITUDE", AV#
15800 INPUT " AMP FEEDBACK RESISTANCE (K-OHMS)", X
15700 RX = X*1000#
16000 INPUT " AMP DUTPUT RESISTANCE (K-OHMS)",X
16100 RD = X*1000#
16200 REM
16300 REM
                   LIST CURRENT PARAMETER VALUES
16400 REM
16500 GOSUB 17100
16600 RETURN
16700 REM
16800 REM
*****
17000 REM
17100 REM
                      LIST CURRENT PARAMETER VALUES
17200 REM
17300 PRINT
17400 PRINT "CURRENT PARAMETER VALUES 1
                                           R1 = ", R1, " OHMS"
                                          L1 = ", CSNG(L1), " HENRY"
17500 PRINT "
                                         2
                                           C1 = ",CSNG(C1*1E+12)," PF"
C0 = ",CSNG(C0*1E+12)," PF"
17600 PRINT "
                                         з
17700 PRINT "
                                         Λ
17800 PRINT "
                                         5
                                          CXTAL1 = ", CSNG(CX*1E+12), " PF"
                                          CXTAL2 = ", CSNG(CY*1E+12), " PF"
17900 PRINT "
                                         6
18000 PRINT "
                 7 AMPLIFIER GAIN MAGNITUDE = ",AV#
8 FEEDBACK RESISTANCE = ",CSNG(RX* 001)," K-OHMS"
18100 PRINT "
                8
                           DUTPUT RESISTANCE = ", CSNG(RD* 001), " K-DHMS"
18200 PRINT "
                 9
18300 PRINT
18400 PRINT "TO CHANGE A PARAMETER VALUE, TYPE (PARAM NO ), (NEW VALUE) "
18500 PRINT "DTHERWISE, TYPE 0.0 "
18600 INPUT N%, X
18700 IF N%=0, THEN RETURN
18800 IF N%=1 THEN R1 = X
18900 IF N%=2 THEN L1 = X
19000 IF N%=3 THEN C1 = X*1E-12
19100 IF N%=4 THEN CO = X*1E-12
19200 IF N%=5 THEN CX = X*1E-12
19300 IF N%=6 THEN CY = X*1E-12
19400 IF N%=7 THEN AV# = X
19500 IF N%=8 THEN RX = X*1000'
19600 IF N%=9 THEN RD = X*1000'
19700 GOTD 17400
19800 REM
19900 REM
20100 REM
20200 REM
                          CIRCUIT ANALYSIS
20300 REM
20400 REM. This routine calculates the loop gain at complex frequency SQ+jFQ
20500 REM
20600 REM 1 Crystal impedance RE + jXE
20700 REM
20800 X1 = FNXL(FQ,L1) + FNXC(SQ,FQ,C1)
20900 RE = FNRP((R1+FNRL(SQ,L1)+FNRC(SQ,FQ,C1)), X1, FNRC(SQ,FQ,C0), FNXC(SQ,FQ,C0))
21000 XE = FNXP((R1+FNRL(SQ,L1)+FNRC(SQ,FQ,C1)), X1, FNRC(SQ,FQ,C0), FNXC(SQ,FQ,C0))
21100 REM
21200 REM 2 RF + jXF = (RE+jXE)::(amp]ifier feedback resistance)
21300 REM
21400 RF = FNRP(RX, 0, RE, XE)
21500 XF = FNXP(RX, 0, RE, XE)
21600 REM
21700 REM
           3 Input impedance Zi = RI + JXI = impedance of CXTAL1
21800 REM
21900 RI = FNRC(SQ, FQ, C()
22000 XI = FNXC(SQ, FQ, CX)
22100 REM
22200 REM
           4 Load impedance ZL = (impedance of CXTAL2)::[(RF+RI)+j(XF+XI)]
22300 REM
22400 RL = FNRP((RF+RI), (XF+XI), FNRC(SQ, FQ, CY), FNXC(SQ, FQ, CY))
22500 XL = FNXP((RF+RI , (XF+XI), FNRC(S0 F0 CY), FNXC(S0, F0, CY))
22600 REM
22700 REM
           5 Amplifier gain A = -AV*ZL/(ZL+RD)
22800 REM
                                = A(real) + (A(imaginary)
22900 REM
23000 AR#
          = -AV#*FNRR(RI, XI, (RO+RL), XI)
23100 AI#
          = -AV#*FNXR(RL, XL, (RD+RL), XL)
23200 REM
23300 REM
           6 Feedback ratio (beta; = (R]+(xI)/L(RF+R1)+(XF+XI))
23400 REM
                                     = B(real(+ jP(imaginary)
```

23500 REM 23600 BR# = ENRR(RI, XI, (RI+RE), (XI+XE))23700 BI# = FNXR(RI, XI, (RI+RF), (XI+XF)) 23800 REM 23900 REM 7 Amplifier gain in magnitude/phase form. AR+jAI = A at AP degrees 24000 REM 24100 A = FNZM(AR#, AI#) 24200 AP = FNZP(AR#, AI#) 24300 REM 24400 REM 8 (beta) in magnitude/phase form BR+jBI = B at BP degrees 24500 REM 24600 B = FNZM(BR#, BI#) 24700 BP = FNZP(BR#, BI#) 24800 REM 24900 REM 9 Loop gain G = (BR+jBI)\*(AR+jAI)25000 REM ∓ G(real) + jG(imaginary) 25100 REM 25200 GR = FNRM(AR#, AI#, BR#, BI#) 25300 GI = FNXM(AR#, AI#, BR#, BI#) 25400 REM 25500 REM 10 Loop gain in magnitude/phase form GR+jGI = AL at AQ degrees 25600 REM 25700 AL = FNZM(GR,GI) 25800 AQ = FNZP(GR,GI) 25900 RETURN 26000 REM 26100 REM 26300 REM 26400 REM PRINT CIRCUIT ANALYSIS RESULTS 26500 REM 26600 PRINT 26700 PRINT " FREQUENCY = ", SQ, " + J", FQ, " HZ" 26800 PRINT " XTAL IMPEDANCE = ", FNZM(RE, XE)," OHMS AT ", FNZP(RE, XE);" DEGREES" 26900 PRINT " (RE = ", CSNG(RE), " OHMS)" (XE = ", CSNG(XE), " OHMS)" 27000 PRINT " 27100 PRINT " LOAD IMPEDANCE = ", FNZM(RL, XL), " OHMS AT ", FNZP(RL, XL), " DEGREES" 27200 PRINT " LUAD IMPEDANCE = ", FREMINE, XL)," UMMS AT 27200 PRINT " AMPLIFIER GAIN = ", A, " AT ", AP," DEGREES" 27300 PRINT " LEDBACK RATIO = ", B," AT ", BP," DEGREES" 27400 PRINT " LOOP GAIN = ", AL," AT ", AQ, " DEGREES" 27500 RETURN 27600 REM 27700 REM \* 27900 REM 28000 REM SEARCH FOR FREQUENCY (S+JF) 28100 REM AT WHICH LOOP GAIN HAS ZERO PHASE ANGLE 28200 REM 28300 REM This routine searches for the frequency at which the imaginary part 28400 REM of the loop gain is zero. The algorithm is as follows r the loop gain is zero. The algorithm is as follows. 1. Calculate the sign of the imaginary part of the loop gain (GI) 2. Increment the frequency 3. Calculate the sign of GI at the incremented frequency 28500 REM 28600 RFM 28700 REM If the sign of GI has not changed, go back to 2 If the sign of GI has changed, and this frequency is within 28800 REM 4 28900 REM 5 Hz of the previous sign-change, exit the routine Otherwise, divide the frequency increment by -10 29000 REM 29100 REM 6 Go back to 2 29200 REM 29300 REM The routine is entered with the starting frequency SQ+jFQ and starting increment DS+jDF already defined by the calling program 29400 REM In actual use either DS or DF 1s zero, so the routine searches for 29500 REM a GI=O point by incrementing either SQ or FQ while holding the other constant. It returns control to the calling program with the 29600 REM 29700 REM 29800 REM incremented part of the frequency being within 1Hz of the actual 29900 REM GI=0 point 30000 REM 30100 REM 1 CALCULATE THE SIGN OF THE IMAGINARY PART OF THE LOOP GAIN (GI). 30200 REM 30300 GOSUB 20200 30400 GOSUB 26600 30500 IF GI=0 THEN RETURN 30600 SX% = INT(SGN(GI)) 30700 IF SX%=+1 THEN DS = -DS 30800 REM (REVERSAL OF DS FOR GIRO IS FOR THE POLE-SEARCH ROUTINE.) 30900 REM 31000 REM 2 INCREMENT THE FREQUENCY 31100 REM 31200 SP = 50

```
31300 FP = FQ
31400 SQ = SQ + DS
31500 FQ = FQ + DF
31600 REM
31700 REM 3 CALCULATE THE SIGN OF GI AT THE INCREMENTED FREQUENCY
31800 REM
31900 GDSUB 20200
32000 GOSUB 26600
32100 IF INT(SGN(GI))=0 THEN RETURN
32200 REM
32300 REM
             4 IF THE SIGN OF GI HAS NOT CHANGED, GO BACK TO 2
32400 REM
32500 IF SX%+INT(SGN(GI))=0 THEN PRINT ELSE 31400
32600 SX% = -SX%
32700 REM
            5 IF THE SIGN OF GI HAS CHANGED, AND IF THIS FREQUENCY IS WITHIN
1HZ OF THE PREVIOUS SIGN-CHANGE, AND IF GI IS NEGATIVE, THEN,
EXIT THE ROUTINE (THE ADDITIONAL REQUIREMENT FOR NEGATIVE GI
32800 REM
32700 REM
33000 REM
33100 REM
                 IS FOR THE POLE-SEARCH ROUTINE )
33200 REM
33300 IF ABS(SP-SQ)<1 AND ABS(FP-FQ) 1 AND SX%=-1 THEN RETURN
33400 REM
33500 REM
            6 DIVIDE THE FREQUENCY INCREMENT BY -10
33600 REM
33700 DS = -DS/10#
33800 DF = -DF/10#
33900 REM
34000 REM
             7 GO BACK TO 2
34100 REM
34200 GOTO 31200
34300 REM
34400 REM
34600 REM
34700 REM
                              SEARCH FOR POLE EREQUENCY
34800 REM
34900 REM
             This routine searches for the frequency at which the loop gain = 1
             at O degrees That frequency is the pole frequency of the closed-
loop gain function. The pole frequency is a complex number, SG+JFQ
(Hz) Oscillator start-up ensues if SG?O. The algorithm is based on
the calculated behavior of the phase angle of the loop gain in the
35000 REM
35100 REM
35200 REM
35300 REM
             region of interest on the complex plane. The locus of points of zero phase angle crosses the j-axis at the oscillation frequency and at
35400 REM
35500 REM
             some higher frequency. In between these two crossings of the j-axis,
35600 REM
              the locus lies in Quadrant I of the complex plane, forming an
35700 REM
35800 REM
              approximate parabola which opens to the left. The basic plan is to
35900 REM
             follow the locus from where it crosses the j-axis at the oscillation frequency, into Quadrant I, and find the point on that locus where
36000 REM
36100 REM
              the loop gain has a magnitude of 1. The algorithm is as follows
36200 REM
                1 Find the oscillation frequency, O+jFG
36300 REM
                  At this frequency calculate the sign of (AL-1) (AL = magnitude
                2
                    of loop gain )
36400 REM
36500 REM
                з
                  Increment FQ
36600 REM
                4 For this value of FQ, find the value of SQ for which the loop
36700 REM
                    gain has zero phase

5 For this value of SO+jFQ. calculate the sign of (AL-1)
6 If the sign of (AL-1) has not changed, go back to 3
7 If the sign of (AL-1) has changed, and this value of FQ is within 1Hz of the previous sign-change, exit the routine.

36800 REM
36900 REM
37000 REM
37100 REM
                  Otherwise, divide the FQ-increment by -10
Go back to 3
37200 REM
                8
37300 REM
37400 REM
37500 REM
             1 FIND THE OSCILLATION FREQUENCY, 0+,FQ
37600 REM
37700 GOSUB 9700
37800 GOSUB 30300
37900 REM
38000 REM
             2 AT THIS FREQUENCY, CALCULATE THE SIGN OF (AL-1)
38100 REM
38200 SY% = INT(SGN(AL-1())
38300 IF SY%=-1 THEN STOP
38400 REM ESTABLISH INITIAL INCREMENTATION VALUE FOR FQ
38500 F1 = FQ
38600 DF = (FA-F1)/10#
38700 GOSUB 30300
38800 DE = (FQ-F1)/10#
38900 DF = 0
39000 = F1
```

39100 REM 39200 REM 3 INCREMENT FQ 39300 REM 39400 = F0 = F0 + DE39500 REM 39600 REM 4. FOR THIS VALUE OF FG, FIND THE VALUE OF SQ FOR WHICH THE LOOP 39700 REM GAIN HAS ZERO PHASE. (THE ROUTINE WHICH DOES THAT NEEDS DF = 0, 39800 REM SQ THAT IT CAN HOLD FQ CONSTANT, AND NEEDS AN INITIAL VALUE FOR DS, WHICH IS ARBITRARILY SET TO DS = 1000.) 39900 REM 40000 REM 40100 DS = 1000#40200 50 = 040300 GDSUB 30300 40400 IF AL=1! THEN RETURN 40500 REM 40600 REM 5. FOR THIS VALUE OF SQ+JFQ, CALCULATE THE SIGN OF (AL-1). 6 IF THE SIGN OF (AL-1) HAS NOT CHANGED, GO BACK TO 3 40700 REM 40800 REM 40900 IF SY%+INT(SGN(AL-1'))=0 THEN PRINT ELSE 39400 41000 REM 7. IF THE SIGN OF (AL-1) HAS CHANGED, AND THIS VALUE OF FO IS WITHIN 41100 REM 1HZ OF THE PREVIOUS SIGN-CHANGE, EXIT THE ROUTINE 41200 REM 41300 REM 41400 IF ABS(F1-FG)<1 THEN RETURN 41500 REM 41600 REM 8. DIVIDE THE FO-INCREMENT BY -10. 41700 REM 41800 DE = -DE/10# 41900 F1 = FQ42000 SY% = -SY% 42100 REM 42200 REM 9 OD BACK TO 3 42300 REM 42400 GOTO 39400 42500 REM 42600 REM 42800 REM 42900 REM STEADY-STATE ANALYSIS 43000 REM 43100 REM The circuit model used in this analysis is similar to the one used in the small-signal analysis, but differs from it in two respects 43200 REM 43300 REM First, it includes clamping and clipping effects described in the 43400 REM text. Second, the voltage source in the Thevenin equivalent of the 43500 REM amplifier is controlled by the input voltage in accordance with an 43600 REM input-output curve defined elsewhere in the program. 43700 REM The analysis applies a sinusoidal input signal of arbitrary amplitude, at the oscillation frequency, to the XTAL1 pin, then calculates the resulting waveform from the voltage source. Using 43800 REM 43900 REM calculates the resulting waveform from the voltage source USIng standard Fourier techniques, the fundamental frequency component of this waveform is extracted. This frequency component is then multiplied by the factor  $\frac{1}{2L}(\frac{1}{2L+RO})$ , and the result is taken to be the signal appearing at the XTAL2 pin. This signal is then multiplied by the feedback ratio (beta), and the result is taken to be the signal appearing at the XTAL1 pin. The algorithm is now percent. 44000 REM 44100 REM 44200 REM 44300 REM 44400 REM 44500 REM repeated using this computed XTAL1 signal as the assumed input sinusoid. Every time the algorithm is repeated, new values appear at XTAL1 and XTAL2, but the values change less and less with each 44600 REM 44700 REM 44800 REM repetition Eventually they stop changing. This is the steady-state. The algorithm is as follows 44900 REM 45000 REM 45100 REM 1. Compute approximate oscillation frequency Call a circuit analysis at this frequency. 45200 REM 45300 REM 3 Find the quiescent levels at XTAL1 and XTAL2 (to establish the 45400 REM beginning DC level at XTAL1) 45500 REM Assume an initial amplitude for the XTAL1 signal л 45600 REM Correct the DC level at XTAL1 for clamping effects, if necessary 5 45700 REM 6 Using the appropriate input-output curve, extract a DC level and 45800 REM the fundamental frequency component (multiplying the latter by 45900 REM :ZL/(ZL+RO);) Clip off the negative portion of this output signal, if the 46000 REM 7. 46100 REM negative peak falls below zero If this signal, multiplied by (beta), differs from the input amplitude by less than inv. or if the algorithm has been repeated 46200 REM 8 46300 REM 46400 REM 10 times, exit the routine Otherwise, multiply the XTAL2 amplitude by (beta) and feed it 46500 REM 46600 REM back to XTAL1, and go back to 5 46700 REM 46800 REM 1 COMPUTE APPROXIMATE OSCILLATION EREQUENCY

```
46900 GOSUB 9700
47000 REM
                 2. CALL A CIRCUIT ANALYSIS AT THIS FREQUENCY.
47100 REM
47200 GOSUB 20800
47300 PRINT
                PRINT
                           PRINT "ASSUMED OSCILLATION FREQUENCY. "
47400 GOSUB 26600
47500 PRINT
                 PRINT
47600 REM
47700 REM
                 3 FIND QUIESCENT POINT
             At quiescence the voltages at XTAL1 and XTAL2 are equal This
voltage level is found by trial-and-error, based on the input-
output curve, so that a person can change the input-output curve
as desired without having to re-calculate the quiescent point )
47800 REM
47900 REM
48000 REM
48100 REM
48200 VI = 0
48300 VB = 1
48400 K1 = 1
48500 VI = VI + VB
48600 GOSUB 13600
48700 IF ABS(VD-VI)< 001 THEN 49200
48800 IF K1+SGN(VD-VI)=0 THEN 48900 ELSE 48500
48900 K1 = SGN(VD-VI)
49000 VB = -VB/10
47100 GOTO 48500
47200 VB = VI
49300 PRINT "QUIESCENT POINT = "; VB
49400 REM
                 4 ASSUME AN INITIAL AMPLITUDE FOR THE XTAL1 SIGNAL
49500 REM
49600 EI =
             01
49700 NR% = 0
49800 REM
49900 REM
                 5. CORRECT FOR CLAMPING EFFECTS, IF NECESSARY.
50000 REM (K1 and K2 are curve-fitting parameters for the RDM parts.)
50100 K1 = (2.5-VB)/(3-VB)
50200 K2 = (VB-1.25)/(3-VB)
50300 IF IC%=2 OR IC%=4 THEN IF EI<(VB+ 5) THEN EO = VB ELSE EO = EI - 5
50400 IF ICX=1 OR ICX=3 THEN IF EI<(VB+ 5) THEN EO = VB ELSE EO = K1*EI+K2
50500 NR% = NR% + 1
50600 REM
50700 REM
                6. DERIVE XTAL2 AMPLITUDE
50800 V0 = 0
50900 VC = 0
51000 VS = 0
51100 FOR N% = -25 TO +24
51200 VI = E0 - EI*COS(PI*N%/25)
51300 GOSUB 13600
51500 V0 = V0 + V0

51500 VC = VC + V0*C0S(PI*N%/25)
51600 VS = VS + V0*SIN(PI*N%/25)
51700 NEXT N%
51800 VO = VO/50
51900 V1 = SQR(VC^2+VS^2)/25*FNZM(RL,XL)/FNZM((RL+R0),XL)
52000 REM
52100 REM
                 7 CLIP XTALZ SIGNAL
52200 IF VO-V1<0 THEN VL = 0 ELSE VL = VO-V1
52300 PRINT PRINT "XTAL1 SWING = ", EO-EI," TO ", EO+EI
52400 PRINT "XTAL2 SWING = ", VL," TO ", VO+V1
52500 REM
52600 REM
                 8 TEST FOR TERMINATION
52700 IF ABS(EL-V1*B) C OC1 OR NRX=10 THEN PETURN
52800 REM
52900 REM
                 9 FEED BACK TO XTAL1 AND REPEAT
53000 EI = V1*B
53100 GOTO 50300
```

# Design Considerations When Using CHMOS

23

na ser en ser en la companya de la servició de la servició de la servició de la servició de la servició de la s

an ang tao ang Mang tao ang tao Mang tao ang tao 

# CHAPTER 23 DESIGN CONSIDERATIONS WHEN USING CHMOS

#### 23.0 WHAT IS CHMOS?

CHMOS is Intel's n-well CMOS process which is based on the highly developed HMOS-II technology. There are three other types of CMOS processes: p-well, twin-tub, and silicon on sapphire (SOS). All four CMOS structures are discussed in the accompanying article reprint, "Inside CMOS Technology." SOS and twin-tub offer superior performance, but are very costly to manufacture. The n-well technology offers about the same performance as p-well and has been chosen for Intel's microcontrollers because it is imore readily adapted to the currently used and well understood HMOS-II technology. This CMOS technology also offers a known path to higher performance products in the future.

Because CMOS tends to have lower gate density and a higher gate count than an NMOS circuit of the same functionality, the ability to scale down the transistor size in CMOS processes is essential to improving the price/ performance ratio. The penalty paid for the size reduction, however, is a departure from the traditional CMOS supply voltage range of 3 to 18 volts. CHMOS will be limited to a maximum of 6 volts VCC.

Further reduction in CHMOS die size is accomplished by using dynamic nodes at appropriate points in the circuit, whereas, traditional CMOS is fully static. This reduces the gate count, and therefore, the die size — achieving lower cost. However, the use of dynamic nodes imposes a minimum clock frequency requirement on the CHMOS part.

#### 23.1 NOISE IMMUNITY

CMOS noise immunity is greatly over stated. Noise immunity has been described as the amount of noise that can be induced at the input of a gate that will not change the logic state of the output. Noise margin, on the other hand, is the DC levels that will be applied to an input from another output (Voh, Vol) and the trip point of that input.

On the surface, CMOS would seem ideal for use in noisy environments. Output voltages are rail-to-rail, and input switch points are approximately 50% of VCC. There is one thing wrong with this analysis — CMOS has high impedance inputs. High impedance inputs need only voltage and very little current (nano Amps) to switch its output logic state. TTL, on the other hand, needs voltage and at least 20  $\mu$ A (for an LS device) to switch its output logic state. Because it is a lot more difficult to induce noise in the form of current than in the form of voltage, CMOS tends to be more noise sensitive than TTL.

However, NMOS also has high impedance inputs and has input leakages typically less than 1  $\mu$ A. Because NMOS output voltage swings are considerably less than CMOS,

CMOS has the advantage when inputs and outputs are noisy. Another advantage of CMOS over NMOS is the p-channel pullup instead of a depletion pullup. The p-channel pullup is able to charge up the stray capacitance faster thus signal rise times are significantly improved.

In conclusion, don't fool yourself into thinking that CMOS eliminates the need to be concerned about noise problems. Time is well spent following good design practices and layout techniques from the earliest phases of a project.

#### 23.2 LATCH-UP

CHMOS is not immune to traditional CMOS latch-up, but the latch-up threat is highly overrated. Latch-up is usually the result of unforeseen operating conditions, such as an unexpected power-up sequence, inadvertent removal and re-application of a supply voltage, or "hot-socketing" the part (plugging a chip into its socket while the system is active). An energetic voltage spike on VCC or the I/O lines might also trigger latch-up, but a little ringing on the data lines isn't going to cause any problems.

It is helpful to understand the mechanisms involved in the latch-up phenomenon. Figure 23-1A shows the circuit diagram of a typical CMOS output stage. Figure 23-1B shows a plan view of how this stage might look in n-well CMOS (with the gate electrodes of the FETs stripped away, since they are not germane to the discussion). There are two parasitic bipolar transistors in this structure, one pnp and the other npn. The n-well forms the base region of the pnp transistor, which is connected to VCC through the distributed resistance of the n-well. The source and drain of the p-channel pullup FET are dual emitters to the pnp transistor. The p-type substrate is the collector of this transistor and also serves as the base of the npn transistor which is connected to VSS through the distributed resistance of the substrate. The collector of this transistor is the n-well, and the drain and source of the pulldown n-channel FET are dual emitters. These parasitic transistors are shown in Figure 23-1C.

Any pullup FET that shares the same n-well region acts as additional multiple emitters to the parasitic pnp transistor. Much worse, ALL pulldown FETs and input protection devices on the IC act as additional collectors to the parasitic npn transistor. This has several implications. Latch-up is not limited to output stages, inputs only pins and internal gates can also be the cause. So when latchup does occur, it's hard to tell which device caused it.

In normal operation, both of these parasitic bipolar junction transistors are in an off state, and do not hamper the operation of the FETs. However, if either parasitic junction transistor should turn on, its collector current might turn the other parasitic junction transistor on, and an SCR type effect rapidly ensues which is called latch-up.



Figure 23-1. CHMOS Inverter

What might turn on one of the parasitic junction transistors? Look at Figure 23-1C. The base of the parasitic pnp is at VCC, and the base of the npn is at VSS. If the ouput line swings a diode drop above VCC, or below VSS, it forward-biases the "D" emitter of either the pnp or the npn transistor.

Suppose it is the pnp emitter that is forward-biased by the output line swinging a diode drop above VCC. Some of the current that enters that emitter now exits the parasitic device as collector current. It flows down to the juncture of Rsub and the base of the npn transistor. If Rsub is low, the current is shunted through it to VSS, and the npn transistor stays off. If Rsub is high, some of the current crosses the base-emitter junction of the npn, and that transistor will likely turn on.

It is important to note that the designer of the integrated circuit has a certain amount of control over the turn-on probabilities. Grounded guard rings placed around the npn emitters will have the effect of reducing the value of Rsub. Reducing the value of Rsub has the effect of increasing the amount of current that has to enter the pnp D emitter in order to turn the npn transistor on. The CHMOS, the npn transistor will not turn on if the current entering the pnp D emitter is less than 10 mA.

A similar sequence of events can occur when the output line swings a diode drop below VSS. In this case it is the npn transistor that is in danger of turning on the pnp, depending on the value of Rwell and how much current is involved. Again, the IC designer can reduce the value of Rwell by the judicious placement of guard rings, connected to VCC, around the pnp emitters. When the output line swings a diode drop below VSS, if the current that exits the output pin does not exceed 10 mA, there will be no latch-up.

#### 23.3 POWER SUPPLY CONSIDERATIONS

The power supply, as viewed by the microcontroller, should be low in inductance because of the peak currents

associated with CHMOS switching characteristics. Note that the repetition rate of these peak currents increases with the clock frequency. Bypass capacitors of approximately 0.1 $\mu$ F should be used with proper PCB layout to rensure a low inductance, high peak current power source. Low inductance capacitors are also available that fit under the package. These capacitors are also advantages for HMOS in noisy environments (See Application Note AP125 "Designing Microcontroller Systems For Electrically Noisy Environments" in this manual for detailed discussion).

Power supply glitches must be filtered to ensure that the maximum voltage rating of the device is not violated. Violation may induce an SCR effect between VCC/VDD and Vss (latch-up).

The polarity of the power supply must never be reversed. The n-well is connected to VCC and the p-type substrate is connected to ground so normally that pn junction is reversed biased. If VCC or VDD are ever more negative than -0.5 volts with respect to Vss, the n-well/substrate pn junction will be forward biased and short VCC/VDD to ground.

When the microcontroller is powered separately from the surrounding circuitry, the microcontroller should always be powered up before any input signal is applied. The reverse is true when powering down, input signals first then the microcontroller.

When separate VCC and VDD power supplies are used for the 80C49, VDD and VCC must track each other within 1.5 volts (except during power down) and also maintain the 5v 20% specification. This ensures that the CPU, powered by VCC, and the RAM, powered by VDD, have proper voltage levels to communicate. If VCC and VDD cannot be powered up simultaneously, VDD should be applied first.

#### 23.4 MINIMIZING POWER CONSUMPTION

The reason CMOS parts draw considerably less current than an NMOS part is that there is no direct path between VCC and ground (refer to figure 10-1A). When the p-channel pullup FET is on the n-channel pulldown FET is off and the output line gets pulled up. The opposite is true, when the n-channel FET is on the p-channel FET is off and the output goes low. There is leakage associated with either the n-channel and p-channel FETs in the off state. The sum of all the leakages from every inverter on the chip is what is called the "quiescent current." This current is in the order of microAmps and is the lesser of the two currents that add up to the total ICC.

When the inverter is switching in either direction, there is a moment in time when both FETs are on creating a low resistance path between VCC and ground. The capacitance on the output line (pin capacitance; trace capacitance, and input capacitance to the next stage) is also charged or discharged which also increases current consumption. This "dynamic current" is a couple of orders of magnitude higher than the quiescent current.

Power supply voltage also comes into play with both types of currents. If VCC is high, the leakage across the off FET is increased. Output capacitance now has to be charged up to a higher level. So a higher VCC also contributes to making ICC larger.

Frequency of switch can also affect the amount of current used. If the inverter stage is switched very slowly, then the average current is equal to the quiescent current. As the frequency of switching is increased, the dynamic current contributes more and more to the total ICC until the dynamic current totally swamps the quiescent current.

Now that we are aware of what components make up the total ICC, we can work on ways of minimizing it. VCC can play a big roll in minimizing power. If the whole purpose in going to CMOS is to minimize heat dissipation and the power is drawn from the 110 volt AC socket, tweak your power supply to the minimum voltage that the system will run. On the other hand if batteries are used you must consider types of batteries available, lifetime of the battery, and the voltage drop off at the end of its life to determine what voltage to start at. Remember the lower the voltage the lower the current draw.

The application also has to be analyzed for what kind of response time is needed to determine how fast the microcontroller needs to run. If the end application is a direct human interface, then the response time can be relatively slow and the processor can run at minimum speed. But if real time decisions need to be made on evaluating incoming data, then the microcontroller needs all the time it can get. The idea is to run the microcontroller as slow as you can and still get the task accomplished.

Intel has added idle mode and power down features to help further manage your power consumption. Idle mode in the 80C51/80C31 stops the clock to the CPU while keeping the oscillator, RAM, interrupts, timer/counter, and serial port alive. Stopping the clock to the CPU decreases the current in the CPU from dynamic to mostly quiescent. Idle mode consumes approximately 1/10th the operating current.

Idle mode allows the microcontroller to minimize its current when no processing needs to be done. The live interrupts, timer/counter, and the serial port can wake the CPU and since the oscillator is running the response time is quick.

Data on the ports are left in the state they were in when idle was invoked. If careful attention is given to the logic state of the port, total system current can be reduced. The state of the port for reduced current is dependent on what the port is driving. If it is a transistor, the transistor should be put into its off state. If the port pin is driving another CMOS gate, the loading of the port pin would be minimal and a choice of the logic state may be made on what is



Figure 23-2. MCS®-48 Power Down Circuit

on the ouputs of the CMOS gate. If TTL is being driven, the reduced current would be when the port pin is high. A little thought in this area can go a long way in minimizing system current.

Power down removes all internal clocks to decrease the current to totally quiescent current while the contents of the RAM are saved. This mode is useful in hand held applications where data needs to be saved between uses. On the 80C51, the port pins are left in the same state they were in when the power down mode was called. The same thought processes that were needed for reduced current in the idle mode are valid for power down also.

Figure 23-2 shows a simple circuit that uses one quad NOR CMOS integrated circuit and some external resistors and capacitors to power down the CHMOS MCS48 family under the control of one input. To activate the operation of the microcontroller, the AWAKE/ signal is pulled low and in turn, node A goes low turning on the p-channel VFET. This allows VCC to the microcontroller to be pulled to the power supply minus Vsd. Node A being low brings RESET high after a time determined by the R1C1 time constant. The RC has been chosen to allow 10 mS between VCC going high and RESET going high to allow the oscillator time to stabilize.

Powering down is accomplished by AWAKE/ going high which pulls RESET low. The time delay R2C2 allows the reset signal enough time to signal the microcontroller to save the RAM before VCC is shut off.

When idle mode and power down are used in conjunction with slow operating speed it can reduce your power needs to a minimum. Unused input only pins on the MCS48 family such as SS/, T0, and T1 should not be allowed to float. The inputs would float about the trip point of the input buffer. This switching of the input buffer can waste up to .5 mA per input. Tie all unused input only pins high or low.

When the CHMOS units are being used with external program or data memory, PortO (Data Bus on the MCS48 products) is left floating when in idle mode. PortO also floats on the 80C51 when in the power down mode. The same condition as described above can happen with the input gate on those pins. Without tying these pins high or low at least .5 mA  $\times$  8 or 4 mA could be wasted. Tie the PortO pins high or low through a 500K $\Omega$  or 1M $\Omega$  resistor. A little extra board space is minimal when considering the extra power savings.

The quasi-bidirectional pins have internal pullups so the inputs on these pins never float.

#### 23.5 CHMOS I/O PORT STRUCTURE

The CHMOS I/O ports have similar drive capability to their HMOS counterparts, but the differences must be noted.

#### 23.5.1 As An Output Pin

The I/O port structure is implemented as shown in Figure 23-3.

As an output pin latched to a low (0) state, pullups P1, P2, and P3 are in an off state while the pulldown N1 is on. This configuration uses little current, since there is no patch between VCC and ground in the output buffer stage.

#### DESIGN CONSIDERATIONS WHEN USING CHMOS



Figure 23-3. CHMOS Quasi-Bidirectional I/O Port Structure



Figure 23-4. CHMOS I/O Current Characteristics

When the output pin is to be latched in the high (1) state, the data line turns N1 off and turns on the weak ( $5\mu$ A) pullup P2. At the same time P1 (a strong pullup) turns on for one state time pulling the output up very quickly. Once the output voltage is above approximately 2 volts, P3 turns on to supply the source current. P3 and the inverter form a latch. This latch along with the support of P2 keeps the output high. Figure 23-4 shows the VOH vs IOH curve for this output structure when P1 is off.

#### 23.5.2 As An Input Pin

To use the I/O port as an input, a one must be written to the pin first, leaving the pin in a high state. When the input goes below 2 volts, P3 turns off to avoid any high sink currents from being presented to the input device. Note when returning back to a one, P2 is the only internal pullup that is on. This will result in a long rise time if P2 is the only pullup.

#### 23.5.3 Interfacing Between CHMOS and Other Logic Families

Interfacing Intel's CHMOS to other logic families is very simple and straight forward. When VCC is kept within 10% of 5 volts all inputs (except those noted in the data sheets) and outputs are TTL compatible. CMOS compatibility is achieved as long as VCC is kept within 20% of 5 volts.

When driving a high current load, the output current (Ioh) must be limited to keep the output voltage (Voh) at a minimum of 2 volts. If the voltage is pulled below 2 volts the output current will be dropped to approximately 5  $\mu$ A. See Figure 23-4.

# **Inside CMOS Technology**



Photo 1: The die for the 80C51, with the functions of the various sections identified.

How CMOS devices are manufactured and a look at three of them by Martin B. Pawloski, Tony Moroyan, and Joe Altnether CMOS (complementary metaloxide semiconductor) has often been called the ideal technology. It has low power dissipation, high immunity to power-supply noise, symmetric switching characteristics, and a large supply-voltage tolerance. But CMOS has rarely been used for advanced VLSI (very-largescale-integration) microcomputer designs. Because of the complexity of the CMOS process, the ICs (integrated circuits) produced have traditionally had a relatively poor price/performance ratio.

As a result, CMOS was used only in applications that required low power and were neither performance conscious (such as in calculators and watches) nor cost conscious (many military applications, for example). Suddenly, however, all major semiconductor companies have announced either advanced CMOS products or the intention of designing their next generation of high-performance microprocessors using CMOS technology.

What has happened to make CMOS both affordable and high performance? For one thing, the dominant VLSI technology, NMOS (n-channel metal-oxide semiconductor), is rapidly approaching the process complexity of standard CMOS. It is not unusual nowadays for NMOS technology to have up to four transistor types with different operating characteristics. Much of the complexity of this process is added simply to help VLSI designers keep the operating power of their circuits under control.

Second, CMOS circuit designers are being more selective in the use of static CMOS logic. Critically placed dynamic logic, creative circuit design, and use of modes that offer varying degrees of power consumption are all tricks designers are using to maintain the advantages of CMOS.

Finally, aggressive reduction in CMOS transistor size is being used to bring CMOS performance in line with that of NMOS. As a matter of fact, many manufacturers are developing CMOS as a derivative of their advanced NMOS processes. This not only improves CMOS performance levels but also boosts reliability and reduces development costs.

#### The Evolution of LSI

Early LSI circuits were built with p-channel MOS transistors, which permitted high-circuit densities yet were relatively slow and difficult to interface to normal integrated circuits, such as TTL (transistortransistor logic). As an example, the 1103-type 1K by 1-bit dynamic RAM (random-access read/write memory), circa 1971, required its inputs (address, controls, and data) to swing between 1 and 15 volts (V) although its output was measured in millivolts - hardly TTL compatible! About 1974, NMOS came to the rescue. It provided faster speed, and most of its inputs and outputs were TTL compatible.

# Low power requirements are a major advantage of designing a system that uses CMOS.

NMOS was more difficult to manufacture than PMOS because contaminants would vary the thresholds of the n-channel transistors, causing deviations in speed and performance. But this problem was quickly overcome through ultraclean processing rooms, and NMOS became the workhorse technology because it cost less to manufacture, was easy to use, and had good speed-power characteristics. And NMOS technology had potential for greater improvement of its speed-power characteristics through scaling (or shrinking) of the silicon devices. The result of this scaling was HMOS (high-speed NMOS), which accomplished three objectives: increased speed, reduced power, and increased density.

Over the past 10 years, the reduction in transistor size has, at the device level, increased memory density by a factor of 64, increased speed by a factor of 3, and reduced power consumption by a factor of 100. However, the scaling cannot continue ad infinitum because of resolution limitations of the photolithographic equipment used to make the circuits as well as breakdown mechanisms within the devices. More important, even before these limitations are reached, heat dissipation will prohibit major enhancements with NMOS. Heat generation increases exponentially with transistor count, and, at densities approaching 150,000 transistors per integrated circuit, special cooling measures are required. This heat can accelerate failure mechanisms within the silicon, reducing device and system reliability. To hurdle this barrier, low-power devices must be used.

#### The Importance of Power Consumption

The development of NMOS was spurred on by the semiconductor industry's drive to produce highvolume, large-capacity memory devices, for which high density, rather than low power consumption, was the primary concern. As VLSI began to emerge, however, power dissipation became a limiting factor in continued increases in NMOS packing densities. Thus, the semiconductor industry turned to CMOS as a potential alternative.

CMOS achieves its low power dissipation through the use of both p- and n-channel transistors (hence the name "complementary"). Essentially, no DC power is dissipated in either logical state, and AC power occurs only during the relatively short switching period. Because most circuitry in a complex design is active only 10 to 20 percent of the time, CMOS achieves a dramatic reduction in power dissipation compared with NMOS, which continually dissipates DC power whenever an operating voltage is applied.

Low power requirements are a major advantage of designing a system that uses CMOS. Reducing power requirements has a domino effect that often substantially reduces the cost of the end product:



**Figure 1:** A comparison of NMOS and CMOS technologies. Figure 1a shows the schematic diagrams of an inverter as implemented in both NMOS and CMOS. A hypothetical input waveform and the resulting transistor currents are shown in 1b and 1c.

• low power allows smaller, lowercost power supplies to be used

• power distribution in the system is simplified

• cooling fans can be eliminated

• printed-circuit boards can be packed more densely and can thus become smaller

With smaller power supplies, denser circuit boards, and no fans, smaller cabinets can be used, resulting in savings in chassis and enclosure costs. Also, power fail-safe and hand-held use become possible if battery operation is feasible.

#### **Basic CMOS Operation**

To truly understand the promises (and problems) facing both the CMOS VLSI digital designer and the CMOS systems designer, one must first understand some CMOS fundamentals.

Figure 1 compares the circuit diagrams and current characteristics of both an NMOS and a CMOS inverter. The NMOS inverter uses an n-channel depletion-mode transistor as the pull-up device (which drives the output line high) and an n-channel enhancement-mode transistor as the pull-down device (which drives the output line low). The pull-up transistor is used as a load; its operation approximates that of a constant current source. The pull-down transistor is used as the switching device; when active, it discharges the load, and when inactive it lets the pull-up charge the load. MOS loads are primarily capacitive and include the parasitic capacitances of the inverter itself, interconnect capacitances, and the thin-oxide capacitances of all the gates the inverter is driving.

Let's note several characteristics of an NMOS inverter. When the pull-down device is turned on, it not only has to sink the current from the capacitive load, but it also has to sink the current supplied by the pull-up load device. Even in the quiescent state this current component from the pull-up device still exists. Because logic gates spend most of their time in the quiescent state, this quiescent current accounts for up to 90 percent of the total power dissipated in NMOS VLSI designs; the remaining 10 percent is switching or dynamic power.

A second related characteristic is that the inverter's output voltage in the low state,  $V_{OL}$  is dependent on the ratio of the impedances of the pull-down and pull-up devices. This ratio affects the noise margin and switching speed and is generally around 4:1. Such a ratio results in a  $V_{OL}$  on the order of 0.2 V to 0.3 V. It also causes asymmetric switching characteristics: the fall time of the inverter is significantly faster than its rise time.

The CMOS inverter uses a pchannel enhancement-mode transistor as the pull-up device and an n-channel enhancement-mode transistor as the pull-down device. In a CMOS inverter, both the pull-up and pull-down transistors are used as switching devices. When the input changes from low to high, the p-channel device shuts off and the n-channel transistor *discharges* the load. When the input changes from



Figure 2: The speed versus power consumption characteristics of NMOS and CMOS technologies. Note the advantages gained by scaling (reducing the size) of the integrated components.

high to low, the n-channel device shuts off and the p-channel transistor charges the load. While almost all current from the CMOS inverter is used to charge or discharge the load, a small current component does not flow through the load. This is a result of the fact that both the p-channel and n-channel transistors are on for a short period of time during the input voltage transition. This current component is typically less than 10 percent of the total inverter current, though it depends greatly on the rise and fall times of the input signal.

With no quiescent power component, a CMOS inverter's dynamic power dissipation represents only a small fraction of an equiva-



**Figure 3:** Cross sections of transistors formed by each of the four major CMOS processes. Figure 3a is a p-well bulk CMOS transistor; figure 3b shows an n-well bulk device; figure 3c is an example of a twin-tub bulk CMOS transistor; the transistor in figure 3d is formed using silicon-on-sapphire technology.

lent NMOS inverter's power dissipation. Also, the CMOS inverter is a "ratio-less" design, having only one transistor active after an input transition. This lets  $V_{OL}$  go all the way to ground potential, resulting in better noise tolerance than NMOS inverters. It is also a simple matter to design CMOS circuits with outputs that have equal rise and fall times. While this is important in some circuits, it is generally not taken advantage of in VLSI designs because it requires greater chip area.

For NMOS and CMOS technologies with similar transistor dimensions and gate oxides, gate delays are essentially identical. The speedpower products for such a set of NMOS and CMOS technologies are shown in figure 2. This graphically illustrates the tremendous power advantage CMOS offers when used in high-performance VLSI designs.

While CMOS enjoys significant electrical advantages over NMOS, it does have a cost disadvantage. One small factor is the larger number of process steps needed to fabricate a CMOS device. More significant is the larger die required because CMOS has lower gate density.

#### **CMOS Technologies**

Figure 3 shows the four major CMOS technologies in use today: p-well bulk, n-well bulk, twin-tub bulk, and silicon-on-sapphire (SOS). P-well CMOS uses a p-type diffusion into an n-type bulk silicon substrate to form an n-channel transistor. The p-channel transistor is built directly in the bulk. This is the original CMOS technology, which has many years of good performance and reliability behind it.

The n-well CMOS process starts with a p-type substrate. N-type material is diffused into it to form the n-well in which p-channel devices are built. N-channel devices are built directly in the bulk substrate. An n-well CMOS process is usually derived from an advanced NMOS process. It also permits a highly optimized n-channel transistor, which yields a slight performance advantage over a p-well CMOS process. Twin-tub CMOS combines n-well and p-well technologies by diffusing both an n-well for the p-channel transistor and a p-well for the n-channel transistor. The twin wells are usually formed in a lightly doped n-type substrate. While it is a slightly more complex and costly process than either n-well CMOS or p-well CMOS, twin-tub CMOS has the advantage of being able to optimize the performance of both the n-channel and pchannel devices. Thus, this process gives the highest overall performance of the bulk CMOS technologies.

The highest performing CMOS technology is SOS. Silicon islands are grown on an insulating sapphire substrate. N-channel or p-channel transistors are then built on the islands. High performance is achieved due to the significant reduction of parasitic capacitance. SOS also offers good gate density because no parasitic bipolar transistors are around to cause a phenomenon called latch up. Unfortunately, SOS devices are difficult and expensive to manufacture. For example, unused sapphire wafers cost approximately 10 times more than bulk silicon wafers.

While CMOS suffers a cost penalty of about 20 percent due to process differences, it generally suffers more significantly because of die size. (While processing steps have a linear relationship with cost, die size has an exponential relationship.) CMOS dies are larger than equivalent NMOS designs even when aggressive transistor scaling is employed. Three major factors contribute to this: the area used in trying to prevent latch up, CMOS logic-gate structure, and static design techniques.

## Latch Up Prevention

Bulk CMOS technologies have parasitic bipolar transistors that, if improperly biased, can cause a phenomenon called latch up. This potentially destructive action results from triggering an SCR (silicon-controlled rectifier) formed by the transistors and can cause extremely large currents to flow. Figure 4 shows the construction of the parasitic SCR in an n-well bulk CMOS device.



**Figure 4:** Parasitic SCR in bulk CMOS can cause latch up. Figure 4a shows how the parasitic transistors are formed in the silicon; figure 4b is a diagram of the equivalent circuit.

Two well-defined conditions must exist before latch up can occur. First, for the SCR to be triggered,  $IR_{well}$  or  $IR_{mb}$  must be greater than or equal to 0.7 V. This forward-biases the baseemitter junctions of the parasitic bipolar transistors. Second, to sustain the latch up condition, the product of the  $\beta s$  (gains) of the two bipolar transistors must equal at least 1.

In order to minimize the chance of one of the SCR's transistors being forward-biased, every attempt is made to reduce the resistance values as much as is feasible. This has the effect of requiring significantly larger injected currents before the SCR can be triggered. To reduce the resistance values, guard rings are used in the circuitry. (Guard rings are low-resistivity connections to the supply voltages placed around the CMOS p-channel and n-channel transistors.) While guard rings reduce the SCR bias resistor values, they also increase the space between n-channel transistors and p-channel transistors (thus reducing the gate density). To somewhat minimize this effect, particularly sensitive areas (like VLSI component's I/O pins) are heavily guard ringed, while the more protected internal circuitry is less so.

A less controllable method of preventing latch up is to try and decrease the  $\beta$ s of the parasitic transistors. While the vertical pnp transistor's  $\beta$  is set by the process design, the lateral npn transistor is more directly controllable. Its  $\beta$  can be drastically reduced by increasing the nwell-to-n+ diffusion spacing (or pwell-to-p+ diffusion spacing in pwell technology). This method reduces the  $\beta$  by increasing the width of the transistor's base. While this is an effective way of decreasing the gain of the parasitic structure, it also reduces the gate density.

In bulk CMOS technologies, to



Figure 5: A comparison of typical logic gates in NMOS and CMOS form. Figure 5a is an NMOS NOR gate, while figure 5b is a CMOS version; figure 5c is an NMOS NAND gate, and figure 5d is a CMOS version.

give absolute protection against latch up is not only tremendously expensive in silicon area, but it is also virtually impossible. CMOS designers sacrifice area to ensure there is enough margin in their design to protect it from latch up in normal operating-system environments.

## Logic-Gate Structures

Gate densities are also reduced in CMOS because standard CMOS logic gates are built from more transistors than their NMOS equivalents. Standard CMOS logic-gate design has a 1:1 ratio of n-channel transistors to p-channel transistors. For example, the two input gates shown in figure 5 take four transistors in CMOS and only three in NMOS. The relative density decreases as the number of inputs increases. For example, three-input gates require six transistors in CMOS and only four in NMOS; four-input gates require eight transistors in

CMOS and only five in NMOS, etc. As a matter of fact, it is rare to have a standard CMOS gate with more than three inputs because the selfloading and the transistor stack make the structure inefficient in both speed and area. On the other hand, it is not unusual in NMOS to have gates with as many as eight inputs.

## **Static Design Techniques**

A final reason for the lower CMOS gate densities is the use of static logic (modern VLSI NMOS microcomputer designs rely heavily on dynamic circuitry). Dynamic circuitry essentially uses a small capacitor as a latch to store logic values. This technique saves both area (by reducing the number of transistors in a gate) and power (by reducing the number of gates in structures like latches, flip-flops, shift registers, etc.). Employing dynamic design can reduce an NMOS latch's area by 30 percent and its power consumption by 50 percent. However, the problem with dynamic circuitry is that the capacitor used to store the logic value is leaky and will, over time, discharge and lose its data. This is the same problem faced by dynamic memory designers. The solution is to periodically refresh the capacitor, which forces a minimum operating frequency to be adhered to.

CMOS can also use dynamic circuitry, especially to increase the ratio of n-channel transistors to pchannel transistors. Because static CMOS designs have a 1:1 ratio of n-channel to p-channel transistors, being able to increase this ratio will have the effect of giving CMOS a higher gate density (but the minimum operating-frequency characteristic of dynamic circuitry often conflicts with the CMOS potential of absolutely minimizing power). Therefore, while true static CMOS design does give the lowest possible power consumption (by allowing the device to operate at frequencies all the way to DC), dynamic CMOS designs, being more dense and resulting in smaller die sizes, tend to be more cost-effective. Thus, two trends are developing in the use of CMOS for VLSI microcomputer design.

Designers of the next generation of 16- and 32-bit microprocessors are choosing CMOS. Here, the goal is not to operate at the lowest possible power level but rather to keep the operating power under a maximum level for cooler junction temperatures, higher performance levels, and the ability to use standard low-cost packages. In these designs, extensive use is made of dynamic logic. The ratio of n-channel transistors to p-channel transistors is often as high as 3:1.

Designers of 4- and 8-bit singlechip microcomputers are choosing CMOS to accommodate a host of new portable, hand-held, and ultra-low-power applications. Here, the goal is to minimize the operating power levels consistent with the performance required by the application. In the simpler microcomputers, true CMOS static logic is used—their simpler structure still allows a relatively small die size, while the low-performance applications they are appropriate for allow low operating frequencies. On the other hand, the more complex, higher-performance, singlechip VLSI components still make maximum use of static logic but are forced into dynamic logic for large arrays to keep the die cost down.

## Future CMOS

CMOS will be the technology of choice for VLSI microcomputer designs. For one thing, with the advent of hundreds of thousands of transistors on a die, CMOS is the only technology that offers a cost-effective solution to the power-density problem.

A second and more subtle future issue is reduced supply voltage. As MOS transistors continue to be scaled to smaller dimensions to eke out further performance and density advances, the standard 5-V supply voltage must be reduced, if only for internal circuitry, to limit substrate current and hot-electron effects. CMOS is better suited for lower supply-voltage operation because its switch point is a fixed percentage of the supply voltage. Also, due to its "ratio-less" structures, CMOS enjoys better noise tolerance than NMOS. another important factor at lower supply voltages.

continue to make major strides in its relative cost disadvantage to NMOS. Where CMOS formerly sold at as much as a fourfold premium, today it is selling at somewhat less than twice the price of comparable NMOS devices. With its continued use of standard, low-cost packaging technology as well as the more creative use of dynamic circuitry and hybrid static/dynamic designs, CMOS will rapidly approach the cost of NMOS. As a matter of fact, several major semiconductor manufacturers have stated that CMOS/NMOS price parity will occur this decade, and some manufacturers say it will happen as early as 1985. When CMOS and NMOS cost the same, why would anyone buy NMOS?

## e Finally, CMOS has made and will anyo

## A CMOS Single-Chip Computer: Intel's 80C51

## by Martin B. Pawloski

Intel's 80C51 is an interesting example of how the static logic versus dynamic logic trade-off was made in an actual product design. The 8051 is an 8-bit, single-chip microcomputer with 4K bytes of ROM, 128 bytes of RAM, two 16-bit counter/timers, multilevel interrupt control, 32 I/O pins, full-duplex UART (universal asynchronous receiver/transmitter), and on-chip oscillator and clock circuits. A die with the sections identified by functions is shown in photo 1 on page 94.

The CMOS version of the 8051, called the 80C51, is targeted at a number of applications that require both high performance and low power consumption. In areas like telephony, automotive control, industrial control, and portable instrumentation, the 80C51 operates at or near its maximum speed, even if only for short intervals. (For example, most realtime applications need an externalinterrupt response time of less than 100 microseconds ( $\mu$ s); more demanding applications require better than 10-µs response. While the response must be quick, and the interrupt routine executed quickly; the

| Product | Technology | V <sub>cc</sub> Supply<br>Voltage<br>Range | Operating-<br>Frequency<br>Range | Normal<br>Operating<br>Mode<br>(I <sub>cc</sub> Max) | ldle Mode<br>(I <sub>cc</sub> Max) | Power Down<br>Mode<br>(I <sub>cc</sub> Max) |
|---------|------------|--------------------------------------------|----------------------------------|------------------------------------------------------|------------------------------------|---------------------------------------------|
|         |            |                                            | 12 MHz Max                       | 24 mA                                                | 3 mA                               | 50 µA                                       |
| 80C51   | CMOS       | 4–6 V                                      | 12 MHz Min                       | 24 mA                                                | 0.3 mA                             | 50 µA                                       |
| 8051    | HMOS       | 45–55 V                                    | 12 MHz Max                       | 150 mA                                               | ·                                  | 20 mA                                       |
|         |            |                                            | 1.2 MHz Min                      | 130 mA                                               |                                    | 20 mA                                       |

processor spends a significant portion of its time idle.)

Once the performance requirements of the application are known, it is possible to specify a minimum operating frequency. For the 80C51, a hybrid static/dynamic design was proposed that allows a minimum die size and includes various modes of operation to minimize power consumption.

First, the only areas of the design that were made dynamic were the (very large) ROM and Control arrays. These arrays contain almost 50,000 transistors and constitute a major portion of the die. By making them dynamic, an area savings on the order of 40 to 50 percent was accomplished.

Second, the processor, all the peripheral functions, the RAM, and the I/O ports were made static. This allowed two modes of operation other than normal operating mode: *Idle* mode and *Power Down* mode.

Because in many applications the processor does nothing more than wait for an event to happen, in the Idle mode the major clocks of the device are stopped and only smaller ancillary clocks operate to drive the peripheral counter/timers, externalinterrupt control, and the serial channel. When one of the peripherals generates an interrupt, the processor clocks are restarted and instruction execution resumes in the interruptservice routine. The Idle mode reduces power consumption by almost an order of magnitude.

In Power Down mode, all the clocks inside the device are shut off and only the internal 128 bytes of RAM are "kept alive." The only current consumed is a minute amount due to pn-junction leakage. Static logic was designed in the peripheral sections in order to support this mode because no clocks are available to refresh dynamic logic. In both the Idle and Power Down modes, special provisions are made for the dynamic circuits in the ROM and Control areas to enter a pseudostatic condition that prevents any extraneous power consumption due to voltage drift on capacitive storage nodes.

Table 1 compares the NMOS 8051 to the CMOS 80C51. The 80C51, designed in Intel's HMOS-derived nwell process called CHMOS, is less than 10 percent larger than the NMOS design and consumes only 15 percent of the normal operating power. More significant power savings are possible by operating the 80C51 at lower frequencies or by using the Idle mode.

Martin B. Pawloski (5000 West Williams Field Rd., Chandler, AZ 85224) is involved in the product planning, definition, and implementation of both NMOS and CMOS single-chip microcomputers at Intel Corp.

## A Look at CMOS Dynamic Memory by Joe Altnether

The fast-growing portable-computer market is placing severe demands on semiconductor memory. For optimum system performance, these components must limit their power dissipation to suit battery operation and backup, and they must achieve the high data bandwidths and increased speeds needed for fast processing and high-resolution graphics. As the market reaches a projected \$4.8 billion level by 1987 (a tenfold increase over 1982 levels), these requirements will combine to fuel the use of high-performance CMOS dynamic RAMs.

One architecture that can increase the speed of a CMOS dynamic RAM incorporates static-column address decoders: static circuits perform the selection of the column address of the RAM. Previously, this architecture has not been used with dynamic RAMs because of the increased power consumption of the static circuits over that of the dynamic circuits, and the advantage of low power consumption would have been lost. But with CMOS, the increased power consumption is negligible.

## **Memory-device** Architecture

RAMs are organized internally as rows and columns of storage cells. Data access occurs at the intersection of a row address and a column address. In dynamic RAMs, the row

## by joe Annemer

and column addresses are multiplexed to reduce package size and pin count: the row addresses are clocked into the device with the RAS (row address strobe) signal, causing one row of data (1 bit from each of the 256 columns in a 64K-bit dynamic RAM) to be fed into the 256 internal sense amplifiers. (Because of the low internal signal levels, each column must have an associated sense amplifier to sense and restore memory-cell data.) Next, column addresses are presented to the device and clocked into it with the CAS (column address strobe) signal. These column addresses are then decoded to select one of the 256 bits. Faster access and cycle times are obtained within a row (or "page") after the first access to it because the 256 bits within the row continue to reside in the sense amplifiers and need not be refetched. Reapplying only column addresses, then, in what is known as Page Mode operation, provides fast serial accesses and can increase cycle times by a factor of 2.

The CMOS dynamic RAM can incorporate static-column circuits to provide performance equivalent to that of high-speed static RAMs. With CMOS, the static-decoding circuits reduce the internal number of clocks by a factor of 3, eliminating the need to allow for setup and hold times of signals with respect to clocks and the need to compensate for timing skews due to process variances. With staticcolumn circuits, precharge times are drastically reduced (in Page Mode operation of the Static-Column-mode device, precharge time is reduced from 30 nanoseconds [ns] to 5 ns). This precharge time reduction and the faster access times typically increase the memory's bandwidth to 20 MHz. (Performance of memory discussed here is based on the experimental 64K-bit CMOS dynamic RAM that Intel presented at the ISSCC conference in February 1983.)

With static-column architecture, two different types of Page Mode operation are possible: Static Column mode and Ripplemode. Static Column mode uses the RAS line and row addresses in the conventional manner, but once the row has been selected, data can be accessed merely by changing column addresses. As with a static RAM, column addresses must remain stable and valid for the entire address access cycle. Access time is measured from column addresses rather than the occurrence of CAS. (Typically, access from column addresses is 30 ns; from CAS, it is 10 ns.)

In operation, CAS is used to place the output in a high-impedance state or to activate an output buffer. CAS can be held active during the entire page cycle. In fact, it is possible to keep CAS permanently active (i.e., grounded). During a write cycle, however, addresses as well as data are latched by CAS or WE, whichever occurs last. Operation is identical to that of an NMOS dynamic RAM in this case. This action ensures that the data is written into the proper memory location.

Although Static Column mode provides fast, easy accesses, speed at the system level is limited by how fast addresses for the next cycle become valid; the time to generate and stabilize the addresses must be added to the cycle time. Increased system speed can be obtained by using Ripplemode. With this mode, staticcolumn circuits are again used to obtain access from valid column addresses, but the addresses are latched on the falling edge of CAS, removing the requirement for addresses to remain valid throughout the entire cycle. As a result, during the current cycle addresses for the next cycle can be set up or pipelined.

Column addresses enter the RAM through the internal address latch. This latch, controlled by CAS, provides flow-through operation. When CAS is inactive, the latch is open, and addresses pass through continuously to the static-column decoders. Any change in address is transmitted immediately to the decoder. Consequently, access to the RAM is again measured from valid column addresses. The latch captures the current address on the fall of CAS, permitting the system address to change while the access occurs. CAS also serves as an output enable on the data output. Static Column mode and Ripplemode both permit continuous data streams up to 20 MHz.

CMOS technology and staticcolumn architecture provide more than low power consumption and high bandwidth. In addition, staticcolumn decoding simplifies system design by eliminating critical timing relationships while providing higher system speed. Access from column addresses gives usable speed for single random accesses within the RAM. Also, the CMOS technology enhances reliability by incorporating a mechanism to significantly reduce soft errors. Finally, increased stored charge creates larger internal signal levels, which can more easily be differentiated from noise. As a result, the CMOS dynamic RAM has wider operating margins and system reliability is improved.

## Power Consumption

At the system level, dynamic memory has three components of power: active, standby, and refresh. The system's power consumption is defined as

$$P = V(MI_A + KI_S + NI_R)$$

where P = system power, V = voltage (5.5 V worst case),  $l_A$  = active current,  $I_A$  = standby current,  $I_R$  = refresh current, M = number of active devices, K = number of devices in standby, and N = total number of devices.

CMOS reduces the first term, the active current, relative to NMOS by a factor of 2. In addition, the lower active current reduces supply voltage transients, thus simplifying printed-circuit-board design and reducing decoupling-capacitor requirements.

The second term, standby current, is also reduced by a factor of 2 at TTL input levels. Driving the RAS signal to a CMOS level ( $V_{op}$  – 0.5 V) places the device in a low-power-standby mode and typically draws 10 microamperes ( $\mu$ A)—a factor of 50 reduction over NMOS!

Refresh current, the third term in the equation, is cycle-time dependent. Current increases with the frequency of refresh. In dynamic RAMs, data is stored on a capacitor that must be replenished or recharged every 2 or 4 milliseconds (ms). This refresh time is a function of the stored charge and the leakage current. With the CMOS dynamic RAM, the cell storage capacitance is 0.125 picofarad (pF) compared to 0.040 pF to 0.085 pF in an NMOS dynamic RAM. This low capacitance, coupled with lower leakage currents, permits the CMOS refresh period to be extended to 64 ms in standby.

At the standard 128 refresh cycles/2 ms (equivalent to a 15.625-µs refresh period), the NMOS device draws about 4.8 milliamperes (mA) and

asymptotically approaches the standby current of 4 mÅ as the refresh period approaches infinity. Even eliminating refresh entirely only reduces the current to 4 mÅ, which is only a 16 percent improvement. As a result, extending NMOS refresh does not significantly reduce the system's power consumption.

Contrast this characteristic to the improvement CMOS offers. At 15.625 μs, the CMOS dynamic RAM draws approximately 10 percent of the NMOS current, or 0.42 mA at TTL levels. Extending the refresh period reduces the current asymptotically to the standby current of 0.05 mA. At a 64-ms refresh period, the current is reduced to 0.15 mA, a 300 percent reduction. When battery powered, the CMOS system has a 10 times longer life than does the NMOS system, and an extended refresh mode offers another fivefold improvement. A 256K-byte CMOS memory can retain data for nearly one week on only AA nickel-cadmium (nicad) cells-more than sufficient for most portable systems.

## High-Speed Applications

Ripplemode and Static Column mode are ideal for applications involving high-speed buffers, telecommunications, and graphics. Bitmapped graphics systems would seem to be a natural fit with Page Mode operation. However, this was not always the case. Prior to the Intel 2164A 64K by 1-bit NMOS dynamic RAM, it was difficult to retrieve all 256 bits within a single row. of memory because of the RAS-low time limitation of 10  $\mu$ s. Even with a Page Mode cycle time of 125 ns, to retrieve all 256 bits would require 32  $\mu$ s—three times longer than allowed. The 2164A extended the RAS-low time to 75  $\mu$ s, permitting the extraction of all 256 bits during a single Page Mode cycle.

At the end of the cycle, the device cannot be reaccessed again until after a certain off-time allows internal nodes to be precharged to be ready for the next cycle. As a result, the 2164A can stream data at greater than a 7-MHz rate continuously. This function matches the timing and operation of low-performance, bit-mapped graphics memories. One 2164A, for example, can map all the data for the 256 by 256 matrix of a graphics display. During the horizontal scan time, the RAM performs a Page Mode cycle and one full line is displayed. During retrace time, the memory must be refreshed and can be updated with new data if required. This type of update is relatively slow; consequently, it limits the speed of animation on the screen because the processor has access to the memory only 25 percent of the time.

To increase resolution, more lines, each with more pixels, must be used. By performing two sequential Page Mode cycles from two different RAMs, pixel densities to 512 bits per line can be achieved. As pixel density increases, the memory cycle time must decrease to paint more pixels on a line in the same amount of time. This cycle-time limitation plus the fact that memory can be updated only during blanking has precluded dynamic RAMs from use in higher-resolution graphics displays. These systems are usually built with high-speed, expensive static RAMs.

With Ripplemode, memory update during screen display time, also known as cycle stealing, is possible. As an example, a 512 by 384 display requires 512 bits/line and 1 bit every 67 ns. Data is read from four memory devices in a series of eight Ripplemode reads each. Data is temporarily stored in a video-output register file and then shifted to the video screen at a rate slower than the Ripplemode reads. Following this, enough time is available to perform an update cycle before the next eight Ripplemode reads are performed to continue screen refresh. Eight was the number chosen to minimize the time the processor must wait to update the memory. In addition to this cycle stealing, which updates during display time, memory updates are also performed during blanking. Along with this system, a similar system was built using 2164As with Extended Page Mode operation. Each system used an iAPX 86 processor

and similar software. A comparison of both systems showed the CHMOS (complementary high-speed metaloxide semiconductor) system to have a 42 percent higher drawing speed. Animation on the CHMOS system was vastly improved.

## Usable Speed

Memory design using dynamic RAMs has always been a challenge. Although multiplexing addresses does reduce the package pin count. and increase system density, it limits the access and cycle times in the system. To access a dynamic RAM, low-order row addresses are presented and latched into the dynamic RAM with RAS. Row addresses must be held for a period  $t_{RAH}$  after the fall of RAS to guarantee proper operation. Next, the addresses must be changed to high-order column addresses and latched into the dynamic RAM with CAS, creating a timing window  $t_{RCD}$ , which is the RAS-to-CAS delay.

Within this window, the designer must guarantee row address hold time, change the addresses, and account for any timing skew on the CAS signal. If column addresses are valid at the maximum specified  $t_{RAC}$ , access time  $t_{RAC}$  is measured from the high-to-low transition of RAS.

The cycle time is the sum of the access time and the cycle precharge time  $t_{RP}$ . The access time is a function of  $t_{RCD}$ , which has contradictory requirements. It must be as long as possible to simplify system design and at the same time as short as possible to enhance system speed. Cycle time is affected directly by the length of  $t_{RP}$ .

Static-column operation eliminates the  $t_{RCD}$  problem. After row addresses have been latched into the RAM, the second portion of the access begins from valid column addresses. In other words, column access does not wait for CAS to become valid, but operates in a fashion similar to that of a static RAM. This is due to the flow-through operation of the CAS latch. CAS serves only to latch the addresses and to provide an output enable. Access from valid column addresses simplifies design by removing the CAS signal from the critical timing path.

Systems using dynamic RAMs are typically CAS access-limited because controllers generate timing signals in discrete clock increments. A CMOS dynamic RAM system might operate at 8 MHz without Wait states. Using any other 64K-bit dynamic RAM would require the injection of one or two Wait states, resulting in a corresponding performance penalty. Consequently, the advantage of higher processor speed is negated without the high-speed dynamic RAM. For systems incorporating either discrete or LSI controllers, the CMOS dynamic RAM simplifies the system design and offers higher system performance.

## **High Reliability**

Soft errors are random, nonrecurring failures caused by ionizing radiation present within the environment. All matter contains small amounts of radioactive material. Alpha particles emitted by an IC's packaging material can penetrate the enclosed circuit. As they do so, they generate hole-electron pairs. Any high-impedance node in the vicinity sensitive to 1 million electrons may be affected, because the difference between a 1 and a 0 (known as the critical charge) is about 1 million electrons. Consequently, data in one cell could change from a 1 to a 0 or vice versa. Correct data can be rewritten into the affected cell and the memory will again function correctly, thus the term "soft error."

When first discovered during tests of 16K-bit dynamic RAMs, soft errors occurred at a rate five times greater than catastrophic or hard-error failures. While device designers worked to eliminate the alpha-particle sensitivity, systems designers added error-correcting circuits (ECC), which increased system reliability, but the systems were larger and more expensive due to the additional components required. Also, the system had to test and correct the data, slowing the system's performance. All this was due to soft errors. Obviously, what is really required is the elimination of soft errors.

CMOS technology offers such a solution. The CMOS dynamic RAM cell is built on an n-well in a p-substrate, creating a p-n junction or diode at the boundary. When alpha particles create hole-electron pairs in a CMOS device, something else occurs. First, the n-well is very shallow, and the majority of hole-electron pairs are created in the p-substrate. Holes cannot transfer across the reverse-biased p-n junction, which acts as a barrier to soft-error effects. Any electrons that do cross the junction are gathered at the +5-V node away from the storage cell. The probability that sufficient hole-electron pairs are created within the n-well that cell upset could occur is so low that the soft-error rate of CMOS dynamic RAMs is typically orders of magnitude below that of their NMOS counterparts.

High storage capacitance also plays a role in the reduction of soft errors. The number of stored charged electrons representing a 1 or a 0 is directly proportional to the storage capacitance. Higher capacitance equates to more stored charge, which in turn increases the critical charge. The critical charge is the number of particles that differentiate a 1 from a 0. Increasing the critical charge beyond 1 million electrons significantly reduces the susceptibility to soft errors. This, in addition to the n-well mechanism, reduces the soft-error rate to much less than 0.001 percent per 1000 hours.

Studies were performed to compare reliability of systems with and without error correction for both NMOS and CMOS dynamic RAMs. The results show one surprise: at 256K bytes and below, the CMOS system without ECC is more reliable than the NMOS system with ECC, because of the cycle-time dependence of soft errors. In small systems, the memory is accessed more frequently, and the probability of a soft error is increased. With a soft-error rate at the very minimum 100 times less than NMOS, the CMOS dynamic RAM does not experience this effect.

Systems below 256K-byte capacities

benefit by the elimination of ECC circuits from a cost, performance, and simplicity-of-design standpoint. First, ECC increases the access time of the system by 50 ns to check and correct data. Assuming a 120-ns RAM access, ECC increases the access by 42 percent. Moreover, the penalty on cycle time is even greater, especially when you are writing a single byte into a 2-byte word. In this instance, data must be accessed and corrected, the new byte merged into the word, and check bits generated. Finally, the system must write the new data into memory. Added to this are any system-timing skews. As a result, a 200-ns cycle time stretches to a 335-ns system cycle time or an increase of 68 percent. Therefore, using a CMOS dynamic RAM not only improves system reliability but enhances system speed and simplicity of design.

Joe Altnether is technical marketing manager at Intel Corp. (2111 N.E 25th Ave., Hillsboro, OR 97123).

From Inside CMOS Technology by Martin B. Pawloski, Tomy Moroyan, and Joe Altnether appearing in the September 1983 issue of BYTE magazine. Copyright © 1983 Byte Publications, Inc. Used with the permission of Byte Publications, Inc.

3

## ARTICLE REPRINT

MAY. 1984 Modulars Procession Nocimies Procession to tailors polication KIN KOWONEN AND FROMAD PASHEY

Copyright by Electronics, May, 1984 All Rights Reserved, Reprinted by Permiss

**ORDER NUMBER 231097-001** 





# Modular approach to C-MOS technology tailors process to application

Despite the proliferation of applications, a few C-MOS process variations can address the functional requirements of many different products

by Kim Kokkonen and Richard Pashley, Intel Corp , Santa Clara, Calif

□ In the past few years, the interest in complementary-MOS technology and its applications to new products has exploded. Traditional arguments for C-MOS center on its low power dissipation, the large noise margins of complementary logic, and its simple ratioless design. With the advent of very large-scale integration, these arguments are taking on new meaning and importance.

As an example, Fig. 1 compares the performance of H-MOS (high-performance n-channel MOS ) inverters with their equivalent in Intel's C-H-MOS (complementary high-performance MOS) technology. Though H-MOS's speed continues to improve with further scaling, its delay-power product is more than an order of magnitude higher than a C-H-MOS implementation with identical n-channel transistors. In a VLSI part with 50,000 gates, C-H-MOS could mean the difference between 1 and 10 watts of power dissipation, which might save the expense and difficulty of a sophisticated cooling system or extend a portable system's operating time by a factor of 10.

That C-MOS performance is now on a par with n-MOS technology has also accelerated its popularity. In addition, the density of C-MOS circuitry has improved dramatically with advances in technology. Finally, the number of process alternatives has grown so large that almost any integrated-circuit design can be supported with available C-MOS technology.

Unfortunately, the wave of enthusiasm for C-MOS and the needs of different applications have multiplied the number of approaches that C-MOS developers are taking. Several major issues remain in VLSI C-MOS design—namely latchup and soft-error prevention, interconnections, and logic-design techniques. A building-block approach with a limited number of basic process modules can be used to create a close-knit family of technologies that squarely addresses these issues and simultaneously supports a wide range of applications.

## The basis for C-H-MOS

A firm foundation in n-MOS-transistor physics will support the advancement of C-MOS technology. As channel lengths approach 1 micrometer, n-channel transistors become more difficult to optimize because the standard 5-volt power supply causes problems with high-intensity fields. Improperly designed transistors may be unreliable as a result of hot-carrier injection into gate oxides, or they may cause less localized problems by injecting carri-

ers into the MOS substrate—there to bleed charge from storage nodes or even trigger a destructive latchup.

The resources to develop and verify the reliability of a  $1-\mu m$  n-channel transistor are well established and substantial. In Intel's C-H-MOS process, the basic design of the n-channel transistor is identical to its H-MOS counterpart, as shown in the table. Even at the more detailed levels of doping profiles, the H-MOS and C-H-MOS transistors are nearly identical.

Thus a high-performance C-MOS technology may be born out of an established n-MOS line. The relatively simple addition of an n-well in the same high-resistivity substrate results in a C-MOS process that serves as the basis for several optimized technologies. This is just a start, however, as other important issues remain.

Latchup has been the traditional nemesis of C-MOS. Given the presence of parasitic silicon controlled rectifiers within every bulk C-MOS chip, a current pulse of sufficient magnitude either inside or outside the chip may cause a catastrophic latchup. Many schemes have been proposed to combat latchup, ranging from carefully scrutinizing the layout (which imposes no burden on the technology) to a buried layer (which significantly in-



 Power down. Despite the continuous improvement of H-MOS (high-performance MOS) by scaling, the delay-power product for C-H-MOS (complementary-MOS H-MOS) is more than an order of magnitude lower in the typical integrated circuit.

Electronics / May 3, 1984

| n-CHANNEL TRANSISTOR COMPARISON |                  |                             |                        |                          |                         |  |  |  |
|---------------------------------|------------------|-----------------------------|------------------------|--------------------------|-------------------------|--|--|--|
| Tec<br>n-MOS                    | hnology<br>C-MOS | Gate-oxide<br>thickness (Å) | Channel<br>length (μm) | Threshold<br>voltage (V) | Graded drain<br>profile |  |  |  |
| H-MOS I                         |                  | 700                         | 3.0                    | 0.7                      | no                      |  |  |  |
| H-MOS II                        | C-H-MOS          | 400                         | 2.0                    | <b>Ö</b> .7              | no                      |  |  |  |
| H-MOS II                        | C-H-MOS III      | 250                         | 1.0                    | 0.7                      | yes                     |  |  |  |

creases complexity and processing cost). All have some degree of effectiveness.

A modular approach to a broad-based line of C-MOS technologies requires other measures besides mere physical latchup resistance. The latchup spoiler must be applicable to dynamic random-access memories, erasable programmable ready-only memories, and static RAMs, as well as to microprocessors and controllers. In order to improve latchup resistance, it cannot increase the distance between n- and p-channel transistors (this constraint is most significant in random logic and full C-MOS six-transistor static-RAM cells). The technique must be compatible with low-cost and large-volume manufacturing. Finally, the approach must be consistent with the use of an automated checking algorithm, so that every gate of a large semirandom logic design need not be scrutinized for latchup susceptibility.

## **Epitaxial benefits**

Figure 2 shows the margin gained in latchup trigger current when an epitaxial substrate is used. The epitaxial substrate brings the same latchup benefits to all product lines, and in many cases provides additional advantages such as improved surface lifetimes (for dynamic RAMs) and reduced dc resistance (for E-PROMs and logic). Epitaxial substrates are now available in volume from commercial silicon vendors, adding less than 5% to the cost of a finished wafer. No additional or exotic fabrication equipment needs to be installed. Because the epitaxial



2. Benefits. By raising the margin of latchup trigger current, an epitaxial substrate effects a dramatic improvement in combatting latchup, a major concern in complementary-MOS chip design.

substrate's heavily doped bulk effectively eliminates the vertically triggered latchup mode, it is possible to develop a set of computer-aided-design tools that can flag latchup-sensitive lavouts on the largest VLSI chips.

Since grasping the phenomenon of upsets induced by alpha particles, in 1977, memory designers have taken care to ensure that enough charge is stored within each cell to minimize

the problem. As critical chip dimensions are reduced, this problem becomes more severe, however, since both parasitic and storage capacitances are naturally reduced. For the latest 1.5-µm n-MOS process, stored charge is low enough to caution even microprocessor designers to guard against random storage nodes suffering from soft errors. Fortunately, C-MOS provides a natural barrier against soft errors if the storage node is located within the C-MOS well.

The well junction is reverse-biased by the power-supply voltage. The electric field at this junction naturally repels any carriers generated outside the well that might otherwise diffuse up to surface storage nodes. The combination of the well structure and an epitaxial substrate is even more effective. Here the funneling mechanism that usually collapses local electric fields during the passage of an alpha particle is also minimized. By using epitaxial substrates and the protection of a C-MOS well, the amount of charge collected during an alpha event can be reduced by an order of magnitude.

Of course, the designer must arrange for the storage node to reside within the well. This constraint, combined with other performance issues, leads to different choices of well and substrate polarities, depending on application. For example, in a C-MOS technology that is optimized for dynamic RAM, the ideal memory cell should have a pchannel pass gate and a p-channel capacitor located within an n-well in a p-type substrate. The p-channel transistor is chosen because it injects far fewer spurious carriers into the substrate and thus does not by itself disturb the state of neighboring cells.

The conductance of the p-channel device, while lower than that of an n-channel device of the same size, does not degrade the RAM's performance, since dynamic-RAM sensing is limited primarily by the amount of stored charge. Experimental results with C-H-MOS dynamic RAMs based on these principles show a soft-error rate of less than 300 FIT (failures in time, or device failures per billion hours) at a power supply of only 3 v. This is an improvement of more than three orders of magnitude over traditional n-MOS dynamic-RAM technology and offers the possibility of dynamic-RAM systems that require no error correction and that are compatible with lowvoltage battery backup.

High-density, high-performance static RAMs present the other side of the coin. The smallest static-RAM cells today are built using polysilicon-load resistors that sustain the stored-node voltage. On the time scale of an alpha event, however, these resistors in effect do not exist. Because the storage node's RC time constant is on the order of milliseconds and the alpha event's time scale is nanoseconds, the cell appears dynamic. In this sense, polysilicon-load static-RAM cells are very similar to dynamic-RAM cells. The major difference arises in the way the cells sense the cell's information. The static-RAM cell provides a direct current, and to maximize the cell's performance, that current must be as large as possible while contained in a minimum area. Thus the chip designer must use high-gain n-channel transistors for the cell's pass gates and pulldowns. For good soft-error protection, then, the cell must be located in a p-well within an n-type substrate.

The p-well approach benefits even full C-MOS six-transistor static-RAM cells. The area of such cells depends strongly on the distance allowed between n- and p-channel devices. Using a straightforward implementation of epitaxial C-MOS, the p-well approach provides more margin against latchup at small n-to-p spacings (Fig. 3). This phenomenon occurs because of the differing diffusion properties of n- and p-type dopants. The heavy doping in the n-type substrate is less mobile than is the p-type dopant, resulting in less outdiffusion during thermal processing and thus minimizing the shunt resistance that controls latchup.

## Hooking it up

One of the challenges of C-MOS in logic applications is interconnection. Designers of n-MOS chips are accustomed to buried contacts, which directly connect n-type polysilicon and n-type transistor source or drain regions. Because C-MOS requires contact to both p and n regions, the traditional n-type buried contact becomes much less useful, and a version suitable for both diffusion polarities is quite difficult to implement. This increases the burden on contact and metallization modules.

For high-density C-MOS logic, the first level of metal is all but consumed by local connections between p and n transistors. The payback from adding a second level of metal for longer-distance routing is very high. A good example exists for the six-transistor static-RAM cell commonly used by logic designers. Figure 4 compares single- and double-metal versions of this cell, both imple-

mented with 1.5- $\mu$ m design rules. Here the second-metal layer provides the bit lines for the cell. Similar arguments justify the use of second metal in global power, clock, and data routing in complex microprocessor chips.

Contacts themselves are more difficult to build in C-MOS. N-MOS technology accustomed process engineers to adding a phosphorus contact plug after the contacts have been etched. This plug brought several advantages: the phosphorus gettered metallic contaminants from the wafer, reducing junction leakage; and the high-temperature diffusion rounded the profile of the contact sidewall, easing the step coverage of the metal subsequently deposited. Further, the plug had self-aligning features. If the



3. P-well margin. With an epitaxial substrate, a p-well structure (upper curve) yields a greater margin against latchup than n-well at smaller n- and p-device spacings.

contact etch attacked the silicon substrate or if the contact was misaligned toward the field-oxide edge, the plug would rejuvenate the resulting weakened junctions. In C-MOS, these same attributes must be obtained differently, through improved fabrication, cleanliness, new gettering techniques, improved dielectrics, and tightly controlled contact etching. Figure 5 shows the difference in implementing a  $1.5\mu$ m contact structure in n-MOS and C-MOS.

Along with the proliferation of C-MOS technologies has come a wave of innovation in C-MOS design techniques. For digital logic, the major contenders for broad use are full complementary design and domino logic, first proposed by AT&T Bell Laboratories (Fig. 6). For many applications, traditional C-MOS logic is a winner. It requires no clocks, has larger operating margins, and uses fewer transistors for simple gates. For more complex gates, however, domino logic uses fewer transistors and runs faster. The speed results from connecting fewer transistors in series and reducing gate-fanout loading by



4. Payback. The use of double-metal layers for a six-transistor static-RAM cell can produce a large savings in real-estate. In two cells implemented with a 1.5-µm design rules, the savings can amount to one third of the total area: The cell at right uses second-layer metal for bit lines.

Electronics/May 3, 1984



up to a factor of two compared with full C-MOS.

Interestingly, the choice of design style influences the optimal type of C-MOS well. The speed of full C-MOS is limited by the slower of the two transistor polarities. Since the trip point is quite close to half the power supply, the time required for either transistor type to discharge its load capacitance by about 2.5 v sets the gate's speed. Since the p-channel device is the weaker one, it pays to choose a well type that improves the p-channel's conductance. P-well does this because the p-device is fabricated in an uncompensated substrate and thus has maximum mobility. Comparisons between n-

5. Making contact. Contacts are more difficult to build in C-MOS than in conventional n-MOS. The phosphorous contact plug used in n-MOS after contact etching (a) adds desirable features such as reduced junction leakage and improved step coverage by the metal layer. To gain the same advantages in C-MOS reguires greater process control (b).

and p-well construction show that the p-channel's conductance may be improved by as much as 10% with the proper well type.

By contrast, domino logic is at its best in an n-well technology. Here, the n-channel transistor dominates both performance and transistor count. Placing the n-channel device outside the well improves its conductance and reduces the dominant parasitic junction capacitance. Density also increases because no well contacts are required for the majority of the transistors.

The twin-well approach to C-MOS blurs these distinctions. In this approach, a high-resistivity epitaxial layer is grown on a heavily doped starting wafer. Then the doping for each transistor polarity may be independently optimized without need for doping compensation. Performance arguments based on mobility or junction capacitance thus become moot. Nonetheless, domino logic will still be best on a p-type substrate (equivalent to n-well) because it does

not require well contacts to collect the large parasitic substrate currents from the n-channel transistors, thus improving packing density.

## Matching process to product

These and other technical arguments may be combined into a consistent strategy (Fig. 7) for creating a line of C-MOS processes serving a broad marketplace. For at least the next several years, a complete technology line must include C-MOS based on both p- and n-type substrates. Fortunately, choosing epitaxial-latchup control minimizes the development cost of running both process-

6. Logic. Two major contenders for digital logic design are full complementary (a) and domino logic (b). The former requires no clocks and is simpler for many applications. Domino logic, which performs best in an n-well technology, is faster and simpler for more complex circuits.



Electronics/May 3, 1984

es. Dynamic RAMs are supported on the n-well side to minimize pattern sensitivities induced by substrate currents while protecting the p-channel cell from soft errors. E-PROMs are built in a similar n-well C-H-MOS process. Placing Intel's n-MOS E-PROM cell in an epitaxial p-type substrate eliminates parasitic effects caused by high substrate currents flowing during cell programming.

Microcontrollers land on the n-well side also, so that they may incorporate on-chip E-PROM cells. Most microcontroller products come in two versions, one with onchip E-PROM for system-development and manufacturing flexibility, and another with on-chip ROM for lowest cost. Using n-well C-MOS, a single core design can support both versions. Telecommunications and signal-processing products can also take advantage of the n-well E-PROM process, both for its high-quality polysilicon-polysilicon capacitors and for the E-PROM cell's programmable features. High-performance static RAMs, whether six-transistor or polysilicon-load, can take advantage of a p-well C-H-MOS process. High-end microprocessors can key off the dense n-to-p packing and double-metal capability offered by the six-transistor static-RAM process.

Because these processes are modular, development is simplified and manufacturing overhead is minimized. Just as all the 1.5- $\mu$ m C-H-MOS III technologies share a common transistor module, the difficult contact module was developed once to be shared among all. Specialized features such as double polysilicon or double metal are extensions of the common base.

## The future

C-MOS technology is still developing at a frenetic pace. Surprisingly, the application of some newer techniques and the demands of next-generation circuits may bring the various forms of C-MOS closer together, rather than further splitting the number of integrated processes.

One example of this trend is the development of a trench-isolation technique for separating n and p devices. When this module is perfected, there will be no reason to develop six-transistor static-RAM cells on p-well technology. The near-ideal trench isolation will prevent latchup on either substrate type. Similarly, if stacked C-MOS static-RAM cells can be perfected, there will be no need for polysilicon loads. The stacked C-MOS cell will have the same density but with improved performance and softerror immunity. At that time, twin-well C-MOS on a p-type substrate, augmented by specialized features for specific product lines, will become the one approach to a broad line of C-MOS processes.

Another factor affecting future C-MOS integration is the continued scaling of transistors. It is well known that the weaker p-channel transistor is gradually catching up on the n-channel device as channel lengths enter the submicrometer region. Eventually, the performance differences may become so small that p- and n-channel devices will be used interchangeably. Before this level is reached, however, the 5-v power-supply standard must be reduced. Because of the large base of TTL-compatible designs and the impossibility of converting the world to a new standard overnight, components operating from the new reduced supply will need to maintain TTL compatibility and also be able to operate in a system that mixes



7. Technology tree. A relatively small line of C-MOS process variations, or modules, can be matched to a wide variety of products to serve a broad marketplace. The broken lines indicate directions of potential future growth.

older 5-v components with lower-voltage ones. An onchip 5-to-3-v converter may be one way to solve the problem. This technique, however, will waste up to 40%of the total chip power within the voltage regulator.

C-MOS technology provides an elegant solution because it can drive TTL-compatible output levels from a system power supply as low as 3 V. Since TTL levels are referenced to the negative (ground) rail, the grounded substrate offered by n-well C-MOS is a much-preferred means of integrating submicrometer transistors into such a system. This will be a strong motive to standardize on psubstrate C-MOS.

A final factor that tends to drive future C-MOS processes toward commonality is the growing importance of RC delays in overall chip performance. The latest high-performance static RAMs use an aluminum strap in parallel with the polysilicon word line because the RC delay induced by even the best refractory metal polycides is several nanoseconds too long. Studies of dynamic RAMs larger than 1 megabit similarly indicate that refractory word lines will probably be inadequate, forcing the technology to support two layers of metal. Combining these observations with those made previously regarding the evolution of static-RAM cells leads to the conclusion that most future C-MOS technologies will have two layers of polysilicon as well as two layers of metal.

The development of silicon-on-insulator technology is the one major factor that could renew the divergence of C-MOS approaches in the future. However, until the quality of SOI substrates is adequate to support dynamic RAM and E-PROM cells, and not just static logic, it will not play a major role in a broad-based and modular technology strategy.

Electronics/May 3, 1984

## Advanced Packaging Information

# 24

## CHAPTER 24 ADVANCED PACKAGING

## 24.1 Introduction

Today, system designers using LSI and VLSI devices are continuously facing problems associated with achieving the highest system performance level and most complex functional level of a particular system application in the smallest physical size possible. Until recently the available solutions to these device problems were limited to the traditional standard dual-inline-package (DIP) based on 100mil center-to-center lead spacing and flat packages (FP). Today, these device problems are being solved in a number of new ways; DIPs based on 50 mil center-tocenter lead spacing, surface mounted small outline DIP, surface mounted chip carriers, surface mounted gull-wing flat package and pin grid arrays. Among these possible solutions the two that are emerging as the next standard IC packages for LSI/VLSI devices are the surface mounted chip carrier and the pin grid array.

## 24.2 What Are Surface Mounted Chip Carriers?

The chip carrier is basically the business portion of a DIP. Chip carriers are available in two general types: leadless and leaded.

The leadless chip carrier construction is accomplished in much the same manner as the multi-layer ceramic DIP package, but it is missing the side-brazed legs and much of the ceramic surrounding the die cavity area. Instead, it consists of a ceramic package with I/O pads on all four sides, a die cavity area, metalization traces to the I/O pads, and a hermetically sealable lid. Leadless chip carriers are available in either square or rectangular package outlines. The leadless chip carrier can be attached to a board surface either directly, by socketing, or by the addition of add-on leads.

The leaded chip carrier construction is accomplished also in much the same manner as the plastic DIP package, but has leads that are bent down and under the package on all four sides rather than like the DIP. It is also missing much of the plastic surrounding the die platform and consists of plastic material encapsulating the die platform with I/O pads or leads on all four sides. The plastic leaded chip carrier is available in square or rectangular package outline, that can be attached to a board surface either directly or by a socket.

Chip carriers are registered JEDEC standard packages. The standard is based upon two basic package types, one with 50mil center-to-center terminal spacing, the other with 40mil spacing. Each package type was developed with certain application in mind, such as mounting methods, board material, thermal characteristics and external features. Intel's Microcontroller Operation offers two varieties of JEDEC packages, both with 50mil spacing, a square ceramic leadless type and a square plastic leaded type.

In addition to these mechanical packaging advantages, there are also electrical benefits. The package arrangement of the chip carriers I/O pads, on all four sides, allows for package traces to be shorter and more uniform in length. This allows lower resistance, less capacitance and less inductance, resulting in higher system performance and improved switching characteristics.

## 24.3 Why Chip Carriers?

Figure 24.1 shows the differences between the surface area (in<sup>2</sup>) versus pin count of both a ceramic dip and a ceramic leadless chip carrier device. Note that an 18-pad chip carrier offers a 57% saving in area. As the pin counts increase, the chip carrier surface area advantage becomes significantly more obvious. This space efficiency allows the system designer to increase the number of components on a board or decrease the overall board size and, thus, the overall system size.



Figure 24.1. Package Area



Figure 24.2. Package Area

Figure 24.2 shows the differences between the surface area  $(in^2)$  versus pin count of both a plastic DIP and a plastic Leaded Chip Carrier device. As can be seen, the savings in area is also as significant as the pin count increases, allowing the same system benefits.

However, the biggest advantage a ceramic chip carrier has over a ceramic dip is in its weight. Figure 24.3 shows the difference between the weight (grams) versus pin count of both ceramic DIP and ceramic Leadless Chip Carrier.



Figure 24.3. Package Weight

For an 18-pin count, there is a 77% weight saving and as the pin counts increase to 28 and to 48, this weight savings increases to 90% and 95%, respectively. In the case of the plastic leaded chip carrier, the weight savings over a plastic DIP is noticeable but not significant. However, it is in the ability to decrease the board size and, thus, economizing on material and weight reduction that the significant advantage exists.

## 24.4 What Are Pin Grid Arrays?

The Pin Grid Array is basically a combination of the ceramic DIP and ceramic Leadless Chip Carrier. The Pin Grid Array construction is accomplished in much the same manner as the multi-layer ceramic DIP, but it is missing the side-brazed legs and much of the ceramic surrounding the die cavity. Instead, it consists of a ceramic package with leads coming off the bottom in rows or circular patterns. The Pin Grid Array is available in square package outlines with lead spacing of 100 mils and can be attached to a board in the same manner as a DIP.

Pin Grid Arrays are being proposed as JEDEC standard packages and will have from 1 to 10 nested rows of legs and may have a die cavity mounting area oriented up or down.

## 24.5 Why Pin Grid Array?

Figure 24.4 shows the difference between the surface area  $(in^2)$  versus pin count of both a 50 mil spacing chip carrier and a 100 mil spacing Pin Grid Array device. Note that at approximately 68 pins and above the Pin Grid Array becomes a better solution for higher pin count requirements than the chip carrier. In addition, the 100 mil lead spacing and through board mounting technique provides customers with an assembly technology that is familiar.



Figure 24.4 Surface Array

## **CERAMIC LEADLESS CHIP CARRIER**

All dimensions in inches and (millimeters)

44-Leadless Hermetic Chip Carrier JEDEC Package Type C 



## **CERAMIC LEADLESS CHIP CARRIER**

All dimensions in inches and (millimeters)

44-Leadless Hermetic Chip Carrier JEDEC Package Type C



## PLASTIC LEADED CHIP CARRIER

All dimensions in inches and (millimeters)

44-Leaded Chip Carrier JEDEC Package Type C





## intel

**Pinouts** 

MCS®-51 Family

the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the second state of the se





## \*Top View Looking Through Package

## **ADVANCED PACKAGING**



\*Top View Looking Through Package

24-7

## **CERAMIC PIN GRID ARRAY**

All dimensions in inches and (millimeters)

68-Pin Hermetic Pin Grid Array





## Pinouts MCS®-96 Family

intal



MCS®-96 Pin Table

| PIN | SYMBOL    | PIN | SYMBOL     | PIN | SYMBOL     | PIN | SYMBOL      |
|-----|-----------|-----|------------|-----|------------|-----|-------------|
| 1   | ACH7/P0.7 | 18  | AD0/P3.0   | 35  | READY      | 52  | HSI2/HSO4   |
| 2   | ACH6/P0.6 | 19  | AD1/P3.1   | 36  | T2RST/P2.4 | 53  | HSI1        |
| 3   | ACH2/P0.2 | 20  | AD2/P3.2   | 37  | BHE        | 54  | HSIO        |
| 4   | ACH0/P0.0 | 21  | AD3/P3.3   | 38  | WR         | 55  | P1.4        |
| 5   | ACH1/P0.1 | 22  | AD4/P3.4   | 39  | PWM/P2.5   | 56  | P1.3        |
| 6   | ACH3/P0.3 | 23  | AD5/P3.5   | 40  | P2.7       | 57  | P1.2        |
| 7   | NMI       | 24  | AD6/P3.6   | 41  | VBB        | 58  | P1.1        |
| 8   | EA        | 25  | AD7/P3.7   | 42  | VSS        | 59  | P1.0        |
| 9   | vcc       | 26  | AD8/P4.0   | 43  | HSO3       | 60  | TXD/P2.0    |
| 10  | VSS       | 27  | AD9/P4.1   | 44  | HSO2       | 61  | RXD/P2.1    |
| 11  | XTAL1     | 28  | AD10/P4.2  | 45  | P2.6       | 62  | RESET       |
| 12  | XTAL2     | 29  | AD11/P4.3  | 46  | P1.7       | 63  | EXTINT/P2.2 |
| 13  | CLKOUT    | 30  | AD12/P4.4  | 47  | P1.6       | 64  | VPD         |
| 14  | TEST      | 31  | AD13/P4.5  | 48  | P1.5       | 65  | VREF        |
| 15  | INST      | 32  | AD14/P4.6  | 49  | HSO1       | 66  | ANGND       |
| 16  | ALE       | 33  | AD15/P4.7  | 50  | HSO0       | 67  | ACH4/P0.4   |
| 17  | RD        | 34  | T2CLK/P2.3 | 51  | HSI3/HS05  | 68  | ACH5/P0.5   |

\* Top View Looking Through Package

l ,

.

, 1

## into

Intel Corp 5015 Bradford Drive Suite 2 Huntsville 35805 Tel: (205) 830-4010

Intel Corp 11225 N. 28th Drive Suite 214D Phoenix 85029 Tel (602) 869-4980

Intel Corp 1161 N El Dorado Place Suite 301 Tucson 85715 Tel (602) 299-6815 CALIFORNIA

Intel Corp 21515 Vanowen Street Suite 116 Canoga Park 91303 Tel: (818) 704-8500

Intel Corp 2250 E Impenal Highway Suite 218 El Segundo 90245 Tel (213) 640-6040

Intel Corp 1510 Arden Way, Suite 101 Sacramento 95815 Tel (916) 920-8096

Intel Corp 4350 Executive Drive Suite 150 San Diego 92111 (619) 452-5880

(013) 422-0600 Intel Corp \* 2000 East 4th Street Suite 100 Santa Ana 92705 Tel (714) 835-9642 TWX 910-595-1114

Intel Corp \* 1350 Shorebird Way Mt View 94043 Tel (415) 968-8086 TWX 910-339-9279 910-338-0255

COLORADO

Intel Corp 4445 Northpark Drive Suite 100 Colorado Springs 80907 Tel (303) 594-6622

Intel Corp • 650 S Cherry Street Suite 720 Denver 80222 Tel (303) 321-8086 TWX 910-931-2289

CONNECTICUT Intel Corp 26 Mill Plain Road Danbury 06810 Tel (203) 748-3130 TWX. 710-456-1199

EMC Corp 222 Summer Street Stamford 06901 Tel (203) 327-2934

FLORIDA Intel Corp. 242 N Westmonte Drive Suite 105 Altamonte Springs 32714 Tel. (305) 869-5588

Intel Corp 1500 NW 62nd Street Suite 104 Ft. Lauderdale 33309 Tel (305) 771-0600 TWX. 510-956-9407

FLORIDA (Cont'd) Intel Corp. 11300 4th Street South Suite 170 SI Petersburg 33702 Tel: (813) 577-2413

-----Intel Corp 3280 Pointe Parkway Suite 200 Norcross 30092 Tel: (404) 449-0541

ILLINOIS Intel Corp \* 2550 Guif Road Suite 815 Rolling Meadows 60008 Tel (312) 981-7200 TWX 910-651-5881

INDIANA Intel Corp 8777 Purdue Road Sunte 125 Indianapolis 46268 Tel (317) 875-0623

IOWA Intel Corp, St Andrews Building 1930 St Andrews Drive N E Cedar Rapids 52402 Tel (319) 393-5510

Intel Corp 8400 W 110th Street Suite 170 Overland Park 66210 Tel (913) 642-8080 LOUISIANA

Industrial Digital Systems Corp Tel (504) 899-1654

MARYLAND Intel Corp.\* 7321 Parkway Drive South Suite C Hanover 21076 Tel (301) 796-7500 TWX 710-862-1944

Intel Corp 7833 Walker Drive Greenbelt 20770 Tel (301) 441-1020

MASSACHUSETTS Intel Corp \* 27 Industral Avenue Chelmsford 01824 Tel (617) 256-1800 TWX 710-343-6333

MICHIGAN

intel Corp, 7071 Orchard Lake Road Suite 100 West Bloomfield 48033 Tel (313) 851-8096

MINNESOTA Intel Corp 3500 W 80th Street Suite 360 Bloomington 55431 Tel: (612) 835-6722 TWX 910-576-2867

MISSOURI Intel Corp. 4203 Earth City Expressway Suite 131 Earth City 63045 Tel. (314) 291-1990 NEW JERGEY

DOMESTIC SALES OFFICES

Intel Corp \* Raritan Plaza III Raritan Center Edison 08837 Tel: (201) 225-3000 TWX 710-480-6238

NEW MEXICO

Intel Corp 8500 Menual Boulevard N E. Suite B 295 Albuquerque 87112 Tel: (505) 292-8086

NEW YORK Intel Corp \* 300 Vanderbilt Motor Par Hauppauge 11788 Tel (516) 231-3300 TWX. 510-227-6236

Intel Corp Suite 28 Hollowbrook Park 15 Myers Corners Road Wappinger Falls 12590 Tel (914) 297-6161 TWX 510-248-0060

Intel Corp \* 211 White Spruce Boulevard Rochester 14623 Tel. (716) 424-1050 TWX 510-253-7391

T-Squared 6443 Ridings Road Syracuse 13206 Tel (315) 463-8592 TWX 710-541-0554

T-Squared 7353 Pritsford-Victor Road Victor 14564 Tel. (716) 924-9101 TWX\* 510-254-8542

NORTH CAROLINA

Intel Corp 2700 Wycliff Road Suite 102 Raleigh 27607 Tel (919) 781-8022 оню

Intel Corp \* 6500 Poe Avenue Dayton 45414 Tel (513) 890-5350 TWX 810-450-2528

Intel Corp \* Chagrin-Brainard Bldg, No 300 28001 Chagrin Boulevard Cleveland 44122 Tel. (216) 464-2736 TWX 810-427-9298

OKLAHOMA Intel Corp. 4157 S Harvard Avenue Suite 123 Tulsa 74135 Tel. (918) 749-8688

OBEGON Intel Corp 10700 SW Beavert Hillsdale Highway Suite 22 Beaverton 97005 Tel (503) 641-8086 TWX: 910-467-8741

PENNSYL VANIA

Intel Corp \* 455 Pennsylvania Avenue Fort Washington 19034 Tel: (215) 641-1000 TWX: 510-661-2077

Intel Corp \* 400 Penn Center Boulevard Suite 610 Pittsburgh 15235 Tel (412) 823-4970

Q E D Electronics 139 Terwood Road Willow Grove 19090 Tel (215) 657-5600 TEXAS Intel Corp.\* 12300 Ford Road Suite 380 Dallas 75234 Tel (214) 241-8087 TWX. 910-860-5617 Intel Corp \* 7322 S W. Freeway Suite 1490 Houston 77074 Tel. (713) 988-8086 TWX 910-881-2490 Industrial Digital Systems Corp. 5925 Sovereign Suite 101 Houston 77036 Tel (713)988-9421 Intel Corp 313 E Anderson Lane Suite 314 Austin 78752 Tel (512) 454-3628

PENNSYLVANIA (Cont'd)

UTAH

Intel Corp 5201 Green Street Sutte 290 Salt Lake City 84123 Tel (801) 263-8051 VIRGINIA

Intel Corp. 1603 Santa Rosa Road Suite 109 Richmond 23288 Tel (804) 282-5668

WASHINGTON

Intel Corp. 110 110th Avenue N E. Suite 510 Bellevue 98004 Tel. (206) 453-8086 TWX 910-443-3002

Intel Corp 408 N Mulian Road Suite 102 Spokane 99206 Tel (509) 928-8086

WISCOMRIM

Intel Corp 450 N Sunnyslope Road Suite 130 Chancellory Park I Brockfield 53005 Tel. (414) 784-8087

CANADA

Intel Semiconductor of Canada, Ltd Suite 202, Bell Mews 39 Highway 7 Nepean K2H 8R2 Tel. (613) 829-9714 Tel. (613) 829-9714 Tel.LX 053-4115

Intel Semiconductor of Canada, Ltd 190 Attwell Drive Suite 500 Rexdale M9W 6H8 Tei (416) 675-2105 Tei LEX: 06983574

OHEREC

Intel Semiconductor of Canada, Ltd. 3860 Cote Vertu Rd Suite 210 St. Laurent H4R 1V4 Tel (514) 334-0560 TELEX 05-824172

\*Field Application Location

ONTARIO

#### -----

tArrow Electronics, Inc 3611 Memorial Parkway So Huntsville 35801 Tel (205) 882-2730

Hamilton/Avnet Electronics 4940 Research Drive Huntsville 35805 Tel (205) 837-7210 TWX. 810-726-2162

†Pioneer Electronics 1207 ,Putnam Drive N W Huntsville 35805 Tel (205) 837-9300 TWX: 810-726-2197

tHamilton/Avnet Electronics 505 S Madison Drive Tempe 85281 Tel (602) 231-5140 TWX 910-950-0077

 †Wyle
 Distribution
 Group

 8155
 N
 24th
 Avenue

 Phoenix
 85021
 Tel
 (602)
 249-2232

 TWX
 910-951-4282
 TWX
 910-951-4282

## CALIFORNIA

†Arrow Electronics, Inc 521 Weddell Drive Sunnyvale 94086 Tel (408) 745-6600 TWX. 910-339-9371

tArrow Electronics, Inc 19748 Dearborn Street Chatsworth 91311 Tel: (213) 701-7500 TWX 910-493-2086

Arrow Electronics, Inc 2961 Dow Avenue Tustin 92680 Tel (714) 838-5422 TWX 910-595-2860

tAvnet Electronics 350 McCormick Aver Costa Mesa 92626 Tel (714) 754-6051 TWX 910-595-1928

thamilton/Avnet Elect 1175 Bordeaux Drive Sunnyvale 94086 Tel (408) 743-3300 TWX 910-339-9332

†Hamilton/Avnet Electronics 4545 Viewridge Avenue San Diego 92123 Tel (619) 571-7500 TWX 910-595-2638

Hamilton/Avnet Electronics 20501 Plummer Street Chatsworth 91311 Tel: (213) 700-6271 TWX 910-494-2207

†Hamilton/Avnet Electronics 4103 Northgate Boulevard Sacramento 95834 Tel (916) 920-3150

Hamilton/Avnet Electronics 3002 G Street Ontario 91311 Tel (714) 989-9411

Hamilton/Avnet Electronics 19515 So Vermont Avenue Torrance 90502 Tel (213) 615-3913 TWX 910-349-6263

Hamilton Electro Sales 10912 W Washington Bouk Culver City 20230 Tel (213) 558-2458 TWX 910-340-6364

†Hamilton Electro Sales 3170 Pullman Street Costa Mesa 92626 Tel (714) 641-4150 TWX 910-595-2638

Hamilton Electro Sales 9650 De Soto Avenue Chatsworth 91311 Tel (818) 700-6500

Kierulff Electronics, Inc 1180 Murphy Avenue San Jose 95131 Tel (408) 947-3471 TWX 910-379-6430

CALIFORNIA . (Cont'd) Kieruff Electronics, Inc 14101 Franklin Avenue Tustin 92680 Tel (714) 731-5711 TWX 910-595-2599

Kierulff Electronics, Inc 5650 Jillson Avenue Commerce 90040 Tel (213) 725-0325 TWX 910-580-3106

two sto-odo-stoo two participation of two text maryland Street El segundo 90245 Tel (213) 322-8100 TWX 910-348-7140 or 7111

†Wyle Distribution Group 17872 Cowan Avenue Irvine 92714 Tel. (714) 843-9953 TWX 910-595-1572

tWyle Distribution Group 11151 Sun Center Drive Rancho Cordova 95670 Tei (916) 638-5282

tWyle Distribution Group 9525 Chesapeake Drive San Diego, 92123 Tel (619) 565-9171 TWX 910-335-1590

tWyle Distribution Group 3000 Bowers Avenue Santa Clara 95051 Tel (408) 727-2500 TWX 910-338-0296

Wyle Military 17810 Teller Avenue Irvine 92750 Tel (714) 851-9958 TWX 310-371-9127

Wyle Systems 15292 Bolsa Chica Huntington Beach 92649 Tel (714) 851-9953 TWX 910-595-2642

COLORADO

tWyle Distribution Group 451 E 124th Avenue Thornton 80241 Tel (303) 457-9953 TWX 910-936-0770.

Hamilton/Avnet Electronics 8765 E Orchard Road Suite 708 Englewood 80111 Tel: (303) 740-1017 TWX 910-935-0787

## COMMECTICUT

tArrow Electronics, Inc 12 Beaumont Road Wallingford 06492 Tel: (203) 265-7741 TWX 710-476-0162

Hamilton/Avnet Electronics Commerce Industrial Park Commerce Drive Danbury 06810 Tel (203) 797-2800 TWX 710-456-9974

†Pioneer Northeast Electronics 112 Main Street Norwalk 06851 Tel (203) 853-1515 TWX 710-468-3373

## FLORIDA

†Arrow Electronics, Inc. 1001 N W 62nd Streef Suite 108 F1 Lauderdale 33309 Tel (305) 776-7790 TWX 510-955-9456

†Arrow Elèctronics, Inc 1530 Bottlebrush Drive N E Palm Bay 32905 Tel (305) 725-1480 TWX 510-959-6337

Hamilton/Avnet Electronics 6801 N.W 15th Way Ft Lauderdale 3309 Tel (305) 971-2900 TWX 510-956-3097

†Hamilton/Avnet Electror 3197 Tech Drive North St Petersburg 33702 Tel (813) 576-3930 TWX 810-863-0374

FLORIDA (Cont'd)

DOMESTIC DISTRIBUTORS

Hamilton/Avnet Electronics 6947 University Boulevard Winterpark 32792 Tel (305) 628-3888 TWX 810-853-0322

†Pioneer Electronics 221 N Lake Boulevard Suite 412 Alta Monte Springs 32701 Tel: (305) 834-9090 TWX 810-853-0284

 TPioneer
 Electronics

 1500
 62nd
 Street
 N.W

 Suite
 506
 71
 71.7520

 Tel
 (305)
 771-7520
 TWX
 510-955-9653

## AROBOIA

†Arrow Electronics, Inc 2979 Pacific Drive Norcross 30071 Tel. (404) 449-8252 TWX 810-766-0439

tHamilton/Avnet Electronics 5825 D Peachtree Corners Norcross 30092 Tel (404) 447-7500 TWX 810-766-0432

 This
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 State
 <thS

## ILLINOIS

tArrow Electronics, Inc 2000 E. Alonguin Street Schaumberg 60195 Tel (312) 397-3440 TWX. 910-291-3544

tHamilton/Avnet Electronics 1130 Thorndale Avenue Bensenville 60106 Tel. (312) 860-7780 TWX 910-227-0060 
 Pioneer
 Electronics

 1551
 Carmen
 Drive

 Elk
 Grove
 Village
 60007

 Tel
 (312)
 437-9680
 TWX
 910-222-1834

tArrow Electronics, 2718 Rand Road Indianapolis 46241 (317) 243-9353 TWX. 810-341-3119

†Hamilton/Avnet Electronics 485 Gradle Drive Carmel 46032 Tel (317) 844-9333 TWX 810-260-3966

†Pioneer Electronics 6408 Castleplace Drive Indianapolis 46250 Tel (317) 849-7300 TWX 810-260-1794

## KANSAS tHamilton/Avnet Electronics 9219 Quivera Road Overland Park. 66215 Tel (913) 888-8900 TWX 910-743-0005

MARYLAND

Arrow Electronics, Inc 8300 Gulford. Road #H Rivers Center. Columbia 21046 Tel (301) 995-0003 TWX 710-236-9005

†Hamilton/Avnet Electro 6822 Oak Hall Lane Columbia 21045 Tel (301) 995-3500 TWX 710-862-1861

tMesa Technology Corporation 16021 Industrial Drive Gaithersburg 20877 Tel (301) 948-4350 TWX<sup>-</sup> 710-828-9702

tPioneer Electronics 9100 Gaither Road Gaithersburg 20877 Tel (301) 948-0710 TWX 710-828-0545

MARRACHURFTTR

tHamilton/Avnet Electro 50 Tower Office Park Woburn 01801 Tel (617) 935-9700 TWX 710-393-0382

tPioneer Northeast Elect 44 Hartwell Avenue Lexington 02173 Tel (617) 863-1200 TWX 710-328-6617

#### MICHIGAN

†Arrow Electronics, Inc 3810 Varsity Drive Ann Arbor 48104 Tel (313) 971-8220 TWX 810-223-6020

 Pioneer
 Electronics

 13485
 Stamford

 Livonia
 48150

 Tel.
 (313)

 TWX
 810-242-3271

tHamilton/Avnet Electronia 32487 Schoolcraft Road Livonia 48150 Tel (313) 522-4700 TWX: 810-242-8775

Hamilton/Avnet Electr 2215 29th Street S,E Space A5 Grand Rapids 49508 Tel (616) 243-8805 TWX 810-273-6921

MINNESOTA

tArrow Electronics, Inc. 5230 W. 73rd Street Edina 55435 Tel (612) 830-1800 TWX 910-576-3125

tHamilton/Avnet Electron 10300 Bren Road East Minnetonka 55343 Tel (612) 932-0600 TWX (910) 576-2720

tPioneer Electronics 10203 Bren Road East Minnetonka 55343 Tel (612) 935-5444 TWX 910-576-2738

#### MISSOURI

tArrow Electronics, 1 2380 Schuetz St Louis 63141 Tel: (314) 567-6888 TWX. 910-764-0882

tHamilton/Avnet Electror 13743 Shoreline Court Earth City 63045 Tel: (314) 344-1200 TWX. 910-762-0684

NEW HAMPSHIRE

†Arrow Electronics, Inc 1 Perimeter Road Manchester 03103 Tel: (603) 668-6968 TWX: 710-220-1684

## NEW JERREY

†Arrow Electronics, Inc 6000 Lincoln East Mariton 08053 Tel (215) 928-1800 TWX 710-897-0829

†Arrow Electronics, In 2 Industrial Road Fairfield 07006 Tel (201) 575-5300 TWX 710-998-2206

Hamilton/Avnet Electronics 1 Keystone Avenue Bidg. 36 Cherry Hill 08003 Tel (609) 424-0110 TWX 710-940-0262

†Hamilton/Avnet Elec 10 Industrial Farifield 07006 Tel: (201) 575-3390 TWX 710-734-4388

†Microcomputer System Technical Demonstrator Centers

## intel

#### NEW JERSEY (Cont'd)

Prober Northeast Electr 45 Route 46 Pinebrook 07058 Tel: (201) 575-3510 TWX 710-734-4382

†MTI Systems Sales 383 Route 46 W Fairfield 07006 Tel (201) 227-5552

## NEW MEXICO

 TAlliance
 Electronics
 Inc

 11030
 Cochit
 S E

 Albuquerque
 87123
 Tel
 (505)
 292-3360

 TWX
 910-989-1151
 Tel
 (505)
 292-3360

tHamilton/Avnet Electronics 2524 Baylor Drive S E Albuquerque 87106 Tel (505) 765-1500 TWX 910-989-0614

NEW YORK †Arrow Electronics, Inc 25 Hub Drive Melville 11735 Tel (516) 694-6800 TWX 510-224-6126

tArrow Electronics, Inc 3000 South Winton Road Rochester 14623 Tel (716) 275-0300 TWX 510-253-4766

tArrow Electronics, Inc 7705 Maltage Drive Liverpool 13088 Tel (315) 652-1000 TWX 710-545-0230

tArrow Electronics, Inc 20 Oser Avenue Hauppauge 11788 Tet: (516) 231-1000 TWX 510-227-6623

Hamilton/Avnet Electronics 333 Metro Park Rochester 14623 Tel (716) 475-9130 TWX 510-253-5470

tHamilton/Avnet Electronics 16 Corporate Circle E Syracuse 13057 Tel (315) 437-2641 TWX 710-541-1560

tHamilton/Avnet Electronics 5 Hub Drive Melville, Long Island 11747 Tel (516) 454-6000 TWX 510-224-6166

tPioneer Northeast Electronics 1806 Vestal Parkway East Vestal 13850 Tel (607) 748-8211 TWX 510-252-0893

Proneer Northeast Electronics 60 Crossway Park West Woodbury, Long Island 11797 Tel (516) 921-8700 TWX 510-221-2184

†Pioneer Northeast Electronics 840 Fairport Park 14450 Tel (716) 381-7070 TWX 510-253-7001

 HTI
 Systems
 Sales

 38
 Harbor
 Park
 Drive

 P O
 Box
 271

 Port
 Washington
 11050

 Tel
 (516)
 621-6200

 TWX
 510-223-0846

## NORTH CAROLINA

†Arrow Electronics, Inc 5240 Greendary Road Rateigh 27604 Tel (919) 876-3132 TWX 510-928-1856

†Hamilton/Avnet Electronics 3510 Spring Forest Drive Raleigh 27604 Tel (919) 878-0819 TWX 510-928-1836

Proneer Electronics 9801, A-Southern Pine Boulevard Charlotte 28210 Tel (704) 524-8188 TWX 810-621-0366

**CHIO** †Arrow Electronics, Inc 7620 McEwen Road Centerville 45459 Tel (513) 435-5563 TWX 810-459-1611

\* Arrow Electronics, Inc 6238 Cochran Road Solon 44139 Tel (216) 248-3990 TWX 810-427-9409

tHamilton/Avnet Electronics 954 Senate Drive Dayton 45459 Tel (513) 433-0610 TWX 810-450-2531

†Hamilton/Avnet Electronics 4588 Emery Industrial Parkway Warrensville Heights 44128 Tel (216) 831-3500 TWX 810-427-9452

†Pioneer Electronics 4433 Interpoint Boulevard Dayton 45424 Tel: (513) 236-9900 TWX 810-459-1622

tPioneer Electronics 4800 E 131st Street Cleveland 44105 Tel (216) 587-3600 TWX 810-422-2211

#### OKLAHOMA †Arrow Electronics, Inc 4719 S Memorial Drive Tulsa 74145 Tel (918) 665-7,700

OREGON †Almac Electronics Corporation 8022 S W Nimbus, Bidg 7 Beaverton 97005 Tel (503) 641-9070 TWX 910-467-8743

tHamilton/Avnet Electronics 6024 S W Jean Road Bldg C, Suite 10 Lake Oswego 97034 Tel (503) 635-7848 TWX 910-455-8179

#### PENNSYLVANIA

†Arrow Electronics, Inc 650 Seco Road Monroeville 15146 Tel (412) 856-7000

 Pioneer
 Electronics

 259
 Kappa
 Drive

 Prttsburgh
 15238
 Tel

 Tel
 (412)
 782-2300

 TWX
 710-795-3122
 TWX

### PENNSYLVANIA (Cont'd)

tPioneer Electronics 261 Gibraiter Road Horsham 19044 Tel (215) 674-4000 TWX 510-665-6778

DOMESTIC DISTRIBUTORS

TEXAS †Arrow Electronics, Inc 3220 Commander Drive Carroliton 75006 Tel (214) 380-6464 TWX. 910-860-5377

10899 Kinghurst Suite 100 Houston 77099 Tel (713) 530-4700 TWX 910-880-4439

tArrow Electronics, Inc 2227 W Braker Lane Austin 78758 Tel (512) 835-4180 TWX 910-874-1348

 THamilton/Avnet
 Electronics

 2401
 Rutland

 Austin
 78757

 Tel
 (512)
 837-8911

 TWX
 910-874-1319

tHamilton/Avnet Electronics 2111 W Walnut Hill Lane Irving 75062 Tel (214) 659-4100 TWX 910-860-5929

Hamilton/Avnet Electronics 8750 West Park Hosuton 77063 Tel (713) 780-1771 TWX 910-881-5523

 Pioneer
 Electronics

 9901
 Burnet
 Road

 Austin
 78758
 Tel

 Tel
 (512)
 835-4000

 TWX
 910-874-1323
 State

 this
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort
 stort

 Pioneer
 Electronics

 5853
 Point
 West
 Drive

 Houston
 77036
 Tel
 (713)
 988-5555

 TWX
 910-881-1606
 State
 State
 State

#### UTAH

†Hamilton/Avnet Electronics 1585 West 2100 South Salt Lake City 84119 Tel (801) 972-2800 TWX 910-925-4018

Wyle Distribution Group 1959 South 4130 West, Unit B Salt Lake City 84104 Tel (801) 974-9953

## WASHINGTON

Almac Electronics Corporation 14360 SE Eastgate Way Believue 98007 Tel (206) 643-9992 TWX 910-444-2067

Arrow Electronics, Inc 14320 N E 21st Street Bellevue 98007 Tel (206) 643-4800 TWX 910-444-2017

†Hamilton/Avnet Electronics 14212 N E 21st Street Bellevue 98005 Tel (206) 453-5874 TWX 910-443-2469

#### WISCONSIN

tArrow Electronics, Inc 430 W Rausson Avenue Oakcreek 53154 Tel (414) 764-6600 TWX 910-262-1193

†Hamilton/Avnet Electronics 2975 Moorland Road New Berlin 53151 Tel (414) 784-4510 TWX 910-262-1182

## CANADA

ALBERTA

†Hamilton/Avnet Electronics 2816 21st Street N E Calgary T2E 622 Tel (403) 230-3586 TWX 03-827-642

Zentronics Bay No 1 3300 14th Avenue N E Calgary T2A 6J4 Tel (403) 272-1021

BRITISH COLUMBIA

Zentronics 108-11400 Bridgeport Road Richmond V6X 112 Tel (604) 273-5575 TWX 04-5077-89

MANITOBA

Zentronics 590 Berry Street Winnipeg R3H OS1 Tei (204) 775-8661

ONTARIO

Hamilton/Avinet Electronics 6845, Rexwood Road Units G & H Mississauga L4V 1R2 Tel (416) 677-7432 TWX 610-492-8867

Hamilton/Avnet Electronics 210 Colonnade Road South Nepean K2E 7L5 Tel (613) 226-1700 TWX 05-349-71

Zentronics 8 Tilbury Court Brampton L6T 3T4 Tel (416) 451-9600 TWX 06-976-78

Zentronics 564/10 Weber Street North Waterloo N2L 5C6 Tel (519) 884-5700

Zentronics 155 Colonnade Road Unit 17 Nepean K2E 7K1 Tel (613) 225-8840 TWX 06-976-78

## QUEBEC

Hamilton/Avnet Electronics 2670 Sabourin Street St Laurent H4S 1M2 Tel (514) 331-6443 TWX: 610-421-3731

Zentronics 505 Locke Street St Laurent H4T 1X7 Tel (514).735-5361 TWX 05-827-535

Microcomputer System Technical Demonstrator Centers

## EUROPEAN SALES OFFICES

#### BELOUM

Intel Corporation S A Parc Servy Rue du Moulin a Papier 51 Boite 1 B-1160 Brusseis Tel. (02)661 07 11 TELEX: 24814

#### DENMARK

Intel Denmark A/S\* Glentevej 61 - 3rd Floor DK-2400 Copenhagen Tel: (01) 19 80 33 TELEX: 19567

### FINI AND

Intel Finland OY Hameenlie 103 SF - 00550 Helsinki 55 Tel: 0/716 955 TELEX. 123 332

#### FRANCE

Intel Corporation, SARL\* 5 Place de la Balance Silic 223 94528 Rungis Cedex Tel: (01) 687 22 21 TELEX 270475

## FRANCE (Cont'd) Intel Corporation, S.A.R L. Immeuble BBC 4 Quai des Etroits 69005 Lyon Tel (7) 842 40 89 TELEX. 305153

WERT OFRMANY

Intel Semiconductor GmbH\* Seidistrasse 27 D-8000 Munchen 2 Tel (89) 53891 TELEX 05-23177 INTL D

Intel Semiconductor GmbH\* Mainzer Strasse 75 D-6200 Wiesbaden 1 Tel (6121) 70 08 74 TELEX 04186183 INTW D Intel Semiconductor GmbH Brueckstrasse 61 7012 Fellbach Stuttgart Tel: (711) 58 00 82 TELEX. 7254826 INTS D

Intel Semiconductor GmbH\* Hohenzüllern Strasse 5\* 3000 Hannover 1 Tel (511) 34 40 81 TELEX. 923625 INTH D

#### IRRAFI

Intel Semiconductor Ltd.\* PO Box 1659 Harfa Tel`4/524 261 TELEX 46511 

Intel Corporation Italia Spa\* Milanofiori, Palazzo E 20094 Assago (Milano) Tel. (02) 824 00 06 TELEX: 315183 INTMIL

NETHERLANDS Intel Semiconductor Nederland B.V \* Alexanderpoort Building Marten Meesweg 93 3068 Rotterdam Tel (10) 21 23 77 TELEX: 22263

## NORWAY Intel Norway A/S PO Box 92 Hvarrvelen 4 N-2013 Skjetten Tel. (2) 742 420 TELEX 18018

## **GDAIN**

Intel Ibena Calle Zurbaran 28 Madrid 04 Tel: (34) 1410 40 04 TELEX: 46880

## **ewene**M

Intel Sweden A B.\* Dalvagen 24 S-17136 Solna Tel (08) 734 01 00 TELEX 12261

SWITZERLAND Intel Semiconductor A G \* Talackerstrasse 17 8152 Glattbrugg postfach CH-8065 Zurich Tel. (01) 829 29 77 TELEX 57989 ICH CH

UNITED KINGDOM

Intel Corporation (U.K.)- Ltd.\* Pipers Way Swindon, Witshire SN3 1RJ Tel (0793) 488 388 TELEX 444447 INT SWN

\*Field Application Location

## EUROPEAN DISTRIBUTORS/REPRESENTATIVES

### AUSTRIA

Bacher Elektronische Geraete GmbH Rotemuehigasse 26 A 1120 Vienna Tel (222) 83 56 46 TELEX. 11532 BASAT A

-REI GUM Ave. des Croix de Guerre 94 B1120 Brussels Tel· (02) 216 01 60 TELEX 25441

## DENMARK ITT MultiKomponent A/S Naverland 29 DK-2600 Gloskrup Tel. (02) 45 66 45 TX 33355

FINLAND

Oy Fintronic AB Melkonkatu 24 A SF-00210 Hetsinki 21 Tel (0) 692 60 22 TELEX 124 224 Ftron SF

FRANCE Generim Z.I de Courtaboeuf Avenue de la Baltique 91943 Les Ullis Cedex-B.P 88 Tel: (1) 907 78 78 TELEX: F691700

Jermyn S A 16, Avenue Jean-Jaures 94600 Choisy-Le-Roi Tel: (1) 853 12 00 TELEX. 260967

Metrologie La Tour d'Asnieres 4, Avenue Laurent Cely 92606-Asnieres Tel (1) 790 62 40 TELEX 611-448

Tekelec Airtronic Cite des Bruyeres \* Rue Carle Vernet B.P 2 92310 Sevres Tel (1) 534 75 35 TELEX 204552

WEST GERMANY

Electronic 2000 Vertriebs A G Stahlgruberring 12 D-8000 Munich 82 Tel, (89) 42 00 10 TELEX 522561 EIEC D Jermyn GmbH Postfach 1180 Posttach 1180 Schulstrasse 84 D-6277 Bad Camberg Tel. (06434) 231 TELEX. 484426 JERM D

CES Computer Electronics Systems GmbH 2359 Henstedt-Ulzburg Tel (04193) 4026 TELEX 2180260

Metrologie GmbH Hansastrasse 15 8000 Munich 21 Tel (89) 57 30 84 TELEX: D 5213189

Proelectron Vertriebs GmbH Max Planck Strasse 1-3 6072 Drevich bei Frankfurt Tel (6103) 33564 TELEX 417983

## IRELAND

Micro Marketing Glenageary Office Park Glenageary Co Dublin Tel: (1) 85 62 88 TELEX. 31584

ISRAEL Eastronics Ltd 11 Rozanis Street P.O Box 39300 Tel Avv 61390 Tel (3) 47 51 51 TELEX 33638

ITALY

Eledra 3S S P A Viale Elvezia, 18 I 20154 Milano Tel. (2) 34 97 51 TELEX 332332

Intesi Milanofori Pal E/5 20090 Assago Milano Tel. (02) 82470 TELEX 311351

## NETHERI ANOS

Koning & Hartman Koperwerf 30 PO Box 43220 2544 EN's Gravenhage Tel 31 (70) 210 101 TELEX 31528

NORWAY Nordisk Elektronic (Norge) A/S Postoffice Box 122 Smedsvingen 4 1364 Hvalstad Tel. (2) 846 210 TELEX 17546

## PORTUGAL

Ditram Componentes E Electronica LDA Av Miguel Bombarda, 133 P1000 Lisboa Tel. (19) 545 313 TELEX 14182 Brieks-P

## SPAIN

Interface S A Av Pompeu Fabra 12 08024 Barcelona Tel (3) 219 80 11 TELEX 51508

ITT SESA Miguel Angel 21, 6 Piso Madrid 10 Tel (34) 14 1954 00 TELEX 27461

OWEDEN

AB Gosta Backstrom Box 12009 Alstroemergatan 22 S-10221 Stockholm 12 Tel (8) 541 080 TELEX 10135

Nordisk Electronik AB Box 27301 Sandhamnsgatan 71 S-10254 Stockholm Tel (8) 635 040 TELEX 10547

Telko AB Gardsfogdevagen 1 Box 186 S-161 26 Bromma Tel (6) 98 08 20 TELEX 11941

SWITZERI AND

Industrade AG Herlistrasse 31 CH-8304 Wallisellen Tel (01) 830 50 40 TELEX 56788 INDEL CH

Bytech Ltd Unit 57 London Road Earley, Reading Berksfire Tel: (0734) 61031 TELEX 848215

Comway Microsystems Ltd Market Street UK-Bracknell, Berkshire Tel 44 (344) 55333 TELEX: 847201

Rapid Recall, Ltd Rapid House/Denmark St High Wycombe Berks, England HP11 2ER Tel (0494) 26 271 TELEX 837931

#### YUGOSLAVIA

,

UNITED KINGDOM

Jermyn industries Vestry Estate Sevenoaks, Kent Tel: (0732) 450144 TELEX 95142

M E D L East Lane Road North Wembley Middlesex HA9 7PP Tel: (190) 49307 TELEX 28817

H R Microelectronics Enterprises PO Box 5604 San Jose, California 95150 Tel 408/978-8000 TELEX 278-559

## INTERNATIONAL SALES OFFICES

## 

Intel Australia Pty Ltd \* (Mailing Address) P.O. Box 571 North Sydney NSW, 2065

## (Shipping Address) Spectrum Building 200 Pacific Highway

200 Pacinic rngr....., Level 6 Crows Nest, NSW, 2065 Tel: 011-61-2-957-2744 TELEX 790-20097 FAX 011-61-2-957-2744

## -----Initel Semiconductor Ltd.\* 1701-3 Connaught Centre 1 Connaught Road Tel· 011-852-5-215-311 TWX 60410 ITLHK

## ----

Imel Japan K.K 5-6 Tokodai, Toyosato-machi Tsukuba-gun, Ibaraki-ken 300-26 Tel. 029747-8511 TELEX 03656-160

Intel Japan K.K.\* 2-1-15 Naka-machi Atsugi, Kanagawa 243 Tel 0462-23-3511 Intel Japan KK \* 2-51-2 Kojima-cho Chofu, Tokyo 182 Tel 0424-88-3151

Intel Japan K K.\* 2-69 Hon-cho Kumagaya, Saltama 360 Tel: 0485-24-6871

Intel Japan K.K.\* 2-4-1 Terauchi Toyonaka, Osaka 560 Tel: 06-863-109!

JAPAN (Cont'd) Intel Japan K.K. 1-5-1 Marunouchi Chiyoda-ku, Tokyo 100 Tel: 03-201-3621

Intel Japan K.K \* 1-23-9 Shinmachi Setagaya-ku, Tokyo 154 Tel: 03-426-2231

Intel Japan K.K.<sup>e</sup> Mitsui-Seimei Musashi-Kosugi Bidg. 915 Shinmaruko, Nakahara-ku Kawasaki-Shi, Kanagawa 211 Tel 044-733-7011

Intel Japan K.K. 1-1 Shibahon-cho Mishima-shi Shizuoka-Ken 411 Tel 0559-72-4121

#### -

Intel Semiconductor Asia Ltd Singsong Bidg. 8th Floor #906 25-4 Yoldo-Dong, Youngdeungpo-Secul 150 Tel. 011-82-2-784-8196 or 8286 TELEX. K29312 INTELKO

Sintakuruna Intel Semiconductor Ltd 101 Thomson Road 21-06 Goldhill Square Singapore 1130 Tel: 011-66-2507811 TWX: RS 39921 CABLE. INTELSGP

\*Field Application Location

## INTERNATIONAL DISTRIBUTORS/REPRESENTATIVES

#### ARGENTINA

VLC S R.L. Sarmento 1630, 1 Piso 1042 Buenos Aires Tel 011-54-1-35-1201/9242 TELEX. 17575 EDARG

Agent Solmex International Corporation 15 Park Row, Room #1730 New York, New York 10038 Tel (212) 406-3052 Attn. Gaston Briones

### ALINTRAL IA

Total Electronics (Mailing Address) Private Bag 250 Burwood, Victoria 3125

## (Shipping Address) 9 Harker Street Burwood Victoria 3125 Tel 011-61-3-288-4044 TELEX AA 31261

Total Electronics P O Box 139 Artarmon, N S W 2064 Tel 011-61-02-438-1855 TELEX 26297

## BRAZIL

lootron S.A 05110 Av Mutinga 3650-6 Andar Pirituba Sao Paulo Tel 011-55-11-833-2572 TELEX 1122274 ICOTBR

## CHILE

DIN (Mailing Address) Av. VIC, MacKenna 204 Casilia 6055. Santiago Tel 011-56-2-277-564 TELEX: 352-0003

(Shipping Address) A102 Greenville Center 3801 Kennett Pike Wilmington, Delaware 19807

## HONG KONG

Novel Precision Machinery Co., Ltd Flat D 20 Kingsford Ind, Bidg Phase 1 26 Kwai Hei Street NT Tel 011-852-5-0-223222 TWX: 39114 JINMI HX

Schmidt & Co, Ltd 18/F Great Eagle Centre Wanchar Tel 011-852-5-833-0222 TWX 74766 SCHMC HK

## 

Micronic Devices 65 ARUN Complex D V G Road Basavan Gudi Bangalore 560004 Tel 011-91-812-600-631 TELEX 011-5947 MDEV

Micronic Devices 104/109C Nirmal Industrial Estate Sion (E) Bombay 400022 Tel, 011-91-22-48-61-70 TELEX: 011-71447 MDEV IN

Micronic Devices R-694 New Rajinder Nager New Delhi 110060

Ramiak International, Inc (Agent) 465 S Mathilda Avenue Suite 302 Sunnyvele, CA 94086 Tel (408).733-8767

S & S Corporation (Mailing Address) P O Box 1185 Mauldin, South Carolina, 29657

(Shipping Address) 308 Green Drive Liberty, South Carolina 29657

## JAPAN

Asahi Electronics Co. Ltd. KMM Bidg. Room 407 2-14-1 Asano, Kokurakita-Ku Kitakyushu City 802 Tel: (093) 511-6471 TELEX AECKY 7126-16

#### JAPAN (Cont'd)

Hamilton-Avnet Electronics Japan Ltd YU and YOU Bidg. 1-5-7 Horidome-Cho Nihonbashi Chuo-Ku, Tokyo 103 Tel<sup>-</sup> (03) 662-9911 TELEX: 2523774

Ryoyo Electric Corporation Konwa Bidg. 1-12-22, Tsukiji Chuo-Ku, Tokyo 104 Tel: (03) 543-7711/541-7311

Tokyo Electron Ltd. Shinjuku Nomura Bidg. 26-2 Nishi-Shinjuku 1-Chome Shinjuku-Ku, Tokyo 160 Tel. (03) 343-4411 TELEX. 232-2220 LABTEL J

#### KOREA

J-TEK Corporation 2nd Floor, Government Pension Bidg, 24-3, Youdo-Dong Youngdungpo-Ku Seoul 150 Tel: 011-82-2-782-8039 TELEX: KODIGIT K25299

Koram Digital USA (Agent) 14066 East Firestone Boulevard Sante Fe Springs, CA 90670 Tel. (714) 739-2204 TWX: 194715 KORAM DIGIT LSA

#### NEW ZEALAND

McLean Information Technology Ltd 459 Kyber Pass Road, Newmarket, P.O. Box 9464, Newmarket Auckland 1, New Zealand Tel, 011-64-9-501-219, 501-801, 587-037 TELEX, NZ21570 THERMAL

#### PAKISTAN

Computer Applications Ltd. 7D Gizn Boulevard Defense Karachi-46 Tel: 011-92-21-530-306/7 TELEX. 24434 GAFAR PK

#### PAKISTAN (Cont'd)

Horizon Training Co., Inc (Agent) 1 Lafayette Center 1120 20th Street N W Suite 530 Washington, D.C. 20036 Tei (202) 887-1900 TWX: 246890 HORN

Senarci Figineers Corporation Pty. Ltd. Units 1003-1008 Block 3 10th Floor PSA Multi Slovey Complex Teols, longraph Peak Singapore 5 Tel 011-65-271-3163 TELEX: RS23967 GENEROC CABLE GENEROCHP

Mitac Corporation 3rd Floor #75, Section 4 Nanking East Road Taipel Tel: 011-886-2-771-0940, 0941 TELEX 11942 TAIAUTO

Mectel International, Inc. (Agent) 3385 Viso Court Santa Clara, CA 95050 Tel (408) 988-4513 TWX: 910-338-2201 FAX 408-980-9742

\*Field Application Location

OABOBE

### SOUTH AFRICA

Electronic Building Elements, Pty. Ltd. P.O. Box 4609 Pretoria 0001 Tel: 011-27-12-46-9221 TELEGRAM. ELBILEM

## TAIWAN

VUQOBLAVIA

H. R. Microelectronics Ente P O Box 5604 San Jose, California 95150 Tel: (408) 978-8000 TELEX. 278-559 s Entern

## inte

## DOMESTIC SERVICE OFFICES

ai Corp 211

Co. E 110 Intel 2000 Suite Santr Tel: TWX 4th Sh na 92705

intel Corp. 4350 Executive Driv Suite 150 San Diego 92121 Tel: (619) 452-5880 ve Drivi

intel Corp. 5530 N. Corbin Avi Sulte 120 Tarzana 91356 Tel: (213) 708-0333

----ntel Corp. 50 South Cherry Guine 720 Denver 80222 Tel. (303) 321-8086 TWX: 910-931-2289

## CONNECTICUT

Intel Corp. 26 Mill Plain Road Danbury 06811 Tel: (203) 748-3130 FLORIDA

Intel Corp. 1500 N.W. 62nd Street Suite 104 FL Lauderdale 33309 Tel: (305) 771-0600 TWX: 510-956-9407

PLORIDA (Cont'd)

Intel Corp. 500 N. Ma 205 and 32751 (305) 628-2393 610-853-9219

GEORGIA Intel Corp. 3280 Pointe Parkway Suite 200 Norcross 30092 Tel. (404) 441-1171

**ILLINOIS** 

Intel Corp. 2550 Golf Road Suite 815 Rolling Meadows 60008 Tel: (312) 981-7285 TWX. 910-253-1825

KAMBAR Intel Corp. 8400 W. 110th Street Suite 170 Overland Park 66210 Tel: (913) 642-8080

RYLAND

I Corp. Floor Product Service IS Walker Drive enbelt 20770 : (301) 441-1020 BACHUSETTS

tel Corp 7 industri Chelmsford 01824 Tel. (617) 256-1800

intel Corp 7071 Orchard Lake Ro Suite 100 West Bioomfield 48033 Tel: (313) 851-8905

Intel Corp. 4203 Earth City Express Suite 143 Earth City 63045 Tel: (314) 291-2015

Sylvan Avenus ewood Cliffs 07 (201) 567-0820 710-991-850 Engle Tel· TWX.

Intel Corp Bariter an Plaza ... an Center on 08817 (201) 225-3000

ANUORTH CAROLINA Intel Corp 2306 W. Meadowvi Suite 206 Greensboro 27407 Tel (919) 294-1541 Boad

## оню Intel Corp. Chagrin-Brainard Bidg Suite 305 28001 Chagrin Boule Cleveland 44122 Tel: (216) 464-8915 TWX: 610-427-9298

Corn

Poe on 45414 (513) 890-5350

Intel Con 10700 ghway uite 22 enton 97005 (503) 641-8086 910-467-8741

Intel Corp. 5200 N.E. Elam Young Park Hillaboro 97123 Tel (503) 681-8080

Intel Corp 201 Penn Center Boule Suite 301 W Pittsburgh 15235 Tel: (313) 354-1540

TEXAS Intel Corp. 313 E Anderson Lane Suite 314 Austin 78752 Tel (512)454-3628 TWX. 910-874-1347

Intel Corp 12300 Ford Road Suite 380 Dallas 75234 Tel: (214) 241-808 TWX: 910-860-5617

WARHINGTON Intel Corp 110 110th Avi Suite 510 Bellevue 9800 nue NE.

510 /ue 98004 1-800-525-5560 910-443-3002

waaaawaw

Intel Corp. 450 N. Sunnyslope Road Suite 130 Brookfield 53005 Tel (414) 784-8087

## intel

## **UNITED STATES**

Intel Corporation 3065 Bowers Avenue Santa Clara, CA 95051

JAPAN

Intel Japan K.K. 5-6 Tokodai Toyosato-machi Tsukuba-gun, Ibaraki-ken 300-26 Japan

FRANCE

Intel 5 Place de la Balance Silic 223 94528 Rungis Cedex France

UNITED KINGDOM Intel Piper's Way Swindon Wiltshire, England SN3 1RJ

WEST GERMANY Intel Seidstrasse 27 D-8000 Munchen 2 West Germany

ISBN 0-917017-15-3

Printed in U.S.A./C-792/1284/100K/RRD PB Microcontrollers