 рәррәqu p
 [EnUBW S،.JOS inter

# 8XC251SB Embedded Microcontroller User's Manual 

# 8XC251SB Embedded Microcontroller User's Manual 

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

Intel 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 Intel sales office or your distributor to obtain the latest specifications before placing your product order.
MDS is an ordering code only and is not used as a product name or trademark of Intel Corporation.
Intel Corporation and Intel's FASTPATH are not affiliated with Kinetics, a division of Excelan, Inc. or its FASTPATH trademark or products.
*Other brands and names are the property of their respective owners.
Additional copies of this document or other Intel literature may be obtained from:
Intel Corporation
Literature Sales
P.O. Box 7641

Mt. Prospect, IL 60056-7641
or call 1-800-879-4683

## CONTENTS

CHAPTER 1
GUIDE TO THIS MANUAL
1.1 MANUAL CONTENTS ..... 1-1
1.2 NOTATIONAL CONVENTIONS AND TERMINOLOGY ..... 1-3
1.3 RELATED DOCUMENTS ..... 1-5
1.3.1 Data Sheet ..... 1-6
1.3.2 Application Notes ..... 1-6
1.4 CUSTOMER SERVICE. ..... 1-7
1.4.1 How to Use Intel's FaxBack Service ..... 1-7
1.4.2 How to Use Intel's Application BBS ..... 1-8
1.4.3 How to Find the Latest ApBUILDER Files and Hypertext Manuals and Data Sheets on the BBS ..... 1-9
CHAPTER 2
ARCHITECTURAL OVERVIEW
2.1 8XC251SB CORE ..... 2-4
2.1.1 CPU ..... 2-4
2.1.2 Clock and Reset Unit ..... 2-5
2.1.3 Interrupt Handler ..... 2-6
2.1.4 On-chip Code Memory ..... 2-6
2.1.5 On-chip RAM ..... 2-7
2.2 ON-CHIP PERIPHERALS ..... 2-7
2.2.1 Timer/Counters and Watchdog Timer ..... 2-7
2.2.2 Programmable Counter Array (PCA) ..... 2-7
2.2.3 Serial I/O Port ..... 2-8
CHAPTER 3
ADDRESS SPACES
3.1 ADDRESS SPACES FOR MCS ${ }^{\circledR} 251$ MICROCONTROLLERS ..... 3-1
3.1.1 Compatibility with the MCS ${ }^{\circledR} 51$ Architecture ..... 3-2
3.2 THE 8XC251SB MEMORY SPACE. ..... 3-5
3.2.1 On-chip General-purpose Data RAM ..... 3-6
3.2.2 On-chip Code Memory (87C251SB/83C251SB) ..... 3-6
3.2.2.1 Accessing On-chip Code Memory in Region 00: ..... 3-6
3.2.3 External Memory ..... 3-8
3.3 THE 8XC251SB REGISTER FILE ..... 3-8
3.3.1 Byte, Word, and Dword Registers ..... 3-8
3.3.2 Dedicated Registers ..... 3-10
3.3.2.1 Accumulator and $B$ Register ..... 3-10
3.3.2.2 Extended Data Pointer, DPX ..... 3-10
3.3.2.3 Extended Stack Pointer, SPX ..... 3-11
3.4 SPECIAL FUNCTION REGISTERS (SFRS) ..... 3-12
CHAPTER 4
PROGRAMMING
4.1 BINARY MODE AND SOURCE MODE CONFIGURATIONS ..... 4-1
4.1.1 Selecting Binary Mode or Source Mode ..... 4-2
4.2 PROGRAMMING FEATURES OF THE MCS ${ }^{\circledR} 251$ ARCHITECTURE ..... 4-4
4.2.1 Data Types ..... 4-4
4.2.2 Register Notation ..... 4-4
4.2.3 Address Notation ..... 4-5
4.2.4 Addressing Modes ..... 4-5
4.3 DATA INSTRUCTIONS ..... 4-6
4.3.1 Data Addressing Modes ..... 4-6
4.3.1.1 Register Addressing ..... 4-8
4.3.1.2 Immediate ..... 4-8
4.3.1.3 Direct ..... 4-8
4.3.1.4 Indirect ..... 4-9
4.3.1.5 Displacement ..... 4-9
4.3.2 Arithmetic Instructions ..... 4-10
4.3.3 Logical Instructions ..... 4-11
4.3.4 Data Transfer Instructions ..... 4-11
4.4 BIT INSTRUCTIONS ..... 4-12
4.4.1 Bit Addressing ..... 4-12
4.5 CONTROL INSTRUCTIONS ..... 4-14
4.5.1 Addressing Modes for Control Instructions ..... 4-14
4.5.2 Conditional Jumps ..... 4-15
4.5.3 Unconditional Jumps ..... 4-16
4.5.4 Calls and Returns ..... 4-16
4.6 PROGRAM STATUS WORDS ..... 4-17
CHAPTER 5
INTERRUPT SYSTEM
5.1 OVERVIEW ..... 5-1
5.2 8XC251SB INTERRUPT SOURCES ..... 5-3
5.2.1 External Interrupts ..... 5-3
5.2.2 Timer Interrupts ..... 5-4
5.3 PROGRAMMABLE COUNTER ARRAY (PCA) INTERRUPT. ..... 5-5
5.4 SERIAL PORT INTERRUPT ..... 5-5
5.5 INTERRUPT ENABLE ..... 5-5
5.6 INTERRUPT PRIORITIES ..... 5-6
5.7 INTERRUPT PROCESSING ..... 5-9
5.7.1 Minimum Fixed Interrupt Time ..... 5-10
5.7.2 Variable Interrupt Parameters ..... 5-10
5.7.2.1 Response Time Variables ..... 5-10
5.7.2.2 Computation of Worst-case Latency With Variables ..... 5-12
5.7.2.3 Latency Calculations ..... 5-13
5.7.2.4 Blocking Conditions ..... 5-14
5.7.2.5 Interrupt Vector Cycle ..... 5-14
5.7.3 ISRs in Process ..... 5-15
CHAPTER 6
INPUT/OUTPUT PORTS
6.1 INPUT/OUTPUT PORT OVERVIEW ..... 6-1
6.2 I/O CONFIGURATIONS. ..... 6-2
6.3 PORT 1 AND PORT 3 ..... 6-2
6.4 PORT 0 AND PORT 2 ..... 6-2
6.5 READ-MODIFY-WRITE INSTRUCTIONS ..... 6-5
6.6 QUASI-BIDIRECTIONAL PORT OPERATION ..... 6-5
6.7 PORT LOADING. ..... 6-7
6.8 EXTERNAL MEMORY ACCESS ..... 6-7
CHAPTER 7
TIMER/COUNTERS AND WATCHDOG TIMER
7.1 TIMER/COUNTER OVERVIEW. ..... 7-1
7.2 TIMER/COUNTER OPERATION ..... 7-1
7.3 TIMER 0. ..... 7-4
7.3.1 Mode 0 (13-bit Timer) ..... 7-4
7.3.2 Mode 1 (16-bit Timer) ..... 7-5
7.3.3 Mode 2 (8-bit Timer With Auto-reload) ..... 7-5
7.3.4 Mode 3 (Two 8-bit Timers) ..... 7-5
7.4 TIMER 1 ..... 7-6
7.4.1 Mode 0 (13-bit Timer) ..... 7-9
7.4.2 Mode 1 (16-bit Timer) ..... 7-9
7.4.3 Mode 2 (8-bit Timer with Auto-reload) ..... 7-9
7.4.4 Mode 3 (Halt) ..... 7-9
7.5 TIMER 0/1 APPLICATIONS ..... 7-9
7.5.1 Auto-load Setup Example ..... 7-9
7.5.2 Pulse Width Measurements ..... 7-10
7.6 TIMER 2 ..... 7-10
7.6.1 Capture Mode ..... 7-11
7.6.2 Auto-reload Mode ..... 7-12
7.6.2.1 Up Counter Operation ..... 7-12
7.6.2.2 Up/Down Counter Operation ..... 7-13
7.6.3 Baud Rate Generator Mode ..... 7-14
7.6.4 Clock-out Mode ..... 7-14
7.7 WATCHDOG TIMER ..... 7-16
7.7.1 Description ..... 7-16
7.7.2 Using the WDT ..... 7-18
7.7.3 WDT During Idle Mode ..... 7-18
7.7.4 WDT During PowerDown ..... 7-18
CHAPTER 8
PROGRAMMABLE COUNTER ARRAY
8.1 PCA DESCRIPTION ..... 8-1
8.2 PCA TIMER/COUNTER ..... 8-2
8.3 PCA COMPARE/CAPTURE MODULES ..... 8-5
8.3.1 16-bit Capture Mode ..... 8-5
8.3.2 Compare Modes ..... 8-7
8.3.3 16-bit Software Timer Mode ..... 8-7
8.3.4 High-speed Output Mode ..... 8-8
8.3.5 PCA Watchdog Timer Mode ..... 8-9
8.3.6 Pulse Width Modulation Mode ..... 8-11
CHAPTER 9
SERIAL I/O PORT
9.1 OVERVIEW ..... 9-1
9.2 MODES OF OPERATION ..... 9-4
9.2.1 Synchronous Mode (Mode 0) ..... 9-4
9.2.1.1 Transmission (Mode 0) ..... 9-4
9.2.1.2 Reception (Mode 0) ..... 9-5
9.2.2 Asynchronous Modes (Modes 1, 2, and 3) ..... 9-6
9.2.2.1 Transmission (Modes 1, 2, 3) ..... 9-6
9.2.2.2 Reception (Modes 1, 2, 3) ..... 9-6
9.3 FRAMING BIT ERROR DETECTION (MODES 1, 2, AND 3) ..... 9-7
9.4 MULTIPROCESSOR COMMUNICATION (MODES 2 AND 3) ..... 9-7
9.5 AUTOMATIC ADDRESS RECOGNITION ..... 9-7
9.5.1 Given Address ..... 9-8
9.5.2 Broadcast Address ..... 9-9
9.5.3 Reset Addresses ..... 9-10
9.6 BAUD RATES ..... 9-10
9.6.1 Baud Rate for Mode 0 ..... 9-10
9.6.2 Baud Rates for Mode 2 ..... 9-10
9.6.3 Baud Rates for Modes 1 and 3 ..... 9-10
9.6.3.1 Timer 1 Generated Baud Rates (Modes 1 and 3) ..... 9-11
9.6.3.2 Selecting Timer 1 as the Baud Rate Generator ..... 9-11
9.6.3.3 Timer 2 Generated Baud Rates (Modes 1 and 3) ..... 9-12
9.6.3.4 Selecting Timer 2 as the Baud Rate Generator ..... 9-12
CHAPTER 10
MINIMUM HARDWARE SETUP
10.1 MINIMUM HARDWARE SETUP ..... 10-1
10.2 ELECTRICAL ENVIRONMENT ..... 10-2
10.2.1 Power and Ground Pins ..... 10-2
10.2.2 Unused Pins ..... 10-2
10.2.3 Noise Considerations ..... 10-2
10.3 CLOCK SOURCES ..... 10-3
10.3.1 On-chip Oscillator (Crystal) ..... 10-3
10.3.2 On-chip Oscillator (Ceramic Resonator) ..... 10-4
10.3.3 External Clock ..... 10-4
10.4 RESET ..... 10-5
10.4.1 Externally Initiated Resets ..... 10-6
10.4.2 WDT Initiated Resets ..... 10-6
10.4.3 Reset Operation ..... 10-6
10.4.4 Power-on Reset ..... 10-7
CHAPTER 11
SPECIAL OPERATING MODES
11.1 GENERAL ..... 11-1
11.2 POWER CONTROL REGISTER ..... 11-1
11.2.1 Serial I/O Control Bits ..... 11-1
11.2.2 Power Off Flag ..... 11-1
11.3 IDLE MODE ..... 11-4
11.3.1 Entering Idle Mode ..... 11-4
11.3.2 Exiting Idle Mode ..... 11-5
11.4 POWERDOWN MODE ..... 11-5
11.4.1 Entering Powerdown Mode ..... 11-6
11.4.2 Exiting Powerdown Mode ..... 11-6
11.5 ON-CIRCUIT EMULATION (ONCE) MODE ..... 11-7
11.5.1 Entering ONCE Mode ..... 11-7
11.5.2 Exiting ONCE Mode ..... 11-7
CHAPTER 12
EXTERNAL MEMORY INTERFACE
12.1 EXTERNAL MEMORY INTERFACE SIGNALS ..... 12-1
12.2 CONFIGURING THE EXTERNAL MEMORY INTERFACE. ..... 12-2
12.2.1 Page Mode and Nonpage Mode (PAGE Bit) ..... 12-3
12.2.2 RD\#, PSEN\#, and the Number of External Address Pins (Bits RD1:0) ..... 12-3
12.2.2.1 Sixteen External Address Bits and a Single Read Signal (RD1 = 1, RD0 = 0) ..... 12-4
12.2.2.2 Seventeen External Address Bits and a Single Read Signal (RD1 = 0, RD0 = 1) ..... 12-4
12.2.2.3 Sixteen External Address Bits and Two Read Signals (RD1 = 1, RD0 = 1) ..... 12-5
12.2.3 Wait States (WSA, WSB, XALE) ..... 12-6
12.2.4 Mapping On-chip Code Memory to Data Memory (87C251SB/83C251SB) ..... 12-7
12.3 EXTERNAL BUS CYCLES ..... 12-7
12.3.1 Inactive External Bus ..... 12-7
12.3.2 Bus Cycle Definitions ..... 12-8
12.3.3 Nonpage Mode Bus Cycles ..... 12-8
12.3.4 Page Mode Bus Cycles ..... 12-10
12.4 WAIT STATES ..... 12-13
12.4.1 Extending PSEN\#/RD\#/WR\# ..... 12-13
12.4.2 Extending ALE ..... 12-14
12.5 PORT 0 AND PORT 2 STATUS ..... 12-15
12.5.1 Port 0 and Port 2 Pin Status in Nonpage Mode ..... 12-15
12.5.2 Port 0 and Port 2 Pin Status in Page Mode ..... 12-16
12.6 EXTERNAL MEMORY DESIGN EXAMPLES ..... 12-16
12.6.1 Nonpage Mode, 64 Kbytes External EPROM, 64 Kbytes External RAM ..... 12-16
12.6.1.1 An Application Requiring Fast Access to the Stack ..... 12-16
12.6.1.2 An Application Requiring Fast Access to Data ..... 12-17
12.6.2 Nonpage Mode, 128 Kbytes External RAM ..... 12-19
12.6.3 Page Mode, 128 Kbytes External Flash ..... 12-21
12.6.4 Page Mode, 64 Kbytes External EPROM, 64 Kbytes External RAM ..... 12-21
12.6.5 Page Mode, 64 Kbytes External Flash, 32 Kbytes External RAM ..... 12-22
12.7 EXTERNAL BUS AC TIMING SPECIFICATIONS ..... 12-24
12.7.1 Explanation of AC Symbols ..... 12-28
12.7.2 AC Timing Definitions ..... 12-28
CHAPTER 13
PROGRAMMING AND VERIFYING NONVOLATILE MEMORY
13.1 GENERAL ..... 13-1
13.2 PROGRAMMING AND VERIFYING MODES ..... 13-2
13.3 GENERAL SETUP ..... 13-3
13.4 OTPROM PROGRAMMING ALGORITHM ..... 13-4
13.5 VERIFY ALGORITHM. ..... 13-5
13.6 PROGRAMMABLE FUNCTIONS ..... 13-5
13.6.1 On-chip Code Memory ..... 13-5
13.6.2 Configuration Bytes ..... 13-6
13.6.3 Lock Bit System ..... 13-9
13.6.4 Encryption Array ..... 13-10
13.6.5 Signature Bytes ..... 13-10
13.7 VERIFYING THE 83C251SB (ROM) ..... 13-10
13.8 VERIFYING THE 80C251SB (ROMLESS) ..... 13-11
APPENDIX A
INSTRUCTION SET REFERENCE
A. 1 NOTATION FOR INSTRUCTION OPERANDS ..... A-2
A. 2 OPCODE MAP AND SUPPORTING TABLES ..... A-4
A. 3 INSTRUCTION SET SUMMARY ..... A-11
A.3.1 Execution Times for Instructions that Access the Port SFRs ..... A-11
A.3.2 Instruction Summaries ..... A-14
A. 4 INSTRUCTION DESCRIPTIONS ..... A-26
APPENDIX BSIGNAL DESCRIPTIONS
APPENDIX C
REGISTERS
GLOSSARY
INDEX

## FIGURES

Figure Page
2-1 Functional Block Diagram of the 8XC251SB ..... 2-2
2-2 The CPU ..... 2-5
2-3 8XC251SB Timing ..... 2-6
3-1 Address Spaces for MCS ${ }^{\circledR} 251$ Microcontrollers ..... 3-1
3-2 Address Spaces for the MCS ${ }^{\circledR} 51$ Architecture ..... 3-3
3-3 Address Space Mappings MCS ${ }^{\circledR} 51$ Architecture to MCS ${ }^{\circledR} 251$ Architecture ..... 3-4
3-4 8XC251SB Memory Space ..... 3-7
3-5 The Register File ..... 3-9
3-6 Dedicated Registers in the Register File and their Corresponding SFRs ..... 3-11
4-1 Binary Mode Opcode Map ..... 4-3
4-2 Source Mode Opcode Map ..... 4-3
4-3 Program Status Word Register. ..... 4-19
4-4 Program Status Word 1 Register. ..... 4-20
5-1 Interrupt Control System ..... 5-2
5-2 Interrupt Enable Register ..... 5-6
5-3 Interrupt Priority High Register ..... 5-8
5-4 Interrupt Priority Low Register ..... 5-8
5-5 The Interrupt Process ..... 5-9
5-6 Response Time Example \#1 ..... 5-11
5-7 Response Time Example \#2 ..... 5-12
6-1 Port 1 and Port 3 Structure. ..... 6-3
6-2 Port 0 Structure ..... 6-3
6-3 Port 2 Structure ..... 6-4
6-4 Internal Pullup Configurations ..... 6-6
7-1 Basic Logic of the Timer/Counters ..... 7-2
7-2 $\quad$ Timer 0/1 in Mode 0 and Mode 1 ..... 7-4
7-3 Timer 0/1 in Mode 2, Auto-Reload ..... 7-5
7-4 Timer 0 in Mode 3, Two 8-bit Timers ..... 7-6
7-5 TMOD: Timer/Counter Mode Control Register ..... 7-7
7-6 TCON: Timer/Counter Control Register ..... 7-8
7-7 Timer 2: Capture Mode ..... 7-11
7-8 Timer 2: Auto Reload Mode (DCEN = 0) ..... 7-12
7-9 Timer 2: Auto Reload Mode (DCEN = 1) ..... 7-13
7-10 Timer 2: Clock Out Mode ..... 7-15
7-11 T2MOD: Timer 2 Mode Control Register ..... 7-16
7-12 T2CON: Timer 2 Control Register ..... 7-17
8-1 Programmable Counter Array ..... 8-3
8-2 PCA 16-bit Capture Mode ..... 8-6
8-3 PCA Software Timer and High-speed Output Modes ..... 8-8
8-4 PCA Watchdog Timer Mode ..... 8-10
8-5 PCA 8-bit PWM Mode ..... 8-11
8-6 PWM Variable Duty Cycle ..... 8-12
8-7 CMOD: PCA Timer/Counter Mode Register ..... 8-13
8-8 CCON: PCA Timer/Counter Control Register. ..... 8-14

## FIGURES

Figure Page
8-9 CCAPMx. PCA Compare/Capture Module Mode Registers ..... 8-16
9-1 Serial Port Block Diagram ..... 9-2
9-2 Serial Port Special Function Register ..... 9-3
9-3 Mode 0 Timing ..... 9-5
9-4 Data Frame (Modes 1, 2, and 3) ..... 9-6
9-5 Timer 2 in Baud Rate Generator Mode ..... 9-13
10-1 Minimum Setup ..... 10-1
10-2 CHMOS On-chip Oscillator ..... 10-3
10-3 External Clock Connection ..... 10-4
10-4 External Clock Drive Waveforms ..... 10-5
10-5 Reset Timing Sequence ..... 10-8
11-1 Power Control (PCON) Register. ..... 11-2
11-2 Idle and Powerdown Clock Control ..... 11-3
12-1 Internal and External Memory Spaces for RD1 $=1$, RD0 $=0$. ..... 12-4
12-2 Internal and External Memory Spaces for RD1 $=0$, RD0 $=1$ ..... 12-5
12-3 Internal and External Memory Spaces for RD1 $=1$, RD0 $=1$ ..... 12-6
12-4 External Code Fetch or Data Read Bus Cycle (Nonpage Mode) ..... 12-9
12-5 External Write Bus Cycle (Nonpage Mode) ..... 12-9
12-6 Bus Structure in Nonpage Mode and Page Mode ..... 12-10
12-7 External Code Fetch Bus Cycle (Page Mode) ..... 12-11
12-8 External Data Read Bus Cycle (Page Mode) ..... 12-12
12-9 External Write Bus Cycle (Page Mode) ..... 12-12
12-10 External Code Fetch or Data Read Bus Cycle with One PSEN\#/RD\# Wait State (Nonpage Mode) ..... 12-13
12-11 External Write Bus Cycle with One WR\# Wait State (Nonpage Mode) ..... 12-14
12-12 External Code Fetch or Data Read Bus Cycle with One ALE Wait State (Nonpage Mode) ..... 12-14
12-13 80C251SB in Nonpage Mode with External EPROM and RAM ..... 12-17
12-14 The Memory Space for the Systems of Figure 12-13 and Figure 12-18 ..... 12-18
12-15 87C251SB/83C251SB in Nonpage Mode with 128 Kbytes of External RAM ..... 12-19
12-16 The Memory Space for the System of Figure 12-15. ..... 12-20
12-17 80C251SB in Page Mode with External Flash ..... 12-21
12-18 80C251SB in Page Mode with External EPROM and RAM ..... 12-22
12-19 80C251SB in Page Mode with External Flash and RAM ..... 12-23
12-20 The Memory Space for the System of Figure 12-19 ..... 12-24
12-21 External Bus Cycles for Data/Instruction Read and Data Write in Nonpage Mode ..... 12-25
12-22 External Bus Cycles for Data Read and Data Write in Page Mode ..... 12-26
12-23 External Bus Cycles for Instruction Read in Page Mode ..... 12-27
13-1 Setup for Programming and Verifying ..... 13-3
13-2 OTPROM Programming Waveforms ..... 13-4
13-3 Configuration Byte 0 ..... 13-7
13-4 Configuration Byte 1 ..... 13-8
13-5 OTPROM Timing ..... 13-11

## TABLES

Table Page
2-1 Summary of 8XC251SB Features ..... 2-4
3-1 Address Mappings ..... 3-4
3-2 Register Bank Selection ..... 3-8
3-3 Dedicated Registers in the Register File and their Corresponding SFRs ..... 3-12
3-4 8XC251SB SFR Map and Reset Values ..... 3-13
3-5 Core SFRs ..... 3-14
3-6 I/O Port SFRs ..... 3-14
3-7 Serial I/O SFRs ..... 3-15
3-8 Timer/Counter and Watchdog Timer SFRs ..... 3-15
3-9 Programmable Counter Array (PCA) SFRs ..... 3-15
4-1 Examples of Opcodes in Binary and Source Modes ..... 4-2
4-2 Data Types ..... 4-4
4-3 Notation for Byte Registers, Word Registers, and Dword Registers ..... 4-5
4-4 Addressing Modes for Data Instructions in the MCS® 51 Architecture ..... 4-6
4-5 Addressing Modes for Data Instructions in the MCS® 251 Architecture. ..... 4-7
4-6 Bit-addressable Locations ..... 4-13
4-7 Addressing Two Sample Bits. ..... 4-13
4-8 Addressing Modes for Bit Instructions ..... 4-14
4-9 Addressing Modes for Control Instructions. ..... 4-15
4-10 Compare-conditional Jump Instructions ..... 4-16
4-11 The Effects of Instructions on the PSW and PSW1 Flags ..... 4-18
5-1 Interrupt System Pin Signals ..... 5-1
5-2 Interrupt System Special Function Registers ..... 5-3
5-3 Interrupt Control Matrix ..... 5-4
5-4 Level of Priority ..... 5-7
5-5 Interrupt Priority Within Level ..... 5-7
5-6 Interrupt Latency Variables ..... 5-13
5-7 Actual vs. Predicted Latency Calculations ..... 5-13
6-1 Input/Output Port Pin Descriptions ..... 6-1
6-2 Instructions for External Data Moves ..... 6-8
7-1 Timer/Counter and Watchdog Timer SFRs ..... 7-2
7-2 External Signals ..... 7-3
7-3 Timer 2 Modes of Operation ..... 7-15
8-1 PCA Special Function Registers (SFRs) ..... 8-4
8-2 External Signals ..... 8-4
8-3 PCA Module Modes ..... 8-15
9-1 Serial Port Signals ..... 9-1
9-2 Serial Port Special Function Registers ..... 9-2
9-3 Summary of Baud Rates ..... 9-10
9-4 Timer 1 Generated Baud Rates for Serial I/O Modes 1 and 3 ..... 9-12
9-5 Selecting the Baud Rate Generator(s) ..... 9-13
9-6 Timer 2 Generated Baud Rates ..... 9-14
11-1 Pin Conditions in Various Modes. ..... 11-3
12-1 External Memory Interface Signals ..... 12-1

## TABLES

Table Page
12-2 Configuration Bits RD1:0 ..... 12-3
12-3 Wait State Selection ..... 12-6
12-4 Bus Cycle Definitions (No Wait States) ..... 12-8
12-5 Port 0 and Port 2 Pin Status In Normal Operating Mode ..... 12-15
12-6 AC Timing Symbol Definitions ..... 12-28
12-7 AC Timing Definitions for Specifications on the 8XC251SB ..... 12-29
12-8 AC Timing Definitions for Specifications on the Memory System ..... 12-30
13-1 Programming and Verifying Modes ..... 13-2
13-2 Configuration Byte Values for 80C251SB and 80C251SB-16 ..... 13-9
13-3 Lock Bit Function ..... 13-9
13-4 Contents of the Signature Bytes. ..... 13-10
13-5 OTPROM Timing Definitions ..... 13-12
A-1 Notation for Register Operands ..... A-2
A-2 Notation for Direct Addresses. ..... A-3
A-3 Notation for Immediate Addressing ..... A-3
A-4 Notation for Bit Addressing ..... A-3
A-5 Notation for Destinations in Control Instructions ..... A-3
A-6 Instructions for MCS® 51 Microcontrollers ..... A-4
A-7 New Instructions for the MCS ${ }^{\circledR} 251$ Architecture ..... A-5
A-8 Data Instructions ..... A-6
A-9 High Nibble, Byte 0 of Data Instructions ..... A-6
A-10 Bit Instructions ..... A-7
A-11 Byte 1 (High Nibble) for Bit Instructions. ..... A-7
A-12 PUSH/POP Instructions ..... A-8
A-13 Control Instructions ..... A-8
A-14 Displacement/Extended MOVs ..... A-9
A-15 INC/DEC ..... A-10
A-16 Encoding for INC/DEC ..... A-10
A-17 Shifts ..... A-10
A-18 State Times to Access the Port SFRs ..... A-12
A-19 Summary of Add and Subtract Instructions ..... A-14
A-20 Summary of Compare Instructions ..... A-15
A-21 Summary of Increment and Decrement Instructions ..... A-16
A-22 Summary of Multiply, Divide, and Decimal-adjust Instructions ..... A-16
A-23 Summary of Logical Instructions ..... A-17
A-24 Summary of Move Instructions ..... A-19
A-25 Summary of Exchange, Push, and Pop Instructions ..... A-22
A-26 Summary of Bit Instructions ..... A-23
A-27 Summary of Control Instructions ..... A-24
A-28 Flag Symbols ..... A-26
B-1 Signals Arranged by Functional Categories ..... B-1
B-2 Description of Columns of Table B-3 ..... B-2
B-3 Signal Descriptions ..... B-2
C-1 $\quad 8 \mathrm{XC} 251 \mathrm{SB}$ Special Function Registers (SFRs) ..... C-5

## inte.

## Guide to This Manual

## CHAPTER 1 GUIDE TO THIS MANUAL

This manual describes the 8 XC 251 SB embedded microcontroller which is the first member of the MCS ${ }^{\circledR} 251$ microcontroller family. It is intended for use by both software and hardware designers familiar with the principles of microcontrollers.

### 1.1 MANUAL CONTENTS

This manual contains 13 chapters and 3 appendixes. This chapter, Chapter 1, provides an overview of the manual. This section summarizes the contents of the remaining chapters and appendixes. The remainder of this chapter describes notational conventions and terminology used throughout the manual and provides references to related documentation.

Chapter 2 - Architectural Overview - provides an overview of device hardware. It covers core functions (pipelined CPU, clock and reset unit, and on-chip memory) and on-chip peripherals (timer/counters, watchdog timer, programmable counter array, and serial I/O port.)

Chapter 3 - Address Spaces - describes the three address spaces of the MCS 251 microcontroller: memory address space, special function register (SFR) space, and the register file. It also provides a map of the SFR space showing the location of the SFRs and their reset values and explains the mapping of the address spaces of the MCS ${ }^{\circledR} 51$ architecture into the address spaces of the MCS 251 architecture.

Chapter 4 - Programming - provides an overview of the instruction set. It describes each instruction type (control, arithmetic, and logical, etc.) and lists the instructions in tabular form. This chapter also discusses the binary mode and source mode configurations, addressing modes, bit instructions, and the program status words. For additional information about the instruction set, see Appendix A.

Chapter 5 - Interrupts - describes the 8XC251SB interrupt circuitry which provides a TRAP instruction interrupt and seven maskable interrupts: two external interrupts, three timer interrupts, a PCA interrupt, and a serial port interrupt. This chapter also discusses the interrupt priority scheme, interrupt enable, interrupt processing, and interrupt response time.

Chapter 6- Input/Output Ports - describes the four 8-bit I/O ports (ports 0-3) and explains how to configure them for general-purpose I/O and alternate special functions. It also describes the use of ports 2 and 4 as the external address/data bus.

Chapter 7- Timer/Counters and WDT - describes the three on-chip timer/counters and discusses their application. This chapter also provides instructions for using the hardware watchdog timer (WDT) and describes the operation of the WDT during the idle and powerdown modes.

Chapter 8 - Programmable Counter Array (PCA) - describes the PCA on-chip peripheral and explains how to configure it for general-purpose applications (timers and counters) and special applications (programmable WDT and pulse-width modulator).

Chapter 9 - Serial I/O Port - describes the full-duplex serial I/O port and explains how to program it to communicate with external peripherals. This chapter also discusses baud rate generation, framing error detection, multiprocessor communications, and automatic address recognition.

Chapter 10 - Minimum Hardware Considerations - describes the basic requirements for operating the 8 XC 251 SB in a system. It also discusses on-chip and external clock sources and describes device resets, including power-on reset.

Chapter 11 - Special Operating Modes - provides an overview of the idle, powerdown, and on-circuit emulation (ONCE) modes and describes how to enter and exit each mode. This chapter also describes the (PCON) register and lists the status of the device pins during the special modes and reset (Table 11-1).

Chapter 12 - External Memory Interface - discusses the options available for configuring the external memory interface for a variety of applications. These options include page mode (for accelerated external code fetches), the number of external address bits (16 or 17), the number of external wait states, the regions of memory for strobing PSEN\# and RD\#, and making a portion of the on-chip code memory accessible as data. This chapter also discusses external memory signals, control registers, and external bus cycles and their timing, and provides several examples of external memory designs.

Chapter 13 - Programming and Verifying Nonvolatile Memory - provides instructions for programming and verifying on-chip code memory, configuration bytes, signature bytes, lock bits and the encryption array. This chapter provides the bit definitions of the configuration bytes.

Appendix A - Instruction Set Reference - provides reference information for the instruction set. It describes each instruction; defines the bits in the program status word registers (PSW, PSW1); shows the relationships between instructions and PSW flags; and lists hexadecimal opcodes, instruction lengths, and execution times. For additional information about the instruction set, see Chapter 4, "Programming."

Appendix B - Signal Descriptions - describes the function(s) of each device pin. Descriptions are listed alphabetically by signal name. This appendix also provides a list of the signals grouped by functional category.

Appendix C - Registers - provides for convenient reference a copy of the register definition figures that appear throughout the manual.

### 1.2 NOTATIONAL CONVENTIONS AND TERMINOLOGY

The following notations and terminology are used in this manual. The Glossary defines other terms with special meanings.
\#
The pound symbol (\#) has either of two meanings, depending on the context. When used with a signal name, the symbol means that the signal is active low. When used in an instruction, the symbol prefixes an immediate value in immediate addressing mode.
italics

XXXX

Assert and Deassert

Instructions

Logic 0 (Low)

Logic 1 (High)

Italics identify variables and introduce new terminology. The context in which italics are used distinguishes between the two possible meanings.

Variables in registers and signal names are commonly represented by $x$ and $y$, where $x$ represents the first variable and $y$ represents the second variable. For example, in register Px.y, $x$ represents the variable $[1-4]$ that identifies the specific port, and $y$ represents the register bit variable [7:0]. Variables must be replaced with the correct values when configuring or programming registers or identifying signals.

Uppercase X (no italics) represents an unknown value or a "don't care" state or condition. The value may be either binary or hexadecimal, depending on the context. For example, 2XAFH (hex) indicates that bits 11:8 are unknown; 10XX in binary context indicates that the two LSBs are unknown.

The terms assert and deassert refer to the act of making a signal active (enabled) and inactive (disabled), respectively. The active polarity (high/low) is defined by the signal name. Active-low signals are designated by a pound symbol (\#) suffix; active-high signals have no suffix. To assert RD\# is to drive it low; to assert ALE is to drive it high; to deassert RD\# is to drive it high; to deassert ALE is to drive it low.

Instruction mnemonics are shown in upper case to avoid confusion. You may use either upper case or lower case.

An input voltage level equal to or less than the maximum value of $\mathrm{V}_{\mathrm{IL}}$ or an output voltage level equal to or less than the maximum value of $\mathrm{V}_{\mathrm{OL}}$. See data sheet for values.

An input voltage level equal to or greater than the minimum value of $\mathrm{V}_{\mathrm{IH}}$ or an output voltage level equal to or greater than the minimum value of $\mathrm{V}_{\mathrm{OH}}$. See data sheet for values.

| Numbers | Hexadecimal numbers are represented by a string of hexadecimal digits followed by the character $H$. Decimal and binary numbers are represented by their customary notations. (That is, 255 is a decimal number and 11111111 is a binary number. In some cases, the letter $B$ is added for clarity.) |
| :---: | :---: |
| Register Bits | Bit locations are indexed by 7:0 for byte registers, 15:0 for word registers, ands 31:0 for double-word (dword) registers, where bit 0 is the least-significant bit and 7,15 , or 31 is the most-significant bit. An individual bit is represented by the register name, followed by a period and the bit number. For example, PCON. 4 is bit 4 of the power control register. In some discussions, bit names are used. For example, the name of PCON. 4 is POF, the power off flag. |
| Register Names | Register names are shown in upper case. For example, PCON is the power control register. If a register name contains a lowercase character, it represents more than one register. For example, CCAPM $x$ represents the five registers: CCAPM0 through CCAPM4. |
| Reserved Bits | Some registers contain reserved bits. These bits are not used in this device, but they may be used in future implementations. Do not write a " 1 " to a reserved bit. The value read from a reserved bit is indeterminate. |
| Set and Clear | The terms set and clear refer to the value of a bit or the act of giving it a value. If a bit is set, its value is " 1 "; setting a bit gives it a " 1 " value. If a bit is clear, its value is " 0 "; clearing a bit gives it a " 0 " value. |
| Signal Names | Signal names are shown in upper case. When several signals share a common name, an individual signal is represented by the signal name followed by a number. Port pins are represented by the port abbreviation, a period, and the pin number (e.g., P0.0, P0.1). A pound symbol (\#) appended to a signal name identifies an active-low signal. |
| Units of Measure | The following abbreviations are used to represent units of measure: |

A amps, amperes
DCV direct current volts
Kbyte kilobytes
$\mathrm{K} \Omega$ kilo-ohms
mA milliamps, milliamperes
Mbyte megabytes
MHz megahertz

| ms | milliseconds |
| :--- | :--- |
| mW | milliwatts |
| ns | nanoseconds |
| pF | picofarads |
| W | watts |
| V | volts |
| $\mu \mathrm{A}$ | microamps, microamperes |
| $\mu \mathrm{F}$ | microfarads |
| $\mu \mathrm{s}$ | microseconds |
| $\mu \mathrm{W}$ | microwatts |

### 1.3 RELATED DOCUMENTS

The following documents contain additional information that is useful in designing systems that incorporate the 8XC251SB microcontroller. To order documents, please call Intel Literature Fulfillment (1-800-548-4725 in the U.S. and Canada; $+44(0) 793-431155$ in Europe).

Embedded Microcontrollers
Embedded Processors
Order Number 272396
Embedded Applications
Packaging
Order Number 270648
Order Number 240800

### 1.3.1 Data Sheet

The data sheet is included in Embedded Microcontrollers and is also available individually.
8XC251SB CHMOS Single-Chip 8-bit Microcontroller
Order Number 272459
(Commercial/Express)

### 1.3.2 Application Notes

The following application notes apply to the MCS 251 microcontroller.
AP-125, Designing Microcontroller Systems
Order Number 210313
for Electrically Noisy Environments
AP-155, Oscillators for Microcontrollers
Order Number 230659
AP-709, Maximizing Performance Using MCS 251 Microcontroller
Order Number 272671 -Programming the 8XC251SB

The following MCS 51 microcontroller application notes also apply to the MCS 251 microcontroller.

AP70, Using the Intel MCS 51 Boolean Processing Capabilities
Order Number 203830
AP-223, 8051 Based CRT Terminal Controller
Order Number 270032
AP-252, Designing With the 80C51BH
Order Number 270068
AP-425, Small DC Motor Control
Order Number 270622
AP-410, Enhanced Serial Port on the 83C51FA
Order Number 270490
AP-415, 83C51FA/FB PCA Cookbook
Order Number 270609
AP-476, How to Implement $I^{2} \mathrm{C}$ Serial Communication
Order Number 272319 Using Intel MCS 51 Microcontrollers

### 1.4 CUSTOMER SERVICE

This section provides telephone numbers and describes various customer services.

- Customer Support (U.S. and Canada) 800-628-8686
- Customer Training (U.S. and Canada) 800-234-8806
- Literature Fulfillment
- 800-468-8118 (U.S. and Canada)
- +44(0)793-431155 (Europe)
- FaxBack* Service
- 800-628-2283 (U.S. and Canada)
- +44(0)793-496646 (Europe)
- 916-356-3105 (worldwide)
- Application Bulletin Board System
- 800-897-2536 (U.S. and Canada)
- 916-356-3600 (worldwide, up to 14.4-Kbaud line)
- 916-356-7209 (worldwide, dedicated 2400-baud line)
$-\quad+44(0) 793-496340$ (Europe)
Intel provides 24-hour automated technical support through our FaxBack service and our centralized Intel Application Bulletin Board System (BBS). The FaxBack service is a simple-to-use information system that lets you order technical documents by phone for immediate delivery to your fax machine. The BBS is a centralized computer bulletin board system that provides updated application-specific information about Intel products.


### 1.4.1 How to Use Intel's FaxBack Service

Think of the FaxBack service as a library of technical documents that you can access with your phone. Just dial the telephone number (see page 1-7) and respond to the system prompts. After you select a document, the system sends a copy to your fax machine.

Each document is assigned an order number and is listed in a subject catalog. First-time users should order the appropriate subject catalogs to get a complete listing of document order numbers.

The following catalogs and information packets are available:

1. Microcontroller, Flash, and iPLD catalog
2. Development Tools Handbook
3. System catalog
4. DVI and multimedia catalog
5. BBS catalog
6. Microprocessor and peripheral catalog
7. Quality and reliability catalog
8. Technical questionnaire

### 1.4.2 How to Use Intel's Application BBS

The Application Bulletin Board System (BBS) provides centralized access to information, software drivers, firmware upgrades, and revised software. Any user with a modem and computer can access the BBS. Use the following modem settings.

- $14400, \mathrm{~N}, 8,1$

If your modem does not support 14.4 K baud, the system provides auto configuration support for 1200 - through 14.4 K -baud modems.

To access the BBS, just dial the telephone number (see page 1-7) and respond to the system prompts. During your first session, the system asks you to register with the system operator by entering your name and location. The system operator will then set up your access account within 24 hours. At that time, you can access the files on the BBS. For a listing of files, call the FaxBack service and order catalog \#6 (the BBS catalog).

If you encounter any difficulty accessing our high-speed modem, try our dedicated 2400 -baud modem (see page 1-7). Use the following modem settings.

- 2400 baud, $\mathrm{N}, 8,1$


### 1.4.3 How to Find the Latest ApBUILDER Files and Hypertext Manuals and Data Sheets on the BBS

The latest $A p$ BUILDER files and hypertext manuals and data sheets are available first from the BBS. To access the files:

1. Select $[F]$ from the BBS Main menu.
2. Select [L] from the Intel Apps Files menu.
3. The BBS displays the list of all area levels and prompts for the area number.
4. Select [25] to choose the $A p$ BUILDER / Hypertext area.
5. Area level 25 has four sublevels: (1) General, (2) 196 Files, (3) 186 Files, and (4) 8051 Files.
6. Select [1] to find the latest $A p B$ BUILDER files or the number of the appropriate productfamily sublevel to find the hypertext manuals and data sheets.
7. Enter the file number to tag the files you wish to download. The BBS displays the approximate download time for tagged files.

## intel.

## Architectural <br> Overview

## CHAPTER 2 ARCHITECTURAL OVERVIEW

The 8 XC 251 SB is the first microcontroller in Intel's family of MCS ${ }^{\circledR} 251$ microcontrollers. This family of 8-bit microcontrollers extends the features and performance of the widely-used MCS 51 microcontrollers, while providing binary-code compatibility. Pin compatible with the 8XC51FX, the 8 XC 251 SB provides a high-performance upgrade with minimal impact on existing hardware and software. Typical control applications for the 8 XC 251 SB include copiers, scanners, and CD ROM and tape drives. It is also well suited for communications applications, such as phone terminals, business/feature phones, and phone switching and transmission systems.

All MCS 251 microcontrollers share a set of common features:

- 24-bit linear addressing and up to 16 Mbytes of memory
- a register-based CPU with registers accessible as bytes, words, and double words.
- a page mode for accelerating external instruction fetches
- an instruction pipeline
- an enriched instruction set, including 16-bit arithmetic and logic instructions
- a 64-Kbyte extended stack space
- a minimum instruction-execution time of two clocks (vs. 12 clocks for MCS 51 microcontrollers)
- binary-code compatibility with MCS 51 microcontrollers

Several benefits are derived from these features:

- preservation of code written for MCS 51 microcontrollers
- a significant increase in core execution speed in comparison with MCS 51 microcontrollers at the same clock rate
- support for larger programs and more data
- increased efficiency for code written in C

Figure 2-1 is a functional block diagram of the 8 XC 251 SB . The core, which is common to all MCS 251 microcontrollers, is described in " 8 XC 251 SB Core" on page $2-4$. A specific microcontroller in the family has its own on-chip peripherals, I/O ports, external system bus, size of onchip RAM, and type and size of on-chip program memory.


Figure 2-1. Functional Block Diagram of the 8XC251SB

The 8XC251SB peripherals include a dedicated watchdog timer, a timer/counter unit, a programmable counter array (PCA), and a serial I/O unit. The 8XC251SB has four 8-bit I/O ports, P0-P4. Each port pin can be individually programmed as a general I/O signal or a special-function signal that supports the external bus or one of the on-chip peripherals. Ports P0 and P2 comprise the external bus, which has 16 lines that are multiplexed for a 16-bit address and 8 -bit data. (You can also configure the 8 XC 251 SB to have a $17^{\text {th }}$ external address bit. See Chapter 12, "External Memory Interface.") Ports P1 and P3 comprise bus-control and peripheral signals.

The 8 XC 251 SB has two power-saving modes. In idle mode, the CPU clock is stopped, while clocks to the peripherals continue to run. In powerdown mode, the on-chip oscillator is stopped, and the chip enters a static state. An enabled interrupt or a hardware reset can bring the chip back to its normal operating mode from idle or powerdown. See Chapter 11, "Special Operating Modes" for details on the power-saving modes.

MCS 251 microcontrollers use an instruction set that has been expanded to include new operations, addressing modes, and operands. Many instructions can operate on 8 -, 16-, or 32 -bit operands, providing easier and more efficient programming in high-level languages such as C . Additional new features include the TRAP instruction, a new displacement addressing mode, and several conditional jump instructions. Chapter 4, "Programming," describes the instruction set and compares it with the instruction set for MCS 51 microcontrollers.

You can configure the 8 XC 251 SB to run in binary mode or source mode. In either mode, the 8XC251SB can execute all instructions in the MCS 51 architecture and the MCS 251 architecture. However, source mode is more efficient for MCS 251 architecture instructions, and binary mode is more efficient for MCS 51 architecture instructions. In binary mode, object code for an MCS 51 microcontroller can run on the 8XC251SB without recompiling.

If a system was originally developed using an MCS 51 microcontroller, and if the new 8XC251SB-based system will run code written for the MCS 51 microcontroller, performance will be better with the 8 XC 251 SB running in binary mode. Object code written for the MCS 51 mi crocontroller runs faster on the 8 XC 251 SB .

However, if most of the code is rewritten using the new instruction set, performance will be better with the 8 XC 251 SB running in source mode. In this case the 8 XC 251 SB can run significantly faster than the MCS 51 microcontroller. See Chapter 4, "Programming" for a discussion of binary mode and source mode.

MCS 251 microcontrollers store both code and data in a single, linear 16-Mbyte memory space. The 8 XC 251 SB can address up to 128 Kbytes of external memory. The special function registers (SFRs) and the register file have separate address spaces. See Chapter 3, "Address Spaces" for a description of the address spaces.

Table 2-1 summarizes some features of the 8 XC 251 SB .
Table 2-1. Summary of 8XC251SB Features

| Address <br> Space | Register <br> File | Code Memory | Data <br> RAM | I/O <br> Lines | External <br> Bus | Interrupt <br> Sources |
| :---: | :---: | :---: | :---: | :---: | :--- | :---: |
| 256 <br> Kbytes | 40 bytes | 83C251SB: 16 Kbytes ROM <br> 87C251SB: 16 Kbytes OTPROM <br> 80C251SB: 0 Kbytes | 1 Kbyte | 32 | Multiplexed: <br> $16 / 17$ Address Bits <br> 8 Data Bits | 11 |

### 2.1 8XC251SB CORE

The 8XC251SB core architecture contains the clock and reset unit, the interrupt handler, the bus interface, the peripheral interface, and the CPU. The CPU contains the instruction sequencer, ALU, register file, and data memory interface.

### 2.1.1 CPU

Figure 2-2 is a functional block diagram of the CPU (central processor unit). The 8XC251SB fetches instructions from on-chip code memory two bytes at a time or from external memory in single bytes. The instructions are sent over the 16 -bit code bus to the execution unit. You can configure the 8XC251SB to operate in page mode for accelerated instruction fetches from external memory. In page mode, if an instruction fetch is to the same 256 -byte "page" as the previous fetch, the fetch requires one state (two clocks) rather than two states (four clocks).

The 8XC251SB register file has forty registers, which can be accessed as bytes, words, and double words. As in the MCS 51 architecture, registers $0-7$ consist of four banks of eight registers each, where the active bank is selected by the program status word (PSW) for fast context switches.

The 8 XC 251 SB is a single-pipeline machine. When the pipeline is full and code is executing from on-chip code memory, an instruction is completed every state time. When the pipeline is full and code is executing from external memory (with no wait states and no extension of the ALE signal) an instruction is completed every two state times.


Figure 2-2. The CPU

### 2.1.2 Clock and Reset Unit

The timing source for the 8XC251SB can be an external oscillator or an internal oscillator with an external crystal/resonator (see Chapter 10, "Minimum Hardware Setup"). The basic unit of time in MCS 251 microcontrollers is the state time (or state), which is two oscillator periods (see Figure 2-3). The state time is divided into phase 1 and phase 2 .

The 8XC251SB peripherals operate on a peripheral cycle, which is six state times. (This peripheral cycle is particular to the 8 XC 251 SB and not a characteristic of the MCS 251 architecture.) A one-clock interval in a peripheral cycle is denoted by its state and phase. For example, the PCA timer is incremented once each peripheral cycle in phase 2 of state 5 (denoted as S5P2).

The reset unit places the 8 XC 251 SB into a known state. A chip reset is initiated by asserting the RST pin or allowing the watchdog timer to time out (see Chapter 10, "Minimum Hardware Setup").


Figure 2-3. 8XC251SB Timing

### 2.1.3 Interrupt Handler

The interrupt handler can receive interrupt requests from eleven sources: seven maskable sources and the TRAP instruction. When the interrupt handler grants an interrupt request, the CPU discontinues the normal flow of instructions and branches to a routine that services the source that requested the interrupt. You can enable or disable the interrupts individually (except for TRAP) and you can assign one of four priority levels to each interrupt. See Chapter 5, "Interrupt System" for a detailed description.

### 2.1.4 On-chip Code Memory

For the 83 C 251 SB and the 87 C 251 SB , memory locations FF:0000H-FF:3FFFH are implemented with 16 -Kbytes of on-chip code memory (ROM in the 83 C 251 SB and EPROM in the 87 C 251 SB ). Following a reset, the first instruction is fetched from location FF:0000H. For the 80C251SB location FF:0000H is always in external memory.

### 2.1.5 On-chip RAM

The 8XC251SB has 1-Kbyte of on-chip data RAM (locations $20 \mathrm{H}-41 \mathrm{FH}$ ) which can be accessed with direct, indirect, and displacement addressing. Ninety-six of these locations ( $20 \mathrm{H}-7 \mathrm{FH}$ ) are bit addressable. An additional 32 bytes of on-chip RAM ( $00 \mathrm{H}-1 \mathrm{FH}$ ) provide storage for the four banks of registers R0-R7.

### 2.2 ON-CHIP PERIPHERALS

The on-chip peripherals, which lie outside the core, perform specialized functions. Software accesses the peripherals via their special function registers (SFRs). The 8XC251SB has four peripherals: the watchdog timer, the timer/counters, the programmable counter array (PCA), and the serial I/O port.

### 2.2.1 Timer/Counters and Watchdog Timer

The timer/counter unit has three timer/counters, which can be clocked by the oscillator (for timer operation) or by an external input (for counter operation). You can set up an 8-bit, 13-bit, or 16bit timer/counter, and you can program them for special applications, such as capturing the time of an event on an external pin, outputting a programmable clock signal on an external pin, or generating a baud rate for the serial I/O port. Timer/counter events can generate interrupt requests.

The watchdog timer is a circuit that automatically resets the 8 XC 251 SB in the event of a hardware or software upset. When enabled by software, the watchdog timer begins running, and unless software intervenes, the timer reaches a maximum count and initiates a chip reset. In normal operation, software periodically clears the timer register to prevent the reset. If an upset occurs and software fails to clear the timer, the resulting chip reset disables the timer and returns the system to a known state. The watchdog and the timer/counters are described in Chapter 7, "Timer/Counters and WatchDog Timer."

### 2.2.2 Programmable Counter Array (PCA)

The programmable counter array (PCA) has its own timer and five capture/compare modules that perform several functions: capturing (storing) the timer value in response to a transition on an input pin; generating an interrupt request when the timer matches a stored value; toggling an output pin when the timer matches a stored value; generating a programmable PWM (pulse width modulator) signal on an output pin; and serving as a software watchdog timer. Chapter 8, "Programmable Counter Array" describes this peripheral in detail.

### 2.2.3 Serial I/O Port

The serial I/O port provides one synchronous and three asynchronous communication modes. The synchronous mode (mode 0 ) is half-duplex: the serial port outputs a clock signal on one pin and transmits or receives data on another pin.

The asynchronous modes (modes 1-3) are full-duplex (i.e., the port can send and receive simultaneously). Mode 1 uses a serial frame of 10 bits: a start bit, 8 data bits, and a stop bit. The baud rate is generated by overflow of timer 1 or timer 2 . Modes 2 and 3 use a serial frame of 11 bits: a start bit, eight data bits, a programmable ninth data bit, and a stop bit. The ninth bit can be used for parity checking or to specify that the frame contains an address and data. In mode 2 , you can use a baud rate of $1 / 32$ or $1 / 64$ of the oscillator frequency. In mode 3 , you can use the overflow from timer 1 or timer 2 to determine the baud rate.

In its synchronous modes (modes 1-3) the serial port can operate as a slave in an environment where multiple slaves share a single serial line. It can accept a message intended for itself or a message that is being broadcast to all of the slaves, and it can ignore a message sent to another slave.

## inte.

## Address Spaces

## CHAPTER 3 ADDRESS SPACES

MCS ${ }^{\circledR} 251$ microcontrollers have three address spaces: a memory space, a special function register (SFR) space, and a register file. This chapter describes these address spaces as they apply to all MCS 251 microcontrollers and to the 8XC251SB in particular. It also discusses the compatibility of the MCS 251 architecture and the MCS 51 architecture in terms of their address spaces.

### 3.1 ADDRESS SPACES FOR MCS ${ }^{\circledR} 251$ MICROCONTROLLERS

Figure 3-1 shows the memory space, the SFR space, and the register file for MCS 251 microcontrollers. (The address spaces are depicted as being eight bytes wide with addresses increasing from left to right.)


Figure 3-1. Address Spaces for MCS ${ }^{\circledR} \mathbf{2 5 1}$ Microcontrollers

It is convenient to view the unsegmented, 16-Mbyte memory space as consisting of $25664-\mathrm{Kbyte}$ regions, numbered 00 : to FF :.

## NOTE

The memory space in the MCS 251 architecture is unsegmented. The 64Kbyte "regions" 00:, 01:, ..., FF: are introduced only as a convenience for discussions. Addressing in the MCS 251 architecture is linear; there are no segment registers.

MCS 251 microcontrollers can have up to 64 Kbytes of on-chip code memory in region FF:. Onchip data RAM begins at location $00: 0000 \mathrm{H}$. The first 32 bytes $(00: 0000 \mathrm{H}-00: 001 \mathrm{FH})$ provide storage for a part of the register file. On-chip, general-purpose data RAM begins at 00:0020H. The sizes of the on-chip code memory and on-chip RAM depend on the particular device.

The register file has its own address space (Figure 3-1). The 64 locations in the register file are numbered decimally from 0 to 63 . Locations $0-7$ represent one of four, switchable register banks, each having 8 registers (see "The 8XC251SB Register File" on page 3-8). The 32 bytes required for these banks occupy locations $00: 0000 \mathrm{H}-00: 001 \mathrm{FH}$ in the memory space. Register file locations 8-63 do not appear in the memory space.

The SFR space can accommodate up to 512 8-bit special function registers with addresses $\mathrm{S}: 000 \mathrm{H}-\mathrm{S}: 1 \mathrm{FFH}$. Some of these locations may be unimplemented in a particular device. In the MCS 251 architecture, the prefix " S :" is used with SFR addresses to distinguish them addresses from the memory space addresses $00: 0000 \mathrm{H}-00: 01 \mathrm{FFH}$.

### 3.1.1 Compatibility with the MCS ${ }^{\circledR} 51$ Architecture

The address spaces in the MCS 51 architecture are mapped into the address spaces in the MCS 251 architecture. This mapping allows code written for MCS 51 microcontrollers to run on MCS 251 microcontrollers. (Chapter 4, "Programming," discusses the compatibility of the two instruction sets.)

Figure 3-2 shows the address spaces for the MCS 51 architecture ${ }^{\dagger}$. Internal data memory locations $00 \mathrm{H}-7 \mathrm{FH}$ can be addressed directly and indirectly. Internal data locations $80 \mathrm{H}-\mathrm{FFH}$ can only be addressed indirectly. Directly addressing these locations accesses the Special Function Registers (SFRs).

The register file (registers R0-R7) comprises four, switchable register banks, each having 8 registers. The 32 bytes required for the four banks occupy locations $00 \mathrm{H}-1 \mathrm{FH}$ in the on-chip data memory.

[^0]The 64-Kbyte code memory has a separate memory space. Data in the code memory can be accessed only with the MOVC instruction. Similarly, the 64-Kbyte external data memory can be accessed only with the MOVX instruction.

Figure 3-3 shows how the address spaces in the MCS 51 architecture map into the address spaces in the MCS 251 architecture; details are listed in Table 3-1.


R0 Register File R7


Figure 3-2. Address Spaces for the MCS ${ }^{\circledR} 51$ Architecture


Figure 3-3. Address Space Mappings MCS ${ }^{\circledR} 51$ Architecture to MCS ${ }^{\circledR} 251$ Architecture

Table 3-1. Address Mappings

| Memory Type | MCS® 51 Architecture |  |  | MCS® 251 Architecture |
| :---: | :---: | :---: | :---: | :---: |
|  | Size | Location | Data Addressing | Location |
| Code | 64 Kbytes | 0000H-FFFFH | Indirect using MOVC instr. | FF:0000H-FF:FFFFH |
| External Data | 64 Kbytes | 0000H-FFFFH | Indirect using MOVX instr. | 01:0000H-01:FFFFH |
| Internal Data | 128 bytes | 00H-7FH | Direct, Indirect | 00:0000H-00:007FH |
|  | 128 bytes | 80H-FFH | Indirect | 00:0080H-00:00FFH |
| SFRs | 128 bytes | S:80H-S:FFH | Direct | S:080H-S:0FFH |
| Register File | 8 bytes | R0-R7 | Register | R0-R7 |

The 64-Kbyte code memory for MCS 51 microcontrollers maps into region FF: of the memory space for MCS 251 microcontrollers. Assemblers for MCS 251 microcontrollers assemble code for MCS 51 microcontrollers into region FF:, and data accesses to code memory are directed to this region. The assembler also maps the interrupt vectors to region FF:. This mapping is transparent to the user; code executes just as before without modification.

The 64-Kbyte external data memory for MCS 51 microcontrollers is mapped into the memory region specified by bits $16-23$ of the data pointer DPX, i.e., DPXL, which is accessible as register file location 57 and also as the SFR at S:084H (see "Dedicated Registers" on page 3-10). The reset value of DPXL is 01 H , which maps the external memory to region 01: as shown in Figure 3-3. You can change this mapping by writing a different value to DPXL. A mapping of the MCS 51 microcontroller external data memory into any 64-Kbyte memory region in the MCS 251 architecture provides complete run-time compatibility because the lower 16 address bits are identical in the two address spaces.

The on-chip data memory for MCS 51 microcontrollers is mapped to region 00 : to ensure complete run-time compatibility. From location 00 H to 7 FH , the internal data memory is the same in the two architectures. In the MCS 251 architecture, the data memory extends beyond these 128 bytes to allow enhanced data and stack access using new instructions.

The 128-byte SFR space for MCS 51 microcontrollers is mapped into the 512-byte SFR space of the MCS 251 architecture starting at address $\mathrm{S}: 080 \mathrm{H}$, as shown in Figure 3-3. This provides complete compatibility with direct addressing of MCS 51 microcontroller SFRs (including bit addressing). The SFR addresses are unchanged in the new architecture. In the MCS 251 architecture, SFRs A, B, DPL, DPH, and SP (as well as the new SFRs DPXL and SPH) reside in the register file for high performance. However, to maintain compatibility, they are also mapped into the SFR space at the same addresses as in the MCS 51 architecture.

### 3.2 THE 8XC251SB MEMORY SPACE

The logical memory space for the 8XC251SB microcontroller is shown in Figure 3-4. The arrows on the left side indicate the addressing modes that apply to the partitions of the memory space. (Chapter 4, "Programming," discusses addressing modes.) The right side of the figure shows the hardware implementation of the different areas of the memory space. For the 8 XC 251 SB , the usable memory space consists of four 64-Kbyte regions: 00 :, 01 :, FE:, and FF:. Code can execute from all four regions. Regions $02:-\mathrm{FD}$ : are reserved. Reading a location in the reserved area returns an unspecified value. Software can execute a write to the reserved area, but nothing is actually written.

### 3.2.1 On-chip General-purpose Data RAM

Memory locations 00:0020H-00:041FH are implemented as 1 Kbyte of on-chip RAM, which can be used for general data storage. Instructions cannot execute from on-chip data RAM. The data is accessible by direct, indirect, and displacement addressing. Locations 00:0020H-00:007FH are also bit addressable.

### 3.2.2 On-chip Code Memory (87C251SB/83C251SB)

The $87 \mathrm{C} 251 \mathrm{SB} / 83 \mathrm{C} 251 \mathrm{SB}$ has $16-\mathrm{Kbytes}$ of on-chip OTPROM/ROM at locations FF:0000HFF:3FFFH. This memory is intended primarily for code storage, although its contents can also be read as data with the indirect and displacement addressing modes. Following a chip reset, program execution begins at FF:0000H. Chapter 13, "Programming and Verifying Nonvolatile Memory," describes programming and verification of the OTPROM/ROM.

## NOTE

Beware of executing code from the upper eight bytes of the on-chip OTPROM/ROM (FF:3FFF8H-FF:3FFFFH). The 8XC251SB may attempt to prefetch code from external memory (at an address above FF:3FFFH) and thereby disrupt I/O ports 0 and 2. Fetching code constants from these eight bytes does not affect ports 0 and 2 .

A code fetch in the range FF: $0000 \mathrm{H}-\mathrm{FF}: 3 \mathrm{FFFH}$ accesses the on-chip OTPROM/ROM only if $\mathrm{EA} \#=1$. For EA\# $=0$, a code fetch in this address range accesses external memory. The value of EA\# is latched when the chip leaves the reset state.

### 3.2.2.1 Accessing On-chip Code Memory in Region 00:

The $87 \mathrm{C} 251 \mathrm{SB} / 83 \mathrm{C} 251 \mathrm{SB}$ can be configured so that the upper 8 Kbytes of the on-chip code memory can be read as data in region 00: (see "Configuration Bytes" on page 13-6). This is useful for accessing code constants stored in OTPROM/ROM. Specifically, the upper 8 Kbytes of code memory are mapped to locations $00: \mathrm{E} 000 \mathrm{H}-00: \mathrm{FFFFH}$ (as well as to locations FF:E000H$\mathrm{FF}: \mathrm{FFFFH}$ ) if the following three conditions hold:

- The $87 \mathrm{C} 251 \mathrm{SB} / 83 \mathrm{C} 251 \mathrm{SB}$ is configured with EMAP $=0$ in the CONFIG1 register (Chapter 13, "Programming and Verifying Nonvolatile Memory").
- $E A \#=1$.
- The access is a data read, not a code fetch.

If one or more of these conditions do not hold, accesses to locations $00: \mathrm{E} 000 \mathrm{H}-00: \mathrm{FFFFH}$ are referred to external memory.


Figure 3-4. 8XC251SB Memory Space

### 3.2.3 External Memory

Regions 01: and FE: and portions of regions 00 : and FF: of the memory space are implemented as external memory (Figure 3-4). External memory is described in Chapter 12, "External Memory Interface."

### 3.3 THE 8XC251SB REGISTER FILE

The 8 XC 251 SB register file consists of 40 locations: $0-31$ and 56-63, as shown in Figure 3-5. Locations 0-7 are in the on-chip RAM. The other locations are in the CPU.

Registers 0-7 actually consist of four switchable banks of eight registers each. These 32 bytes are stored in locations $00: 0000 \mathrm{H}-00: 001 \mathrm{FH}$ in the memory space and are implemented in the on-chip RAM. However, because these locations are dedicated to the register file, they are not considered a part of the general-purpose, 1-Kbyte on-chip RAM (locations 00:0020H-00:041FH).

Bits RS1 and RS0 in the PSW register select one of the four register banks to be active, i.e., to currently serve as register file locations $0-7$, as shown in Table 3-2. (The PSW is described in "Program Status Words" on page 4-17.) This bank selection can be used for fast context switches. The inactive banks are inaccessible via the register file; however, registers in both the active and inactive banks can be addressed as locations in the memory space.

Register file locations 32-55 are reserved and cannot be accessed.
Table 3-2. Register Bank Selection

| Bank | Address Range | PSW Selection Bits |  |
| :--- | :--- | :---: | :---: |
|  |  | RS1 | RS0 |
| Bank 0 | $00 \mathrm{H}-07 \mathrm{H}$ | 0 | 0 |
| Bank 1 | $08 \mathrm{H}-0 \mathrm{FH}$ | 0 | 1 |
| Bank 2 | $10 \mathrm{H}-17 \mathrm{H}$ | 1 | 0 |
| Bank 3 | $18 \mathrm{H}-1 \mathrm{FH}$ | 1 | 1 |

### 3.3.1 Byte, Word, and Dword Registers

Depending on its location in the register file, a register is addressable as a byte, a word, and/or a dword, as shown in the right side of Figure 3-5. A register is named for its least-significant byte. For example:

R 4 is the byte register consisting of location 4.
WR4 is the word register consisting of registers 4 and 5.
DR4 is the dword register consisting of registers 4-7.

Locations R0-R15 are addressable as bytes, words, or dwords. Locations 16-31 are addressable only as words or dwords. Locations 56-63 are addressable only as dwords. Registers are addressed only by the names shown in Figure 3-5 - except for the 32 registers that comprise the four banks of registers R0-R7, which can also be accessed as locations $00: 0000 \mathrm{H}-00: 001 \mathrm{FH}$ in the memory space.


Figure 3-5. The Register File

### 3.3.2 Dedicated Registers

The register file has four dedicated registers:

- R10 is the B-register
- R11 is the accumulator (ACC)
- DR56 is the extended data pointer, DPX
- DR60 is the extended stack pointer, SPX

These registers are located in the register file; however, R10, R11, and some bytes of DR56 and DR60 are also accessible as SFRs. The bytes of DPX and SPX can be accessed in the register file only by addressing the dword registers. The dedicated registers in the register file and their corresponding SFRs are illustrated in Figure 3-6 and listed in Table 3-3 on page 3-12.

### 3.3.2.1 Accumulator and B Register

The 8-bit accumulator (ACC) is byte register R11, which is also accessible in the SFR space as ACC at $\mathrm{S}: 0 \mathrm{E} 0 \mathrm{H}$ (Figure 3-6). The $B$ register, used in multiplies and divides, is register R10, which is also accessible in the SFR space as B at $\mathrm{S}: 0 \mathrm{FOH}$. Accessing ACC or B as a register is one state faster than accessing them as SFRs.

Instructions in the MCS 51 architecture use the accumulator as the primary register for data moves and calculations. However, in the MCS 251 architecture, any of registers R1-R15 can serve for these tasks $\dagger$. As a result, the accumulator does not play the central role that it has in MCS 51 microcontrollers.

### 3.3.2.2 Extended Data Pointer, DPX

Dword register DR56 is the extended data pointer, DPX (Figure 3-6). The lower three bytes of DPX (DPL, DPH, and DPXL) are accessible as SFRs. DPL and DPH comprise the 16-bit data pointer DPTR. While instructions in the MCS 51 architecture always use DPTR as the data pointer, instructions in the MCS 251 architecture can use any word or dword register as a data pointer.

DPXL, the byte in location 58, specifies the region of memory ( $00:-\mathrm{FF}$ :) that maps into the 64Kbyte external data memory space in the MCS 51 architecture. In other words, the MOVX instruction addresses the region specified by DPXL when it moves data to and from external memory. The reset value of DPXL is 01 H .

[^1]
### 3.3.2.3 Extended Stack Pointer, SPX

Dword register DR60 is the stack pointer, SPX (Figure 3-6). The low byte (location 60) is the 8bit stack pointer, SP, in the MCS 51 architecture. The byte at location 61 is the stack pointer high, SPH. The two bytes allow the stack to extend to the top of memory region 00:. SP and SPH can be accessed as SFRs.

Two instructions, PUSH and POP directly address the stack pointer. Subroutine calls (ACALL, ECALL, LCALL) and returns (ERET, RET, RETI) also use the stack pointer. To preserve the stack, do not use DR60 as a general-purpose register.


Figure 3-6. Dedicated Registers in the Register File and their Corresponding SFRs

Table 3-3. Dedicated Registers in the Register File and their Corresponding SFRs

| Register File |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Name |  |  | Mnemonic | Reg. | Location |
| Stack Pointer (SPX) |  | - | - | DR60 | 60 |
|  |  | - | - |  | 61 |
|  | Stack Pointer, High |  | SPH |  | 62 |
|  | Stack Pointer, Low |  | SP |  | 63 |
| Data <br> Pointer <br> (DPX) | Data Pointer, Extended High |  | - | DR56 | 56 |
|  | Data Pointer, Extended Low |  | DPXL |  | 57 |
|  | DPTR | Data Pointer, High | DPH |  | 58 |
|  |  | Data Pointer, Low | DPL |  | 59 |
| Accumulator (A Register) |  |  | A | R11 | 11 |
| B Register |  |  | B | R10 | 10 |


| SFRs |  |
| :---: | :---: |
| Mnemonic | Address |
| - | - |
| - | - |
| SPH | S:BDH |
| SP | S:81H |
| - | - |
| DPXL | S:84H |
| DPH | S:83H |
| DPL | S:82H |
| ACC | S:EOH |
| B | S:FOH |

### 3.4 SPECIAL FUNCTION REGISTERS (SFRS)

The special function registers (SFRs) reside in the their associated on-chip peripherals or in the core. Table 3-4 shows the SFR address space with the SFR mnemonics and reset values. SFR addresses are preceded by "S:" to differentiate them from addresses in the memory space. Unoccupied locations in the SFR space (the shaded locations in Table 3-4) are unimplemented, i.e., no register exists. If an instruction attempts to write to an unimplemented SFR location, the instruction executes, but nothing is actually written. If an unimplemented SFR location is read, it returns an unspecified value.

## NOTE

SFRs may be accessed only as bytes; they may not be accessed as words or dwords.

Table 3-4. 8XC251SB SFR Map and Reset Values

|  | 0/8 | 1/9 | 2/A | 3/B | 4/C | 5/D | 6/E | 7/F |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| F8 |  <br> 4): | $\begin{gathered} \mathrm{CH} \\ 00000000 \end{gathered}$ | CCAPOH <br> xxxxxxxx | CCAP1H xxxxxxxx | CCAP2H <br> xxXxXXXx | CCAP3H <br> xxxxxXxx | CCAP4H <br> XXXXXXXX |  | FF |
| F0 | $\begin{gathered} \text { B } \\ 00000000 \end{gathered}$ |  |  | < |  |  |  |  | F7 |
| E8 | $\stackrel{\square}{4}$ | $\begin{gathered} C L \\ 00000000 \end{gathered}$ | CCAPOL <br> XXXXXXXX | CCAP1L <br> xxxxxxxx | CCAP2L xxxxxxxx | CCAP3L <br> xxxxxxxx | CCAP4L <br> xxxxxxxx |  | EF |
| E0 | $\begin{gathered} \text { ACC } \\ 00000000 \end{gathered}$ |  |  |  |  |  |  |  | E7 |
| D8 |  | $\begin{gathered} \text { CMOD } \\ 00 \times x \times 000 \end{gathered}$ | $\begin{array}{r} \text { CCAPM0 } \\ \times 0000000 \end{array}$ | $\begin{aligned} & \text { CCAPM1 } \\ & \times 0000000 \end{aligned}$ | $\begin{aligned} & \text { CCAPM2 } \\ & \times 0000000 \end{aligned}$ | $\begin{array}{r} \text { CCAPM3 } \\ \times 0000000 \end{array}$ | $\begin{array}{r} \text { CCAPM4 } \\ \times 0000000 \end{array}$ |  | DF |
| D0 | $\begin{gathered} \text { PSW } \\ 00000000 \end{gathered}$ | $\begin{gathered} \text { PSW1 } \\ 00000000 \end{gathered}$ |  |  |  |  |  | $\underset{\sim}{\text { ® }}$ | D7 |
| C8 | $\begin{gathered} \text { T2CON } \\ 00000000 \end{gathered}$ | T2MOD <br> xxxxxx00 | RCAP2L 00000000 | $\begin{aligned} & \text { RCAP2H } \\ & 00000000 \end{aligned}$ | $\begin{gathered} \text { TL2 } \\ 00000000 \end{gathered}$ | $\begin{gathered} \text { TH2 } \\ 00000000 \end{gathered}$ |  | Mus | CF |
| C0 |  |  |  |  | $\stackrel{4}{4}$ |  |  |  | C7 |
| B8 | $\begin{gathered} \text { IPLO } \\ \times 000000 \end{gathered}$ | $\begin{aligned} & \text { SADEN } \\ & 00000000 \end{aligned}$ |  |  |  | $\begin{gathered} \text { SPH } \\ 00000000 \end{gathered}$ |  |  | BF |
| B0 | $\begin{gathered} \text { P3 } \\ 11111111 \end{gathered}$ |  |  |  |  |  |  | $\begin{gathered} \text { IPHO } \\ \times 0000000 \end{gathered}$ | 37 |
| A8 | $\begin{gathered} \text { IE0 } \\ 00000000 \end{gathered}$ | $\begin{aligned} & \text { SADDR } \\ & 00000000 \end{aligned}$ |  |  |  |  |  |  | AF |
| A0 | $\begin{gathered} \hline \text { P2 } \\ 11111111 \end{gathered}$ |  |  |  |  |  | WDTRST xxxxxxxx |  | A7 |
| 98 | $\begin{gathered} \text { SCON } \\ 00000000 \end{gathered}$ | SBUF xxxxxxxx |  |  |  |  |  |  | 9F |
| 90 | $\begin{gathered} \text { P1 } \\ 11111111 \end{gathered}$ |  |  |  | \% |  |  |  | 97 |
| 88 | $\begin{gathered} \text { TCON } \\ 00000000 \end{gathered}$ | $\begin{gathered} \text { TMOD } \\ 00000000 \end{gathered}$ | $\begin{gathered} \text { TLO } \\ 00000000 \end{gathered}$ | $\begin{gathered} \text { TL1 } \\ 00000000 \end{gathered}$ | $\begin{gathered} \text { THO } \\ 00000000 \end{gathered}$ | $\begin{gathered} \text { TH1 } \\ 00000000 \end{gathered}$ |  |  | 8F |
| 80 | $\begin{gathered} \text { PO } \\ 11111111 \end{gathered}$ | $\begin{gathered} \text { SP } \\ 00000111 \end{gathered}$ | $\begin{gathered} \text { DPL } \\ 00000000 \end{gathered}$ | $\begin{gathered} \text { DPH } \\ 00000000 \end{gathered}$ | $\begin{gathered} \text { DPXL } \\ 00000001 \end{gathered}$ |  | $\overrightarrow{M r}$ | $\begin{gathered} \text { PCON } \\ 00 \times x 0000 \end{gathered}$ | 87 |
|  | 0/8 | 1/9 | 2/A | 3/B | 4/C | 5/D | 6/E | 7/F |  |

NOTE: Shaded areas represent unimplemented SFR locations. Locations S:000H-S:07FH and $\mathrm{S}: 100 \mathrm{H}-\mathrm{S}: 1 \mathrm{FFH}$ are also unimplemented.

The following tables list the mnemonics, names, and addresses of the SFRs:
Table 3-5 on page 3-14 - Core SFRs
Table 3-6 on page 3-14 - I/O Port SFRs
Table 3-7 on page 3-15 - Serial I/O SFRs
Table 3-8 on page 3-15 - Timer/Counter and Watchdog SFRs
Table 3-9 on page 3-15 - Programmable Counter Array (PCA) SFRs

Table 3-5. Core SFRs

| Mnemonic | Name | Address |
| :--- | :--- | :---: |
| ACC $^{\dagger}$ | Accumulator | $\mathrm{S}: \mathrm{EOH}$ |
| $\mathrm{B}^{\dagger}$ | B register | $\mathrm{S}: \mathrm{FOH}$ |
| PSW | Program Status Word | $\mathrm{S}: \mathrm{DOH}$ |
| PSW $^{\dagger}$ | Program Status Word 1 | $\mathrm{S}: \mathrm{D} 1 \mathrm{H}$ |
| SP $^{\dagger}$ | Stack Pointer - LSB of SPX | $\mathrm{S}: 81 \mathrm{H}$ |
| SPH $^{\dagger}$ | Stack Pointer High - MSB of SPX | $\mathrm{S}: \mathrm{BDH}$ |
| DPTR $^{\dagger}$ | Data Pointer (2 bytes) | - |
| DPL $^{\dagger}$ | Low Byte of DPTR | $\mathrm{S}: 82 \mathrm{H}$ |
| DPH $^{\dagger}$ | High Byte of DPTR | $\mathrm{S}: 83 \mathrm{H}$ |
| DPXL $^{\dagger}$ | Data Pointer, Extended Low | $\mathrm{S}: 84 \mathrm{H}$ |
| PCON | Power Control | $\mathrm{S}: 87 \mathrm{H}$ |
| IE0 | Interrupt Enable Control 0 | $\mathrm{S}: \mathrm{A8H}$ |
| IPH0 | Interrupt Priority Control High 0 | $\mathrm{S}: \mathrm{B7H}$ |
| IPL0 | Interrupt Priority Control Low 0 | $\mathrm{S}: \mathrm{B8H}$ |

$\dagger$ These SFRs can also be accessed by their corresponding registers in the register file (see Table 3-3).

Table 3-6. I/O Port SFRs

| Mnemonic | Name | Address |
| :--- | :--- | :---: |
| P0 | Port 0 | $\mathrm{S}: 80 \mathrm{H}$ |
| P1 | Port 1 | $\mathrm{S}: 90 \mathrm{H}$ |
| P2 | Port 2 | $\mathrm{S}: \mathrm{AOH}$ |
| P3 | Port 3 | $\mathrm{S}: \mathrm{BOH}$ |

Table 3-7. Serial I/O SFRs

| Mnemonic | Name | Address |
| :--- | :--- | :---: |
| SCON | Serial Control | $\mathrm{S}: 98 \mathrm{H}$ |
| SBUF | Serial Data Buffer | $\mathrm{S}: 99 \mathrm{H}$ |
| SADEN | Slave Address Mask | $\mathrm{S}: \mathrm{B} 9 \mathrm{H}$ |
| SADDR | Slave Address | $\mathrm{S}: \mathrm{A} 9 \mathrm{H}$ |

Table 3-8. Timer/Counter and Watchdog Timer SFRs

| Mnemonic | Name | Address |
| :--- | :--- | :---: |
| TL0 | Timer/Counter 0 Low Byte | $\mathrm{S}: 8 \mathrm{AH}$ |
| TH0 | Timer/Counter 0 High Byte | $\mathrm{S}: 8 \mathrm{CH}$ |
| TL1 | Timer/Counter 1 Low Byte | $\mathrm{S}: 8 \mathrm{BH}$ |
| TH1 | Timer/Counter 1 High Byte | $\mathrm{S}: 8 \mathrm{DH}$ |
| TL2 | Timer/Counter 2 Low Byte | $\mathrm{S}: \mathrm{CCH}$ |
| TH2 | Timer/Counter 2 High Byte | $\mathrm{S}: \mathrm{CDH}$ |
| TCON | Timer/Counter 0 and 1 Control | $\mathrm{S}: 88 \mathrm{H}$ |
| TMOD | Timer/Counter 0 and 1 Mode Control | $\mathrm{S}: 89 \mathrm{H}$ |
| T2CON | Timer/Counter 2 Control | $\mathrm{S}: \mathrm{C} 8 \mathrm{H}$ |
| T2MOD | Timer/Counter 2 Mode Control | $\mathrm{S}: \mathrm{C} 9 \mathrm{H}$ |
| RCAP2L | Timer 2 Reload/Capture Low Byte | $\mathrm{S}: \mathrm{CAH}$ |
| RCAP2H | Timer 2 Reload/Capture High Byte | $\mathrm{S}: \mathrm{CBH}$ |
| WDTRST | WatchDog Timer Reset | $\mathrm{S}: \mathrm{A} 6 \mathrm{H}$ |

Table 3-9. Programmable Counter Array (PCA) SFRs

| Mnemonic | Name | Address |
| :--- | :--- | :---: |
| CCON | PCA Timer/Counter Control | S:D8H |
| CMOD | PCA Timer/Counter Mode | S:D9H |
| CCAPM0 | PCA Timer/Counter Mode 0 | S:DAH |
| CCAPM1 | PCA Timer/Counter Mode 1 | S:DBH |
| CCAPM2 | PCA Timer/Counter Mode 2 | S:DCH |
| CCAPM3 | PCA Timer/Counter Mode 3 | S:DDH |
| CCAPM4 | PCA Timer/Counter Mode 4 | S:DEH |

Table 3-9. Programmable Counter Array (PCA) SFRs (Continued)

| Mnemonic | Name | Address |
| :--- | :--- | :---: |
| CL | PCA Timer/Counter Low Byte | S:E9H |
| CH | PCA Timer/Counter High Byte | S:F9H |
| CCAP0L | PCA Compare/Capture Module 0 Low Byte | S:EAH |
| CCAP1L | PCA Compare/Capture Module 1 Low Byte | S:EBH |
| CCAP2L | PCA Compare/Capture Module 2 Low Byte | S:ECH |
| CCAP3L | PCA Compare/Capture Module 3 Low Byte | $\mathrm{S}:$ EDH |
| CCAP4L | PCA Compare/Capture Module 4 Low Byte | $\mathrm{S}:$ EEH |
| CCAP0H | PCA Compare/Capture Module 0 High Byte | S:FAH |
| CCAP1H | PCA Compare/Capture Module 1 High Byte | S:FBH |
| CCAP2H | PCA Compare/Capture Module 2 High Byte | S:FCH |
| CCAP3H | PCA Compare/Capture Module 3 High Byte | $\mathrm{S}:$ FDH |
| CCAP4H | PCA Compare/Capture Module 4 High Byte | S:FEH |

## inte.



## Programming

## CHAPTER 4 <br> PROGRAMMING

The instruction set for the $\mathrm{MCS}^{\circledR} 251$ architecture is a superset of the instruction set for the MCS 51 architecture. This chapter describes the addressing modes and summarizes the instruction set, which is divided into data instructions, bit instructions, and control instructions. (Appendix A, "Instruction Set Reference" contains an opcode map and a detailed description of each instruction.) The program status words PSW and PSW1 are also described (page 4-17). The chapter begins with a discussion of the binary-mode and source-mode encodings of the instruction set.

## NOTE

The instruction execution times given in Appendix A are for code executing from on-chip code memory and for data that is read from and written to onchip RAM. Execution times are increased by executing code from external memory, accessing peripheral SFRs, accessing data in external memory, using a wait state, or extending the ALE pulse.

For some instructions, accessing the port SFRs, $\mathrm{P} x, x=1-3$, increases the execution time. These cases are noted individually in the tables in Appendix A.

### 4.1 BINARY MODE AND SOURCE MODE CONFIGURATIONS

Binary mode and source mode refer to two ways of assigning opcodes to the instruction set for the MCS 251 architecture. One of these modes must be selected when the chip is configured. Depending on the application, binary mode or source mode may produce more efficient code. This section describes the binary and source modes and provides some guidelines for selecting the mode for your application.

The MCS 251 architecture has two types of instructions:

- instructions that originate in the MCS 51 architecture
- instructions that are unique to the MCS 251 architecture

Figure 4-1 shows the opcode map for binary mode. On the left (areas I and II) is the opcode map for the instructions that originate in the MCS 51 architecture. Every opcode ( $00 \mathrm{H}-\mathrm{FFH}$ ), is used for an instruction except A5H, which is reserved. On the right (area III) is the opcode map for the instructions that are unique to the MCS 251 architecture. (Some of these opcodes are reserved for future instructions.) Note that the opcode values for areas II and III are identical ( $06 \mathrm{H}-\mathrm{FFH}$ ). To distinguish between the two areas, the opcodes in area III are given the prefix A 5 H . The area III opcodes are then A506H-A5FFH.

Figure 4-2 shows the opcode map for source mode. Areas II and III have switched places (compare Figure 4-1). The instructions that are unique to the MCS 251 architecture now have opcodes without the A5H prefix. The instructions from area II of the MCS 51 architecture use the escape prefix A5H.

To illustrate the difference between the binary-mode and source-mode opcodes, Table 4-1 shows the opcode assignments for three sample instructions.

Table 4-1. Examples of Opcodes in Binary and Source Modes

| Instruction | Opcode |  |
| :--- | :--- | :--- |
|  | Binary Mode | Source Mode |
| DEC A | 14 H | 14 H |
| SUBB A,R4 | 9 CH | A59CH |
| SUB R4,R4 | A59CH | 9 CH |

### 4.1.1 Selecting Binary Mode or Source Mode

If you have code that was written for an MCS 51 microcontroller and you want to run it unmodified on an MCS 51 microcontroller, choose binary mode. You can use the object code without reassembling the source code. You can also assemble the source code with an assembler for the MCS 251 architecture and have it produce object code that is binary-compatible with MCS 51 microcontrollers. The remainder of this section discusses the selection of binary mode or source mode for code that may contain instructions from both architectures.

An instruction with a prefixed opcode requires one more byte for code storage, and if an additional fetch is required for the extra byte, the execution time is increased by one state. This means that using fewer prefixed opcodes produces more efficient code.

If a program uses only instructions from the MCS 51 architecture, the binary-mode code is more efficient because it uses no prefixes. On the other hand, if a program uses many more new instructions than instructions from the MCS 51 architecture, source mode is likely to produce more efficient code. For a program where the choice is not clear, the better mode can be found by experimenting with a simulator.


Figure 4-1. Binary Mode Opcode Map


Figure 4-2. Source Mode Opcode Map

### 4.2 PROGRAMMING FEATURES OF THE MCS ${ }^{\circledR} 251$ ARCHITECTURE

The instruction set for MCS 251 microcontrollers provides the user with new instructions that exploit the features of the architecture while maintaining compatibility with the instruction set for MCS 51 microcontrollers. Many of the new instructions can operate on either 8-bit, 16-bit, or 32bit operands. (In comparison with 8 -bit and 16 -bit operands, 32 -bit operands are accessed with fewer addressing modes.) This capability increases the ease and efficiency of programming MCS 251 microcontrollers in a high-level language such as C.

The instruction set is divided into "Data Instructions"( page 4-6), "Bit Instructions" (page 4-12), and "Control Instructions" (page 4-14). Data instructions process 8-bit, 16-bit, and 32-bit data; bit instructions manipulate bits; and control instructions manage program flow.

### 4.2.1 Data Types

Table 4-2 lists the data types that are addressed by the instruction set. A word or dword (double word) in memory can have its least significant byte at any address; alignment on two-byte or fourbyte boundaries is not required.

Table 4-2. Data Types

| Data Type | Number of Bits |
| :--- | :---: |
| Bit | 1 |
| Byte | 8 |
| Word | 16 |
| Dword (Double Word) | 32 |

### 4.2.2 Register Notation

In register-addressing instructions, specific indices denote the registers that can be used in that instruction. For example, the instruction ADD A,Rn uses "Rn" to denote any one of R0, R1, ..., R7; i.e., the range of $n$ is $0-7$. The instruction ADD Rm,\#data uses " $R m$ " to denote $R 0, R 1, \ldots$, R15; i.e., the range of $m$ is $0-15$. Table 4-3 summarizes the notation used for the register indices. When an instruction contains two registers of the same type (e.g., MOV Rmd,Rms) the first index " $d$ " denotes "destination" and the second index " $s$ " denotes "source."

Table 4-3. Notation for Byte Registers, Word Registers, and Dword Registers

| Register <br> Type | Register <br> Symbol | Destination <br> Register | Source <br> Register | Register Range |
| :---: | :---: | :---: | :---: | :--- |
| Byte | Ri | - | - | R0, R1 |
|  | Rn | - | - | R0-R7 |
|  | $R m$ | Rmd | Rms | R0-R15 |
| Word | WRj | WRjd | WRjs | WR0, WR2, WR4, ..., WR30 |
| Dword | DRk | DRkd | DRks | DR0, DR4, DR8, ..., DR28, DR56, DR60 |

### 4.2.3 Address Notation

In the MCS 251 architecture, memory addresses include a region number (00:, 01:, ..., FF:) (Figure 3-1 on page 3-1). SFR addresses have a prefix "S:" (S:000H-S:1FFH). The distinction between memory addresses and SFR addresses is necessary, because memory locations 00:0000H$00: 01 \mathrm{FFH}$ and SFR locations S:000H-S:1FFH can both be directly addressed in an instruction.

Instructions in the MCS 51 architecture use $80 \mathrm{H}-\mathrm{FFH}$ as addresses for both memory locations and SFRs, because memory locations are addressed only indirectly and SFR locations are addressed only directly. For compatibility, software tools for MCS 251 controllers recognize this notation for instructions in the MCS 51 architecture. No change is necessary in any code written for MCS 51 controllers.

For new instructions in the MCS 251 architecture, the memory region prefixes ( $00:, 01, \ldots, \mathrm{FF}$ ) and the SFR prefix (S:) are required. Also, software tools for the MCS 251 architecture permit 00 : to be used for memory addresses $00 \mathrm{H}-\mathrm{FFH}$ and permit the prefix S : to be used for SFR addresses in instructions in the MCS 51 architecture.

### 4.2.4 Addressing Modes

The MCS 251 architecture supports the following addressing modes:

- register addressing: The instruction specifies the register that contains the operand.
- immediate addressing: The instruction contains the operand.
- direct addressing: The instruction contains the operand address.
- indirect addressing: The instruction specifies the register that contains the operand address.
- displacement addressing: The instruction specifies a register and an offset. The operand address is the sum of the register contents (the base address) and the offset.
- relative addressing: The instruction contains the signed offset from the next instruction to the target address (the address for transfer of control, e.g., the jump address).
- bit addressing: The instruction contains the bit address.

More detailed descriptions of the addressing modes are given in "Data Addressing Modes" on page 4-6, "Bit Addressing" on page 4-12, and "Addressing Modes for Control Instructions" on page 4-14.

### 4.3 DATA INSTRUCTIONS

Data instructions consist of arithmetic, logical, and data-transfer instructions for 8-bit, 16-bit, and 32-bit data. This section describes the data addressing modes and the set of data instructions.

### 4.3.1 Data Addressing Modes

This section describes the data-addressing modes, which are summarized in two tables: Table 4-4 for the instructions that are native to the MCS 51 architecture, and Table 4-5 for the new data instructions in the MCS 251 architecture.

## NOTE

References to registers R0-R7, WR0-WR6, DR0, and DR2 always refer to the register bank that is currently selected by the PSW and PSW1 registers (see "Program Status Words" on page 4-17). Registers in all banks (active and inactive) can be accessed as memory locations in the range $00 \mathrm{H}-1 \mathrm{FH}$.

Table 4-4. Addressing Modes for Data Instructions in the MCS ${ }^{\circledR} 51$ Architecture

| Mode | Address Range of Operand | Assembly Language Reference | Comments |
| :---: | :---: | :---: | :---: |
| Register | 00H-1FH | R0-R7 <br> (Bank selected by PSW) |  |
| Immediate | Operand in Instruction | \#data = \#00H-\#FFH |  |
| Direct | 00H-7FH | dir8 $=00 \mathrm{H}-7 \mathrm{FH}$ | On-chip RAM |
|  | SFRs | $\begin{aligned} \text { dir8 }= & 80 \mathrm{H}-\mathrm{FFH} \\ & \text { or SFR mnemonic. } . \end{aligned}$ | SFR address |
| Indirect | OOH-FFH | @R0, @R1 | Accesses on-chip RAM or the lowest 256 bytes of external data memory (MOVX). |
|  | 0000H-FFFFF | @DPTR, @A+DPTR | Accesses external data memory (MOVX). |
|  | 0000H-FFFFH | @ A+DPTR, © ${ }^{\text {a }}$ +PC | Accesses region FF: of code memory (MOVC). |

Table 4-5. Addressing Modes for Data Instructions in the MCS ${ }^{\circledR} 251$ Architecture

| Mode | Address Range of Operand | Assembly Language Notation | Comments |
| :---: | :---: | :---: | :---: |
| Register | 00:0000H-00:001FH <br> (R0-R7, WR0-WR3, DR0, DR2) (1) | R0-R15, WR0-WR30, DR0-DR28, DR56, DR60 | R0-R7, WR0-WR6, DR0, and DR2 are in the register bank currently selected by the PSW and PSW1. |
| $\begin{aligned} & \text { Immediate, } \\ & 2 \text { bits } \end{aligned}$ | N.A. (Operand is in the instruction) | \#short = 1, 2, or 4 | Used only in increment and decrement instructions. |
| Immediate, 8 bits | N.A. (Operand is in the instruction) | \#data8 = \#00H-\#FFH |  |
| Immediate, 16 bits | N.A. (Operand is in the instruction) | \#data16 = \#0000H-\#FFFFH |  |
| Direct, 8 address bits | 00:0000H-00:007FH | dir8 $=00: 0000 \mathrm{H}-00: 007 \mathrm{FH}$ | On-chip RAM |
|  | SFRs | $\begin{aligned} \text { dir8 }= & \text { S:080H-S:1FFH (2) } \\ & \text { or SFR mnemonic } \end{aligned}$ | SFR address |
| Direct, 16 address bits | 00:0000H-00:FFFFH | dir16 $=00: 0000 \mathrm{H}-00:$ FFFFH |  |
| Indirect, 16 address bits | 00:0000H-00:FFFFH | @WR0-@WR30 |  |
| Indirect, 24 address bits | 00:0000H-FF:FFFFH | @DR0-@DR30, @DR56, @ DR60 | Upper 8 bits of DRk must be 00 H . |
| Displacement, 16 address bits | 00:0000H-00:FFFFH | @WRj + dis16 = @ WRO +OH through @WR30 + FFFFH | Offset is signed; address wraps around in region 00:. |
| Displacement, 24 address bits | 00:0000H-FF:FFFFH | @DRk + dis24 = <br> @DRO +OH -through @DR28 + FFFFH, <br> @DR56 + (OH-FFFFH), <br> @DR60 $+(0 \mathrm{H}-\mathrm{FFFFH})$ | Offset is signed, upper 8 bits of DRk must be 00 H . |

## NOTES:

1. These registers are accessible in the memory space as well as in the register file (see "The 8XC251SB Register File" on page 3-8).
2. The MCS 251 architecture supports SFRs in locations S:000H-S:1FFH; however, in the 8XC251SB, all SFRs are in the range $\mathrm{S}: 080 \mathrm{H}-\mathrm{S}: 0 \mathrm{FFH}$.

## NOTE

Instructions from the MCS 51 architecture access external memory through the region of memory specified by byte DPXL in the extended data pointer register, DPX (DR56). Following reset, DPXL contains 01H, which maps the external memory to region 01 :. You can specify a different region by writing to DR56 or the DPXL SFR. (See "Dedicated Registers" on page 3-10.).

### 4.3.1.1 Register Addressing

Both architectures address registers directly.

- MCS 251 architecture. In the register addressing mode, the operand(s) in a data instruction are in byte registers (R0-R15), word registers (WR0, WR2, ..., WR30), or dword registers (DR0, DR4, ..., DR28, DR56, DR60).
- MCS 51 architecture. Instructions address registers R0-R7 only.


### 4.3.1.2 Immediate

Both architectures use immediate addressing.

- MCS 251 architecture. In the immediate addressing mode, the instruction contains the data operand itself. Byte operations use 8-bit immediate data (\#data); word operations use 16-bit immediate data (\#data16). Dword operations use 16-bit immediate data in the lower word and either zeros in the upper word (denoted by \#0data16) or ones in the upper word (denoted by \#1data16). MOV instructions that place 16-bit immediate data into a dword register (DRk), place the data either into the upper word while leaving the lower word unchanged, or into the lower word with a sign extension or a zero extension.
The increment and decrement instructions contain immediate data (\#short $=1,2$, or 4 ), which specifies the amount of the increment/decrement.
- MCS 51 architecture. Instructions use only 8-bit immediate data (\#data).


### 4.3.1.3 Direct

- MCS 251 architecture. In the direct addressing mode, the instruction contains the address of the data operand. The 8 -bit direct mode addresses on-chip RAM (dir8 $=00: 0000 \mathrm{H}-$ $00: 007 \mathrm{FH}$ ) as both bytes and words, and addresses the SFRs (dir8 $=\mathrm{S}: 080 \mathrm{H}-\mathrm{S}: 1 \mathrm{FFH}$ ) as bytes only. (See the note below Table 4-5 on page 4-7 regarding SFRs in the MCS 251 architecture.) The 16 -bit direct mode addresses both bytes and words in memory (dir16 = 00:0000H-00:FFFFH).
- MCS 51 architecture. The 8-bit direct mode addresses 256 bytes of on-chip RAM (dir8 = $00 \mathrm{H}-7 \mathrm{FH}$ ) as bytes only and the SFRs (dir8 $=80 \mathrm{H}-\mathrm{FFH}$ ) as bytes only.


### 4.3.1.4 Indirect

In arithmetic and logical instructions that use indirect addressing, the source operand is always a byte, and the destination is either the accumulator or a byte register (R0-R15). The source address is a byte, word, or dword. The two architectures do indirect addressing via different registers:

- MCS 251 architecture. Memory is indirectly addressed via word and dword registers:
— Word register ( $@ W R j, j=0,2,4, \ldots, 30$ ). The 16 -bit address in WRj can access locations 00:0000H-00:FFFFH.
— Dword register ( $@ \mathrm{DRk}, \mathrm{k}=0,4,8, \ldots, 28,56$, and 60 ). The 24 least significant bits can access the entire 16-Mbyte address space. The upper eight bits of DRk must be 0 . (If you use DR60 as a general data pointer, be aware that DR60 is the extended stack pointer register DPX.)
- MCS 51 architecture. Instructions use indirect addressing to access on-chip RAM, code memory, and external data RAM. (See the Note on page 4-7 regarding the region of external data RAM that is addressed by instructions in the MCS 51 architecture.)
- Byte register (@Ri, $\mathrm{i}=1,2$ ). Registers R 0 and R 1 indirectly address on-chip memory locations $00 \mathrm{H}-\mathrm{FFH}$ and the lowest 256 bytes of external data RAM.
- 16-bit data pointer (@DPTR or @A+DPTR). The MOVC and MOVX instructions use these indirect modes to access code memory and external data RAM.
- 16-bit program counter (@A+PC). The MOVC instruction uses this indirect mode to access code memory.


### 4.3.1.5 Displacement

Several move instructions use displacement addressing to move bytes or words from a source to a destination. Sixteen-bit displacement addressing (@WRj+dis16) accesses indirectly the lowest 64 Kbytes in memory. The base address can be in any word register WRj. The instruction contains a 16-bit signed offset which is added to the base address. Only the lowest 16 bits of the sum are used to compute the operand address. If the sum of the base address and a positive offset exceeds FFFFH, the computed address wraps around within region 00: (e.g. F000H +2005 H becomes 1005 H ). Similarly, if the sum of the base address and a negative offset is less than zero, the computed address wraps around the top of region 00 : (e.g., $2005 \mathrm{H}+\mathrm{F} 000 \mathrm{H}$ becomes 1005 H ).

Twenty-four-bit displacement addressing (@DRk+dis24) accesses indirectly the entire 16-Mbyte address space. The base address must be in DR0, DR4, ..., DR24, DR28, DR56, or DR60. The upper byte in the dword register must be zero. The instruction contains a 16-bit signed offset which is added to the base address.

### 4.3.2 Arithmetic Instructions

The set of arithmetic instructions is greatly expanded in the MCS 251 architecture. The ADD and SUB instructions (Table A-19 on page A-14) operate on byte and word data that is accessed in several ways:

- as the contents of the accumulator, a byte register ( Rn ), or a word register ( WRj )
- in the instruction itself (immediate data)
- in memory via direct or indirect addressing

The ADDC and SUBB instructions (Table A-19 on page A-14) are the same as those for MCS 51 microcontrollers.

The CMP (compare) instruction (Table A-20 on page A-15) calculates the difference of two bytes or words and then writes to flags CY, OV, AC, N, and Z in the PSW and PSW1 registers. The difference is not stored. The operands can be addressed in a variety of modes. The most frequent use of CMP is to compare data or addresses preceding a conditional jump instruction.

Table A-21 on page A-16 lists the INC (increment) and DEC (decrement) instructions. The instructions for MCS 51 microcontrollers are supplemented by instructions that can address byte, word, and dword registers and increment or decrement them by 1,2 , or 4 (denoted by \#short). These instructions are supplied primarily for register-based address pointers and loop counters.

The MCS 251 architecture provides the MUL (multiply) and DIV (divide) instructions for unsigned 8 -bit and 16 -bit data (Table A-22 on page A-16). Signed multiply and divide are left for the user to manage through a conversion process. The following operations are implemented:

- eight-bit multiplication: 8 bits $\times 8$ bits $\rightarrow 16$ bits
- sixteen-bit multiplication: 16 bits $\times 16$ bits $\rightarrow 32$ bits
- eight-bit division: 8 bits $\div 8$ bits $\rightarrow 16$ bits (8-bit quotient, 8 -bit remainder)
- sixteen-bit division: 16 bits $\div 16$ bits $\rightarrow 32$ bits (16-bit quotient, 16-bit remainder)

These instructions operate on pairs of byte registers (Rmd,Rms), word registers (WRjd,WRjs), or the accumulator and $B$ register ( $\mathrm{A}, \mathrm{B}$ ). For 8-bit register multiplies, the result is stored in the word register that contains the first operand register. For example, the product from an instruction MUL R3,R8 is stored in WR2. Similarly, for 16-bit multiplies, the result is stored in the dword register that contains the first operand register. For example, the product from the instruction MUL WR6,WR18 is stored in DR4.

For 8-bit divides, the operands are byte registers. The result is stored in the word register that contains the first operand register. The quotient is stored in the lower byte, and the remainder is stored in the higher byte. A 16-bit divide is similar. The first operand is a word register, and the result is stored in the double word register that contains that word register. If the second operand (the divisor) is zero, the overflow flag (OV) is set and the other bits in PSW and PSW1 are meaningless.

### 4.3.3 Logical Instructions

The MCS 251 architecture provides a set of instructions that perform logical operations. The ANL, ORL, and XRL (logical AND, logical OR, and logical exclusive OR) instructions operate on bytes and words that are accessed via several addressing modes (Table A-23 on page A-17). A byte register, word register, or the accumulator can be logically combined with a register, immediate data, or data that is addressed directly or indirectly. These instructions affect the Z and N flags.

In addition to the CLR (clear), CPL (complement), SWAP (swap), and four rotate instructions that operate on the accumulator, MCS 251 microcontrollers have three shift commands for byte and word registers:

- SLL (Shift Left Logical) shifts the register one bit left and replaces the LSB with 0.
- SRL (Shift Right Logical) shifts the register one bit right and replaces the MSB with 0.
- SRA (Shift Right Arithmetic) shifts the register one bit right; the MSB is unchanged.


### 4.3.4 Data Transfer Instructions

Data transfer instructions copy data from one register or memory location to another. These instructions include the move instructions (Table A-24 on page A-19) and the exchange, push, and pop instructions (Table A-24 on page A-19). Instructions that move only a single bit are listed with the other bit instructions in Table A-26 on page A-23.

MOV (Move) is the most versatile instruction, and its addressing modes are expanded in the MCS 251 architecture. MOV can transfer a byte, word, or dword between any two registers or between a register and any location in the address space.

The MOVX (Move External) instruction moves a byte from external memory to the accumulator or from the accumulator to memory. The external memory is in the region specified by DPXL, whose reset value is 01 H . (See "Dedicated Registers" on page 3-10.)

The MOVC (Move Code) instruction moves a byte from code memory (region FF:) to the accumulator.

MOVS (Move with Sign Extension) and MOVZ (Move with Zero Extension) move the contents of an 8-bit register to the lower byte of a 16-bit register. The upper byte is filled with the sign bit (MOVS) or zeros (MOVZ). The MOVH (Move to High Word) instruction places 16-bit immediate data into the high word of a dword register.

The XCH (Exchange) instruction interchanges the contents of the accumulator with a register or memory location. The XCHD (Exchange Digit) instruction interchanges the lower nibble of the accumulator with the lower nibble of a byte in on-chip RAM. XCHD is useful for BCD (binary coded decimal) operations.

The PUSH and POP instructions facilitate storing information (PUSH) and then retrieving it (POP) in reverse order. Push can push a byte, a word, or a dword onto the stack, using the immediate, direct, or register addressing modes. POP can pop a byte or a word from the stack to a register or to memory.

### 4.4 BIT INSTRUCTIONS

A bit instruction addresses a specific bit in a memory location or SFR. There are four categories of bit instructions:

- SETB (Set Bit), CLR (Clear Bit), CPL (Complement Bit). These instructions can set, clear or complement any addressable bit.
- ANL (And Logical), ANL/ (And Logical Complement), ORL (OR Logical), ORL/ (Or Logical Complement). These instructions allow ANDing and ORing of any addressable bit or its complement with the CY flag.
- MOV (Move) instructions transfer any addressable bit to the carry (CY) bit or vice versa.
- Bit-conditional jump instructions execute a jump if the bit has a specified state. The bitconditional jump instructions are classified with the control instructions and are described in "Conditional Jumps" on page 4-15.


### 4.4.1 Bit Addressing

The bits that can be individually addressed are in the on-chip RAM and the SFRs (Table 4-6). The bit instructions that are unique to the MCS 251 architecture can address a wider range of bits than the instructions from the MCS 51 architecture.

Table 4-6. Bit-addressable Locations

| Architecture | Bit-addressable Locations |  |
| :---: | :---: | :--- |
|  | On-chip RAM | SFRs |
| MCS 251® Architecture | $20 \mathrm{H}-7 \mathrm{FH}$ | All defined SFRs |
| MCS 51 Architecture | $20 \mathrm{H}-2 \mathrm{FH}$ | SFRs with addresses ending in OH <br> or $8 \mathrm{H}:$ <br> $80 \mathrm{H}, 88 \mathrm{H}, 90 \mathrm{H}, 98 \mathrm{H}, \ldots, \mathrm{F} 8 \mathrm{H}$ |

There are some differences in the way the instructions from the two architectures address bits. In the MCS 51 architecture, a bit (denoted by bit51) can be specified in terms of its location within a certain register, or it can be specified by a bit address in the range $00 \mathrm{H}-7 \mathrm{FH}$. The MCS 251 architecture does not have bit addresses as such. A bit can be addressed by name or by its location within a certain register, but not by a bit address.

Table 4-7 illustrates bit addressing in the two architectures by using two sample bits:

- RAMBIT is bit 5 in RAMREG, which is location 23H. ("RAMBIT" and "RAMREG" are assumed to be defined in user code.)
- IT1 is bit 2 in TCON, which is an SFR at location 88 H .

Table 4-7. Addressing Two Sample Bits

| Location | Addressing <br> Mode | MCS® <br> Architecture | MCS 251 <br> Architecture |
| :--- | :--- | :--- | :--- |
| On-chip RAM | Register Name | RAMREG.5 | RAMREG.5 |
|  | Register Address | 23H.5 | 23H.5 |
|  | Bit Name | RAMBIT | RAMBIT |
|  | Bit Address | 1DH | NA |
| SFR | Register Name | TCON.2 | TCON.2 |
|  | Register Address | 88.2 H | S:88.2H |
|  | Bit Name | IT1 | IT1 |
|  | Bit Address | 8A | NA |

Table 4-8 lists the addressing modes for bit instructions, and Table A-26 on page A-23 summarizes the bit instructions. "bit" denotes a bit that is addressed by a new instruction in the MCS 251 architecture, and "bit51" denotes a bit that is addressed by an instruction in the MCS 51 architecture.

Table 4-8. Addressing Modes for Bit Instructions

| Architecture | Variants | Bit Address | Memory/SFR Address | Comments |
| :--- | :--- | :--- | :--- | :---: |
| MCS <br> Architecture <br> (bit) | Memory | NA | 20H.0-7FH.7 |  |
|  | SFR | NA | All defined SFRs |  |
| MCS 51 <br> Architecture <br> (bit51) | Memory | 00H-7FH | $20 \mathrm{H} .0-7 \mathrm{FH.7}$ |  |
|  | SFR | 80H-F8H | XXH.0-XXH.7, where XX $=80$, <br> $88,90,98, \ldots, F 0, F 8$. | SFRs are not defined <br> at all bit-addressable <br> locations. |

### 4.5 CONTROL INSTRUCTIONS

Control instructions-instructions that change program flow-include calls, returns, and conditional and unconditional jumps (see Table A-27 on page A-24). Instead of executing the next instruction in the queue, the processor executes a target instruction.

### 4.5.1 Addressing Modes for Control Instructions

A control instruction provides the address of a target instruction. The instruction can specify the target address implicitly, as in a return from a subroutine, or explicitly, in the form of a relative, direct, or indirect address:

- Relative addressing: The control instruction provides the target address as an 8-bit signed offset (rel) from the address of the next instruction.
- Direct addressing: The control instruction provides a target address, which can have 11 bits (addr11), 16 bits (addr16), or 24 bits (addr24). The target address is written to the PC.
- addr11: Only the lower 11 bits of the PC are changed; i.e., the target address must be in the current 2-Kbyte block (the 2-Kbyte block that includes the first byte of the next instruction).
- addr16: Only the lower 16 bits of the PC are changed; i.e., the target address must be in the current 64-Kbyte region (the 64-Kbyte region that includes the first byte of the next instruction).
- addr24: The target address can be anywhere in the 16-Mbyte address space.
- Indirect addressing: There are two types of indirect addressing for control instructions:
- For the instructions LCALL @WRj and LJMP @WRj, the target address is in the current $64-$ Kbyte region. The 16 -bit address in WRj is placed in the lower 16 bits of the PC. The upper eight bits of the PC remain unchanged from the address of the next instruction.
- For the instruction JMP @ A+DPTR, the sum of the accumulator and DPTR is placed in the lower 16 bits of the PC, and the upper eight bits of the PC are FF:, which restricts the target address to the code memory space of the MCS 51 architecture.

Table 4-9 lists the addressing modes for the control instructions.
Table 4-9. Addressing Modes for Control Instructions

| Description | Address Bits <br> Provided | Address Range |
| :--- | :---: | :--- |
| Relative, 8-bit relative address (rel) | 8 | -128 to +127 from first byte of next instruction |
| Direct, 11-bit target address (addr11) | 11 | Current 2 Kbytes |
| Direct, 16-bit target address (addr16) | 16 | Current 64 Kbytes |
| Direct, 24-bit target address (addr24) $\dagger$ | 24 | $00: 0000 \mathrm{H}-$ FF:FFFFH |
| Indirect (@WRi) $\dagger$ | 16 | Current 64 Kbytes |
| Indirect (@A+DPTR) | 16 | $64-$-Kbyte region specified by DPXL (reset <br> value $=01 H)$ |

$\dagger$ These modes are not used by instructions in the MCS ${ }^{\circledR} 51$ architecture.

### 4.5.2 Conditional Jumps

The MCS 251 architecture supports bit-conditional jumps, compare-conditional jumps, and jumps based on the value of the accumulator. A bit-conditional jump is based on the state of a bit. In a compare-conditional jump, the jump is based on a comparison of two operands. All conditional jumps are relative, and the target address (rel) must be in the current 256-byte block of code.

The instruction set includes three kinds of bit-conditional jumps:

- JB (Jump on Bit): Jump if the bit is set.
- JNB (Jump on Not Bit): Jump if the bit is clear.
- JBC (Jump on Bit then Clear it): Jump if the bit is set; then clear it.
"Bit Addressing" on page 4-12 describes the bit addressing used in these instructions.
Compare-conditional jumps test a condition resulting from a compare (CMP) instruction that is assumed to precede the jump instruction. The jump instruction examines the PSW and PSW1 registers and interprets their flags as though they were set or cleared by a compare (CMP) instruction. Actually, the state of each flag is determined by the last instruction that could have affected that flag.

The condition flags are used to test one of the following six relations between the operands:

- equal ( $=$ ), not equal ( $\neq$ )
- greater than $(>)$, less than ( $<$ )
- greater than or equal $(\geq)$, less than or equal ( $(\leq)$

For each relation there are two instructions, one for signed operands and one for unsigned operands (Table 4-10).

Table 4-10. Compare-conditional Jump Instructions

| Operand <br> Type | Relation |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $=$ | $\neq$ | $>$ | $<$ | $\geq$ | $\leq$ |  |
| Unsigned | JE | JNE | JG | JL | JGE | JLE |  |
|  |  |  | JSL | JSGE | JSLE |  |  |

### 4.5.3 Unconditional Jumps

There are five unconditional jumps. NOP and SJMP jump to addresses relative to the program counter. AJMP, LJMP, and EJMP jump to direct or indirect addresses.

- NOP (No Operation) is an unconditional jump to the next instruction.
- SJMP (Short Jump) jumps to any instruction within -128 to 127 of the next instruction.
- AJMP (Absolute Jump) changes the lowest 11 bits of the PC to jump anywhere within the current 2-Kbyte block of memory. The address can be direct or indirect.
- LJMP (Long Jump) changes the lowest 16 bits of the PC to jump anywhere within the current 64-Kbyte region.
- EJMP (Extended Jump) changes all 24 bits of the PC to jump anywhere in the $16-\mathrm{Mbyte}$ address space. The address can be direct or indirect.


### 4.5.4 Calls and Returns

The MCS 251 architecture provides relative, direct, and indirect calls and returns.
ACALL (Absolute Call) pushes the lower 16 bits of the next instruction address onto the stack and then changes the lower 11 bits of the PC to the 11 -bit address specified by the instruction. The call is to an address that is in the same 2-Kbyte block of memory as the address of the next instruction.

LCALL (Long Call) pushes the lower 16 bits of the next-instruction address onto the stack and then changes the lower 16 bits of the PC to the 16 -bit address specified by the instruction. The call is to an address in the same 64-Kbyte block of memory as the address of the next instruction.

ECALL (Extended Call) pushes the 24 bits of the next instruction address onto the stack and then changes the 24 bits of the PC to the 24-bit address specified by the instruction. The call is to an address anywhere in the 16 -Mbyte memory space.

RET (Return) pops the top two bytes from the stack to return to the instruction following a subroutine call. The return address must be in the same $64-\mathrm{Kbyte}$ region.

ERET (Extended Return) pops the top three bytes from the stack to return to the address following a subroutine call. The return address can be anywhere in the $16-\mathrm{Mbyte}$ address space.

RETI (Return from Interrupt) provides a return from an interrupt service routine. The operation of RETI depends on the INTR configuration bit in the CONFIG1 register:

- For INTR $=0$, an interrupt causes the two lower bytes of the PC to be pushed onto the stack. The RETI instruction pops these two bytes and uses them as the 16 -bit return address in region FF:. RETI also restores the interrupt logic to accept additional interrupts at the same priority level as the one just processed.
- For INTR $=1$, an interrupt causes four bytes to be pushed onto the stack: the three bytes of the PC plus the PSW1 register. The RETI instruction pops these four bytes and then returns to the specified 24 -bit address, which can be anywhere in the 16 -Mbyte address space. RETI also clears the interrupt request line.

The TRAP instruction is useful for the development of emulations of an MCS 251 microcontroller.

### 4.6 PROGRAM STATUS WORDS

The Program Status Word (PSW) register and the Program Status Word 1 (PSW1) register contain four types of bits (Figure 4-3 on page 4-19 and Figure 4-4 on page 4-20):

- CY, AC, OV, N, and Z are flags set by hardware to indicate the result of an operation.
- The P bit indicates the parity of the accumulator.
- Bits RS0 and RS1 are programmed by software to select the active register bank for registers R0-R7.
- F0 and UD are available to the user as general-purpose flags.

The PSW and PSW1 registers are read/write registers; however, the parity bit in the PSW is not affected by a write. Individual bits can be addressed with the bit instructions ("Bit Instructions" on page 4-12). The PSW and PSW1 bits are used implicitly in the conditional jump instructions ("Conditional Jumps" on page 4-15).

The PSW register is identical to the PSW register in MCS 51 microcontrollers. The PSW1 register exists only in MCS 251 microcontrollers. Bits CY, AC, RSO, RS1, and OV in PSW1 are identical to the corresponding bits in PSW, i.e., the same bit can be accessed in either register. Table 4-11 lists the instructions that affect the CY, AC, OV, N, and Z bits.

Table 4-11. The Effects of Instructions on the PSW and PSW1 Flags

| Instruction Type | Instruction | Flags Affected (1) |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | CY | OV | AC (2) | N | z |
| Arithmetic | ADD, ADDC, SUB, SUBB, CMP | X | X | X | X | X |
|  | INC, DEC |  |  |  | X | X |
|  | MUL, DIV (3) | 0 | X |  | X | X |
|  | DA | X |  |  | X | X |
| Logical | ANL, ORL, XRL, CLR A, CPL A, RL, RR, SWAP |  |  |  | X | X |
|  | $\begin{aligned} & \text { RLC, RRC, SRL, SLL, } \\ & \text { SRA (4) } \end{aligned}$ | X |  |  | X | X |
| Program Control | CJNE | X |  |  | X | X |
|  | DJNE |  |  |  | X | X |

## NOTES:

1. $\mathrm{X}=$ the flag can be affected by the instruction.
$0=$ the flag is cleared by the instruction.
2. The AC flag is affected only by operations on 8 -bit operands.
3. If the divisor is zero, the OV flag is set, and the other bits are meaningless.
4. For SRL, SLL, and SRA instructions, the last bit shifted out is stored in the CY bit.

PROGRAMMING


Figure 4-3. Program Status Word Register

| PSW1 |  |  |  |  |  | Address: Reset State: | $\begin{array}{r} \text { S:D1H } \\ 0000 \text { 0000B } \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 O |  |  |  |  |  |  |  |
| CY | AC | N | RS1 | RS0 | OV | Z | - |
| $\begin{gathered} \text { Bit } \\ \text { Number } \end{gathered}$ | Bit Mnemonic | Function |  |  |  |  |  |
| 7 | CY | Carry Flag: <br> Identical to the CY bit in the PSW register (Figure 4-3 on page 4-19.) |  |  |  |  |  |
| 6 | AC | Auxiliary Carry Flag: <br> Identical to the AC bit in the PSW register (Figure 4-3 on page 4-19.) |  |  |  |  |  |
| 5 | N | Negative Flag: <br> This bit is set if the result of the last logical or arithmetic operation was negative. Otherwise it is cleared. |  |  |  |  |  |
| 4-3 | RS1:0 | Register Bank Select Bits 0 and 1: Identical to the RS1:0 bits in the PSW register (Figure 4-3 on page 4-19). |  |  |  |  |  |
| 2 | OV | Overflow Flag: <br> Identical to the OV bit in the PSW register (Figure 4-3 on page 4-19.) |  |  |  |  |  |
| 1 | Z | Zero Flag: <br> This flag is set if the result of the last logical or arithmetic operation is zero. Otherwise it is cleared. |  |  |  |  |  |
| 0 | - | Reserved: <br> The value read from this bit is indeterminate. Do not write a " 1 " to this bit. |  |  |  |  |  |

Figure 4-4. Program Status Word 1 Register

## inte.

## Interrupt System

## CHAPTER 5 INTERRUPT SYSTEM

### 5.1 OVERVIEW

The 8 XC 251 SB , like other control-oriented computer architectures, employs a program interrupt method. This operation branches to a subroutine and performs some service in response to the interrupt. When the subroutine completes, execution resumes at the point where the interrupt occurred. Interrupts may occur as a result of internal 8XC251SB activity (e.g., timer overflow) or at the initiation of electrical signals external to the microcontroller (e.g., serial port communication). In all cases, interrupt operation is programmed by the system designer, who determines priority of interrupt service relative to normal code execution and other interrupt service routines. Seven of the eight interrupts are enabled or disabled by the system designer and may be manipulated dynamically.

A typical interrupt event chain occurs as follows. An internal or external device initiates an inter-rupt-request signal. This signal, connected to an input pin (see Table 5-1, Interrupt System Pin Signals) and periodically sampled by the 8 XC 251 SB , latches the event into a flag buffer. The priority of the flag (see Table 5-2, Interrupt System Special Function Registers) is compared to the priority of other interrupts by the interrupt handler. A high priority causes the handler to set an interrupt flag. This signals the instruction execution unit to execute a context switch. This context switch breaks the current flow of instruction sequences. The execution unit completes the current instruction prior to a save of the program counter (PC) and reloads the PC with the start address of a software service routine. The software service routine executes assigned tasks and as a final activity performs a RETI (return from interrupt) instruction. This instruction signals completion of the interrupt, resets the interrupt-in-progress priority, and reloads the program counter. Program operation then continues from the original point of interruption.

Table 5-1. Interrupt System Pin Signals

| Signal <br> Name | Type | Description | Multiplexed <br> With |
| :--- | :---: | :--- | :--- |
| INT1:0\# | I | External Interrupts 0 and 1. These inputs set bits IE1:0 in the <br> TCON register. If bits IT1:0 in the TCON register are set, bits IE1:0 <br> are controlled by a negative-edge trigger on INT1\#/INT0\#. If bits <br> INT1:0\# are clear, bits IE1:0 are controlled by a low level trigger on <br> INT1:0\#. | P3.3:2 |

NOTE: Other pin signals are defined in their respective chapters and in Appendix B, "Signal Descriptions."


Figure 5-1. Interrupt Control System

Table 5-2. Interrupt System Special Function Registers

| Mnemonic | Description | Address |
| :--- | :--- | :--- |
| IEO | Interrupt Enable Register. Used to enable and disable programmable <br> interrupts. The reset value of this register is zero (interrupts disabled). | $\mathrm{S}: \mathrm{A8H}$ |
| IPLO | Interrupt Priority Low Register. Establishes relative four-level priority for <br> programmable interrupts. Used in conjunction with IPHO. | $\mathrm{S:B8H}$ |
| IPH0 | Interrupt Priority High Register. Establishes relative four-level priority for <br> programmable interrupts. Used in conjunction with IPLO. | $\mathrm{S}: \mathrm{B7H}$ |

NOTE: Other Special Function Registers are described in their respective chapters.

### 5.2 8XC251SB INTERRUPT SOURCES

Figure 5-1 on page 5-2 illustrates the interrupt control system. The 8 XC 251 SB has eight interrupt sources; seven maskable sources and the TRAP instruction (always enabled). The maskable sources include two external interrupts (INT0\# and INT1\#), three timer interrupts (timers 0, 1, and 2), one programmable counter array (PCA) interrupt, and one serial port interrupt. Each interrupt (except TRAP) has an interrupt request flag, which can be set by software as well as by hardware (see Table 5-3 on page 5-4). For some interrupts, hardware clears the request flag when it grants an interrupt. Software can clear any request flag to cancel an impending interrupt.

### 5.2.1 External Interrupts

External interrupts INT0\# and INT1\# (INTx\#) pins may each be programmed to be level-triggered or edge-triggered, dependent upon bits IT0 and IT1 in the TCON register (see Figure 7-5 on page 7-8). If IT $x=0$, INTx\# is triggered by a detected low at the pin. If IT $x=1$, INTx\# is neg-ative-edge triggered. External interrupts are enabled with bits EX0 and EX1 (EXx) in the IE0 register (see Figure 5-2 on page 5-6). Events on the external interrupt pins set the interrupt request flags IE $x$ in TCON. These request bits are cleared by hardware vectors to service routines only if the interrupt is negative-edge triggered. If the interrupt is level-triggered, the interrupt service routine must clear the request bit. External hardware must deassert INTx\# before the service routine completes, or an additional interrupt is requested. External interrupt pins must be deasserted for at least four state times prior to a request.

External interrupt pins are sampled once every four state times (a frame length of 666.4 ns at 12 MHz ). A level-triggered interrupt pin held low or high for any five-state time period guarantees detection. Edge-triggered external interrupts must hold the request pin low for at least five state times. This ensures edge recognition and sets interrupt request bit EXx. The CPU clears EXx automatically during service routine fetch cycles for edge-triggered interrupts.

Table 5-3. Interrupt Control Matrix

| Interrupt Name | Global <br> Enable | PCA | Timer <br> $\mathbf{2}$ | Serial <br> Port | Timer <br> $\mathbf{1}$ | INT1\# | Timer <br> $\mathbf{0}$ | INTO\# |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Bit Name in Interrupt <br> Enable Register <br> @S:A8H | EA | EC | ET2 | ES | ET1 | EX1 | ET0 | EX0 |
| Interrupt Priority- <br> Within-Level <br> $(7=$ Low Priority, <br> 1=High Priority) | NA | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| Bit Name in Interrupt <br> Priority Low @S:B8H | Reserved | IPL0.6 | IPL0.5 | IPL0.4 | IPL0.3 | IPL0.2 | IPL0.1 | IPL0.0 |
| Bit Name in Interrupt <br> Priority High <br> @S:B7H | Reserved | IPH0.6 | IPH0.5 | IPH0.4 | IPH0.3 | IPH0.2 | IPH0.1 | IPH0.0 |
| Programmable for <br> Negative-edge <br> Triggered or Level- <br> triggered Detect? | NA | Edge | No | No | No | Yes | No | Yes |
| Request Flag | NA | CFF, |  |  |  |  |  |  |
| CCFX |  |  |  |  |  |  |  |  |

### 5.2.2 Timer Interrupts

Two timer-interrupt request bits TF0 and TF1 (see TCON register, Figure 7-5 on page 7-8) are set by timer overflow (the exception is Timer 0 in Mode 3, see Figure 7-3 on page 7-6). When a timer interrupt is generated, the bit is cleared by an on-chip-hardware vector to an interrupt service routine. Timer interrupts are enabled by bits ET0, ET1, and ET2 in the IE0 register (see Figure 5-2 on page 5-6).

Timer 2 interrupts are generated by a logical OR of bits TF2 and EXF2 in register T2CON (see Figure 7-11 on page 7-17). Neither flag is cleared by a hardware vector to a service routine. In fact, the interrupt service routine must determine if TF2 or EXF2 generated the interrupt, and then clear the bit. Timer 2 interrupt is enabled by ET2 in register IE0.

### 5.3 PROGRAMMABLE COUNTER ARRAY (PCA) INTERRUPT

The programmable counter array (PCA) interrupt is generated by logical OR of five event flags (CCFx) and the PCA timer overflow flag (CF) in the CCON register (see Figure 8-8 on page $8-14)$. All PCA interrupts share a common interrupt vector. Bits are not cleared by hardware vectors to service routines. Normally, interrupt service routines resolve interrupt requests and clear flag bits. This allows the user to define the relative priorities of the five PCA interrupts.

The PCA interrupt is enabled by bit EC in the IE0 register (see Figure 5-1 on page 5-2. In addition, the CF flag and each of the CCFx flags must also be individually enabled by bits ECF and ECCF $x$ in registers CMOD and CCAPM $x$ respectively for the flag to generate an interrupt (see Figure $8-8$ on page $8-14$ and Figure $8-9$ on page $8-16$ ).

## NOTE

CCF $x$ refers to 5 separate bits, one for each PCA module (CCF0, CCF1, CCF2, CCF3, CCF4).

CCAPM $x$ refers to 5 separate registers, one for each PCA module (CCAPM0, CCAPM1, CCAPM2, CCAPM3, CCAPM4).

### 5.4 SERIAL PORT INTERRUPT

Serial port interrupts are generated by the logical OR of bits RI and TI in the SCON register (see Figure 9-2 on page 9-3). Neither flag is cleared by a hardware vector to the service routine. The service routine resolves RI or TI interrupt generation and clears the serial port request flag. The serial port interrupt is enabled by bit ES in the IE0 register (see Figure 5-2 on page 5-6).

### 5.5 INTERRUPT ENABLE

Each interrupt source (with the exception of TRAP) may be individually enabled or disabled by the appropriate interrupt enable bit in the IE0 register at S :A8H (see Figure 5-2 on page 5-6). Note IE0 also contains a global disable bit (EA). If EA is set, interrupts are individually enabled or disabled by bits in IE0. If EA is clear, all interrupts are disabled.

| IEO |  |  |  |  |  | Address: Reset State: | $\begin{array}{r} \text { S:A8H } \\ 0000 \text { 0000B } \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 |  |  |  |  |  |  |  |
| EA | EC | ET2 | ES | ET1 | EX1 | ETO | EXO |
|  | Bit Mnemonic | Function |  |  |  |  |  |
| 7 | EA | Global Interrupt Enable: <br> Setting this bit enables all interrupts that are individually enabled by bits $0-6$. Clearing this bit disables all interrupts, except the TRAP interrupt, which is always enabled. |  |  |  |  |  |
| 6 | EC | PCA Interrupt Enable: <br> Setting this bit enables the PCA interrupt. |  |  |  |  |  |
| 5 | ET2 | Timer 2 Overflow Interrupt Enable: Setting this bit enables the timer 2 overflow interrupt. |  |  |  |  |  |
| 4 | ES | Serial I/O Port Interrupt Enable: <br> Setting this bit enables the serial I/O port interrupt. |  |  |  |  |  |
| 3 | ET1 | Timer 1 Overflow Interrupt Enable: <br> Setting this bit enables the timer 1 overflow interrupt. |  |  |  |  |  |
| 2 | EX1 | External Interrupt 1 Enable: <br> Setting this bit enables external interrupt 1. |  |  |  |  |  |
| 1 | ETO | Timer 0 Overflow Interrupt Enable: <br> Setting this bit enables the timer 0 overflow interrupt. |  |  |  |  |  |
| 0 | EXO | External Interrupt 0 Enable: Setting this bit enables external interrupt 0 . |  |  |  |  |  |

Figure 5-2. Interrupt Enable Register

### 5.6 INTERRUPT PRIORITIES

Each of the seven interrupt sources on the 8 XC 251 SB may be individually programmed to one of four priority levels. This is accomplished by a bit in the interrupt priority low and high registers (IPH0. $x /$ IPL0. $x$, see Figure 5-3 and Figure 5-4 on page 5-8). The IPH0 register has the same bit map as the IPL0 register. This gives each interrupt source two priority-level select bits (see Table $5-4)$. The MSB of the priority select bits is in the IPH0 register, and the LSB is in the IPL0 register.

Table 5-4. Level of Priority

| IPHO. $\boldsymbol{X}$ (MSB) | IPLO. $\boldsymbol{X}$ (LSB) | Priority Level |
| :---: | :---: | :--- |
| 0 | 0 | 0 Lowest Priority |
| 0 | 1 | 1 |
| 1 | 0 | 2 |
| 1 | 1 | 3 Highest Priority |

A low-priority interrupt is always interrupted by a higher priority interrupt but not by another interrupt of equal or lower priority. The highest priority interrupt is not interrupted by any other interrupt source. Higher priority interrupts are serviced before lower priority interrupts. The response to simultaneous occurrence of equal priority interrupts (i.e., sampled within the same four state interrupt cycle) is determined by a hardware priority-within-level resolver (see Table 5-5).

Table 5-5. Interrupt Priority Within Level

| Priority Number | Interrupt Name |
| :---: | :---: |
| 1(Highest Priority) | INTO\# |
| 2 | Timer 0 |
| 3 | INT1\# |
| 4 | Timer 1 |
| 5 | Serial Port |
| 6 | Timer 2 |
| 7(Lowest Priority) | PCA |

NOTE
The 8XC251SB interrupt priority-within-level table (Table 5-5) differs from MCS ${ }^{\circledR} 51$ microcontrollers. Other MCS 251 microcontrollers may have unique interrupt priority-within-level tables.

| IPHO |  |  |  |  | Address: Reset State: |  | $\begin{array}{r} \mathrm{S}: \mathrm{B7H} \\ 0000 \text { 0000B } \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 |  |  |  |  |  |  |  |
| - | IPH0.6 | IPH0.5 | IPH0. 4 | IPH0.3 | IPH0. 2 | IPH0. 1 | IPH0.O |
|  | Bit Mnemonic | Function |  |  |  |  |  |
| 7 | - | Reserved. The value read from this bit is indeterminate. Do not write a " 1 " to this bit. |  |  |  |  |  |
| 6 | IPH0.6 | PCA Interrupt Priority Bit High |  |  |  |  |  |
| 5 | IPH0.5 | Timer 2 Overflow Interrupt Priority Bit High |  |  |  |  |  |
| 4 | IPH0.4 | Serial I/O Port Interrupt Priority Bit High |  |  |  |  |  |
| 3 | IPH0.3 | Timer 1 Overflow Interrupt Priority Bit High |  |  |  |  |  |
| 2 | IPH0.2 | External Interrupt Priority Bit High |  |  |  |  |  |
| 1 | IPH0.1 | Timer 0 Overflow Interrupt Priority Bit High |  |  |  |  |  |
| 0 | IPH0.0 | External Interrupt 0 Priority Bit High |  |  |  |  |  |

Figure 5-3. Interrupt Priority High Register

| IPLO |  |  |  |  | Address: Reset State: |  | $\begin{array}{r} \mathrm{S}: \mathrm{B8H} \\ 0000 \text { O000B } \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 |  |  |  |  |  |  |  |
| - | IPL0.6 | IPL0.5 | IPL0.4 | IPL0.3 | IPL0. 2 | IPL0. 1 | IPL0.0 |
| Bit Number | Bit Mnemonic | Function |  |  |  |  |  |
| 7 | - | Reserved. The value read from this bit is indeterminate. Do not write a " 1 " to this bit. |  |  |  |  |  |
| 6 | IPL0.6 | PCA Interrupt Priority Bit Low |  |  |  |  |  |
| 5 | IPL0.5 | Timer 2 Overflow Interrupt Priority Bit Low |  |  |  |  |  |
| 4 | IPL0.4 | Serial I/O Port Interrupt Priority Bit Low |  |  |  |  |  |
| 3 | IPL0.3 | Timer 1 Overflow Interrupt Priority Bit Low |  |  |  |  |  |
| 2 | IPL0.2 | External Interrupt Priority Bit Low |  |  |  |  |  |
| 1 | IPL0.1 | Timer 0 Overflow Interrupt Priority Bit Low |  |  |  |  |  |
| 0 | IPL0.0 | External Interrupt 0 Priority Bit Low |  |  |  |  |  |

Figure 5-4. Interrupt Priority Low Register

### 5.7 INTERRUPT PROCESSING

Interrupt processing is a dynamic operation that begins when a source requests an interrupt and lasts until the execution of the first instruction in the interrupt service routine (see Figure 5-5). Response time is the amount of time between the interrupt request and the resulting break in the current instruction stream. Latency is the amount of time between the interrupt request and the execution of the first instruction in the interrupt service routine. These periods are dynamic due to the presence of both fixed-time sequences and several variable conditions. These conditions contribute to total elapsed time.


Figure 5-5. The Interrupt Process
Both response time and latency begin with the request. The subsequent minimum fixed sequence comprises the interrupt sample, poll, and request operations. The variables consist of (but are not limited to): specific instructions in use at request time, internal versus external interrupt source requests, internal versus external program operation, stack location, presence of wait states, pagemode operation, and branch pointer length.

## NOTE

In the following discussion external interrupt request pins are assumed to be inactive for at least four state times prior to assertion. In this chapter all external hardware signals maintain some setup period (i.e., less than one state time). Signals must meet $V_{\text {IH }}$ and Vil specifications prior to any state time under discussion. This setup state time is not included in examples or calculations for either response or latency.

### 5.7.1 Minimum Fixed Interrupt Time

All interrupts are sampled or polled every four state times (see Figure 5-5 on page 5-9). Two of eight interrupts are latched and polled per state time within any given four-state time window. One additional state time is required for a context switch request. For code branches to jump locations in the current 64-Kbyte memory region (compatible with MCS 51 microcontrollers), the context switch time is 11 states. Therefore, the minimum fixed poll and request time is 16 states ( 4 poll states +1 request state +11 states for the context switch $=16$ state times).

Therefore, this minimum fixed period rests upon four assumptions:

- The source request is an internal interrupt with high enough priority to take precedence over other potential interrupts,
- The request is coincident with internal execution and needs no instruction completion time,
- The program uses an internal stack location, and
- The ISR is in on-chip OTPROM/ROM.


### 5.7.2 Variable Interrupt Parameters

Both response time and latency calculations contain fixed and variable components. By definition, it is often difficult to predict exact timing calculations for real-time requests. One large variable is the completion time of an instruction cycle coincident with the occurrence of an interrupt request. Worst-case predictions typically use the longest-executing instruction in an architecture's code set. In the case of the 8 XC 251 SB , the longest-executing instruction is a 16-bit divide (DIV). However, even this 21- state instruction may have only 1 or 2 remaining states to complete before the interrupt system injects a context switch. This uncertainty affects both response time and latency.

### 5.7.2.1 Response Time Variables

Response time is defined as the start of a dynamic time period when a source requests an interrupt and lasts until a break in the current instruction execution stream occurs (see Figure 5-5 on page 5-9). Response time (and therefore latency) is affected by two primary factors: the incidence of the request relative to the four-state-time sample window and the completion time of instructions in the response period (i.e., shorter instructions complete earlier than longer instructions).

## NOTE

External interrupt signals require one additional state time in comparison to internal interrupts. This is necessary to sample and latch the pin value prior to a poll of interrupts. The sample occurs in the first half of the state time and the poll/request occurs in the second half of the next state time. Therefore, this sample and poll/request portion of the minimum fixed response and latency
time is five states for internal interrupts and six states for external interrupts. External interrupts must remain active for at least five state times to guarantee interrupt recognition when the request occurs immediately after a sample has been taken (i.e., requested in the second half of a sample state time).

If the external interrupt goes active one state after the sample state, the pin is not resampled for another three states. After the second sample is taken and the interrupt request is recognized, the interrupt controller requests the context switch. The programmer must also consider the time to complete the instruction at the moment the context switch request is sent to the execution unit. If 9 states of a 10-state instruction have completed when the context switch is requested, the total response time is 6 states, with a context switch immediately after the final state of the 10 -state instruction (see Figure 5-6).


Figure 5-6. Response Time Example \#1
Conversely, if the external interrupt requests service in the state just prior to the next sample, response is much quicker. One state asserts the request, one state samples, and one state requests the context switch. If at that point the same instruction conditions exist, one additional state time is needed to complete the 10 -state instruction prior to the context switch (see Figure 5-7 on page $5-12$ ). The total response time in this case is four state times. The programmer must evaluate all pertinent conditions for accurate predictability.


Figure 5-7. Response Time Example \#2

### 5.7.2.2 Computation of Worst-case Latency With Variables

Worst-case latency calculations assume that the longest 8 XC 251 SB instruction used in the program must fully execute prior to a context switch. The instruction execution time is reduced by one state with the assumption the instruction state overlaps the request state (therefore, 16-bit DIV is 21 state times - $1=20$ states for latency calculations). The calculations add fixed and variable interrupt times (see Table 5-6 on page 5-13) to this instruction time to predict latency. The worst-case latency (both fixed and variable times included) is expressed by a pseudo-formula:

FIXED_TIME + VARIABLES + LONGEST_INSTRUCTION = MAXIMUM LATENCY PREDICTION

Table 5-6. Interrupt Latency Variables

| Variable | INTO\#, <br> INT1\#, <br> T2EX | External <br> Execution | Page <br> Mode | $>64 \mathrm{~K}$ <br> Jump to <br> ISR (1) | External <br> Memory <br> Wait State | External <br> Stack <br> $<64 \mathrm{~K}(1)$ | External <br> Stack <br> $>64 \mathrm{~K}(1)$ | External <br> Stack <br> Wait State |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Number <br> of <br> States <br> Added | 1 | 2 | 1 | 8 | 1 per <br> bus cycle | 4 | 8 | 1 per <br> bus cycle |

## NOTES:

1. $<64 \mathrm{~K} />64 \mathrm{~K}$ means inside/outside the $64-\mathrm{Kbyte}$ memory region where code is executing.
2. Base-case fixed time is 16 states and assumes:
— A 2-byte instruction is the first ISR byte. - Internal execution

- <64K jump to ISR
- Internal peripheral interrupt
- Internal stack


### 5.7.2.3 Latency Calculations

Assume the use of a zero-wait-state external memory where current instructions, the ISR, and the stack are located within the same 64-Kbyte memory region (compatible with memory maps for MCS 51 microcontrollers.) Further, assume there are 3 states yet to complete in the current 21state DIV instruction when INT0\# requests service. Also assume INT0\# has made the request one state prior to the sample state (as in Figure 5-7 on page 5-12). Unlike in Figure 5-7, the response time for this assumption is three state times as the current instruction completes in time for the branch to occur. Latency calculations begin with the minimum fixed latency of 16 states. From Table 5-6, one state is added for an INT0\# request from external hardware; two states are added for external execution; and four states for an external stack in the current 64-Kbyte region. Finally, three states are added for the current instruction to complete. The actual latency is 26 states. Worst-case latency calculations predict 43 states for this example due to inclusion of total DIV instruction time (less one state).

Table 5-7. Actual vs. Predicted Latency Calculations

| Latency Factors | Actual | Predicted |
| :--- | :--- | :--- |
| Base Case Minimum Fixed Time | 16 | 16 |
| INTO\# External Request | 1 | 1 |
| External Execution | 2 | 2 |
| <64K Byte Stack Location | 4 | 4 |
| Execution Time for Current DIV Instruction | 3 | 20 |
| TOTAL | 26 | 43 |

### 5.7.2.4 Blocking Conditions

If all enable and priority requirements have been met, a single prioritized interrupt request at a time generates a vector cycle to an interrupt service routine (see CALL instructions, Appendix A, "Instruction Set Reference"). There are three causes of blocking conditions with hardware-generated vectors:

1. An interrupt of equal or higher priority level is already in progress (defined as any point after the flag has been set and the RETI of the ISR has not executed).
2. The current polling cycle is not the final cycle of the instruction in progress.
3. The instruction in progress is RETI or any write to the IE0, IPH0, or IPL0 registers.

Any of these conditions blocks calls to interrupt service routines. Condition two ensures the instruction in progress completes before the system vectors to the ISR. Condition three ensures at least one more instruction executes before the system vectors to additional interrupts if the instruction in progress is a RETI or any write to IE0, IPH0, or IPL0. The complete polling cycle is repeated each four state times.

### 5.7.2.5 Interrupt Vector Cycle

When an interrupt vector cycle is initiated, the CPU breaks the instruction stream sequence, resolves all instruction pipeline decisions, and pushes multiple program counter (PC) bytes onto the stack. The CPU then reloads the PC with a start address for the appropriate ISR. The number of bytes pushed to the stack depends upon the INTR bit in the CONFIG1 configuration register (see Figure 13-4 on page 13-8). The complete sample, poll, request and context switch vector sequence is illustrated in the interrupt latency timing diagram (see Figure 5-5 on page 5-9).

## NOTE

If the interrupt flag for a level-triggered external interrupt is set but denied for one of the above conditions and is clear when the blocking condition is removed, then the denied interrupt is ignored. In other words, blocked interrupt requests are not buffered for retention.

### 5.7.3 ISRs in Process

ISR execution proceeds until the RETI instruction is encountered. The RETI instruction informs the processor the interrupt routine is completed. The RETI instruction in the ISR pops PC address bytes off the stack (as well as PSW1 for INTR = 1), and execution resumes at the suspended instruction stream.

## NOTE

A simple RET instruction also returns execution to the interrupted program. In previous implementations this inappropriately allowed the system to operate as though an interrupt service routine is still in progress. The 8XC251SB allows use of both RETI and RET instructions for interrupt completion. However, for code expected to run properly on both MCS 51 microcontrollers and 8 XC 251 SB products, only the execution of a RETI instruction is considered proper completion of the interrupt operation.

With the exception of TRAP, the start addresses of consecutive interrupt service routines are eight bytes apart. If consecutive interrupts are used (IE0 and TF0, for example, or TF0 and IE1), the first interrupt routine (if more than seven bytes long) must execute a jump to some other memory location. This prevents overlap of the start address of the following interrupt routine.

## intel.

## Input/Output Ports

## CHAPTER 6 INPUT/OUTPUT PORTS

### 6.1 INPUT/OUTPUT PORT OVERVIEW

The 8XC251SB uses input/output (I/O) ports to exchange data with external devices. In addition to performing general-purpose I/O, some ports are capable of external memory operations (see Chapter 12, "External Memory Interface"); others allow for alternate functions. All four 8XC251SB I/O ports are bidirectional. Each port contains a latch, an output driver, and an input buffer. Port 0 and port 2 output drivers and input buffers facilitate external memory operations. Port 0 drives the lower address byte onto the parallel address bus, and port 2 drives the upper address byte ( 16 or 17 ) onto the bus. In nonpage mode, the data is multiplexed with the lower address byte on port 0 . In page mode, the data is multiplexed with the upper address byte on port 2 . All port 1 and port 3 pins serve for both general-purpose I/O and alternate functions (see Table 6-1).

Table 6-1. Input/Output Port Pin Descriptions

| Pin <br> Name | Type | Alternate <br> Pin Name | Alternate Description <br> Type |  |
| :--- | :--- | :--- | :--- | :---: |
| P0.7:0 | I/O | AD7:0 | Address/Data Lines (Nonpage Mode), Address Lines (Page Mode) | I/O |
| P1.0 | I/O | T2 | Timer 2 Clock Input/Output | I/O |
| P1.1 | I/O | T2EX | Timer 2 External Input | I |
| P1.2 | I/O | ECl | PCA External Clock Input | I |
| P1.3 | I/O | CEX0 | PCA Module 0 I/O | I/O |
| P1.4 | I/O | CEX1 | PCA Module 1 I/O | I/O |
| P1.5 | I/O | CEX2 | PCA Module 2 I/O | I/O |
| P1.6 | I/O | CEX3 | PCA Module 3 I/O | I/O |
| P1.7 | I/O | CEX4 | PCA Module 4 I/O | I/O |
| P2.7:0 | I/O | A15:8 | Address Lines (Nonpage Mode), Address/Data Lines (Page Mode) | I/O |
| P3.0 | I/O | RXD | Serial Port Receive Data Input | (I/O) |
| P3.1 | I/O | TXD | Serial Port Transmit Data Output | O (O) |
| P3.2 | I/O | INTO\# | External Interrupt 0 | 1 |
| P3.3 | I/O | INT1\# | External Interrupt 1 | I |
| P3.4 | I/O | T0 | Timer 0 Input | 1 |
| P3.5 | I/O | T1 | Timer 1 Input | I |
| P3.6 | I/O | WR\# | Write Signal to External Memory | O |
| P3.7 | I/O | RD\#/A16 | Read Signal to External Memory or 17th Address Bit | O |

### 6.2 I/O CONFIGURATIONS

Each port SFR operates via type-D latches, as illustrated in Figure 6-1 for ports 1 and 3. A CPU "write to latch" signal initiates transfer of internal bus data into the type-D latch. A CPU "read latch" signal transfers the latched Q output onto the internal bus. Similarly, a "read pin" signal transfers the logical level of the port pin. Some port data instructions activate the "read latch" signal while others activate the "read pin" signal. Latch instructions are referred to as read-modifywrite instructions (see "Read-Modify-Write Instructions" on page 6-5). Each I/O line may be independently programmed as input or output.

### 6.3 PORT 1 AND PORT 3

Figure 6-1 shows the structure of ports 1 and 3, which have internal pullups. An external source can pull the pin low. Each port pin can be configured either for general-purpose I/O or for its alternate input or output function (Table 6-1).

To use a pin for general-purpose output, set or clear the corresponding bit in the $\mathrm{P} x$ register ( $x=$ 1,3 ). To use a pin for general-purpose input, set the bit in the $\mathrm{P} x$ register. This turns off the output driver FET.

To configure a pin for its alternate function, set the bit in the $\mathrm{P} x$ register. When the latch is set, the "alternate output function" signal controls the output level (Figure 6-1). The operation of ports 1 and 3 is discussed further in "Quasi-bidirectional Port Operation" on page 6-5.

### 6.4 PORT 0 AND PORT 2

Ports 0 and 2 are used for general-purpose I/O or as the external address/data bus. Port 0 , shown in Figure 6-2, differs from the other ports in not having internal pullups. Figure 6-3 on page 6-4 shows the structure of port 2 . An external source can pull a port 2 pin low.

To use a pin for general-purpose output, set or clear the corresponding bit in the Px register ( $x=$ 0,2 ). To use a pin for general-purpose input set the bit in the Px register to turn off-the output driver FET.


Figure 6-1. Port 1 and Port 3 Structure


Figure 6-2. Port 0 Structure


Figure 6-3. Port 2 Structure
When port 0 and port 2 are used for an external memory cycle, an internal control signal switches the output-driver input from the latch output to the internal address/data line. "External Memory Access" on page 6-7 discusses the operation of port 0 and port 2 as the external address/data bus.

## NOTE

Port 0 and port 2 are precluded from use as general purpose I/O ports when used as address/data bus drivers.

Port 0 internal pullups assist the logic-one output for memory bus cycles only. Except for these bus cycles, the pullup FET is off. All other port 0 outputs are open drain.

### 6.5 READ-MODIFY-WRITE INSTRUCTIONS

Some instructions read the latch data rather than the pin data. The latch based instructions read the data, modify the data, and then rewrite the latch. These are called "read-modify-write" instructions. Below is a complete list of these special 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 P3, A)
JBC (jump if bit = 1 and clear bit, e.g., JBC P1.1, LABEL)
CPL (complement bit, e.g., CPL P3.0)
INC (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 port X)
CLR PX.Y (clear bit Y of port X)
SETB PX.Y (set bit Y of port x)
```

It is not obvious the last three instructions in this list are read-modify-write instructions. These instructions read the port (all 8 bits), modify the specifically addressed bit, and write the new byte back to the latch. These read-modify-write instructions are directed to the latch rather than the pin in order to avoid possible misinterpretation of voltage (and therefore, logic) levels at the pin. For example, a port bit used to drive the base of an external transistor appears to provide incorrect information. When logic one is written to the bit, the external base-emitter transistor junction saturates. Due to Kirchoff's Law of Series Circuits and the characteristics of transistor base-emitter saturation, the voltage measurement on the transistor base is low (below $\mathrm{V}_{\mathrm{IL}}$ ). If the CPU attempts to read the port at the pin, the base voltage of the external transistor is incorrectly interpreted as logic zero. A read of the latch rather than the pin returns the correct logic-one value.

### 6.6 QUASI-BIDIRECTIONAL PORT OPERATION

Port 1, port 2, and port 3 have fixed internal pullups and are referred to as "quasi-bidirectional" ports. When configured as an input, the pin impedance appears as logic one and sources current (see 8 XC 251 SB datasheet) in response to an external logic-zero condition. Port 0 is a "true bidirectional" pin. The pin floats when configured as input. Resets write logical one to all port latches. If logical zero is subsequently written to a port latch, it can be returned to input conditions by a logical one written to the latch. For additional electrical information, refer to the current 8XC251SB datasheet.

## NOTE

Port latch values change near the end of read-modify-write instruction cycles. Output buffers (and therefore the pin state) update early in the instruction after the read-modify-write instruction cycle.

Logical zero-to-one transitions in port 1, port 2, and port 3 utilize an additional pullup to aid this logic transition (see Figure 6-4). This increases switch speed. The extra pullup briefly sources 100 times normal internal circuit current. The internal pullups are field-effect transistors rather than linear resistors. Pullups consist of three p-channel FET (pFET) devices. A pFET is on when the gate senses logical zero and off when the gate senses logical one. pFET \#1 is turned on for two oscillator periods immediately after a zero-to-one transition in the port latch. A logic one at the port pin turns on pFET \#3 (a weak pullup) through the inverter. This inverter and pFET pair form a latch to drive logic one. pFET \#2 is a very weak pullup switched on whenever the associated nFET is switched off. This is traditional CMOS switch convention. Current strengths are $1 / 10$ that of pFET \#3.


Figure 6-4. Internal Pullup Configurations

### 6.7 PORT LOADING

Output buffers of port 1, port 2, and port 3 can each sink 1.6 mA at logic zero (see $\mathrm{V}_{\mathrm{OL}}$ specifications in the 8 XC 251 SB data sheet). These port pins can be driven by open-collector and opendrain devices. Logic zero-to-one transitions occur slowly as limited current pulls the pin to a log-ic-one condition (Figure 6-4 on page 6-6). A logic-zero input turns off pFET \#3. This leaves only $\mathrm{pFET} \# 2$ weakly in support of the transition. In external bus mode, port 0 output buffers each sink 3.2 mA at logic zero (see $\mathrm{V}_{\mathrm{OL} 1}$ in the 8 XC 251 SB data sheet). However, the port 0 pins require external pullups to drive external gate inputs. See the latest revision of the 8XC251SB datasheet for complete electrical design information. External circuits must be designed to limit current requirements to these conditions.

### 6.8 EXTERNAL MEMORY ACCESS

The external bus structure is different for page mode and nonpage mode. In nonpage mode (used by MCS 51 microcontrollers), port 2 outputs the upper address byte; the lower address byte and the data are multiplexed on port 0 . In page mode, the upper address byte and the data are multiplexed on port 2 , while port 0 outputs the lower address byte.

The 8XC251SB CPU writes FFH to the P0 register for all external memory bus cycles. This overwrites previous information in P0. In contrast, the P2 register is unmodified for external bus cycles. When address bits or data bits are not on the port 2 pins, the bit values in P2 appear on the port 2 pins.

In nonpage mode, port 0 uses a strong internal pullup FET to output ones or a strong internal pulldown FET to output zeros for the lower address byte and the data. Port 0 is in a high-impedance state for data input. In page mode, port 0 uses a strong internal pullup FET to output ones or a strong internal pulldown FET to output zeros for the lower address byte or a strong internal pulldown FET to output zeros for the upper address byte.

In nonpage mode, port 2 uses a strong internal pullup FET to output ones or a strong internal pulldown FET to output zeros for the upper address byte. In page mode, port 2 uses a strong internal pullup FET to output ones or a strong internal pulldown FET to output zeros for the upper address byte and data. Port 2 is in a high-impedance state for data input.

## NOTE

In external bus mode port 0 outputs do not require external pullups.

There are two types of external memory accesses: external program memory and external data memory (see Chapter 12, "External Memory Interface"). External program memories utilize signal PSEN\# as a read strobe. MCS 51 microcontrollers use RD\# (read) or WR\# (write) to strobe memory for data accesses. Depending on its RD1:0 configuration bits, the 8XC251SB uses PSEN\# or RD\# for data reads ("RD\#, PSEN\#, and the Number of External Address Pins (Bits RD1:0)" on page 12-3).

During instruction fetches, external program memory can transfer instructions with 16 -bit addresses for binary-compatible code or with 17 -bit addresses for extended memory operations.

External data memory transfers use an 8-, 16-, or 17-bit address bus, depending on the instruction. Table 6-2 lists the instructions that can be used for the three bus widths.

Table 6-2. Instructions for External Data Moves

| Bus Width | Instructions |
| :---: | :--- |
| 8 | MOVX @ Ri; MOV @ Rm; MOV dir8 |
| 16 | MOVX @ DPTR; MOV @ WRj; MOV @ WRj+dis; MOV dir16 |
| 17 | MOV @DRk; MOV @DRk+dis |

## NOTE

Avoid MOV P0 instructions for external memory accesses. These instructions can corrupt input code bytes at port 0 .

External signal ALE (address latch enable) facilitates external address latch capture. The address byte is valid after the ALE pin drives $\mathrm{V}_{\mathrm{OL}}$. For write cycles, valid data is written to port 0 just prior to the write (WR\#) pin asserting $\mathrm{V}_{\mathrm{oL}}$. Data remains valid until WR\# is undriven. For read cycles, data returned from external memory must appear at port 0 before the read (RD\#) pin is undriven (refer to the 8XC251SB datasheet for exact specifications). Wait states, by definition, affect bustiming.

7

# Timer/Counters and Watchdog Timer 

## CHAPTER 7

 TIMER/COUNTERS AND WATCHDOG TIMERThis chapter describes the timer/counters and the watchdog timer (WDT) included as peripherals on the 8 XC 251 SB . When operating as a timer, a timer/counter runs for a programmed length of time, then issues an interrupt request. When operating as a counter, a timer/counter counts negative transitions on an external pin. After a preset number of counts, the counter issues an interrupt request. Timer/counters are covered in sections 7.1 through 7.6.

The watch dog timer provides a way to monitor system operation. It causes a system reset if a software malfunction allows it to expire. The watchdog timer is covered in "Watchdog Timer" on page 7-16.

### 7.1 TIMER/COUNTER OVERVIEW

The 8XC251SB contains three general-purpose, 16-bit timer/counters. Although they are identified as timer 0 , timer 1 , and timer 2 , you can independently configure each to operate in a variety of modes as a timer or as an event counter. Each timer employs two 8-bit timer registers, used separately or in cascade, to maintain the count. The timer registers and associated control and capture registers are implemented as addressable special function registers (SFRs). Table 7-1 briefly describes the SFRs referred to in this chapter. Four of the SFRs provide programmable control of the timers as follows:

- Timer/counter mode control register (TMOD) and timer/counter control register (TCON) control timer 0 and timer 1.
- Timer/counter 2 mode control register (T2MOD) and timer/counter 2 control register (T2CON) control timer 2

For a map of the SFR address space, see Table 3-4 on page 3-13. Table 7-2 describes the external signals referred to in this chapter.

### 7.2 TIMER/COUNTER OPERATION

The block diagram in Figure 7-1 depicts the basic logic of the timers. Here timer registers THx and $\operatorname{TL} x(x=0,1$, and 2 ) connect in cascade to form a 16 -bit timer. Setting the run control bit (TRx) turns the timer on by allowing the selected input to increment TLx. When TLx overflows it increments TH $x$; when TH $x$ overflows it sets the timer overflow flag (TFx) in the TCON or T2CON register. Setting the run control bit does not clear the TH $x$ and TL $x$ timer registers. The timer registers can be accessed to obtain the current count or to enter preset values. Timer 0 and timer 1 can also be controlled by external pin INTx\# to facilitate pulse width measurements.

Table 7-1. Timer/Counter and Watchdog Timer SFRs

| Mnemonic | Description | Address |
| :--- | :--- | :--- |
| TLO <br> THO | Timer 0 Timer Registers. Used separately as 8-bit counters or in cascade <br> as a 16-bit counter. Counts an internal clock signal with frequency Fosc/12 <br> (timer operation) or an external input (event counter operation) | S:8AH <br> S:8CH |
| TL1 <br> TH1 | Timer 1 Timer Registers. Used separately as 8-bit counters or in cascade <br> as a 16-bit counter. Counts an internal clock signal with frequency Foscd <br> (timer operation) or an external input (event counter operation) | S:8BH <br> S:8DH |
| TL2 <br> TH2 | Timer 2 Timer Registers. TL2 and TH2 connect in cascade to provide a <br> 16-bit counter. Counts an internal clock signal with frequency Fosc/12 <br> (timer operation) or an external input (event counter operation) | S:CCH <br> S:CDH |
| TCON | Timer 0/1 Control Register. Contains the run control bits, overflow flags, <br> interrupt flags, and interrupt-type control bits for timer 0 and timer 1. | S:88H |
| TMOD | Timer 0/1 Mode Control Register. Contains the mode select bits, <br> counter/timer select bits, and external control gate bits for timer 0 and <br> timer 1. | S:89H |
| T2CON | Timer 2 Control Register. Contains the receive clock, transmit clock, and <br> capture/reload bits used to configure timer 2. Also contains the run control <br> bit, tounter/timer select bit, overflow flag, external flag, and external enable <br> for timer 2. | S:C8H |
| T2MOD | Timer 2 Mode Control Register. Contains the timer 2 output enable and <br> down count enable bits. | S:C9H |
| RCAP2L | Timer 2 Reload/Capture Registers (RCAP2L, RCAP2H). Provide values <br> to and receive values from the timer registers (TL2,TH2.) | S:CAH <br> S:CBH |
| WDAP2H | Watchdog Timer Reset Register (WDTRST). Used to reset and enable <br> the WDT. | S:A6H |



Figure 7-1. Basic Logic of the Timer/Counters

The C\Tx\# control bit selects timer operation or counter operation by selecting the divided-down system clock or external pin $\mathrm{T} x$ as the source for the counted signal.

For timer operation $(\mathrm{C} / \mathrm{T} x \#=0)$, the timer register counts the divided-down system clock. The timer register is incremented once every peripheral cycle, i.e. once every six states (see "Clock and Reset Unit" on page 2-5). Since six states equals 12 clock cycles, the timer clock rate is $\mathrm{F}_{\mathrm{osc}} / 12$. Exceptions are the timer 2 baud rate and clock-out modes, where the timer register is incremented by the system clock divided by two.

For counter operation $(\mathrm{C} / \mathrm{T} x \#=1)$, the timer register counts the negative transitions on the $\mathrm{T} x$ external input pin. The external input is sampled during every S5P2 state. ("Clock and Reset Unit" on page 2-5 describes the notation for the states in a peripheral cycle.) When the sample is high in one cycle and low in the next, the counter is incremented. The new count value appears in the register during the next S3P1 state after the transition was detected. Since it takes 12 states ( 24 oscillator periods) to recognize a negative 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 peripheral cycle.

Table 7-2. External Signals

| Signal <br> Name | Type | Description | Multiplexed <br> With |
| :--- | :---: | :--- | :--- |
| T2 | I/O | Timer 2 Clock Input/Output. This signal is the external clock input <br> for the timer 2 capture mode; and it is the timer 2 clock-output for the <br> clock-out mode. | P1.0 |
| T2EX | I | Timer 2 External Input. In timer 2 capture mode, a falling edge <br> initiates a capture of the timer 2 registers. In auto-reload mode, a <br> falling edge causes the timer 2 registers to be reloaded. In the up- <br> down counter mode, this signal determines the count direction: <br> high = up, low = down. | P1.1 |
| INT1:0\# | I | External Interrupts 1:0. These inputs set the IE1:0 interrupt flags in <br> the TCON register. TCON bits IT1:0 select the triggering method: <br> IT1:0 = 1 selects edge-triggered (high-to-low); <br> IT1:0 = o selects level-triggered (active low). <br> INT1:0\# also serves as extenal run control for timer 1:0, when <br> selected by TCON bits GATE1:0\#. | P3.3:2 |
| T1:0 | I | Timer 1:0 External Clock Inputs. When timer 1:0 operates as a <br> counter, a falling edge on the T1:0 pin increments the count. | P3.5:4 |

### 7.3 TIMER 0

Timer 0 functions as either a timer or event counter in four modes of operation. Figures 7-2, 7.3.4, and 7-3 show the logical configuration of each mode.

Timer 0 is controlled by the four low-order bits of the TMOD register (Figure 7-4) and bits 5, 4, 1 , and 0 of the TCON register (Figure 7-5). The TMOD register selects the method of timer gating (GATE0), timer or counter operation (T/C0\#), and mode of operation (M10 and M00). The TCON register provides timer 0 control functions: overflow flag (TF0), run control (TR0), interrupt flag (IE0), and interrupt type control (IT0).

For normal timer operation (GATE $0=0$ ), setting TR0 allows TL0 to be incremented by the selected input. Setting GATE0 and TR0 allows external pin INT0\# to control timer operation. This setup can be used to make pulse width measurements. See "Pulse Width Measurements" on page 7-10.

Timer 0 overflow (count rolls over from all 1s to all 0 s) sets the TF0 flag generating an interrupt request.

### 7.3.1 Mode 0 (13-bit Timer)

Mode 0 configures timer 0 as an 13-bit timer which is set up as an 8-bit timer (TH0 register) with a modulo 32 prescaler implemented with the lower five bits of the TL0 register (Figure 7-2). The upper three bits of the TL0 register are ignored. Prescaler overflow increments the TH0 register.


Figure 7-2. Timer 0/1 in Mode 0 and Mode 1

### 7.3.2 Mode 1 (16-bit Timer)

Mode 1 configures timer 0 as a 16-bit timer with TH0 and TLO connected in cascade (Figure 7-2). The selected input increments TLO.

### 7.3.3 Mode 2 (8-bit Timer With Auto-reload)

Mode 2 configures timer 0 as an 8-bit timer (TL0 register) that automatically reloads from the TH0 register (Figure 7.3.4). TL0 overflow sets the timer overflow flag (TF0) in the TCON register and reloads TL0 with the contents of TH0, which is preset by software. When the interrupt request is serviced, hardware clears TF0. The reload leaves TH0 unchanged. See "Auto-load Setup Example" on page 7-9


Figure 7-3. Timer 0/1 in Mode 2, Auto-Reload

### 7.3.4 Mode 3 (Two 8-bit Timers)

Mode 3 configures timer 0 such that registers TL0 and TH0 operate as separate 8-bit timers (Figure 7-3). This mode is provided for applications requiring an additional 8 -bit timer or counter. TLO uses the timer 0 control bits C/T0\# and GATE0 in TMOD, and TR0 and TF0 in TCON in the normal manner. TH0 is locked into a timer function (counting $\mathrm{F}_{\mathrm{OSC}} / 12$ ) and takes over use of the timer 1 interrupt (TF1) and run control (TR1) bits. Thus, operation of timer 1 is restricted when timer 0 is in mode 3. See "Timer 1" on page 7-6 and "Mode 3 (Halt)" on page 7-9.

### 7.4 TIMER 1

Timer 1 functions as either a timer or event counter in three modes of operation. Figures 7-2 and 7.3.4 show the logical configuration for modes 0,1 , and 2 . Timer 1 's mode 3 is a hold count mode.

Timer 1 is controlled by the four high-order bits of the TMOD register (Figure 7-4) and bits 7, 6, 3, and 2 of the TCON register (Figure 7-5). The TMOD register selects the method of timer gating (GATE1), timer or counter operation (T/C1\#), and mode of operation (M11 and M01). The TCON register provides timer 1 control functions: overflow flag (TF1), run control (TR1), interrupt flag (IE1), and interrupt type control (IT1).

Timer 1 operation in modes 0,1 , and 2 is identical to timer 0 . Timer 1 can serve as the baud rate generator for the serial port. Mode 2 is best suited for this purpose.

For normal timer operation (GATE1 $=0$ ), setting TR1 allows timer register TL1 to be incremented by the selected input. Setting GATE1 and TR1 allows external pin INT1\# to control timer operation. This setup can be used to make pulse width measurements. See "Pulse Width Measurements" on page 7-10.

Timer 1 overflow (count rolls over from all 1 s to all 0 s) sets the TF1 flag generating an interrupt request.


Figure 7-3. Timer 0 in Mode 3, Two 8-bit Timers

|  |  |  |  |  | Address: Reset State: |  | $\begin{array}{r} \mathrm{S}: 89 \mathrm{H} \\ 0000 \text { 0000B } \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 |  |  |  |  |  |  |  |
| GATE1 | C/T1\# | M11 | M01 | GATE0 | С/т0\# | M10 | M00 |
| Bit Number | Bit Mnemonic | Function |  |  |  |  |  |
| 7 | GATE1 | Timer 1 Gate: <br> When GATE1 $=0$, run control bit TR1 gates the input signal to the timer register. When GATE1 = 1 and TR1 = 1, external signal INT1 gates the timer input. |  |  |  |  |  |
| 6 | C/T1\# | Timer 1 Counter/Timer Select: <br> C/T1\# = 0 selects timer operation: timer 1 counts the divided-down system clock. C/T1\# = 1 selects counter operation: timer 1 counts negative transitions on external pin T1. |  |  |  |  |  |
| 5, 4 | M11, M01 | Timer 1 Mode Select:   <br> M11 M01   <br> 0 0 Mode 0: <br> 8-bit timer/counter (TH1) with 5-bit prescaler (TL1)   <br> 0 1 Mode 1: <br> 1 16-bit timer/counter  <br> 1 0 Mode 2: <br> 8-bit auto-reload timer/counter (TL1). Reloaded   <br> 1 1 Mode 3: <br> from TH1 Timer 1 1 halted. Retains count.   |  |  |  |  |  |
| 3 | GATEO | Timer 0 Gate: <br> When GATE0 $=0$, run control bit TR0 gates the input signal to the timer register. When GATEO $=1$ and TRO $=1$, external signal INT0 gates the timer input. |  |  |  |  |  |
| 2 | C/TO\# | Timer 0 Counter/Timer Select: <br> C/TO\# $=0$ selects timer operation: timer 0 counts the divided-down system clock. C/TO\# $=1$ selects counter operation: timer 0 counts negative transitions on external pin TO. |  |  |  |  |  |
| 1, 0 | M10, M00 | Timer 0 Mode Select:    <br> M10 M00    <br> 0 0 Mode 0: 8 -bit timer/counter (TH0) with 5-bit prescaler (TLO) <br> 0 1 Mode 1: 1-bit timer/counter <br> 1 0 Mode 2: 8 -bit auto-reload timer/counter (TLO). Reloaded <br> from TH0 at overflow    <br> 1 1 Mode 3: TLO is 8-bit timer/counter. TH0 is 8-bit timer only <br> using timer 1 TR1 and TF1 bits. |  |  |  |  |  |

Figure 7-4. TMOD: Timer/Counter Mode Control Register


Figure 7-5. TCON: Timer/Counter Control Register

When timer 0 is in mode 3, it uses timer 1's overflow flag (TF1) and run control bit (TR1). For this situation, use timer 1 only for applications that do not require an interrupt (such as a baud rate generator for the serial interface port) and switch timer 1 in and out of mode 3 to turn it off and on.

### 7.4.1 Mode 0 (13-bit Timer)

Mode 0 configures timer 0 as a 13-bit timer, which is set up as an 8-bit timer (TH1 register) with a modulo-32 prescaler implemented with the lower 5 bits of the TL1 register (Figure 7-2). The upper 3 bits of the TL1 register are ignored. Prescaler overflow increments the TH1 register.

### 7.4.2 Mode 1 (16-bit Timer)

Mode 1 configures timer 1 as a 16-bit timer with TH1 and TL1 connected in cascade (Figure 7-2). The selected input increments TL1.

### 7.4.3 Mode 2 (8-bit Timer with Auto-reload)

Mode 2 configures timer 1 as an 8-bit timer (TL1 register) with automatic reload from the TH1 register on overflow (Figure 7.3.4). Overflow from TL1 sets overflow flag TF1 in the TCON register and reloads TL1 with the contents of TH1, which is preset by software. The reload leaves TH1 unchanged. See "Auto-load Setup Example" on page 7-9

### 7.4.4 Mode 3 (Halt)

Placing timer 1 in mode 3 causes it to halt and hold its count. This can be used to halt timer 1 when the TR1 run control bit is not available, i.e. when timer 0 is in mode 3 . See the final paragraph of "Timer 1" on page 7-6.

### 7.5 TIMER 0/1 APPLICATIONS

Timer 0 and timer 1 are general purpose timers that can be used in a variety of ways. The timer applications presented in this section are intended to demonstrate timer setup, and do not represent the only arrangement nor necessarily the best arrangement for a given task. These examples employ timer 0 , but timer 1 can be set up in the same manner using the appropriate registers.

### 7.5.1 Auto-Ioad Setup Example

Timer 0 can be configured as an eight-bit timer (TL0) with automatic reload as follows:

1. Program the four low-order bits of the TMOD register (Figure 7-4) to specify: mode 2 for timer $0, \mathrm{C} / \mathrm{T} 0 \#=0$ to select $\mathrm{F}_{\mathrm{oSC}} / 12$ as the timer input, and GATE0 $=0$ to select TR0 as the timer run control.
2. Enter an eight-bit initial value $\left(\mathrm{n}_{0}\right)$ in timer register TL0, so that the timer overflows after the desired number of peripheral cycles.
3. Enter an eight-bit reload value $\left(\mathrm{n}_{\mathrm{R}}\right)$ in register TH0. This can be the same as $\mathrm{n}_{0}$ or different, depending on the application.
4. Set the TR0 bit in the TCON register (Figure 7-5) to start the timer. Timer overflow occurs after $\mathrm{FFH}+1-\mathrm{n}_{0}$ peripheral cycles, setting the TF0 flag and loading $\mathrm{n}_{\mathrm{R}}$ into TL0 from TH0. When the interrupt is serviced, hardware clears TF0.
5. The timer continues to overflow and generate interrupt requests every $\mathrm{FFH}+1-\mathrm{n}_{\mathrm{R}}$ peripheral cycles.
6. To halt the timer, clear the TR0 bit.

### 7.5.2 Pulse Width Measurements

For timer 0 and timer 1, setting GATE $x$ and TR $x$ allows an external waveform at pin INT $x \#$ to turn the timer on and off. This setup can be used to measure the width of a positive-going pulse present at pin INTx\#. Pulse width measurements using timer 0 in mode 1 can be made as follows:

1. Program the four low-order bits of the TMOD register (Figure 7-4) to specify: mode 1 for timer $0, \mathrm{C} / \mathrm{T} 0 \#=0$ to select $\mathrm{F}_{\mathrm{OSC}} / 12$ as the timer input, and GATE $0=1$ to select INT0 as timer run control.
2. Enter an initial value of all zeros in the 16-bit timer register TH0/TL0, or read and store the current contents of the register.
3. Set the TR0 bit in the TCON register (Figure 7-5) to enable INT0.
4. Apply the pulse to be measured to pin INT0. The timer runs when the waveform is high.
5. Clear the TR0 bit to disable INT0.
6. Read timer register TH0/TL0 to obtain the new value.
7. Calculate pulse width $=12 \mathrm{~T}_{\mathrm{OSC}} \times$ (new value - initial value).
8. Example: $\mathrm{F}_{\mathrm{OSC}}=16 \mathrm{MHz}$ and $12 \mathrm{~T}_{\mathrm{OSC}}=750 \mathrm{~ns}$. If the new value $=10,000_{10}$ and the initial value $=0$, the pulse width $=750 \mathrm{~ns} \times 10,000=7.5 \mathrm{~ms}$.

### 7.6 TIMER 2

Timer 2 is a 16-bit timer/counter. The count is maintained by two eight-bit timer registers, TH2 and TL2, connected in cascade. The timer/counter 2 mode control register (T2MOD) (Figure $7-10$ on page $7-16$ ) and the timer/counter 2 control register (T2CON) (Figure 7-11 on page 7-17) control the operation of timer 2.

Timer 2 provides the following operating modes: capture mode, auto-reload mode, baud rate generator mode, and programmable clock-out mode. Select the operating mode with T2MOD and TCON register bits as shown in Table 7-3 on page 7-15. Auto-reload is the default mode. Setting RCLK and/or TCLK selects the baud rate generator mode.

Timer 2 operation is similar to timer 0 and timer 1 . C/T2\# selects $\mathrm{F}_{\text {osc }} / 12$ (timer operation) or external pin T2 (counter operation) as the timer register input. Setting TF2 allows TL2 to be incremented by the selected input.

The operating modes are described in the following paragraphs. Block diagrams in Figure 7-6 through Figure $7-9$ show the timer 2 configuration for each mode.

### 7.6.1 Capture Mode

In the capture mode, timer 2 functions as a 16-bit timer or counter (Figure 7-6). An overflow condition sets bit TF2, which you can use to request an interrupt. Setting the external enable bit EXEN2 allows the RCAP2H and RCAP2L registers to capture the current value in timer registers TH2 and TL2 in response to a 1-to-0 transition at external input T2EX. The transition at T2EX also sets bit EXF2 in T2CON. The EXF2 bit, like TF2, can generate an interrupt.


Figure 7-6. Timer 2: Capture Mode

### 7.6.2 Auto-reload Mode

The auto-reload mode configures timer 2 as a 16-bit timer or event counter with automatic reload. The timer operates an as an up counter or as an up/down counter, as determined by the down counter enable bit (DCEN). At device reset, DCEN is cleared, so in the auto-reload mode, timer 2 defaults to operation as an up counter.

### 7.6.2.1 Up Counter Operation

When DCEN $=0$, timer 2 operates as an up counter (Figure 7-7). The external enable bit EXEN2 in the T2CON register provides two options (Figure 7-11). If EXEN2 $=0$, timer 2 counts up to FFFFH and sets the TF2 overflow flag. The overflow condition loads the 16-bit value in the reload/capture registers (RCAP2H, RCAP2L) into the timer registers (TH2, TL2). The values in RCAP2H and RCAP2L are preset by software.

If $\operatorname{EXEN} 2=1$, the timer registers are reloaded by either a timer overflow or a high-to- low transition at external input T2EX. This transition also sets the EXF2 bit in the T2CON register. Either TF2 or EXF2 bit can generate a timer 2 interrupt request.


Figure 7-7. Timer 2: Auto Reload Mode (DCEN = 0)

TIMER/COUNTERS AND WATCHDOG TIMER

### 7.6.2.2 Up/Down Counter Operation

When DCEN $=1$, timer 2 operates as an up/down counter (Figure 7-8). External pin T2EX controls the direction of the count (Table 7-2 on page 7-3). When T2EX is high, timer 2 counts up. The timer overflow occurs at FFFFH which sets the timer 2 overflow flag (TF2) and generates an interrupt request. The overflow also causes the 16-bit value in RCAP2H and RCAP2L to be loaded into the timer registers TH2 and TL2.

When T2EX is low, timer 2 counts down. Timer underflow occurs when the count in the timer registers (TH2, TL2) equals the value stored in RCAP2H and RCAP2L. The underflow sets the TF2 bit and reloads FFFFH into the timer registers.

The EXF2 bit toggles when timer 2 overflows or underflows changing the direction of the count. When timer 2 operates as an up/down counter, EXF2 does not generate an interrupt. This bit can be used to provide 17-bit resolution.


Figure 7-8. Timer 2: Auto Reload Mode (DCEN = 1)

### 7.6.3 Baud Rate Generator Mode

This mode configures timer 2 as a baud rate generator for use with the serial port. Select this mode by setting the RCLK and/or TCLK bits in T2CON. See Table 7-3 on page 7-15. For details regarding this mode of operation, refer to "Baud Rates" on page 9-10.

### 7.6.4 Clock-out Mode

In the clock-out mode, timer 2 functions as a $50 \%$-duty-cycle, variable-frequency clock (Figure $7-9$ ). The input clock increments TL0 at frequency $\mathrm{F}_{\mathrm{OSC}} / 2$. The timer repeatedly counts to overflow from a preloaded value. At overflow, the contents of the RCAP2H and RCAP2L registers are loaded into TH2/TL2. In this mode, timer 2 overflows do not generate interrupts. The formula gives the clock-out frequency as a function of the system oscillator frequency and the value in the RCAP2H and RCAP2L registers:

$$
\text { Clock-out Frequency }=\frac{\mathrm{F}_{\text {OSC }}}{4 \times(65535-\text { RCAP2H, RCAP2L })}
$$

For a 16 MHz system clock, timer 2 has a programmable frequency range of 61 Hz to 4 MHz . The generated clock signal is brought out to the T2 pin.

Timer 2 is programmed for the clock-out mode as follows:

1. Set the T2OE bit in T2MOD. This gates the timer register overflow to the $\div 2$ counter.
2. Clear the $\mathrm{C} / \mathrm{T} 2 \#$ bit in T 2 CON to select $\mathrm{F}_{\mathrm{oSc}} / 2$ as the timer input signal. This also gates the output of the $\div 2$ counter to pin T 2 .
3. Determine the 16 -bit reload value from formula and enter in the RCAP2H/RCAP2L registers.
4. Enter a 16 -bit initial value in timer register TH2/TL2. This can be the same as the reload value or different depending on the application.
5. To start the timer, set the TR2 run control bit in T2CON.

Operation is similar to timer 2 operation as a baud rate generator. It is possible to use timer 2 as a baud rate generator and a clock generator simultaneously. For this configuration, the baud rates and clock frequencies are not independent since both functions use the values in the RCAP2H and RCAP2L registers.


Figure 7-9. Timer 2: Clock Out Mode

Table 7-3. Timer 2 Modes of Operation

| Mode | RCLK OR TCLK <br> (in T2CON) | CP/RL2\# <br> (in T2CON) | T2OE <br> (in T2MOD) |
| :--- | :---: | :---: | :---: |
| Auto-reload Mode | 0 | 0 | 0 |
| Capture Mode | 0 | 1 | 0 |
| Baud Rate Generator Mode | 1 | X | X |
| Programmable Clock-Out | X | 0 | 1 |


| T2MOD |  |  |  |  |  | Address:Reset State: $\quad$ SXXX XX00B |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 |  |  |  |  |  |  |  |
| - | - | - | - | - | - | T2OE | DCEN |
| Bit Number | Bit Mnemonic | Function |  |  |  |  |  |
| 7:2 | - | Reserved: <br> The values read from these bits are indeterminate. Do not write a " 1 " to these bits. |  |  |  |  |  |
| 1 | T20E | Timer 2 Output Enable Bit: <br> In the timer 2 clock-out mode, connects the programmable clock output to external pin T2. |  |  |  |  |  |
| 0 | DCEN | Down Count Enable Bit: <br> Configures timer 2 as an up/down counter. |  |  |  |  |  |

Figure 7-10. T2MOD: Timer 2 Mode Control Register

### 7.7 WATCHDOG TIMER

The peripheral section of the 8 XC 251 SB contains a dedicated, hardware watchdog timer (WDT) that automatically resets the chip if it is allowed to time out. The WDT provides a means of recovering from routines that do not complete successfully due to software malfunctions. The WDT described in this section is not associated with the PCA watchdog timer, which is implemented in software.

### 7.7.1 Description

The WDT is a 14-bit counter that counts peripheral cycles, i.e. the system clock divided by twelve ( $\mathrm{F}_{\text {osc }} 112$ ). The WDTRST special function register at address $\mathrm{S}: \mathrm{A} 6 \mathrm{H}$ provides control access to the WDT. Two operations control the WDT:

- Device reset clears and disables the WDT (see "Reset" on page 10-5).
- Writing a specific two-byte sequence to the WDTRST register clears and enables the WDT.

If it is not cleared, the WDT overflows on count $3 \mathrm{FFFH}+1$. With $\mathrm{F}_{\mathrm{OSC}}=16 \mathrm{MHz}$, a peripheral cycle is 750 ns and the WDT overflows in $750 \times 16384=12.288 \mathrm{~ms}$. The WDTRST is a writeonly register. Attempts to read it return FFH. The WDT itself is not read or write accessible. The WDT does not drive the external RESET pin.

TIMER/COUNTERS AND WATCHDOG TIMER

| T2CON |  |  |  |  | Address: Reset State: |  | $\begin{gathered} \mathrm{S}: \mathrm{CBH} \\ 0000 \text { 0000B } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 0 0 |  |  |  |  |  |  |  |
| TF2 | EXF2 | RCLK | TCLK | EXEN2 | TR2 | C/T2\# | CP/RL2\# |
| $\begin{gathered} \text { Bit } \\ \text { Number } \end{gathered}$ | Bit Mnemonic | Function |  |  |  |  |  |
| 7 | TF2 | Timer 2 Overflow Flag: <br> Set by timer 2 overflow. Must be cleared by software. TF2 is not set if RCLK = 1 or TCLK = 1 . |  |  |  |  |  |
| 6 | EXF2 | Timer 2 External Flag: <br> If EXEN2 $=1$, capture or reload caused by a negative transition on T2EX sets EFX2. EXF2 does not cause an interrupt in up/down counter mode $(\mathrm{DCEN}=1)$ |  |  |  |  |  |
| 5 | RCLK | Receive Clock Bit: <br> Selects timer 2 overflow pulses (RCLK = 1) or timer 1 overflow pulses ( $\mathrm{RCLK}=0$ ) as the baud rate generator for serial port modes 1 and 3 . |  |  |  |  |  |
| 4 | TCLK | Transmit Clock Bit: <br> Selects timer 2 overflow pulses (TCLK = 1) or timer 1 overflow pulses (TCLK $=0$ ) as the baud rate generator for serial port modes 1 and 3. |  |  |  |  |  |
| 3 | EXEN2 | Timer 2 External Enable Bit: <br> Setting EXEN2 causes a capture or reload to occur as a result of a negative transition on T2EX unless timer 2 is being used as the baud rate generator for the serial port. Clearing EXEN2 causes timer 2 to ignore events at T2EX. |  |  |  |  |  |
| 2 | TR2 | Timer 2 Run Control Bit: Setting this bit starts the timer. |  |  |  |  |  |
| 1 | C/T2\# | Timer 2 Counter/Timer Select: <br> C/T2\# $=0$ selects timer operation: timer 2 counts the divided-down system clock. C/T2\# $=1$ selects counter operation: timer 2 counts negative transitions on external pin T2. |  |  |  |  |  |
| 0 | CP/RL2\# | Capture/Reload Bit: <br> When set, captures occur on negative transitions at T2EX if EXEN2 $=1$. <br> When cleared, auto-reloads occur on timer 2 overflows or negative transitions at T2EX if EXEN2 $=1$. The CP/RL2\# bit is ignored and timer 2 forced to auto-reload on timer 2 overflow, if RCLK $=1$ or TCLK $=1$. |  |  |  |  |  |

Figure 7-11. T2CON: Timer 2 Control Register

### 7.7.2 Using the WDT

To use the WDT to recover from software malfunctions, the user program should control the WDT as follows:

1. Following device reset, write the two-byte sequence $1 \mathrm{EH}-\mathrm{E} 1 \mathrm{H}$ to the WDTRST register to enable the WDT. The WDT begins counting from 0 .
2. Repeatedly for the duration of program execution, write the two-byte sequence $1 \mathrm{EH}-\mathrm{E} 1 \mathrm{H}$ to the WDTRST register to clear and enable the WDT before it overflows. The WDT starts over at 0 .

If the WDT overflows, it initiates a device reset (see "Reset" on page 10-5). Device reset clears the WDT and disables it.

### 7.7.3 WDT During Idle Mode

Operation of the WDT during the power reduction modes deserves special attention. The WDT continues to count while the microcontroller is in idle mode. This means the user must service the WDT during idle. One approach is to use a peripheral timer to generate an interrupt request when the timer overflows. The interrupt service routine then clears the WDT, reloads the peripheral timer for the next service period, and puts the microcontroller back into idle.

### 7.7.4 WDT During PowerDown

The powerdown mode stops all phase clocks. This causes the WDT to stop counting and to hold its count. The WDT resumes counting from where it left off if the powerdown mode is terminated by INT0/INT1. To ensure that the WDT does not overflow shortly after exiting the powerdown mode, clear the WDT just before entering powerdown. The WDT is cleared and disabled if the powerdown mode is terminated by a reset.

## intel.

## Programmable Counter Array

## CHAPTER 8 PROGRAMMABLE COUNTER ARRAY

This chapter describes the programmable counter array (PCA), an on-chip peripheral of the 8XC251SB that performs a variety of timing and counting operations, including pulse width modulation (PWM). The PCA provides the capability for a software watchdog timer (WDT).

### 8.1 PCA DESCRIPTION

The programmable counter array (PCA) consists of a 16 -bit timer/counter and five 16 -bit compare/capture modules. The timer/counter serves as a common time base and event counter for the compare/capture modules, distributing the current count to the modules by means of a 16-bit bus. A special function register (SFR) pair, CH/CL, maintains the count in the timer/counter, while five SFR pairs, CCAP $x \mathrm{H} / \mathrm{CCAP} x \mathrm{~L}$, store values for the modules (see Figure 8-1). Additional SFRs provide control and mode select functions as follows:

- The PCA timer/counter mode register (CMOD) and the PCA timer/counter control register (CCON) control the operation of the timer/counter. See Figures $8-7$ and $8-8$ beginning on page 8-13.
- Five PCA module mode registers (CCAPMx) specify the operating modes of the compare/capture modules. See Figure 8-9 on page 8-16.

For a list of SFRs associated with the PCA, see Table 8-1. For an SFR address map, see Table 3-4 on page 3-13. Port 1 provides external I/O for the PCA on a shared basis with other functions. Table 8-2 identifies the port pins associated with the timer/counter and compare/capture modules. When not used for PCA I/O, these pins can be used for standard I/O functions.

The operating modes of the five compare/capture modules determine the functions performed by the PCA. Each module can be independently programmed to provide input capture, output compare, or pulse width modulation. Module 4 only also has a watchdog-timer mode.

The PCA timer/counter and the five compare/capture modules share a single interrupt vector. The EC bit in the IE special function register is a global interrupt enable for the PCA. Capture events, compare events in some modes, and PCA timer/counter overflow set flags in the CCON register. Setting the overflow flag (CF) generates a PCA interrupt request if the PCA timer/counter interrupt enable bit (ECF) in the CMOD register is set (Figure 8-1). Setting a compare/capture flag (CCFx) generates a PCA interrupt request if the ECCFx interrupt enable bit in the corresponding CCAPM $x$ register is set (Figures 8-2 and 8-3). For a description of the 8XC251SB interrupt system see Chapter 5, "Interrupt System."

### 8.2 PCA TIMER/COUNTER

Figure 8-1 depicts the basic logic of the timer/counter portion of the PCA. The CH/CL special function register pair operates as a 16 -bit timer/counter. The selected input increments the CL (low byte) register. When CL overflows, the CH (high byte) register increments after two oscillator periods; when CH overflows it sets the PCA overflow flag (CF in the CCON register) generating a PCA interrupt request if the ECF bit in the CMOD register is set.

The CPS1 and CPS0 bits in the CMOD register select one of four signals as the input to the timer/counter (Figure 8-7 on page 8-13).

- $\mathrm{F}_{\mathrm{OSC}} / 12$. Provides an clock pulse at S5P2 of every peripheral cycle. With $\mathrm{F}_{\mathrm{osc}}=16 \mathrm{MHz}$, the time/counter increments every 750 nanoseconds.
- $\mathrm{F}_{\mathrm{osc}}$ /4. Provides clock pulses at S1P2, S3P2, and S5P2 of every peripheral cycle. With $\mathrm{F}_{\mathrm{OSC}}=16 \mathrm{MHz}$, the time/counter increments every 250 nanoseconds.
- Timer 0 overflow. The CL register is incremented at S5P2 of the peripheral cycle when timer 0 overflows. This selection provides the PCA with a programmable frequency input.
- External signal on P1.2/ECI. The CPU samples the ECI pin at S1P2, S3P2, and S5P2 of every peripheral cycle. The first clock pulse (S1P2, S3P2, or S5P2) that occurs following a high-to-low transition at the ECI pin increments the CL register. The maximum input frequency for this input selection is $\mathrm{F}_{\mathrm{osc}} / 8$.

For a description of peripheral cycle timing, see "Clock and Reset Unit" on page 2-5.
Setting the run control bit (CR in the CCON register) turns the PCA timer/counter on, if the output of the NAND gate (Figure 8-1) equals logic 1. The PCA timer/counter continues to operate during idle mode unless the CIDL bit of the CMOD register is set. The CPU can read the contents of the CH and CL registers at any time. However, writing to them is inhibited while they are counting i.e., when the CR bit is set.


Figure 8-1. Programmable Counter Array

Table 8-1. PCA Special Function Registers (SFRs)

| Mnemonic | Description | Address |
| :---: | :---: | :---: |
| $\begin{aligned} & \hline \mathrm{CL} \\ & \mathrm{CH} \end{aligned}$ | PCA Timer/Counter. These registers serve as a common 16-bit timer or event counter for the five compare/capture modules. Counts $\mathrm{F}_{\text {osd }} / 12$, $\mathrm{F}_{\text {osc }} / 4$, timer 0 overflow, or the external signal on $\mathrm{P} 1.2 / \mathrm{ECl}$, as selected by CMOD. In PWM mode CL operates as an 8-bit timer. | $\begin{aligned} & \hline \mathrm{S}: \mathrm{E9H} \\ & \mathrm{~S}: \mathrm{F9H} \end{aligned}$ |
| CCON | PCA Timer/Counter Control Register. Contains the run control bit and the overflow flag for the PCA timer/counter, and interrupt flags for the five compare/capture modules. | S:D8H |
| CMOD | PCA Timer/Counter Mode Register. Contains bits for disabling the PCA timer/counter during idle mode, enabling the PCA watchdog timer (module 4), selecting the timer/counter input, and enabling the PCA timer/counter overflow interrupt. | S:D9H |
| CCAPOH CCAPOL | PCA Module 0 Compare/Capture Registers. This register pair stores the comparison value or the captured value. In the PWM mode, the low-byte register controls the duty cycle of the output waveform. | $\begin{aligned} & \text { S:FAH } \\ & \text { S:EAH } \end{aligned}$ |
| CCAP1H CCAP1L | PCA Module 1 Compare/Capture Registers. This register pair stores the comparison value or the captured value. In the PWM mode, the low-byte register controls the duty cycle of the output waveform. | $\begin{aligned} & \text { S:FBH } \\ & \text { S:EBH } \end{aligned}$ |
| CCAP2H CCAP2L | PCA Module 2 Compare/Capture Registers. This register pair stores the comparison value or the captured value. In the PWM mode, the low-byte register controls the duty cycle of the output waveform. | $\begin{aligned} & \text { S:FCH } \\ & \text { S:ECH } \end{aligned}$ |
| CCAP3H CCAP3L | PCA Module 3 Compare/Capture Registers. This register pair stores the comparison value or the captured value. In the PWM mode, the low-byte register controls the duty cycle of the output waveform. | $\begin{aligned} & \text { S:FDH } \\ & \text { S:EDH } \end{aligned}$ |
| CCAP4H CCAP4L | PCA Module 4 Compare/Capture Registers. This register pair stores the comparison value or the captured value. In the PWM mode, the low-byte register controls the duty cycle of the output waveform. | $\begin{aligned} & \text { S:FEH } \\ & \text { S:EEH } \end{aligned}$ |
| CCAPMO CCAPM1 CCAPM2 CCAPM3 CCAPM4 | PCA Compare/Capture Module Mode Registers. Contain bits for selecting the operating mode of the compare/capture modules and enabling the compare/capture flag. See Table 8-3 on page 8-15 for mode select bit combinations. | $\begin{aligned} & \text { S:DAH } \\ & \text { S:DBH } \\ & \text { S:DCH } \\ & \text { S:DDH } \\ & \text { S:DEH } \end{aligned}$ |

Table 8-2. External Signals

| Signal <br> Name | Type | Description | Multiplexed <br> With |
| :--- | :---: | :--- | :---: |
| ECI | I | PCA Timer/counter External Input. This signal is the external clock <br> input for the PCA timer/counter. | P 1.2 |
| CEX0 | $\mathrm{I} / \mathrm{O}$ | Compare/Capture Module External I/O. Each compare/capture <br> CEX1 |  |
| CEX2 | module connects to a Port 1 pin for external I/O. When not used by |  |  |
| the PCA, these pins can handle standard I/O. | P1.3 |  |  |
| CEX3 |  |  | P1.4 |
| CEX4 |  |  | P1.5 |

### 8.3 PCA COMPARE/CAPTURE MODULES

Each compare/capture module is made up of a compare/capture register pair (CCAP $x \mathrm{H} / \mathrm{CCAPxL}$ ), a 16-bit comparator, and various logic gates and signal transition selectors. The registers store the time or count at which an external event occurred (capture) or at which an action should occur (comparison). In the PWM mode, the low-byte register controls the duty cycle of the output waveform.

The logical configuration of a compare/capture module depends on its mode of operation (Figures 8-2 through 8-5). Each module can be independently programmed for operation in any of the following modes:

- 16-bit capture mode with triggering on the positive edge, negative edge, or either edge.
- Compare modes: 16-bit software timer, 16-bit high-speed output, 16-bit WDT (module 4 only), or 8-bit pulse width modulation.
- No operation.

Bit combinations programmed into a compare/capture module's mode register (CCAPMx) determine the operating mode. Figure 8-9 on page 8-16 provides bit definitions and Table 8-3 on page $8-15$ lists the bit combinations of the available modes. Other bit combinations are invalid and produce undefined results.

The compare/capture modules perform their programmed functions when their common time base, the PCA timer/counter, runs. The timer/counter is turned on and off with the CR bit in the CCON register. To disable any given module, program it for the no operation mode. The occurrence of a capture, software timer, or high-speed output event in a compare/capture module sets the module's compare/capture flag (CCFx) in the CCON register and generates a PCA interrupt request if the corresponding enable bit in the CCAPM $x$ register is set.

The CPU can read or write the CCAPxH and CCAPxL registers at any time.

### 8.3.1 16-bit Capture Mode

The capture mode (Figure $8-2$ ) provides the PCA with the ability to measure periods, pulse widths, duty cycles, and phase differences at up to five separate inputs. External I/O pins CEXO through CEX4 are sampled for signal transitions (positive and/or negative as specified). When a compare/capture module programmed for the capture mode detects the specified transition, it captures the PCA timer/counter value. This records the time at which an external event is detected, with a resolution equal to the timer/counter clock period.

To program a compare/capture module for the 16-bit capture mode, program the CAPPx and CAPN $x$ bits in the module's CCAPM $x$ register as follows:

- To trigger the capture on a positive transition, set CAPP $x$ and clear CAPN $x$.
- To trigger the capture on a negative transition, set CAPN $x$ and clear CAPPx.
- To trigger the capture on a positive or negative transition, set both CAPPx and CAPNx.

Table 8-3 on page 8-15 lists the bit combinations for selecting module modes. For modules in the capture mode, detection of a valid signal transition at the I/O pin (CEXx) causes hardware to load the current PCA timer/counter value into the compare/capture registers ( $\mathrm{CCAP} x \mathrm{H} / \mathrm{CCAP} x \mathrm{~L}$ ) and to set the module's compare/capture flag (CCFx) in the CCON register. If the corresponding interrupt enable bit (ECCFx) in the CCAPM $x$ register is set (Figure 8-9 on page 8-16), a the PCA sends an interrupt request to the interrupt handler.

Since hardware does not clear the event flag when the interrupt is processed, the user must clear the flag in software. A subsequent capture by the same module overwrites the existing captured value. To preserve a captured value, save it in RAM with the interrupt service routine before the next capture event occurs.


Figure 8-2. PCA 16-bit Capture Mode

PROGRAMMABLE COUNTER ARRAY

### 8.3.2 Compare Modes

The compare function provides the capability for operating the five modules as timers, event counters, or pulse width modulators. Four modes employ the compare function: 16-bit software timer mode, high-speed output mode, WDT mode, and PWM mode. In the first three of these, the compare/capture module continuously compares the 16-bit PCA timer/counter value with the 16bit value pre-loaded into the module's $\mathrm{CCAPxH} / \mathrm{CCAPxL}$ register pair. In the PWM mode, the module continuously compares the value in the low-byte PCA timer/counter register (CL) with an 8-bit value in the CCAPxL module register. Comparisons are made three times per peripheral cycle to match the fastest PCA timer/counter clocking rate ( $\mathrm{F}_{\mathrm{OSC}} / 4$ ). For a description of peripheral cycle timing, see "Clock and Reset Unit" on page 2-5.

Setting the ECOMx bit in a module's mode register (CCAPMx) selects the compare function for that module (Figure 8-9 on page 8-16). To use the modules in the compare modes, observe the following general procedure:

1. Select the module's mode of operation.
2. Select the input signal for the PCA timer/counter.
3. Load the comparison value into the module's compare/capture register pair.
4. Set the PCA timer/counter run control bit.
5. After a match causes an interrupt, clear the module's compare/capture flag.

### 8.3.3 16-bit Software Timer Mode

To program a compare/capture module for the 16-bit software timer mode (Figure 8-3), set the ECOMx and MATx bits in the module's CCAPM $x$ register. Table 8-3 on page 8-15 lists the bit combinations for selecting module modes.

A match between the PCA timer/counter and the compare/capture registers (CCAPxH/CCAPxL) sets the module's compare/capture flag (CCFx in the CCON register). This generates an interrupt request if the corresponding interrupt enable bit (ECCFx in the CCAPM $x$ register) is set. Since hardware does not clear the compare/capture flag when the interrupt is processed, the user must clear the flag in software. During the interrupt routine, a new 16-bit compare value can be written to the compare/capture registers (CCAP $x \mathrm{H} / \mathrm{CCAP} x \mathrm{~L}$ ).

## NOTE

To prevent an invalid match while updating these registers, user software should write to CCAPxL first, then CCAPxH. A write to CCAPxL clears the $\mathrm{ECOM} x$ bit disabling the compare function, while a write to CCAP $x \mathrm{H}$ sets the ECOM $x$ bit re-enabling the compare function.


Figure 8-3. PCA Software Timer and High-speed Output Modes

### 8.3.4 High-speed Output Mode

The high-speed output mode (Figure 8-3) generates an output signal by toggling the module's I/O pin (CEXx) when a match occurs. This provides greater accuracy than toggling pins in software because the toggle occurs before the interrupt request is serviced. Thus, interrupt response time does not affect the accuracy of the output.

To program a compare/capture module for the high-speed output mode, set the ECOM $x$, MATx, TOG $x$ bits in the module's CCAPM $x$ register. Table 8-3 on page 8-15 lists the bit combinations for selecting module modes. A match between the PCA timer/counter and the compare/capture registers (CCAP $x \mathrm{H} / \mathrm{CCAP} x \mathrm{~L}$ ) toggles the CEX $x$ pin and sets the module's compare/capture flag (CCF $x$ in the CCON register). By setting or clearing the CEX $x$ pin in software, the user selects whether the match toggles the pin from low to high or vice versa.

The user also has the option of generating an interrupt request when the match occurs by setting the corresponding interrupt enable bit (ECCF $x$ in the CCAPM $x$ register). Since hardware does not clear the compare/capture flag when the interrupt is processed, the user must clear the flag in software.

If the user does not change the compare/capture registers in the interrupt routine, the next toggle occurs after the PCA timer/counter rolls over and the count again matches the comparison value. During the interrupt routine, a new 16-bit compare value can be written to the compare/capture registers (CCAP $x \mathrm{H} / \mathrm{CCAP} x \mathrm{~L}$ ).

## NOTE

To prevent an invalid match while updating these registers, user software should write to CCAPxL first, then CCAPxH. A write to CCAPxL clears the ECOM $x$ bit disabling the compare function, while a write to CCAP $x \mathrm{H}$ sets the ECOM $x$ bit re-enabling the compare function.

### 8.3.5 PCA Watchdog Timer Mode

A watchdog timer (WDT) provides the means to recover from routines that do not complete successfully. A WDT automatically invokes a device reset if it does not regularly receive hold-off signals. WDTs are used in applications that are subject to electrical noise, power glitches, electrostatic discharges, etc., or where high reliability is required.

In addition to the 8 XC 251 SB's 14 -bit hardware WDT, the PCA provides a programmable-frequency 16 -bit WDT as a mode option on compare/capture module 4 . This mode generates a device reset when the count in the PCA timer/counter matches the value stored in the module 4 compare/capture registers. A PCA WDT reset has the same effect as an external reset. Module 4 is the only PCA module that has the WDT mode. When not programmed as a WDT, it can be used in the other modes.

To program module 4 for the PCA WDT mode (Figure 8-4), set the ECOM4 and MAT4 bits in the CCAPM4 register and the WDTE bit in the CMOD register. Table 8-3 on page 8-15 lists the bit combinations for selecting module modes. Also select the desired input for the PCA timer/counter by programming the CPS0 and CPS1 bits in the CMOD register (see Figure 8-7 on page 8-13). Enter a 16-bit comparison value in the compare/capture registers (CCAP4H/CCAP4L). Enter a 16-bit initial value in the PCA timer/counter (CH/CL) or use the reset value $(0000 \mathrm{H})$. The difference between these values multiplied by the PCA input pulse rate determines the running time to "expiration." Set the timer/counter run control bit (CR in the CCON register) to start the PCA WDT.

The PCA WDT generates a reset signal each time a match occurs. To hold off a PCA WDT reset, the user has three options:

- periodically change the comparison value in CCAP4H/CCAP4L so a match never occurs
- periodically change the PCA timer/counter value so a match never occurs
- disable the module 4 reset output signal by clearing the WDTE bit before a match occurs, then later re-enable it

The first two options are more reliable because the WDT is not disabled as in the third option. The second option is not recommended if other PCA modules are in use, since the five modules share a common time base. Thus, in most applications the first option is the best one.


Figure 8-4. PCA Watchdog Timer Mode

### 8.3.6 Pulse Width Modulation Mode

The five PCA comparator/capture modules can be independently programmed to function as pulse width modulators (Figure 8-5). The modulated output, which has a pulse width resolution of eight bits, is available at the CEXx pin. The PWM output can be used to convert digital data to an analog signal with simple external circuitry.

In this mode the value in the low byte of the PCA timer/counter (CL) is continuously compared with the value in the low byte of the compare/capture register (CCAP $x \mathrm{~L}$ ). When $\mathrm{CL}<\mathrm{CCAPxL}$, the output waveform (Figure 8-6) is low. When a match occurs (CL=CCAPxL), the output waveform goes high and remains high until CL rolls over from FFH to 00 H , ending the period. At rollover the output returns to a low, the value in CCAP $x \mathrm{H}$ is loaded into CCAP $x \mathrm{~L}$, and a new period begins.


Figure 8-5. PCA 8-bit PWM Mode

The value in CCAP $x \mathrm{~L}$ determines the duty cycle of the current period. The value in $\mathrm{CCAP} x \mathrm{H}$ determines the duty cycle of the following period. Changing the value in CCAPxL over time modulates the pulse width. As depicted in Figure 8-6, the 8 -bit value in CCAPxL can vary from 0 ( $100 \%$ duty cycle) to 255 ( $0.4 \%$ duty cycle).

## NOTE

To change the value in CCAPxL without glitches, write the new value to the high byte register (CCAPxH). This value is shifted by hardware into CCAPxL when CL rolls over from FFH to 00 H .

The frequency of the PWM output equals the frequency of the PCA timer/counter input signal divided by 256. The highest frequency occurs when the $\mathrm{F}_{\mathrm{osC}} 4$ input is selected for the PCA tim$\mathrm{er} /$ counter. For $\mathrm{F}_{\mathrm{OSC}}=16 \mathrm{MHz}$, this is 15.6 KHz .

To program a compare/capture module for the PWM mode, set the ECOM $x$ and PWM $x$ bits in the module's CCAPM $x$ register. Table 8-3 on page 8-15 lists the bit combinations for selecting module modes. Also select the desired input for the PCA timer/counter by programming the CPS0 and CPS1 bits in the CMOD register (see Figure 8-7 on page 8-13). Enter an 8-bit value in CCAPxL to specify the duty cycle of the first period of the PWM output waveform. Enter an 8bit value in CCAP $x H$ to specify the duty cycle of the second period. Set the timer/counter run control bit (CR in the CCON register) to start the PCA timer/counter.


Figure 8-6. PWM Variable Duty Cycle

| CMOD |  |  |  |  | Address: <br> Reset State: |  | $\begin{aligned} & \text { S:D9H } \\ & 00 \times x \text { x000B } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 |  |  |  |  |  |  |  |
| CIDL | WDTE | - | - | - | CPS1 | CPSO | ECF |
| Bit Number | Bit Mnemonic | Function |  |  |  |  |  |
| 7 | CIDL | Counter Idle Control: <br> CIDL $=1$ disables the PCA timer/counter during ide mode. CIDL $=0$ allows the PCA timer/counter to run during idle mode. |  |  |  |  |  |
| 6 | WDTE | Watchdog Timer Enable: <br> WDTE $=1$ enables the watchdog timer output on PCA module 4. <br> WDTE $=0$ disables the PCA watchdog timer output. |  |  |  |  |  |
| 5:3 | - | Reserved: <br> The values read from these bits are indeterminate. Do not write " 1 "s to these bits. |  |  |  |  |  |
| 2:1 | CPS1:0 | PCA Timer/Counter Input Select: <br> CPS1 CPS0 |  |  |  |  |  |
| 0 | ECF | PCA Timer/Counter Interrupt Enable: <br> ECF $=1$ enables the CF bit in the CCON register to generate an interrupt request. |  |  |  |  |  |

Figure 8-7. CMOD: PCA Timer/Counter Mode Register

| CCON |  |  |  |  | Address: Reset State: |  | $\begin{array}{r} \text { S:D8H } \\ 00 \times 0 \text { OOOOB } \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 |  |  |  |  |  |  |  |
| CF | CR | - | CCF4 | CCF3 | CCF2 | CCF1 | CCFO |
| Number | Bit Mnemonic | Function |  |  |  |  |  |
| 7 | CF | PCA Timer/Counter Overflow Flag: <br> Set by hardware when the PCA timer/counter rolls over. This generates an interrupt request if the ECF interrupt enable bit in CMOD is set. CF can be set by hardware or software but can be cleared only by software. |  |  |  |  |  |
| 6 | CR | PCA Timer/Counter Run Control Bit: <br> Set and cleared by software to turn the PCA timer/counter on and off. |  |  |  |  |  |
| 5 | - | Reserved: <br> The value read from this bit is indeterminate. Do not write a " 1 " to this bit. |  |  |  |  |  |
| 4:0 | CCF4 CCF3 CCF2 CCF1 CCFO | PCA Module Compare/Capture Flags: <br> Set by hardware when a match or capture occurs. This generates a PCA interrupt request if the ECCFx interrupt enable bit in the corresponding CCAPMx register is set. Must be cleared by software. |  |  |  |  |  |

Figure 8-8. CCON: PCA Timer/Counter Control Register

Table 8-3. PCA Module Modes

| ECOMx | CAPPx | CAPN $x$ | MATx | TOGx | PWMx | ECCFx | Module Mode |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | No operation |
| X | 1 | 0 | 0 | 0 | 0 | X | 16-bit capture on positive-edge <br> trigger at CEX $x$ |
| X | 0 | 1 | 0 | 0 | 0 | X | 16-bit capture on negative-edge <br> trigger at CEX $x$ |
| X | 1 | 1 | 0 | 0 | 0 | X | 16-bit capture on positive- or <br> negative-edge trigger at CEX $x$ |
| 1 | 0 | 0 | 1 | 0 | 0 | X | Compare: software timer |
| 1 | 0 | 0 | 1 | 1 | 0 | X | Compare: high-speed output |
| 1 | 0 | 0 | 0 | 0 | 1 | 0 | Compare: 8-bit PWM |
| 1 | 0 | 0 | 1 | X | 0 | X | Compare: PCA WDT <br> (CCAPM4 only) (Note 3) |

NOTES:

1. This table shows the CCAPMx register bit combinations for selecting the operating modes of the PCA compare/capture modules. Other bit combinations are invalid. See Figure 8-9 for bit definitions.
2. $x=0-4, \mathrm{X}=$ Don't care.
3. For PCA WDT mode, also set the WDTE bit in the CMOD register to enable the reset output signal.


Figure 8-9. CCAPMx: PCA Compare/Capture Module Mode Registers

## inte.

## Serial I/O Port

## CHAPTER 9 SERIAL I/O PORT

The serial input/output port supports communication with modems and other external peripheral devices. This chapter provides instructions on programming the serial port and generating the serial I/O baud rates with timer 1 and timer 2.

### 9.1 OVERVIEW

The serial I/O port provides both synchronous and asynchronous communication modes. It operates as a universal asynchronous receiver and transmitter (UART) in three full-duplex modes (modes 1, 2, and 3). Asynchronous transmission and reception can occur simultaneously and at different baud rates. The UART supports framing-bit error detection, multiprocessor communication, and automatic address recognition. The serial port also operates in a single synchronous mode (mode 0).

The synchronous mode (mode 0 ) operates at a single baud rate. Mode 2 operates at two baud rates. Modes 1 and 3 operate over a wide range of baud rates, which are generated by timer 1 and timer 2. Baud rates are detailed in ."Baud Rates" on page 9-10.

The serial port signals are defined in Table 9-1, and the serial port special function registers are described in Table 9-2. Figure 9-1 is a block diagram of the serial port.

For the three asynchronous modes, the UART transmits on the TXD pin and receives on the RXD pin. For the synchronous mode (mode 0), the UART outputs a clock signal on the TXD pin and sends and receives messages on the RXD pin (Figure 9-1). The SBUF register, which holds received bytes and bytes to be transmitted, actually consists of two physically different registers. To send, software writes a byte to SBUF; to receive, software reads SBUF. The receive shift register allows reception of a second byte before the first byte has been read from SBUF. However, if software has not read the first byte by the time the second byte is received, the second byte will overwrite the first. The UART sets interrupt bits TI and RI on transmission and reception, respectively. These two bits share a single interrupt request and interrupt vector.

Table 9-1. Serial Port Signals

| Function <br> Name | Type | Description | Multiplexed <br> With |
| :---: | :---: | :--- | :---: |
| TXD | O | Transmit Data. In mode 0, TXD transmits the clock signal. In <br> modes 1, 2, and 3, TXD transmits serial data. | P3.1 |
| RXD | I/O | Receive Data. In mode 0, RXD transmits and receives serial <br> data. In modes 1, 2, and 3, RXD receives serial data. | P3.0 |

Table 9-2. Serial Port Special Function Registers

| Mnemonic | Description | Address |
| :--- | :--- | :---: |
| SBUF | Serial Buffer. Two separate registers comprise the SBUF register. Writing <br> to SBUF loads the transmit buffer; reading SBUF accesses the receive <br> buffer. | 99 H |
| SCON | Serial Port Control. Selects the serial port operating mode. SCON enables <br> and disables the receiver, framing bit error detection, multiprocessor <br> communication, automatic address recognition, and the serial port interrupt <br> bits. | 98 H |
| SADDR | Serial Address. Defines the individual address for a slave device. | A8H |
| SADEN | Serial Address Enable. Specifies the mask byte that is used to define the <br> given address for a slave device. | B8H |



Figure 9-1. Serial Port Block Diagram

SERIAL I/O PORT

The serial port control (SCON) register (Figure 9-2) configures and controls the serial port.

| SCON |  |  |  |  |  | Address: Reset State: |  | $\begin{array}{r} 98 \mathrm{H} \\ 0000 \text { 0000B } \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 ( 0 |  |  |  |  |  |  |  |  |
| FE/SM0 | SM1 | SM2 |  | REN | TB8 | RB8 | TI | RI |
| Bit Number | Bit Mnemonic | Function |  |  |  |  |  |  |
| 7 | FE <br> SMO | Framing Error Bit: <br> To select this function, set the SMODO bit in the PCON register. Set by hardware to indicate an invalid stop bit. Cleared by software. <br> Serial Port Mode Bit 0: <br> To select this function, clear the SMODO bit in the PCON register. Software writes to bits SM0 and SM1 to select the serial port operating mode. Refer to the SM1 bit for the mode selections. |  |  |  |  |  |  |
| 6 | SM1 | Serial Port Mode Bit 1: <br> Software writes to bits SM1 and SM0 (above) to select the serial port operating mode. <br> $\dagger$ Select by programming the SMOD bit in the PCON register (see "Baud Rates" on page 9-10). |  |  |  |  |  |  |
| 5 | SM2 | Serial Port Mode Bit 2: <br> Software writes to bit SM2 to enable and disable the multiprocessor communication and automatic address recognition features. This allows the serial port to differentiate between data and command frames and to recognize slave and broadcast addresses. |  |  |  |  |  |  |
| 4 | REN | Receiver Enable Bit: <br> To enable reception, set this bit. To enable transmission, clear this bit. |  |  |  |  |  |  |
| 3 | TB8 | Transmit Bit 8: <br> In modes 2 and 3, software writes the 9th data bit to be transmitted to TB8. Not used in modes 0 and 1. |  |  |  |  |  |  |
| 2 | RB8 | Receiver Bit 8: <br> Mode 0: Not used. <br> Mode 1 (SM2 clear): Set or cleared by hardware to reflect the stop bit received. <br> Modes 2 and 3 (SM2 set): Set or cleared by hardware to reflect the 9th bit received. |  |  |  |  |  |  |

Figure 9-2. Serial Port Special Function Register

| $\mathbf{1}$ | TI | Transmit Interrupt Flag Bit: <br> Set by the transmitter after the last data bit is transmitted. Cleared by <br> software. |
| :--- | :--- | :--- |
| $\mathbf{0}$ | RI | Receive Interrupt Flag Bit: <br> Set by the receiver after the last data bit of a frame has been received. <br> Cleared by software. |

Figure 9-2. Serial Port Special Function Register (Continued)

### 9.2 MODES OF OPERATION

The serial I/O port can operate in one synchronous and three asynchronous modes.

### 9.2.1 Synchronous Mode (Mode 0)

Mode 0 is a half-duplex, synchronous mode, which is commonly used to expand the I/O capabilities of a device with shift registers. The transmit data (TXD) pin outputs a set of eight clock pulses while the receive data (RXD) pin transmits or receives a byte of data. The eight data bits are transmitted and received least-significant bit (LSB) first. Shifts occur in the last phase (S6P2) of every peripheral cycle, which corresponds to a baud rate of $\mathrm{F}_{\mathrm{osc}} / 12$. Figure 9-3 shows the timing for transmission and reception in mode 0.

### 9.2.1.1 Transmission (Mode 0)

Follow these steps to begin a transmission:

1. Write to the SCON register, clearing bits SM0, SM1, and REN.
2. Write the byte to be transmitted to the SBUF register. This write starts the transmission.

Hardware executes the write to SBUF in the last phase (S6P2) of a peripheral cycle. At S6P2 of the following cycle, hardware shifts the LSB (D0) onto the RXD pin. At S3P1 of the next cycle, the TXD pin goes low for the first clock-signal pulse. Shifts continue every peripheral cycle. In the ninth cycle after the write to SBUF, the MSB (D7) is on the RXD pin. At the beginning of the tenth cycle, hardware drives the RXD pin high and asserts RI to indicate the end of the transmission.


Figure 9-3. Mode 0 Timing

### 9.2.1.2 Reception (Mode 0)

To start a reception in mode 0 , write to the SCON register. Clear bits SM0, SM1, and RI and set the REN bit.

Hardware executes the write to SCON in the last phase (S6P2) of a peripheral cycle (Figure 9-3). In the second peripheral cycle following the write to SCON, TXD goes low at S3P1 for the first clock-signal pulse, and the LSB (D0) is sampled on the RXD pin at S5P2. The D0 bit is then shifted into the shift register. After eight shifts at S6P2 of every peripheral cycle, the LSB (D7) is shifted into the shift register, and hardware asserts RI to indicate a completed reception. Software can then read the received byte from SBUF.

### 9.2.2 Asynchronous Modes (Modes 1, 2, and 3)

The serial port has three asynchronous modes of operation.

- Mode 1. Mode 1 is a full-duplex, asynchronous mode. The data frame (Figure 9-4) consists of 10 bits: one start bit, eight data bits, and one stop bit. Serial data is transmitted on the TXD pin and received on the RXD pin. When a message is received, the stop bit is read in the RB8 bit in the SCON register. The baud rate is generated by overflow of timer 1 or timer 2 (see "Baud Rates" on page 9-10).
- Modes 2 and 3. Modes 2 and 3 are full-duplex, asynchronous modes. The data frame (Figure 9-4) consists of 11 bits: one start bit, eight data bits (transmitted and received LSB first), one programmable ninth data bit, and one stop bit. Serial data is transmitted on the TXD pin and received on the RXD pin. On receive, the ninth bit is read from the RB8 bit in the SCON register. On transmit, the ninth data bit is written to the TB8 bit in the SCON register. (Alternatively, you can use the ninth bit as a command/data flag.)
- In mode 2, the baud rate is programmable to $1 / 32$ or $1 / 64$ of the oscillator frequency.
- In mode 3, the baud rate is generated by overflow of timer 1 or timer 2.


Figure 9-4. Data Frame (Modes 1, 2, and 3)

### 9.2.2.1 Transmission (Modes 1, 2, 3)

Follow these steps to initiate a transmission:

1. Write to the SCON register. Select the mode with the SM0 and SM1 bits, and clear the REN bit. For modes 2 and 3, also write the ninth bit to the TB8 bit.
2. Write the byte to be transmitted to the SBUF register. This write starts the transmission.

### 9.2.2.2 Reception (Modes 1, 2, 3)

To prepare for a reception, set the REN bit in the SCON register. The actual reception is then initiated by a detected high-to-low transition on the RXD pin.

### 9.3 FRAMING BIT ERROR DETECTION (MODES 1, 2, AND 3)

Framing bit error detection is provided for the three asynchronous modes. To enable the framing bit error detection feature, set the SMOD0 bit in the PCON register (see Figure 11-1 on page 11-2). When this feature is enabled, the receiver checks each incoming data frame for a valid stop bit. An invalid stop bit may result from noise on the serial lines or from simultaneous transmission by two CPUs. If a valid stop bit is not found, the software sets the FE bit in the SCON register (see Figure 9-2 on page 9-3).

Software may examine the FE bit after each reception to check for data errors. Once set, only software or a reset can clear the FE bit. Subsequently received frames with valid stop bits cannot clear the FE bit.

### 9.4 MULTIPROCESSOR COMMUNICATION (MODES 2 AND 3)

Modes 2 and 3 provide a ninth-bit mode to facilitate multiprocessor communication. To enable this feature, set the SM2 bit in the SCON register (see Figure 9-2 on page 9-3). When the multiprocessor communication feature is enabled, the serial port can differentiate between data frames (ninth bit clear) and address frames (ninth bit set). This allows the microcontroller to function as a slave processor in an environment where multiple slave processors share a single serial line.

When the multiprocessor communication feature is enabled, the receiver ignores frames with the ninth bit clear. The receiver examines frames with the ninth bit set for an address match. If the received address matches the slave's address, the receiver hardware sets the RB8 bit and the RI bit in the SCON register, generating an interrupt.

## NOTE

The ES bit must be set in the IE register to allow the RI bit to generate an interrupt. The IE register is described in Chapter 8, Interrupts.

The addressed slave's software then clears the SM2 bit in the SCON register and prepares to receive the data bytes. The other slaves are unaffected by these data bytes because they are waiting to respond to their own addresses.

### 9.5 AUTOMATIC ADDRESS RECOGNITION

The automatic address recognition feature is enabled when the multiprocessor communication feature is enabled (the SM2 bit is set in the SCON register).

Implemented in hardware, automatic address recognition enhances the multiprocessor communication feature by allowing the serial port to examine the address of each incoming command frame. Only when the serial port recognizes its own address does the receiver set the RI bit in the SCON register to generate an interrupt. This ensures that the CPU is not interrupted by command frames addressed to other devices.

If desired, you may enable the automatic address recognition feature in mode 1. In this configuration, the stop bit takes the place of the ninth data bit. The RI bit is set only when the received command frame address matches the device's address and is terminatêd by a valid stop bit.

## NOTE

The multiprocessor communication and automatic address recognition features cannot be enabled in mode 0 (i.e., setting the SM2 bit in the SCON register in mode 0 has no effect).

To support automatic address recognition, a device is identified by a given address and a broadcast address.

### 9.5.1 Given Address

Each device has an individual address that is specified in the SADDR register; the SADEN register is a mask byte that contains don't-care bits (defined by zeros) to form the device's given address. These don't-care bits provide the flexibility to address one or more slaves at a time. The following example illustrates how a given address is formed. (To address a device by its individual address, the SADEN mask byte must be 1111 1111.)

```
SADDR = 01010110
SADEN = 11111100
Given = 0101 01XX
```

The following is an example of how to use given addresses to address different slaves:


Slave B: $\quad$ SADDR $=11110011$
SADEN = 11111001
Given $=1111$ 0XX1

The SADEN byte is selected so that each slave may be addressed separately. For Slave A, bit 0 (the LSB) is a don't-care bit; for Slaves B and C, bit 0 is a 1 . To communicate with Slave A only, the master must send an address where bit 0 is clear (e.g., 11110000 ).

For Slave A, bit 1 is a 0; for Slaves B and C, bit 1 is a don't care bit. To communicate with Slaves B and C, but not Slave A, the master must send an address with bits 0 and 1 both set (e.g., 1111 0011).

For Slaves A and B, bit 2 is a don't care bit; for Slave C, bit 2 is a 0 . To communicate with Slaves A and B, but not Slave C, the master must send an address with bit 0 set, bit 1 clear, and bit 2 set (e.g., 11110101 ).

To communicate with Slaves A, B, and C, the master must send an address with bit 0 set, bit 1 clear, and bit 2 clear (e.g., 11110001 ).

### 9.5.2 Broadcast Address

A broadcast address is formed from the logical OR of the SADDR and SADEN registers with zeros defined as don't-care bits, e.g.:

| SADDR | $=01010110$ |
| :--- | :--- | :--- |
| SADEN | $=11111100$ |
| $($ SADDR ) OR (SADEN) | $=1111111 \mathrm{X}$ |

The use of don't-care bits provides flexibility in defining the broadcast address, however, in most applications, a broadcast address is 0 FFH .

The following is an example of using broadcast addresses:

| Slave A: | SADDR | $=11110001$ | Slave C: | SADDR |
| :--- | :--- | :--- | :--- | :--- |

Slave B:

$$
\begin{array}{ll}
\text { SADDR } & =11110011 \\
\text { SADEN } & =11111001 \\
\text { Broadcast } & =11111 \times 11
\end{array}
$$

For Slaves A and B, bit 2 is a don't care bit; for Slave C, bit 2 is set. To communicate with all of the slaves, the master must send an address FFH.

To communicate with Slaves A and B, but not Slave C, the master can send an address FBH.

### 9.5.3 Reset Addresses

On reset, the SADDR and SADEN registers are initialized to 00 H , i.e., the given and broadcast addresses are XXXX XXXX (all don't-care bits). This ensures that the serial port is backwards compatible with $M C S{ }^{\circledR} 51$ microcontrollers that do not support automatic address recognition.

### 9.6 BAUD RATES

You must select the baud rate for the serial port transmitter and receiver when operating in modes 1,2 , and 3. (The baud rate is preset for mode 0 .) In its asynchronous modes, the serial port can transmit and receive simultaneously. Depending on the mode, the transmission and reception rates can be the same or different. Table 9-3 summarizes the baud rates that can be used for the four serial I/O modes.

Table 9-3. Summary of Baud Rates

| Mode | No. of <br> Baud Rates | Send and Receive <br> at the Same Rate | Send and Receive <br> at Different Rates |
| :---: | :---: | :---: | :---: |
| 0 | 1 | N/A | N/A |
| 1 | Many |  | Yes |

†Baud rates are determined by overflow of timer 1 and/or timer 2.

### 9.6.1 Baud Rate for Mode 0

The baud rate for mode 0 is fixed at $\mathrm{F}_{\mathrm{osC}} / 12$.

### 9.6.2 Baud Rates for Mode 2

Mode 2 has two baud rates, which are selected by the SMOD1 bit in the PCON register (Figure 11-1 on page 11-2). The following expression defines the baud rate:

$$
\text { Serial I/O Mode } 2 \text { Baud Rate }=2^{\text {SMOD } 1} \times \frac{\mathrm{F}_{\mathrm{OSC}}}{64}
$$

### 9.6.3 Baud Rates for Modes 1 and 3

In modes 1 and 3, the baud rate is generated by overflow of timer 1 (default) and/or timer 2. You may select either or both timer(s) to generate the baud rate(s) for the transmitter and/or the receiver.

### 9.6.3.1 Timer 1 Generated Baud Rates (Modes 1 and 3)

Timer 1 is the default baud rate generator for the transmitter and the receiver in modes 1 and 3. The baud rate is determined by the timer 1 overflow rate and the value of SMOD, as shown in the following formula:

$$
\text { Serial I/O Modes } 1 \text { and } 3 \text { Baud Rate }=2^{\text {SMOD } 1} \times \frac{\text { Timer } 1 \text { Overflow Rate }}{32}
$$

### 9.6.3.2 Selecting Timer 1 as the Baud Rate Generator

To select timer 1 as the baud rate generator:

- Disable the timer interrupt by clearing the ETI bit in the IE0 register (Figure 5-2 on page 5-6).
- Configure timer 1 as a timer or an event counter (set or clear the C/T\# bit in the TMOD register). The TMOD register is described in Chapter 7, Timers/Counters.
- Select timer mode 0-3 by programming the M1, M0 bits in the TMOD register.

In most applications, timer 1 is configured as a timer in auto-reload mode (high nibble of TMOD $=0010 \mathrm{~B})$. The resulting baud rate is defined by the following expression:

$$
\text { Serial I/O Modes } 1 \text { and } 3 \text { Baud Rate }=2^{\text {SMOD } 1} \times \frac{F_{\text {OSC }}}{32 \times 12 \times[256-(\mathrm{TH} 1)]}
$$

Timer 1 can generate very low baud rates with the following setup:

- Enable the timer 1 interrupt by setting the ET1 bit in the IE register.
- Configure timer 1 to run as a 16 -bit timer (high nibble of TMOD $=0001 \mathrm{~B}$ ).
- Use the timer 1 interrupt to initiate a 16-bit software reload.

Table 9-4 lists commonly used baud rates and shows how they are generated by timer 1.

Table 9-4. Timer 1 Generated Baud Rates for Serial I/O Modes 1 and 3

| Baud <br> Rate | Oscillator <br> Frequency <br> (Fosc) | SMOD1 | Timer 1 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | C/T\# |  | Reload <br> Value |  |  |
| 62.5 Kbaud (Max) | 12.0 MHz | 1 | 0 | 2 | FFH |
| 19.2 Kbaud | 11.059 MHz | 1 | 0 | 2 | FDH |
| 9.6 Kbaud | 11.059 MHz | 0 | 0 | 2 | FDH |
| 4.8 Kbaud | 11.059 MHz | 0 | 0 | 2 | FAH |
| 2.4 Kbaud | 11.059 MHz | 0 | 0 | 2 | F4H |
| 1.2 Kbaud | 11.059 MHz | 0 | 0 | 2 | E8H |
| 137.5 Baud | 11.986 MHz | 0 | 0 | 2 | 1 DH |
| 110.0 Baud | 6.0 MHz | 0 | 0 | 2 | $72 H$ |
| 110.0 Baud | 12.0 MHz | 0 | 0 | 1 | FEEBH |

### 9.6.3.3 Timer 2 Generated Baud Rates (Modes 1 and 3)

Timer 2 may be selected as the baud rate generator for the transmitter and/or receiver (Figure 9-5 on page $9-13$ ). The timer 2 baud rate generator mode is similar to the auto-reload mode. A rollover in the TH2 register reloads registers TH2 and TL2 with the 16 -bit value in registers RCAP2H and RCAP2L, which are preset by software.

The timer 2 baud rate is expressed by the following formula:
Serial I/O Modes 1 and 3 Baud Rate $=\frac{\text { Timer } 2 \text { Overflow Rate }}{16}$

### 9.6.3.4 Selecting Timer 2 as the Baud Rate Generator

## NOTE

Turn the timer off (clear the TR2 bit in the T2CON register) before accessing registers TH2, TL2, RCAP2H, and RCAP2L.

To select timer 2 as the baud rate generator for the transmitter and/or receiver, program the RCLCK and TCLCK bits in the T2CON register as shown in Table 9-5. (You may select different baud rates for the transmitter and receiver.) Setting RCLK and/or TCLK puts timer 2 into its baud rate generator mode(Figure 9-5). In this mode, a rollover in the TH2 register does not set the TF2 bit in the T2CON register. Also, a high-to-low transition at the T2EX pin sets the EXF2 bit in the T2CON register but does not cause a reload from (RCAP2H, RCAP2L) to (TH2, TL2). You can use the T2EX pin as an additional external interrupt by setting the EXEN2 bit in T2CON.

You may configure timer 2 as a timer or a counter. In most applications, it is configured for timer operation (i.e., the C/T2\# bit is clear in the T2CON register).

Table 9-5. Selecting the Baud Rate Generator(s)

| RCLCK <br> Bit | TCLCK <br> Bit | Receiver <br> Baud Rate Generator | Transmitter <br> Baud Rate Generator |
| :---: | :---: | :---: | :---: |
| 0 | 0 | Timer 1 | Timer 1 |
| 0 | 1 | Timer 1 | Timer 2 |
| 1 | 0 | Timer 2 | Timer 1 |
| 1 | 1 | Timer 2 | Timer 2 |



Note availability of additional external interrupt.

Figure 9-5. Timer 2 in Baud Rate Generator Mode

Note that timer 2 increments every state time ( $2 \mathrm{~T}_{\mathrm{OSC}}$ ) when it is in the baud rate generator mode. In the baud rate formula that follows, "RCAP2H, RCAP2L" denotes the contents of RCAP2H and RCAP2L taken as a 16-bit unsigned integer:

$$
\text { Serial I/O Modes } 1 \text { and } 3 \text { Baud Rates }=\frac{F_{\text {OSC }}}{32 \times[553-(\text { RCAP2H, RCAP2L })]}
$$

## NOTE

When timer 2 is configured as a timer and is in baud rate generator mode, do not read or write the TH2 or TL2 registers. The timer is being incremented every state time, and the results of a read or write may not be accurate. In addition, you may read, but not write to, the RCAP2 registers; a write may overlap a reload and cause write and/or reload errors.

Table 9-6 lists commonly used baud rates and shows how they are generated by timer 2.

Table 9-6. Timer 2 Generated Baud Rates

| Baud Rate | Oscillator <br> Frequency <br> (Fosc) | RCAP2H | RCAP2L |
| :---: | :---: | :---: | :---: |
| 375.0 Kbaud | 12 MHz | FFH | FFH |
| 9.6 Kbaud | 12 MHz | FFH | D9H |
| 4.8 Kbaud | 12 MHz | FFH | B2H |
| 2.4 Kbaud | 12 MHz | FFH | 64 H |
| 1.2 Kbaud | 12 MHz | FEH | C8H |
| 300.0 baud | 12 MHz | FBH | 1 EH |
| 110.0 baud | 12 MHz | F2H | AFH |
| 300.0 baud | 6 MHz | FDH | $8 F H$ |
| 110.0 baud | 6 MHz | F9H | 57 H |

## inted.

## 10

## Minimum Hardware Setup

## intel.

## CHAPTER 10 MINIMUM HARDWARE SETUP

This chapter discusses the basic operating requirements of the $\mathrm{MCS}{ }^{\circledR} 251$ microcontroller and describes a minimum hardware setup. Topics covered include power, ground, clock source, and device reset. For parameter values, refer to the device data sheet.

### 10.1 MINIMUM HARDWARE SETUP

Figure 10-1 shows a minimum hardware setup that employs the on-chip oscillator for the system clock and provides power-on reset. Control signals and Ports $0,1,2$, and 3 are not shown. See "Clock Sources" on page 10-3 and "Power-on Reset" on page 10-7.


## Note:

$\mathrm{V}_{\mathrm{CC} 2}$ is a secondary power pin that reduces power supply noise. $\mathrm{V}_{\mathrm{SS} 1}$ and $\mathrm{V}_{\mathrm{SS} 2}$ are secondary ground pins that reduce ground bounce and improve power supply by-passing. Connections to these pins are not required for proper device operation.

Figure 10-1. Minimum Setup

### 10.2 ELECTRICAL ENVIRONMENT

The 8 XC 251 SB is a high-speed CHMOS device. To achieve satisfactory performance, its operating environment should accommodate the device signal waveforms without introducing distortion or noise. Design considerations relating to device performance are discussed in this section. See the device data sheet for voltage and current requirements, operating frequency, and waveform timing.

### 10.2.1 Power and Ground Pins

Power the 8XC251SB from a well-regulated power supply designed for high-speed digital loads. Use short, low impedance connections to the power ( $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\mathrm{CC} 2}$ ) and ground ( $\mathrm{V}_{\mathrm{SS}}, \mathrm{V}_{\mathrm{SS} 1}$, and $\mathrm{V}_{\mathrm{SS} 2}$ ) pins.
$\mathrm{V}_{\mathrm{CC} 2}$ is a secondary power pin that reduces power supply noise. $\mathrm{V}_{\mathrm{SS} 1}$ and $\mathrm{V}_{\mathrm{SS} 2}$ are secondary ground pins that reduce ground bounce and improve power supply bypassing. The secondary power and ground pins are not substitutes for $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{S S}$. They are not required for proper device operation; thus, the 8 XC 251 SB is compatible with designs that do not provide connections to these pins.

### 10.2.2 Unused Pins

To provide stable, predictable performance, connect unused input pins to $\mathrm{V}_{\mathrm{SS}}$ or $\mathrm{V}_{\mathrm{CC}}$. Unterminated input pins can float to a mid-voltage level and draw excessive current. Unterminated interrupt inputs may generate spurious interrupts.

### 10.2.3 Noise Considerations

The fast rise and fall times of high-speed CHMOS logic may produce noise spikes on the power supply lines and signal outputs. To minimize noise and waveform distortion follow good board layout techniques. Use sufficient decoupling capacitors and transient absorbers to keep noise within acceptable limits. Connect $0.01 \mu \mathrm{~F}$ bypass capacitors between $\mathrm{V}_{\mathrm{CC}}$ and each $\mathrm{V}_{\mathrm{sS}}$ piṇ. Place the capacitors close to the device to minimize path lengths.

Multilayer printed circuit boards with separate $\mathrm{V}_{\mathrm{CC}}$ and ground planes help minimize noise. For additional information on noise reduction, see Application Note AP-125, "Designing Microcontroller Systems for Noisy Environments."

### 10.3 CLOCK SOURCES

The 8 XC 251 SB can obtain the system clock signal from an external clock source (Figure 10-3) or it can generate the clock signal using the on-chip oscillator amplifier and external capacitors and resonator (Figure 10-2).

### 10.3.1 On-chip Oscillator (Crystal)

This clock source uses an external quartz crystal connected from XTAL1 to XTAL2 as the fre-quency-determining element (Figure 10-2). The crystal operates in its fundamental mode as an inductive reactance in parallel resonance with capacitance external to the crystal. Oscillator design considerations include crystal specifications, operating temperature range, and parasitic board capacitance. Consult the crystal manufacturer's data sheet for parameter values. With high quality components, $\mathrm{C} 1=\mathrm{C} 2=30 \mathrm{pF}$ is adequate for this application.

Pins XTAL1 and XTAL2 are protected by on-chip electrostatic discharge (ESD) devices, D1 and D 2, which are diodes parasitic to the $\mathrm{R}_{\mathrm{F}}$ FETs. They serve as clamps to $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\mathrm{SS}}$. Feedback resistor $R_{F}$ in the inverter circuit, formed from paralleled $n$ - and $p$ - channel FETs, permits the PD bit in the PCON register (Figure 11-1 on page 11-2) to disable the clock during powerdown.

Noise spikes at XTAL1 and XTAL2 can disrupt microcontroller timing. To minimize coupling between other digital circuits and the oscillator, locate the crystal and the capacitors near the chip and connect to XTAL1, XTAL2, and $\mathrm{V}_{\text {sS }}$ with short, direct traces. To further reduce the effects of noise, place guard rings around the oscillator circuitry and ground the metal crystal case.


Figure 10-2. CHMOS On-chip Oscillator

For a more in-depth discussion of crystal specifications, ceramic resonators, and the selection of C1 and C2 see Applications Note AP-155, "Oscillators for Microcontrollers" in the Embedded Applications handbook.

### 10.3.2 On-chip Oscillator (Ceramic Resonator)

In cost-sensitive applications, you may choose a ceramic resonator instead of a crystal. Ceramic resonator applications may require slightly different capacitor values and circuit configuration. Consult the manufacturer's data sheet for specific information.

### 10.3.3 External Clock

To operate the CHMOS 8XC251SB from an external clock, connect the clock source to the XTAL1 pin as shown in Figure 10-3. Leave the XTAL2 pin floating. The external clock driver can be a CMOS gate. If the clock driver is a TTL device, its output must be connected to $\mathrm{V}_{\mathrm{CC}}$ through a $4.7 \mathrm{k} \Omega$ pullup resister.


Note: If TTL clock driver is used, connect a $4.7 \mathrm{k} \Omega$ pull up resistor from driver output to $V_{C C}$.

Figure 10-3. External Clock Connection

For external clock drive requirements, see the device data sheet. Figure $10-4$ shows the clock drive waveform. The external clock source must meet the minimum high and low times ( $\mathrm{T}_{\mathrm{CHCx}}$ and $\mathrm{T}_{\mathrm{CLCX}}$ ) and the maximum rise and fall times ( $\mathrm{T}_{\mathrm{CLCH}}$ and $\mathrm{T}_{\mathrm{CHCL}}$ ) to minimize the effect of external noise on the clock generator circuit. Long rise and fall times increase the chance that external noise will affect the clock circuitry and cause unreliable operation.

The external clock driver may encounter increased capacitance loading at XTAL1 due to the Miller effect of the internal inverter as the clock waveform builds up in amplitude following power on. Once the input waveform requirements are met, the input capacitance remains under 20 pF .


Figure 10-4. External Clock Drive Waveforms

### 10.4 RESET

A device reset initializes the 8 XC 251 SB and vectors the CPU to address $\mathrm{FF}: 0000 \mathrm{H}$. A reset is required after applying power at turn-on. A reset is a means of exiting the idle and powerdown modes or recovering from software malfunctions.

To achieve a valid reset, $\mathrm{V}_{\mathrm{CC}}$ must be within its normal operating range (see device data sheet) and the reset signal must be maintained for 64 clock cycles ( $64 \mathrm{~T}_{\mathrm{OSC}}$ ) after the oscillator has stabilized.

Device reset is initiated in two ways:

- externally, by asserting the RST pin
- internally, if the hardware WDT or the PCA WDT expires

The power off flag (POF) in the PCON register indicates whether a reset is a warm start or a cold start. A cold start reset $(\mathrm{POF}=1)$ is a reset that occurs after power has been off or $\mathrm{V}_{\mathrm{CC}}$ has fallen below 3 V , so the contents of volatile memory are indeterminate. POF is set by hardware when $\mathrm{V}_{\mathrm{CC}}$ rises from less than 3 V to its normal operating level. See "Power Off Flag" on page 11-1. A warm start reset $(\mathrm{POF}=0)$ is a reset that occurs while the chip is at operating voltage, for example, a reset initiated by a WDT overflow or an external reset used to terminate the idle or powerdown modes.

### 10.4.1 Externally Initiated Resets

To reset the 8 XC 251 SB , hold the RST pin at a logic high for at least 64 clock cycles ( $64 \mathrm{~T}_{\mathrm{OSC}}$ ) while the oscillator is running. Reset can be accomplished automatically at the time power is applied by capacitively coupling RST to $\mathrm{V}_{\mathrm{CC}}$ (see Figure 10-1 and "Power-on Reset" on page 10-7). The RST pin has a Schmitt trigger input and a pulldown resistor.

### 10.4.2 WDT Initiated Resets

Expiration of the hardware WDT (overflow) or the PCA WDT (comparison match) generates a reset signal. WDT initiated resets have the same effect as an external reset. See "Watchdog Timer" on page 7-16 and "PCA Watchdog Timer Mode" on page 8-9.

### 10.4.3 Reset Operation

When a reset is initiated, whether externally or by a WDT, the port pins are immediately forced to their reset condition as a fail-safe precaution, whether the clock is running or not.

The external reset signal and the WDT initiated reset signals are combined internally. For an external reset the voltage on the RST pin must be held high for $64 \mathrm{~T}_{\text {osc }}$. For WDT initiated resets, a 5 -bit counter in the reset logic maintains the signal for the required $64 \mathrm{~T}_{\text {OSC }}$ -

The CPU checks for the presence of the combined reset signal every $2 \mathrm{~T}_{\text {OSC }}$. When a reset is detected, the CPU responds by triggering the internal reset routine. The reset routine loads the SFR's with their reset values (see Table 3-4 on page 3-13). Reset does not affect on-chip data RAM or the register file. (However following a cold start reset, these are indeterminate because $\mathrm{V}_{\mathrm{CC}}$ has fallen too low or has been off.) Following a synchronizing operation and the configuration fetch, the CPU vectors to address $\mathrm{FF}: 0000$. Figure $10-5$ shows the reset timing sequence.

While the RST pin is high ALE, PSEN\#, and the port pins are weakly pulled high. The first ALE occurs $32 \mathrm{~T}_{\text {OSC }}$ after the reset signal goes low. For this reason, other devices can not be synchronized to the internal timings of the 8XC251SB.

## NOTE

Externally driving the ALE and/or PSEN\# pins to 0 during the reset routine may cause the device to go into an indeterminate state.

Powering up the 8XC251SB without a reset may improperly initialize the program counter and SFRs and cause the CPU to execute instructions from an undetermined memory location.

### 10.4.4 Power-on Reset

To automatically generate a reset on power up, connect the RST pin to the $V_{C C}$ pin through a $1-\mu \mathrm{F}$ capacitor as shown in Figure 10-1.

When $\mathrm{V}_{\mathrm{CC}}$ is applied, the RST pin rises to $\mathrm{V}_{\mathrm{CC}}$, then decays exponentially as the capacitor charges. The time constant must be such that RST remains high (above the turn-off threshold of the Schmitt trigger) long enough for the oscillator to start and stabilize, plus $64 \mathrm{~T}_{\mathrm{OSC}}$. At power up, $\mathrm{V}_{\mathrm{CC}}$ should rise within approximately 10 ms . Oscillator start-up time is a function the crystal frequency; typical start-up times are 1 ms for a 10 MHz crystal and 10 ms for a 1 Mhz crystal.

During power up, the port pins are in a random state until forced to their reset state by the asynchronous logic.

Reducing $\mathrm{V}_{\mathrm{CC}}$ quickly to 0 causes the RST pin voltage to momentarily fall below 0 V . This voltage is internally limited and does not harm the device.


Figure 10-5. Reset Timing Sequence

## intel.

## Special Operating Modes

## CHAPTER 11 SPECIAL OPERATING MODES

This chapter describes the power control (PCON) register and three special operating modes: idle, powerdown, and on-circuit emulation (ONCE).

### 11.1 GENERAL

The idle and powerdown modes are power reduction modes for use in applications where power consumption is a concern. User instructions activate these modes by setting bits in the PCON register. Program execution halts, but resumes when the mode is exited by an interrupt. While in idle or power-down, the $\mathrm{V}_{\mathrm{CC}}$ pin is the input for backup power.

ONCE is a test mode that electrically isolates the 8XC251SB from the system in which it operates.

### 11.2 POWER CONTROL REGISTER

The PCON special function register (Figure 11-1) provides two control bits for the serial I/O function, bits for selecting the idle and powerdown modes, the power off flag, and two general purpose flags.

### 11.2.1 Serial VO Control Bits

The SMOD1 bit in the PCON register is a factor in determining the serial I/O baud rate. See Figure 11-1 and "Baud Rates" on page 9-10.

The SMOD0 bit in the PCON register determines whether bit 7 of the SCON register provides read/write access to the framing error $(\mathrm{FE})$ bit $(\mathrm{SMOD} 0=1)$ or to SM0, a serial I/O mode select bit (SMOD0 = 0). See Figure 11-1 and Figure 9-2, "Serial Port Special Function Register" on page 9-3.

### 11.2.2 Power Off Flag

Hardware sets the Power Off Flag (POF) in PCON when $\mathrm{V}_{\mathrm{CC}}$ rises from $<3 \mathrm{~V}$ to $>3 \mathrm{~V}$ to indicate that on-chip volatile memory is indeterminate, e.g., at power on. The POF can be set or cleared by software. In general after a reset, check the status of this bit to determine whether a cold start reset or a warm start reset occurred (see "Reset" on page 10-5). After a cold start, user software should clear the POF. If POF $=1$ is detected at other times, do a reset to reinitialize the chip, since for $\mathrm{V}_{\mathrm{CC}}<3 \mathrm{~V}$ data may have been lost or some logic may have malfunctioned.


Figure 11-1. Power Control (PCON) Register

Table 11-1. Pin Conditions in Various Modes

| Mode | Program <br> Memory | ALE <br> Pin | PSEN\# <br> Pin | Port 0 <br> Pins | Port 1 <br> Pins | Port 2 <br> Pins | Port 3 <br> Pins |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Reset | Don't Care | Weak High | Weak High | Floating | Weak High | Weak High | Weak High |
| Idle | Internal | 1 | 1 | Data | Data | Data | Data |
| Idle | External | 1 | 1 | Floating | Data | Data | Data |
| Powerdown | Internal | 0 | 0 | Data | Data | Data | Data |
| Powerdown | External | 0 | 0 | Floating | Data | Data | Data |
| ONCE | Don't Care | Floating | Floating | Floating | Weak High | Weak High | Weak High |



Figure 11-2. Idle and Powerdown Clock Control

### 11.3 IDLE MODE

Idle mode is a power reduction mode that reduces power consumption to about $40 \%$ of normal. In this mode, program execution halts. Idle mode freezes the clocks to the CPU at known states while the peripherals continue to be clocked (Figure 11-2). The CPU status before entering idle mode is preserved, i.e., the program counter, program status word register, and register file retain their data for the duration of idle mode. The contents of the SFRs and RAM are also retained. The status of the port pins depends upon the location of the program memory:

- Internal program memory: the ALE and PSEN\# pins are pulled high and the ports $0,1,2$, and 3 pins are reading data (Table 11-1).
- External program memory: the ALE and PSEN\# pins are pulled high; the port 0 pins are floating; and the pins of ports 1,2 , and 3 are reading data (Table 11-1).


## NOTE

If desired, the PCA may be instructed to pause during idle mode by setting the CIDL bit in the CMOD register (Figure 8-7 on page 8-13).

### 11.3.1 Entering Idle Mode

To enter idle mode, set the PCON register IDL bit. The 8XC251SB enters idle mode upon execution of the instruction that sets the IDL bit. The instruction that sets the IDL bit is the last instruction executed.

## CAUTION

If the IDL bit and the PD bit are set simultaneously, the 8XC251SB enters powerdown mode

### 11.3.2 Exiting Idle Mode

There are two ways to exit idle mode:

- Generate an enabled interrupt. Hardware clears the PCON register IDL bit which restores the clocks to the CPU. Execution resumes with the interrupt service routine. Upon completion of the interrupt service routine, program execution resumes with the instruction immediately following the instruction that activated idle mode. The general purpose flags (GF1 and GF0 in the PCON register) may be used to indicate whether an interrupt occurred during normal operation or during idle mode. When idle mode is exited by an interrupt, the interrupt service routine may examine GF1 and GF0.
- Reset the chip. See "Reset" on page 10-5. A logic high on the RST pin clears the IDL bit in the PCON register directly and asynchronously. This restores the clocks to the CPU. Program execution momentarily resumes with the instruction immediately following the instruction that activated the idle mode and may continue for a number of clock cycles before the internal reset algorithm takes control. Reset initializes the 8XC251SB and vectors the CPU to address $\mathrm{FF}: 0000 \mathrm{H}$.


## NOTE

During the time that execution resumes, the internal RAM cannot be accessed; however, it is possible for the port pins to be accessed. To avoid unexpected outputs at the port pins, the instruction immediately following the instruction that activated idle mode should not write to a port pin or to the external RAM.

### 11.4 POWERDOWN MODE

The powerdown mode places the 8 XC 251 SB in a very low power state. Powerdown mode stops the oscillator and freezes all clocks at known states (Figure 11-2). The CPU status prior to entering powerdown mode is preserved, i.e., the program counter, program status word register, and register file retain their data for the duration of powerdown mode. In addition, the SFRs and RAM contents are preserved. The status of the port pins depends on the location of the program memory:

- Internal program memory: the ALE and PSEN\# pins are pulled low and the ports $0,1,2$, and 3 pins are reading data (Table 11-1).
- External program memory: the ALE and PSEN\# pins are pulled low; the port 0 pins are floating; and the pins of ports 1, 2, and 3 are reading data (Table 11-1).


## NOTE

$\mathrm{V}_{\mathrm{CC}}$ may be reduced to as low as 2 V during powerdown to further reduce power dissipation. Take care, however, that $\mathrm{V}_{\mathrm{CC}}$ is not reduced until powerdown is invoked.

### 11.4.1 Entering Powerdown Mode

To enter powerdown mode, set the PCON register PD bit. The 8XC251SB enters the power-down mode upon execution of the instruction that sets the PD bit. The instruction that sets the PD bit is the last instruction executed.

### 11.4.2 Exiting Powerdown Mode

## CAUTION

If $\mathrm{V}_{\mathrm{CC}}$ was reduced during the powerdown mode, do not exit powerdown until $\mathrm{V}_{\mathrm{CC}}$ is restored to the normal operating level.

There are two ways to exit the powerdown mode:

- Generate an enabled external interrupt. Hardware clears the PD bit in the PCON register which starts the oscillator and restores the clocks to the CPU and peripherals. Execution resumes with the interrupt service routine. Upon completion of the interrupt service routine, program execution resumes with the instruction immediately following the instruction that activated powerdown mode.


## NOTE

To enable an external interrupt, set the IE register EX0 and/or EX1 bit[s]. The external interrupt used to exit powerdown mode must be configured as level sensitive and must be assigned the highest priority. In addition, the duration of the interrupt must be of sufficient length to allow the oscillator to stabilize.

- Generate a reset. See "Reset" on page 10-5. A logic high on the RST pin clears the PD bit in the PCON register directly and asynchronously. This starts the oscillator and restores the clocks to the CPU and peripherals. Program execution momentarily resumes with the instruction immediately following the instruction that activated powerdown and may continue for a number of clock cycles before the internal reset algorithm takes control. Reset initializes the 8 XC 251 SB and vectors the CPU to address FF:0000H.


## NOTE

During the time that execution resumes, the internal RAM cannot be accessed; however, it is possible for the port pins to be accessed. To avoid unexpected outputs at the port pins, the instruction immediately following the instruction that activated the powerdown mode should not write to a port pin or to the external RAM.

### 11.5 ON-CIRCUIT EMULATION (ONCE) MODE

The on-circuit emulation (ONCE) mode permits external testers to test and debug 8XC251SBbased systems without removing the chip from the circuit board. A clamp-on emulator or test CPU is used in place of the 8 XC 251 SB which is electrically isolated from the system.

### 11.5.1 Entering ONCE Mode

To enter the ONCE mode:

1. Assert RST to initiate a device reset. See "Externally Initiated Resets" on page 10-6 and the reset waveforms in Figure 10-5 on page 10-8.
2. While holding RST asserted, apply and hold logic levels to I/O pins as follows: PSEN\# = low, P0.7:5 = low, P0.4 = high, P0.3:0 = low (i.e., port $0=10 \mathrm{H}$ ).
3. Deassert RST, then remove the logic levels from PSEN\# and port 0.

These actions cause the 8 XC 251 SB to enter the ONCE mode. Port 1,2 , and 3 pins are weakly pulled high and port 0 , ALE, and PSEN\# pins are floating (Table 11-1). Thus the device is electrically isolated from the remainder of the system which can then be tested by an emulator or test CPU. Note that in the ONCE mode the device oscillator remains active.

### 11.5.2 Exiting ONCE Mode

To exit ONCE mode, reset the device.

## intel.

## External Memory <br> Interface

## CHAPTER 12 EXTERNAL MEMORY INTERFACE

The external memory interface comprises the external bus (ports 0 and 2) and the bus control signals. Chip configuration bytes determine several interface options: page mode or nonpage mode for external code fetches, the number of external address bits ( 16 or 17), the address ranges for PSEN\# and RD\#, and external wait states. You can use these options to tailor the interface to your application. This chapter describes the external memory interface, its configuration, and the external bus cycles. Examples illustrate several types of external memory designs.

### 12.1 EXTERNAL MEMORY INTERFACE SIGNALS

Table 12-1 describes the external memory interface signals. The address and data signals (AD7:0 on port 0 and A15:8 on port 2 ) are defined for nonpage mode. Address bits A7:0 are multiplexed with the data (D7:0) on port 0 , and address bits A15:8 are on port 2 . In page mode, address bits A7:0 are on port 0 , and address bits A15:8 are multiplexed with the data (D7:0) on port 2 (see "Page Mode Bus Cycles" on page 12-10).

Table 12-1. External Memory Interface Signals

| Signal <br> Name | Type | Description | Multiplexed <br> With |
| :--- | :---: | :--- | :--- | :--- |
| A16 | O | Address Line 16. See RD\#. | N.A. |
| A15:8 $\dagger$ | O | Address Lines. Upper address lines for the external bus. | P2.7:0 |
| AD7:0† | I/O | Address/Data Lines. Multiplexed lower address lines and data lines <br> for the external bus. | P0.7:0 |
| ALE | O | Address Latch Enable. ALE signals the start of an external bus cycle <br> and indicates that valid address information is available on lines A15:8 <br> and AD7:0. An external latch can use ALE to demultiplex the address <br> from the address/data bus. | PROG\# |
| EA\# | I | External Access. Directs program memory accesses to on-chip or off- <br> chip code memory. For EA\# strapped to ground, all program memory <br> accesses are off-chip. For EA\# = strapped to VCc, an access is to on- <br> chip OTPROM/ROM if the address is within the range of the on-chip <br> OTPROM/ROM; otherwise the access is off-chip. The value of EA\# is <br> latched at reset. For a ROMless part, EA\# must be strapped to ground. | $\mathrm{V}_{\text {PP }}$ |

†The descriptions of A15:8/P2.7:0 and AD7:0/P0.7:0 are for the nonpage-mode chip configuration (compatible with 44-Ids PLCC MCS ${ }^{\circledR} 51$ microcontrollers). If the chip is configured for page-mode operation, port 0 carries the lower address bits (A7:0), and port 2 carries the upper address bits (A15:8) and the data (D7:0).

Table 12-1. External Memory Interface Signals (Continued)

| Signal Name | Type | Description | Multiplexed With |
| :---: | :---: | :---: | :---: |
| PSEN\# | 0 | Program Store Enable. Read signal output. This output is asserted for a memory address range that depends on bits RD0 and RD1 in configuration byte CONFIG1 (see also RD\#): <br> RD1 RD0 Address Range for Assertion <br> 0 Reserved <br> 1 All addresses <br> 0 All addresses <br> 1 All addresses $\geq 80: 0000 \mathrm{H}$ | - |
| RD\# | 0 | Read or 17th Address Bit (A16). Read signal output to external data memory or 17th external address bit (A16), depending on the values of bits RD0 and RD1 in configuration byte CONFIG1. (See also PSEN\#): <br> RD1 RDO Function <br> 0 Reserved <br> 1 The pin functions as A16 only. <br> 0 The pin functions as P3.7 only. <br> 1 RD\#: asserted for reads at all addresses £ 7F:FFFFH | P3.7 |
| WR\# | 0 | Write. Write signal output to external memory. For configuration bits RD1 $=$ RD0 $=1$, WR\# is strobed only for writes to locations $000000 \mathrm{H}-$ 01 FFFFH. For other values of RD1 and RDO, WR\# is strobed for writes to all memory locations. | P3.6 |

†The descriptions of A15:8/P2.7:0 and AD7:0/P0.7:0 are for the nonpage-mode chip configuration (compatible with 44-Ids PLCC MCS ${ }^{\circledR} 51$ microcontrollers). If the chip is configured for page-mode operation, port 0 carries the lower address bits (A7:0), and port 2 carries the upper address bits (A15:8) and the data (D7:0).

### 12.2 CONFIGURING THE EXTERNAL MEMORY INTERFACE

This section describes the configuration options that affect the external memory interface. ("Configuration Bytes" on page 13-6 describes the configuration bytes.) The configuration bits described here determine the following interface features:

- page mode or nonpage mode
- the number of external address pins (16 or 17)
- the memory regions assigned to the read signals RD\# and PSEN\#
- the external wait states
- mapping a portion of on-chip code memory to data memory


### 12.2.1 Page Mode and Nonpage Mode (PAGE Bit)

The PAGE bit (bit 1 in CONFIG0) selects page-mode or nonpage-mode code fetches and determines the structure of the external bus. See "Page Mode Bus Cycles" on page 12-10 for a description of page mode and the bus structure.

- $\operatorname{PAGE}=1$. The 8 XC 251 SB operates in nonpage mode. The bus structure is the same as for the MCS 51 architecture, and external code fetches require two state times $\left(4 \mathrm{~T}_{\mathrm{OSC}}\right)$.
- PAGE $=0$. The 8 XC 251 SB operates in page mode. The bus structure is different from the bus structure in MCS 51 controllers, and under certain conditions, external code fetches require only one state time $\left(2 \mathrm{~T}_{\mathrm{OSC}}\right)$.


### 12.2.2 RD\#, PSEN\#, and the Number of External Address Pins (Bits RD1:0)

The RD1:0 configuration bits (bits 2 and 3 in CONFIG0) determine the number of external address lines and the address ranges for strobing the read signals PSEN\# and RD\#. These selections offer different ways of addressing external memory.

A key to using the memory interface is the relationship between internal memory addresses and external memory addresses. While the 8XC251SB has 24 internal address bits, it has only 16 external address pins, A15:0 on ports 0 and 2 . Therefore, internal addresses that differ only in their upper eight bits are indistinguishable at the external address pins. For example, if you write to location $00: 6000 \mathrm{H}$ and location $01: 6000 \mathrm{H}$, the same address $(6000 \mathrm{H})$ appears at the external address pins. The 16 pins can address only 64 Kbytes of external memory. The options provided by bits RD1:0, offer ways to expand the external memory space beyond 64 Kbytes .

Table 12-2 describes how RD\# and PSEN\# function for the values of RD1:0. RD\# can function as a read signal, as a general-purpose I/O signal, or as the seventeenth external address bit A16. PSEN\# always functions as a read signal, and in two cases PSEN\# is a read strobe for data memory as well as code memory. For a design that is compatible with MCS 51 microcontrollers, select RD1 $=1$ and $\mathrm{RD} 0=1$.

Table 12-2. Configuration Bits RD1:0

| RD1 RD0 | External <br> Address Bits | RD\# | PSEN\# |  |
| :---: | :---: | :---: | :--- | :--- |
| 0 | 0 | - | Reserved |  |
| 0 | 1 | 17 | RD\# is the 17th address bit (A16). | PSEN\# is strobed for all addresses. |
| 1 | 0 | 16 | RD\# is a general-purpose I/O signal <br> (P3.7). | PSEN\# is strobed for all addresses. |
| 1 | 1 | 16 | RD\# is strobed for locations <br> 00:0000H-7F:FFFFH. | PSEN\# is strobed for locations <br> $80: 0000 H-F F: F F F F H$. |

### 12.2.2.1 Sixteen External Address Bits and a Single Read Signal (RD1 = 1, RD0 = 0)

For RD1 $=1$ and RD0 $=0$, PSEN\# is strobed for all external reads, and pin RD\#/P3.7 is devoted exclusively to general-purpose I/O, i.e., it does not function as RD\#. With this configuration you can address the minimum amount of external memory ( 64 Kbytes ), but you gain an extra I/O channel (P3.7). Figure 12-1 illustrates the difference between the internal and external memory spaces for these values of RD1:0. Regions $00:, 01$ :, FE:, and FF: of internal memory are mapped into a single $64-K b y t e ~ r e g i o n ~ o f ~ e x t e r n a l ~ m e m o r y . ~ T h i s ~ s e l e c t i o n ~ o f ~ R D 1: 0 ~ c a n ~ b e ~ u s e d, ~ f o r ~ e x-~$ ample, in a design where the $87 \mathrm{C} 251 \mathrm{SB} / 83 \mathrm{C} 251 \mathrm{SB}$ executes from on-chip code memory and accesses 64 Kbytes of external RAM.


Figure 12-1. Internal and External Memory Spaces for RD1 $=1$, RD0 $=0$

### 12.2.2.2 Seventeen External Address Bits and a Single Read Signal (RD1 = 0, RD0 = 1)

For RD1 $=0$ and RD0 $=1$, the RD\# signal becomes the seventeenth external address bit (A16) and PSEN\# is strobed for all external reads. The 17 external address bits can address 128 Kbytes of external memory. As illustrated in Figure 12-2, internal memory regions 00: and FE: are mapped into external memory region 0 , and internal memory regions 01 : and FF: are mapped into external memory region 1 . This option provides supports three basic designs:

- 128 Kbytes of external code memory (addressed as regions FE: and FF:)
- 128 Kbytes of external data memory (addressed as regions 00: and 01:)
- 64 Kbytes of external code memory (addressed as region FF:) and 64 Kbytes of external data memory (addressed as region 00:).

Sections 12.6.2 and 12.6.5 show examples of memory designs with this option.


Figure 12-2. Internal and External Memory Spaces for RD1 = 0, RD0 = 1

### 12.2.2.3 Sixteen External Address Bits and Two Read Signals (RD1 = 1, RDO = 1)

For RD1 $=1$ and $\mathrm{RD} 0=1$, there are 16 external address bits; however, $\mathrm{RD} \#$ is strobed for regions 00: and 01:, and PSEN\# is strobed for regions FE: and FF:. As illustrated in Figure 12-3, regions 00: and 01: are mapped into 64 Kbytes of data memory (strobed by RD\#), and regions FE: and FF: are mapped into 64 Kbytes of code memory (strobed by PSEN\#). This selection is compatible with MCS 51 microcontrollers and supports designs that use both external code memory and external data memory.

For this selection of RD1:0, WR\# is strobed for writes to regions 00: and 01: but is not strobed for writes to regions FE: and FF:. This is compatible with MCS 51 microcontrollers, which cannot write to external code memory. Sections 12.6.1 and 12.6.4 show examples of memory designs with this option.


Figure 12-3. Internal and External Memory Spaces for RD1 = 1, RD0 = 1

### 12.2.3 Wait States (WSA, WSB, XALE)

You can add wait states to external bus cycles by extending the PSEN\#/RD\#/WR\# pulse and/or extending the ALE pulse:

- The WSA bit (bit 5 in CONFIG0) and the WSB bit (bit 3 in CONFIG1) specify the wait states (0 or 1) added by extending the time that PSEN\#/RD\#/WR\# is asserted from $\mathrm{T}_{\mathrm{OSC}}$ to $3 \mathrm{~T}_{\mathrm{OSC}}$. This wait state accommodates slower external devices and allows the 8XC251SB to directly replace the 8 XC 51 FB in a system design. The combinations of WSA and WSB select the memory regions to bé accessed with one wait state (Table 12-3). The option of a wait state for region 01 : is for accessing a slow external device addressed in region 01 : without slowing down accesses to other external devices. "Extending PSEN\#/RD\#/WR\#" on page 12-13 shows bus cycles with PSEN\#/RD\# extended and WR\# extended.

Table 12-3. Wait State Selection

| WSB | WSA | Memory Regions with 1 Wait State |
| :---: | :---: | :--- |
| 0 | 0 | All regions (00:, 01:, FE:, FF:) |
| 0 | 1 | Region 01: |
| 1 | 0 | Regions 00;, FE:, FF: |
| 1 | 1 | None |

- Clearing XALE (bit 4 in CONFIG0) extends the time ALE is asserted from $\mathrm{T}_{\text {osc }}$ to $3 \mathrm{~T}_{\text {osc }}$. This accommodates an address latch that is too slow for the normal ALE signal. "Extending ALE" on page 12-14 shows a bus cycle with ALE extended.

You can add two wait states by extending both ALE and the read/write signals (PSEN\#, RD\#, WR\#).

### 12.2.4 Mapping On-chip Code Memory to Data Memory (87C251SB/83C251SB)

For the $87 \mathrm{C} 251 \mathrm{SB} / 83 \mathrm{C} 251 \mathrm{SB}$, the EMAP bit (bit 0 in CONFIG1) provides the option of accessing the upper 8 Kbytes of on-chip code memory as data memory.

EMAP $=\mathbf{0}$. The upper 8 Kbytes of the on-chip code memory (FF:2000H-FF:3FFFH) are mapped to locations $00: \mathrm{E} 000 \mathrm{H}-00: \mathrm{FFFFH}$ (in addition to locations FF:2000H-FF:3FFFH). This allows code constants to be accessed as data in region 00:. See "On-chip Code Memory ( $87 \mathrm{C} 251 \mathrm{SB} / 83 \mathrm{C} 251 \mathrm{SB}$ )" on page $3-6$ for the exact conditions required for this mapping to be effective.

EMAP $=$ 1. Locations FF:2000H-FF:3FFFH are not mapped to region 00:. Locations $00: \mathrm{E} 000 \mathrm{H}-00: \mathrm{FFFFH}$ are implemented by external RAM.

### 12.3 EXTERNAL BUS CYCLES

The 8XC251SB executes external bus cycles to fetch code, read data, and write data in external memory. This section uses bus waveforms with idealized timings to describe the external bus cycles in nonpage mode and page mode. The bus cycles in this section have no wait states. (For bus cycles with wait states, see "Wait States" on page 12-13.) Timing parameters for the bus cycles are given in "External Bus AC Timing Specifications" on page 12-24.
"Inactive External Bus" describes the situations where the bus is not executing external bus cycles.

### 12.3.1 Inactive External Bus

The external bus is inactive (not executing external bus cycles) under any of these three conditions:

- The chip is in normal operating mode but no external read or write cycles are executing (the bus-idle condition).
- The chip is in idle mode.
- The chip is in powerdown mode.


### 12.3.2 Bus Cycle Definitions

Table 12-4 summarizes the activity on the bus for bus cycles in nonpage mode and page mode with no wait states. Nonpage mode has only two types of bus cycles: a code/data read cycle and a write cycle. Page mode has four types of bus cycles: a code-read cycle for a page miss, a coderead cycle for a page hit, a data-read cycle, and a write cycle. The data-read and write cycles are the same for page mode and nonpage mode (except for the different signals on ports 0 and 2 ).

Table 12-4. Bus Cycle Definitions (No Wait States)

| Mode | Bus Cycle | Bus Activity |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  | State 1 | State 2 | State 3 |
| Nonpage Mode | Code/Data Read | ALE Strobe | PSEN\#/RD\# Strobe | (3) |
|  | Write | ALE Strobe | WR\# Strobe | WR\# High |
| Page Mode | Code Read (Page Miss) | ALE Strobe | PSEN\#/RD\# Strobe | (3) |
|  | Code Read (Page Hit) | PSEN\# Strobe | (4) |  |
|  | Data Read (1) | ALE Strobe | PSEN\#/RD\# Strobe |  |
|  | Write (2) | ALE Strobe | WR\# Strobe | WR\# high |

## NOTES:

1. The code/data read cycle in nonpage mode and the data-read cycle in page mode are the same, except for the different signals on ports 0 and 2.
2. The write cycle is the same in page mode and nonpage mode, except for the difference in bus structure.
3. Only write cycles have a third state.
4. A page hit requires only one state.

### 12.3.3 Nonpage Mode Bus Cycles

In nonpage mode, the external bus structure is the same as for MCS 51 microcontrollers. The upper address bits (A15:8) are on port 2, and the lower address bits (A7:0) are multiplexed with the data (D7:0) on port 0 . External code fetches and data reads use the two-state bus cycle shown in Figure 12-4. For the write cycle (Figure 12-5), a third state is appended to provide recovery time for the bus. Note that the write signal WR\# is strobed for all memory regions, except for the case of RD1 $=1$ and RD0 $=1$, where WR\# is strobed for regions 00 : and 01 : but not for regions FE: and FF :


Figure 12-4. External Code Fetch or Data Read Bus Cycle (Nonpage Mode)


Figure 12-5. External Write Bus Cycle (Nonpage Mode)

### 12.3.4 Page Mode Bus Cycles

Page mode increases performance by reducing the time for external code fetches. Under certain conditions the controller fetches an instruction from external memory in one state time instead of two. Page mode does not affect internal code fetches.

The first code fetch to a 256-byte "page" of memory always uses a two-state bus cycle. Subsequent successive code fetches to the same page (page hits) require only a one-state bus cycle. When a subsequent fetch is to a different page (a page miss) it again requires a two-state bus cycle. The following external code fetches are always page-miss cycles:

- the first external code fetch after a page rollover ${ }^{\dagger}$
- the first external code fetch after an external data bus cycle
- the first external code fetch after powerdown or idle mode
- the first external code fetch after a branch, return, interrupt, etc.

In page mode, the 8 XC 251 SB bus structure is different from the bus structure in MCS 51 controllers (Figure 12-6). The upper address bits A15:8 are multiplexed with the data D7:0 on port 2, and the lower address bits (A7:0) are on port 0.


Figure 12-6. Bus Structure in Nonpage Mode and Page Mode

[^2]Figure 12-7 shows the two types of external bus cycles for code fetches in page mode. The pagemiss cycle is the same as a code fetch cycle in nonpage mode (except for the different signals on ports 0 and 2). For the page-hit cycle, the upper eight address bits are the same as for the preceding cycle. Therefore, ALE is not strobed, and the values of A15:8 are retained in the address latches. In a single state, the new values of A7:0 are placed on port 0 , and memory places the instruction byte on port 2 . Notice that a page hit reduces the available address access time by one state. Therefore, faster memories may be required to support page mode.


Figure 12-7. External Code Fetch Bus Cycle (Page Mode)
Figure 12-8 and Figure 12-9 show the bus cycles for data reads and writes in page mode. These cycles are identical to those for nonpage mode, except for the different signals on ports 0 and 2.


Figure 12-8. External Data Read Bus Cycle (Page Mode)


Figure 12-9. External Write Bus Cycle (Page Mode)

### 12.4 WAIT STATES

The 8 XC 251 SB can be configured to add an external wait state by extending the RD\#/PSEN\#/WR\# pulses or by extending the ALE pulse (see "Wait States (WSA, WSB, XALE)" on page 12-6). You can also configure the chip to use both types of wait states for a total of two external wait states. Accesses to on-chip code and data memory always use zero wait states.

### 12.4.1 Extending PSEN\#/RD\#/WR\#

Figures 12-10 and 12-11 show bus cycles with an extended RD\#/PSEN\# wait state and an extended WR\# wait state.


Figure 12-10. External Code Fetch or Data Read Bus Cycle with One PSEN\#/RD\# Wait State (Nonpage Mode)


Figure 12-11. External Write Bus Cycle with One WR\# Wait State (Nonpage Mode)

### 12.4.2 Extending ALE

Figure 12-12 shows a bus cycle for a code-fetch or a data-read with an extended ALE wait state. The wait state extends the bus cycle from two states to three. For an external write, the extended ALE extends the bus cycle from three states to four.


Figure 12-12. External Code Fetch or Data Read Bus Cycle with One ALE Wait State (Nonpage Mode)

### 12.5 PORT 0 AND PORT 2 STATUS

This section summarizes the status of the port 0 and port 2 pins when these ports are used as the external bus. A more comprehensive description of the ports and their use is given in Chapter 6, "Input/Output Ports."

When port 0 and port 2 are used as the external memory bus, the signals on the port pins can originate from three sources:

- the 8XC251SB CPU (address bits, data bits)
- the port SFRs: P0 and P2 (logic levels)
- an external device (data bits)

The port 0 pins (but not the port 2 pins) can also be held in a high-impedance state. Table 12-5 lists the status of the port 0 and port 2 pins when the chip in is the normal operating mode and the external bus is idle or executing a bus cycle.

Table 12-5. Port 0 and Port 2 Pin Status In Normal Operating Mode

| Port | 8-bit/16-bit <br> Addressing | Nonpage Mode |  | Page Mode |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Bus Cycle | Bus Idle | Bus Cycle | Bus Idle |
| Port 0 | 8 or 16 | AD7:0 (1) | High Impedance | A7:0 (1) | High Impedance |
| Port 2 | 8 | P2 (2) | P2 | P2/D7:0 (2) | High Impedance |
|  | 16 | A15:8 | P2 | A15:8/D7:0 | High Impedance |

## NOTES:

1. During external memory accesses, the CPU writes FFH to the PO register and the register contents are lost.
2. The P2 register can be used to select 256 -byte pages in external memory.

### 12.5.1 Port 0 and Port 2 Pin Status in Nonpage Mode

In nonpage mode the port pins have the same signals as those on the 8XC51FX. For an external memory instruction using a 16-bit address, the port pins carry address and data bits during the bus cycle. However, if the instruction uses an 8-bit address (e.g., MOVX @Ri), the contents of P2 are driven onto the pins. These pin signals can be used to select 256-bit pages in external memory.

During a bus cycle, the CPU always writes FFH to P0, and the former contents of P0 are lost. A bus cycle does not change the contents of P 2 . When the bus is idle, the port 0 pins are held at high impedance, and the contents of P2 are driven onto the P2 pins.

### 12.5.2 Port 0 and Port 2 Pin Status in Page Mode

In a page-mode bus cycle, the data is multiplexed with the upper address byte on port 2 . However, if the instruction uses an 8-bit address (e.g., MOVX @Ri), the contents of P2 are driven onto the pins when data is not on the pins. These logic levels can be used to select 256 -bit pages in external memory. During bus idle, the port 0 and port 2 pins are held at high impedance.
(For port pin status when the chip in is idle mode, powerdown mode, or reset, see Chapter 11, "Special Operating Modes.")

### 12.6 EXTERNAL MEMORY DESIGN EXAMPLES

This section shows five examples of external memory designs for 8XC251SB systems. The examples illustrate the design flexibility provided by the configuration options, especially for the PSEN\# and RD\# signals. Many other designs are possible.

### 12.6.1 Nonpage Mode, 64 Kbytes External EPROM, 64 Kbytes External RAM

Figure 12-13 shows an 80C251SB in nonpage mode with 64 Kbytes of external EPROM and 64 Kbytes of external RAM. The 80 C 251 SB is configured so that RD\# strobes for addresses $\leq 7 \mathrm{~F}:$ FFFFH and PSEN\# strobes for addresses $\geq 80: 0000 \mathrm{H}$ (RD1 = 1 and RD0 $=1$ ). Figure 12-14 shows two ways to address the external memory in the internal memory space.

The lower 1056 bytes of the external RAM must be addressed in region 01:. Addressing the other external RAM locations in either region 00: or region 01: produces the same address at the external bus pins. However, if the external EPROM and the external RAM require different numbers of wait states, the external RAM must be addressed entirely in region 01:. (Recall that regions 00:, FE:, and FF: always have the same number of wait states. See "Wait States (WSA, WSB, XALE)" on page 12-6.)

The examples that follow illustrate two possibilities for addressing the external RAM.

### 12.6.1.1 An Application Requiring Fast Access to the Stack

If an application requires fast access to the stack, the stack can reside in the fast on-chip data RAM ( $00: 0020 \mathrm{H}-00: 041 \mathrm{FH}$ ) and, when necessary, roll out into the slower external RAM. In this case, the external RAM can have a wait state only if the EPROM has a wait state. Otherwise, if the stack rolls out above location 00:041FH, the external RAM would be accessed with no wait state. Regions 00: and 01: on the left side of Figure 12-14 apply to this example.

### 12.6.1.2 An Application Requiring Fast Access to Data

If fast access to a block of data is more important than fast access to the stack, the data can be stored in the on-chip data RAM, and the stack can be located entirely in external memory. If the external RAM has a wait state and the EPROM has no wait state, the external RAM must be addressed entirely in region 01:. Regions 00: and 01: on the right side of Figure 12-14 apply to this example.


Figure 12-13. 80C251SB in Nonpage Mode with External EPROM and RAM


Figure 12-14. The Memory Space for the Systems of Figure 12-13 and Figure 12-18

### 12.6.2 Nonpage Mode, 128 Kbytes External RAM

Figure $12-15$ shows an $87 \mathrm{C} 251 \mathrm{SB} / 83 \mathrm{C} 251 \mathrm{SB}$ in nonpage mode with 128 Kbytes of external RAM. The $87 \mathrm{C} 251 \mathrm{SB} / 83 \mathrm{C} 251 \mathrm{SB}$ is configured so that RD\# functions as A16, and PSEN\# is strobed for all addresses ( $\mathrm{RD} 1=0, \mathrm{RD} 0=1$ ). Figure $12-16$ shows how the external RAM is addressed in the internal memory space. The lower 1056 bytes of external RAM are unavailable because accesses to the lower 1056 bytes in region 00: are directed to on-chip RAM.


Figure 12-15. $\mathbf{8 7 C 2 5 1 S B} / 83 C 251 S B$ in Nonpage Mode with 128 Kbytes of External RAM


Figure 12-16. The Memory Space for the System of Figure 12-15

### 12.6.3 Page Mode, 128 Kbytes External Flash

Figure 12-17 shows the 80C251SB in page mode with 128 Kbytes of external flash. Note that port 2 carries both the upper address bits (A15:0) and the data (D7:0), while port 0 carries only the lower address bits (A7:0). The 80C251SB is configured for 17 external address bits and a single read signal (PSEN\#). The 128 Kbytes of external flash are accessed in pages FE: and FF: in the internal memory space.


Figure 12-17. 80C251SB in Page Mode with External Flash

### 12.6.4 Page Mode, 64 Kbytes External EPROM, 64 Kbytes External RAM

Figure $12-18$ shows an 80 C 251 SB in page mode with 64 Kbytes of external EPROM and 64 Kbytes of external RAM. The 80 C 251 SB is configured so that RD\# strobes for addresses $\leq$ $7 F: F F F F H$, and PSEN\# strobes for addresses $\geq 80: 0000 \mathrm{H}(\mathrm{RD} 1=1$ and RD0 $=1$ ).

This system is the same as the system in Figure 12-13 on page 12-17, except that this design operates in page mode. Accordingly, the two systems have the same memory map (Figure 12-14 on page 12-18), and the comments on addressing external RAM apply here also.


Figure 12-18. 80C251SB in Page Mode with External EPROM and RAM

### 12.6.5 Page Mode, 64 Kbytes External Flash, $\mathbf{3 2}$ Kbytes External RAM

Figure 12-19 shows an 80C251SB in page mode with 64 Kbytes of external flash memory for code storage and 32 Kbytes of external RAM. The 80 C 251 SB is configured so that PSEN\# is strobed for all reads, and RD\# functions as $\mathrm{A} 16(\mathrm{RD} 1=0, \mathrm{RD} 0=1)$. Figure $12-20$ shows how the external flash and RAM are addressed in the internal memory space. The external RAM is accessed for internal addresses 00:0420H-00:7FFFH. The first 1056 bytes of external RAM are unused because accesses to locations $00: 0000 \mathrm{H}-00: 041 \mathrm{FH}$ are directed to on-chip RAM.


Figure 12-19. 80C251SB in Page Mode with External Flash and RAM


Figure 12-20. The Memory Space for the System of Figure 12-19

### 12.7 EXTERNAL BUS AC TIMING SPECIFICATIONS

This section defines the AC timing specifications for the external bus. Refer to the latest data sheet to be sure that your system meets specifications. Figure 12-21 shows the bus waveforms for instruction or data reads and data writes in nonpage mode. Figure 12-22 shows the bus waveforms for data reads and data writes in page mode, and Figure 12-23 shows the bus waveforms for instruction fetches in page mode. Table 12-6 on page 12-28 defines the symbols used in the timing diagrams. Tables 12-8 and 12-7 define the timing parameters.

${ }^{\dagger}$ The value of this parameter depends on wait states. See the table of AC characteristics.

Figure 12-21. External Bus Cycles for Data/Instruction Read and Data Write in Nonpage Mode


Figure 12-22. External Bus Cycles for Data Read and Data Write in Page Mode

$\dagger$ The value of this parameter depends on wait states. See the table of AC characteristics.
$\dagger \dagger$ A page hit (i.e., a code fetch to the same 256 -byte "page" as the previous code fetch) requires one state ( $2 \mathrm{~T}_{\text {OSC }}$ ); a page miss requires two states ( $4 \mathrm{~T}_{\mathrm{OSC}}$ ).

Figure 12-23. External Bus Cycles for Instruction Read in Page Mode

### 12.7.1 Explanation of AC Symbols

Each symbol consists of two pairs of letters prefixed by "T" (for time). The characters in a pair indicate a signal and its condition, respectively. Symbols represent the time between the two signal/condition points. For example, $\mathrm{T}_{\text {LHRL }}$ is the time between signal L (ALE) condition H (high) and R (RD\#) condition $L$ (Low). Table 12-6 defines the signal and condition codes

Table 12-6. AC Timing Symbol Definitions

|  | Signals |
| :--- | :--- |
| A | Address |
| D | DATA |
| L | ALE |
| Q | Data Out |
| R | RD\#/PSEN\# |
| W | WR\# |


| Conditions |  |
| :--- | :--- |
| H | High |
| L | Low |
| V | Valid |
| X | No Longer Valid |
| $Z$ | Floating |

### 12.7.2 AC Timing Definitions

This section defines the timing parameters shown in Figures 12-21, 12-22, and 12-23. Tables 12-8 and 12-7 list the definitions of timing specifications on the memory system and the 8XC251SB.

Table 12-7. AC Timing Definitions for Specifications on the 8XC251SB

| THE 8XC251SB MEETS THESE SPECIFICATIONS |  |  |
| :---: | :---: | :---: |
| Symbol | Definition | Notes |
| $\mathrm{F}_{\text {osc }}$ | Frequency on XTAL: Frequency of the signal input on the XTAL1 input. |  |
| Tosc | 1/Fosc: Period of the signal on XTAL1/XTAL2: AC Timings are referenced to Tosc . |  |
| T ${ }_{\text {LHLL }}$ | ALE Pulse Width: Length of time ALE is asserted. | (2) |
| $\mathrm{T}_{\text {LHRL }}$ | ALE High to RD\# or PSEN\# Low: Time after ALE goes high until RD\# or PSEN\# goes low. | (1) |
| $\mathrm{T}_{\text {RLRH }}$ | RD\# or PSEN\# Pulse Width: Length of time RD\# or PSEN\# is asserted. | (3) |
| $\mathrm{T}_{\text {RHLH }}$ | RD\# High to ALE Asserted: Time after RD\# goes high until the next ALE pulse goes high. | (1) |
| $\mathrm{T}_{\text {RLAZ }}$ | RD\# Low to Address Float: Time after RD\# goes low until the 8XC251SB stops driving the address on the bus. |  |
| $\mathrm{T}_{\text {AVLL }}$ | Address Valid to ALE Low. Length of time the lower byte of the address is valid (on port 0) before ALE goes low. | (2) |
| $\mathrm{T}_{\text {Lhax }}$ | ALE High to Address Hold. Length of time the 8XC251SB holds the lower byte of the address on the bus (port 0) after ALE goes high. | (2) |
| $\mathrm{T}_{\text {LLAX }}$ | Address Hold after ALE Low: Length of time the 8XC251SB holds the lower byte of the address on the bus (port 0) after ALE goes low. |  |
| $\mathrm{T}_{\text {AVRL }}$ | Address Valid to RD\# or PSEN\# Low: Length of time the lower byte of the address is valid on the bus (port 0 ) before RD\# or PSEN\# goes low. | $(1,2)$ |
| $T_{\text {WLWH }}$ | WR\# Pulse Width: Length of time WR\# is asserted. | (3) |
| $\mathrm{T}_{\text {WHLL }}$ | WR\# High to ALE High: Time after WR\# goes high until the next ALE pulse is goes high. |  |
| $\mathrm{T}_{\text {AVWL } 1}$ | Address (port 0) Valid to WR\# Low: Length of time that the 8XC251SB drives the address onto the bus (port 0) before WR\# goes low. | (2) |
| $\mathrm{T}_{\text {AVWL2 }}$ | Address (port 2) Valid to WR\# Low: Length of time that the 8XC251SB drives the address onto the bus (port 2) before WR\# goes low. | (2) |
| $\mathrm{T}_{\text {WHAX }}$ | Address Hold after WR\# High: Time the 8XC251SB holds the upper byte of the address on the bus (port 2) after WR\# goes high. |  |

## NOTES:

1. Specifications for PSEN\# are identical to those for RD\#.
2. If a wait state is added by extending ALE, this time increases by $2 \mathrm{~T}_{\text {osc }}$.
3. If a wait state is added by extending RD\#/PSEN\#NR\#, this time increases by $2 T_{\text {osc }}$.
4. If wait states are added as described in both Note 2 and Note 3 , this time increases by a total of $4 \mathrm{~T}_{\text {osc }}$.

Table 12-8. AC Timing Definitions for Specifications on the Memory System

| THE EXTERNAL MEMORY SYSTEM MUST MEET THESE SPECIFICATIONS |  |  |
| :---: | :---: | :---: |
| Symbol | Definition | Notes |
| $\mathrm{T}_{\text {RHDZ }}$ | Data/Instruction Float After RD\# or PSEN\# High: Time after RD\# or PSEN\# goes high until memory system must float the bus. If this timing is not met, bus contention occurs. | (1) |
| $\mathrm{T}_{\text {RHDX }}$ | Data/Instruction Hold After RD\#/ PSEN\# High: Length of time the memory system must hold data on the bus after RD\# or PSEN\# goes high. | (1) |
| TrLDV | RD\# Low to Input Data Valid: Time after RD\# goes low until the memory system must output valid data/instruction. | $(1,3)$ |
| Tavwh | Data Valid to WR\# High: Length of time the memory system must output valid data before WR\# goes high. |  |
| $\mathrm{T}_{\text {whax }}$ | Data Hold after WR\# High: Length of time the memory system must hold data on the bus after WR\# goes high. |  |
| $\mathrm{T}_{\text {AVDV1 }}$ | Address (port 0) valid to Valid Data/Instruction In: Time after the 8XC251SB places a valid address on the bus (port 0) until the memory system must place valid data on the bus (port 0). | $(2,3,4)$ |
| $\mathrm{T}_{\text {AvDV2 }}$ | Address (port 2) Valid to Valid Data/Instruction In: Time after the 8XC251SB places a valid address on the bus (port 2) until the memory system must place valid data/instruction on the bus (port 0 ). If the bus cycle is an instruction fetch, this applies to a page miss. | $(2,3,4)$ |
| $\mathrm{T}_{\text {AvDV3 }}$ | Address (port 2) Valid to Valid Instruction In: Time after the 8XC251SB places a valid address on the bus (port 2) until the memory system must place a valid instruction on the bus (port 0 ). This applies to a page hit. |  |

## NOTES:

1. Specifications for PSEN\# are identical to those for RD\#.
2. If a wait state is added by extending ALE, this time increases by $2 \mathrm{~T}_{\text {osc }}$ -
3. If a wait state is added by extending RD\#/PSEN\#NR\#, this time increases by $2 T_{\text {osc }}$.
4. If wait states are added as described in both Note 2 and Note 3 , this time increases by a total of $4 \mathrm{~T}_{\text {osc }}$

## intel.

# Programming and Verifying Nonvolatile Memory 

## CHAPTER 13 PROGRAMMING AND VERIFYING NONVOLATILE MEMORY

This chapter provides instructions for programming and verifying on-chip nonvolatile memory on the 8 XC 251 SB . The programming instructions cover the entry of program code into on-chip code memory and other categories of information into nonvolatile memory outside the memory address space. The verify instructions permit reading these memory locations to verify their contents. The operations covered in this chapter are:

- programming and verifying the on-chip code memory (16 Kbytes)
- programming and verifying the configuration bytes (4 bytes)
- programming and verifying the lock bits
- programming the encryption array
(128 bytes)
- verifying the signature bytes
(3 bytes)
The programming instructions apply to the one-time-programmable 87C251SB (OTPROM). The verify instructions apply to the 87 C 251 SB , the 83 C 251 SB (ROM), and the configuration bytes on the 80 C 251 SB (ROMless). In the unprogrammed state, OTPROM contains all 1 s .


### 13.1 GENERAL

The 87C251SB OTPROM device is programmed and verified in the same manner as the 87 C 51 FX , using the same quick-pulse programming algorithm, which programs at $\mathrm{V}_{\mathrm{PP}}=12.75 \mathrm{~V}$ using a series of five $100 \mu$ sROG\# pulses per byte. This results in a programming time of approximately 16 seconds for the 16 -Kbyte on-chip code memory.

Programming and verifying operations differ from normal controller operation. Memory accesses are made one byte at a time, input/output ports are used in a different manner, and some pins (EA\#/ $\mathrm{V}_{\mathrm{PP}}$ and ALE/PROG\#) assume their alternative (programming) functions. For a complete list of signal descriptions, see Appendix B.

In some microcontroller applications, it is desirable that user program code be secure from unauthorized access. The 8XC251SB offers two types of protection for program code stored in the onchip array.

- Program code in the on-chip code memory is encrypted when read out for verification if the encryption array is programmed.
- A three-level lock bit system restricts external access to the on-chip code memory.

It is recommended that user program code be located starting at address FF: 0100 H . Since the first instruction following device reset is fetched from FF: 0000 H , use a jump instruction to $\mathrm{FF}: 0100 \mathrm{H}$ to begin execution of the user program. For information on address spaces, see Chapter 3.

## CAUTION

Execution of user code located in the top eight bytes of the on-chip user memory (i.e., FF:3FF8H-FF:3FFFH) may cause prefetches from the next higher addresses, which are in external memory. External memory fetches make use of port 0 and port 3 and may disrupt program execution if the program uses ports 0 or 3 for a different purpose.

### 13.2 PROGRAMMING AND VERIFYING MODES

Table 13-1 defines the programming and verifying modes and provides details about the setup. The modes correspond to the nonvolatile memory functions, i.e. on-chip code memory, encryption array, configuration bytes, etc. The configuration bytes, signature bytes, encryption array, and lock bits reside in nonvolatile memory outside the memory address space. The value applied to port 0 (see Table 13-1) specifies program or verify and provides the base address for the function. Addresses in the Address column are with respect to the base address.

Table 13-1. Programming and Verifying Modes

| Mode | RST | PSEN\# | $\mathbf{V}_{\text {Pp }}$ | PROG\# | $\begin{array}{c}\text { Port } \\ \mathbf{0}\end{array}$ | $\begin{array}{c}\text { Port } \\ \mathbf{2}\end{array}$ | $\begin{array}{c}\text { Address } \\ \text { Port 1 (high) } \\ \text { Port 3 (low) }\end{array}$ | $\begin{array}{c}\text { Notes }\end{array}$ |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{array}{l}\text { Program - On-chip Code } \\ \text { Memory }\end{array}$ | High | Low | $\begin{array}{c}5 \mathrm{~V}, \\ 12.75 \mathrm{~V}\end{array}$ | 5 Pulses | 68 H | data | $0000 \mathrm{H}-3 \mathrm{FFFH}$ | 1 |
| $\begin{array}{l}\text { Verify - On-chip Code } \\ \text { Memory }\end{array}$ | High | Low | 5 V | High | 28 H | data | $0000 \mathrm{H}-3 \mathrm{FFFH}$ |  |
| $\begin{array}{l}\text { Program - Configuration } \\ \text { Bytes }\end{array}$ | High | Low | $\begin{array}{c}5 \mathrm{~V}, \\ 12.75 \mathrm{~V}\end{array}$ | 5 Pulses | 69 H | data | $0080 \mathrm{H}-0083 \mathrm{H}$ | 1 |
| Verify - Configuration Bytes | High | Low | 5 V | High | 29 H | data | $0080 \mathrm{H}-0083 \mathrm{H}$ |  |
| Program - Lock Bits | High | Low | 5 V, | 25 Pulses | 6 BH | data | $0001 \mathrm{H}-0003 \mathrm{H}$ | 1,2 |
| Verify - Lock bits | High | Low | 5 V | High | 2 BH | data | 0000 H | 3 |
| Program - Encryption Array | High | Low | 5 V, | 25 Pulses | 6 CH | data | $0000 \mathrm{H}-007 \mathrm{FH}$ | 1 |
| Verify - Signature Bytes | High | Low | 5 V | High | 29 H | data | $0030 \mathrm{H}, 0031 \mathrm{H}$, | 0060 H |$]$

## NOTES:

1. To program, raise $\mathrm{V}_{\mathrm{pp}}$ to 12.75 V and pulse the PROG\# pin. See Figure $13-2$ for waveforms.
2. No data input. Identify the lock bits with the address lines as follows: LB3-0003H, LB2-0002H, LB1-0001H
3. The three lock bits are verified in a single operation. The states of the lock bits appear simultaneously at port 2 as follows: LB3 - P2.3, LB2 - P2.2. LB1 - P2.1. High = programmed.

### 13.3 GENERAL SETUP

Figure 13-1 shows the general setup for programming and verifying the OTPROM areas on the 87C251SB. The figure also applies to verifying the 83 C 251 SB and reading the configuration bytes on the 80 C 251 SB .

The controller must be running with an oscillator frequency of 4 MHz to 6 MHz . To program, set up the controller as shown in Table 13-1 with the mode of operation (program/verify and memory area) specified on port 0 , the address with respect to the starting address of the memory area applied to ports 1 and 3, and the data on port 2. Apply a logic high to the RST pin and $\mathrm{V}_{\mathrm{CC}}$ to EA\#/V $\mathrm{V}_{\mathrm{PP}}$. ALE/PSEN\#, normally an output pin, must be held low externally.

To perform the write operation, raise $\mathrm{V}_{\mathrm{PP}}$ to 12.75 V and pulse the PROG\# pin per Table 13-1. Then return $\mathrm{V}_{\mathrm{PP}}$ to 5 V . Waveforms are shown in Figure 13-2.

## CAUTION

The $\mathrm{V}_{\mathrm{PP}}$ source must be well regulated and free of glitches. The voltage on the $\mathrm{V}_{\mathrm{PP}}$ pin must not exceed the specified maximum, even under transient conditions. See latest data sheet.

Verification is performed in a similar manner but without increasing $\mathrm{V}_{\mathrm{PP}}$ and without pulsing PROG\#. Figure 13-2 shows the OTPROM programming and verifying waveforms. For waveform timing information, refer to Figure 13-5 and Table 13-5 at the end of this section.


A4122-01

Figure 13-1. Setup for Programming and Verifying


Figure 13-2. OTPROM Programming Waveforms

### 13.4 OTPROM PROGRAMMING ALGORITHM

The procedure for programming the 87 C 251 SB is as follows:

1. Set up the controller for operation in the appropriate mode according to Table 13-1.
2. Input the 16 -bit address on ports 1 and 3 .
3. Input the data byte on port 2.
4. Raise the voltage on the $\mathrm{V}_{\mathrm{PP}}$ pin from 5 V to 12.75 V .
5. Pulse the PROG\# pin 5 times for the on-chip code memory and the configuration bytes, and 25 times for the encryption array and the lock bits.
6. Reduce the voltage on the $\mathrm{V}_{\mathrm{PP}}$ pin to 5 V .
7. If the procedure is program/immediate-verify, go to "Verify Algorithm" on page 13-5 and perform steps 1 through 4 to verify the currently addressed byte. Make sure the voltage on the $\mathrm{EA} \mathrm{\#} / \mathrm{V}_{\mathrm{PP}}$ pin has been lowered to 5 V before performing the verifying procedure.
8. Repeat steps 1 through 7 until all memory locations are programmed.

### 13.5 VERIFY ALGORITHM

Use this procedure to verify user program code, signature bytes, configuration bytes and lock bits stored in nonvolatile memory on the 8 XC 251 SB . To preserve the secrecy of the encryption key byte sequence, the encryption array can not be verified. Verification can be performed on bytes as they are programmed, or on a block of bytes that have been previously programmed. The procedure for verifying the 8 XC 251 SB is as follows:

1. Set up the controller for operation in the appropriate mode according to Table 13-1.
2. Input the 16 -bit address on ports P1 and P3.
3. Wait for the data on port P 2 to become valid $\left(\mathrm{T}_{\mathrm{AVQV}}=48\right.$ clock cycles, Figure 13-5), then compare the data with the expected value.
4. If the procedure is program/immediate-verify, return to step 8 of "OTPROM Programming Algorithm" on page 13-4 to program the next byte.
5. Repeat steps 1 through 5 until all memory locations are verified.

### 13.6 PROGRAMMABLE FUNCTIONS

This section discusses factors related to programming and verifying the various nonvolatile memory functions.

### 13.6.1 On-chip Code Memory

The 16 -Kbyte on-chip code memory is located in the top region of the memory space starting at address FF: 0000 H . At reset, the 87 C 251 SB and 83 C 251 SB devices vector to this address. See Chapter 3 for detailed information on the 8XC251SB memory space.

To enter user program code and data in the on-chip code memory, perform the procedure described in "OTPROM Programming Algorithm" on page 13-4 using the program on-chip code memory mode (Table 13-1).

To verify that the on-chip code memory is correctly programmed, perform the procedure described in "Verify Algorithm" on page 13-5 using the verify on-chip code memory mode (Table 13-1).

### 13.6.2 Configuration Bytes

The MCS ${ }^{\circledR} 251$ microcontroller contains four configuration bytes, CONFIG0 through CONFIG3, implemented in OTPROM. CONFIG0 through CONFIG3 correspond to addresses 0080 H through 0083 H in Table 13-1. The configuration bytes are located in nonvolatile memory outside the memory address space and are inaccessible by user code. CONFIG0 and CONFIG1 specify the following:

- WSA, WSB. Wait states
- RD0, RD1. This two-bit code determines the address ranges for RD\# and PSEN\# and selects a 16-bit or 17-bit external bus. RD\# as 17th address bit (A16), P3.7 as general purpose pin.
- XALE. Extends ALE pulse.
- SRC. Source code/ binary code
- EMAP. Maps upper 8 Kbytes of on-chip code memory to region 00 H .
- PAGE. Page mode select, external bus structure
- INTR. Return from interrupt

CONFIG2 and CONFIG3 are reserved for future use. See Figure 13-3 and Figure 13-4 for CONFIG0 and CONFIG1 bit assignments and definitions. These figures also give the configuration values for making the 8 XC 251 SB pin compatible with the 8 XC 51 FB and 8 XC 54 . Table 13-2 lists the CONFIG0 and CONFIG1 values for the 80 C 251 SB .

To program the configuration bytes, perform the procedure described in "OTPROM Programming Algorithm" on page 13-4 using the program configuration byte mode (Table 13-1).

To verify that the configuration bytes are correctly programmed, perform the procedure described in "Verify Algorithm" on page 13-5 using the verify configuration byte mode (Table 13-1).

## CONFIGO

7

| - | - | WSA | XALE | RD1 | RD0 | PAGE |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |


| Bit <br> Number | Bit <br> Mnemonic | Function |  |  |  |
| :---: | :---: | :--- | :--- | :--- | :---: |
| $7: 6$ | - | Reserved: <br> Set these bits when writing to CONFIG0. |  |  |  |
| 5 | WSA | Wait State A: <br> Clear this bit to generate one external wait state for memory regions 00:, <br> FE:, and FF:. Set this bit for no wait states for these regions. |  |  |  |
| 4 | XALE | Extend ALE: <br> If this bit is set, the time of the ALE pulse is Tosc. Clearing this bit <br> extends the time of the ALE pulse from Tosc to 3T |  |  |  |
| external wait state. which adds one |  |  |  |  |  |

NOTE: To make the 8XC251SB pin compatible with 44-lead PLCC MCS 51 microcontrollers, use the following bit values in CONFIGO: 1101 1110B.

Figure 13-3. Configuration Byte 0

## CONFIG1



| Bit <br> Number | Bit <br> Mnemonic | Function |
| :---: | :---: | :--- |
| $7: 5$ | - | Reserved: <br> Set these bits when writing to CONFIG1. |
| 4 | INTR | Interrupt Mode: <br> If this bit is set, interrupts push 4 bytes onto the stack (the 3 bytes of the <br> PC register and the PSW1 register). If this byte is clear, interrupts push 2 <br> bytes onto the stack (the 2 lower bytes of the PC register). |
| 3 | WSB | Wait State B: <br> Clear this bit to generate one external wait state for memory region 01:. <br> Set this bit for no wait states for region 01:. |
| $2: 1$ |  | Reserved: <br> Set these bits when writing to CONFIG1. |
| 0 | EMAP | EPROM MAP: <br> Clearing this bit maps the upper 8 Kbytes of on-chip code memory <br> (FF:2000H-FF:3FFFH) to 00:E000H-00:FFFFH. If this bit is set, the <br> upper 8 Kbytes of on-chip code memory are mapped only to FF:2000H- <br> FF:3FFFH. |

NOTE: To make the 8XC251SB pin compatible with 44-lead PLCC MCS 51 microcontrollers, use the following bit values in CONFIG1: 1110 0111B.

Figure 13-4. Configuration Byte 1

Table 13-2. Configuration Byte Values for 80C251SB and 80C251SB-16

| Bit <br> Number | CONFIGO (1) |  | CONFIG1 (1) |  |
| :---: | :---: | :---: | :---: | :---: |
|  | Bit Mnemonic | Value | Bit Mnemonic | Value |
| 7 | Reserved | 1 | Reserved | 1 |
| 6 | Reserved | 1 | Reserved | 1 |
| 5 | WSA | $(2)$ | Reserved | 1 |
| 4 | XALE | 1 | INTR | 0 |
| 3 | RD1 | 1 | WSB | $(2)$ |
| 2 | RD0 | 1 | Reserved | 1 |
| 1 | PAGE | 1 | Reserved | 1 |
| 0 | SRC | 0 | EMAP | 1 |

NOTE:

1. In addition to the configuration given in the table, the 80 C 251 SB and $80 \mathrm{C} 251 \mathrm{SB}-16$ are available in user-defined configurations.
2. The 80 C 251 SB is available with no wait states $(W S A=W S B=1)$.

The 80C251SB-16 is available with one wait state (WSA $=\mathrm{WSB}=0$ ).

### 13.6.3 Lock Bit System

The 87C251SB provides a three-level lock system for protecting user program code stored in the on-chip code memory from unauthorized access. On the 83 C 251 SB , only LB1 protection is available. Table 13-3 describes the levels of protection.

To program the lock bits, perform the procedure described in "OTPROM Programming Algorithm" on page 13-4 using the program lock bits mode (Table 13-1).

To verify that the lock bits are correctly programmed, perform the procedure described in "Verify Algorithm" on page 13-5 using the verify lock bits mode (Table 13-1).

Table 13-3. Lock Bit Function

|  | Lock Bits Programmed |  |  | Protection Type |
| :--- | :---: | :---: | :---: | :--- |
|  | LB3 | LB2 | LB1 |  |
| Level 1 | U | U | U | No program lock features are enabled. On-chip user code is <br> encrypted when verified, if encryption array is programmed. |
| Level 2 | U | U | P | External code is prevented from fetching code bytes from on- <br> chip code memory. Further programming of the on-chip <br> OTPROM is disabled. |
| Level 3 | U | P | P | Same as level 2, plus on-chip code memory verify is disabled. |
| Level 4 | P | P | P | Same as level 3, plus external memory execution is disabled. |

### 13.6.4 Encryption Array

The 87C251SB and 83C251SB controllers include a 128-byte encryption array located in nonvolatile memory outside the memory address space. During verification of the on-chip code memory, the seven low-order address bits also address the encryption array. As the byte of the code memory is read, it is exclusive-NOR'ed (XNOR) with the key byte from the encryption array. If the encryption array is not programmed (still all 1s), the user program code is placed on the data bus in its original, unencrypted form. If the encryption array is programmed with key bytes, the user program code is encrypted and can't be used without know the key byte sequence.

## CAUTION

If the encryption feature is implemented, the portion of the on-chip code memory that does not contain program code should be filled with "random" byte values other than FFH to prevent the encryption key sequence from being revealed.

To program the encryption array, perform the procedure described in "OTPROM Programming Algorithm" on page 13-4 using the program encryption array mode (Table 13-1).

To verify that the configuration bytes are correctly programmed, perform the procedure described in "Verify Algorithm" on page 13-5 using the verify encryption array mode (Table 13-1).

### 13.6.5 Signature Bytes

The 87 C 251 SB and 83 C 251 SB contain factory-programmed signature bytes. These bytes are located at $30 \mathrm{H}, 31 \mathrm{H}$, and 60 H in nonvolatile memory outside the memory address space. To read the signature bytes, perform the procedure described in "Verify Algorithm" on page 13-5 using the verify signature mode (Table 13-1). Signature byte values are listed in Table 13-4.

Table 13-4. Contents of the Signature Bytes

| Device | Address |  |  |
| :---: | :---: | :---: | :---: |
|  | $\mathbf{3 0 H}$ | $\mathbf{3 1 H}$ | $\mathbf{6 0 H}$ |
| 83 C 251 SB | $\mathbf{8 9 H}$ | 40 H | $\mathbf{7 B H}$ |
| 87 C 251 SB | $\mathbf{8 9 H}$ | 40 H | FBH |

### 13.7 VERIFYING THE 83C251SB (ROM)

Nonvolatile memory on the 83 C 251 SB controller is factory programmed. The verification procedure for the 83 C 251 SB is exactly the same as for the 87 C 251 SB OTPROM version. The setup shown in Figure 13-1 applies as do the waveform and timing diagrams. Like the 87C251SB, the 83 C 251 SB contains a 16 -Kbyte on-chip code memory and a 128-byte encryption array.

For information on verifying the contents of nonvolatile memory on the 83 C 251 SB , see "Programmable Functions" on page 13-5 for each function desired. Or more directly, perform the verification procedure described in "Verify Algorithm" on page 13-5 using the appropriate verify mode (Table 13-1).

### 13.8 VERIFYING THE 80C251SB (ROMLESS)

The configuration bytes stored in nonvolatile memory on the 80 C 251 SB can be read using the verify procedure presented in this chapter. For information regarding the configuration bytes see "Configuration Bytes" on page 13-6.


Figure 13-5. OTPROM Timing

Table 13-5. OTPROM Timing Definitions

| Symbol | Definition | Symbol | Definition |
| :--- | :--- | :--- | :--- |
| $1 / T_{\text {GLCL }}$ | Oscillator Frequency | $\mathrm{T}_{\text {GHAX }}$ | Address Hold after PROG\#: |
| $\mathrm{T}_{\text {AVGL }}$ | Address Setup to PROG\# Low | $\mathrm{T}_{\text {GHDX }}$ | Data Hold after PROG\# |
| $\mathrm{T}_{\text {AVQV }}$ | Address to Data Valid | $\mathrm{T}_{\text {GHSL }}$ | $\mathrm{V}_{\text {PP }}$ Hold after PROG\# |
| $\mathrm{T}_{\text {DVGL }}$ | Data Setup to PROG\# Low | $\mathrm{T}_{\text {GHGL }}$ | PROG\# High to PROG\# Low |
| $\mathrm{T}_{\text {EHSH }}$ | ENABLE High to $\mathrm{V}_{\text {PP }}$ | $\mathrm{T}_{\text {GLGH }}$ | PROG\# Width |
| $\mathrm{T}_{\text {EHaz }}$ | Data Float after ENABLE | $\mathrm{T}_{\text {SHGL }}$ | $\mathrm{V}_{\text {PP }}$ Setup to PROG\# Low: |
| $\mathrm{T}_{\text {ELQV }}$ | ENABLE Low to Data Valid |  |  |

NOTE: A = Address, $D=$ Data, $E=$ Enable, $G=$ PROG $\#, H=$ High, $L=$ Low, $Q=$ Data out, $\mathrm{S}=$ Supply ( $\mathrm{V}_{\mathrm{PP}}$ ), $\mathrm{V}=$ Valid, $\mathrm{X}=$ No longer valid, $\mathrm{Z}=$ Floating.

## intel.



## Instruction Set <br> Reference

## APPENDIX A <br> INSTRUCTION SET REFERENCE

This appendix contains reference material for the instructions in the MCS ${ }^{\circledR} 251$ architecture. It includes an opcode map, a summary of the instructions - with instruction lengths and execution times - and a detailed description of each instruction. It contains the following tables:

- Tables A-1 through A-4 describe the notation used for the instruction operands.
- Table A-6 on page A-4 and Table A-7 on page A-5 comprise the opcode map for the instruction set.
- Table A-8 on page A-6 through Table A-17 on page A-10 contain supporting material for the opcode map.
- Table A-18 on page A-12 lists execution times for a group of instructions that access the port SFRs.
- The following tables list the instructions with their lengths in bytes and their execution times:

Add and Subtract Instructions, Table A-19 on page A-14
Compare Instructions, Table A-20 on page A-15
Increment and Decrement Instructions, Table A-21 on page A-16
Multiply, Divide, and Decimal-adjust Instructions, Table A-22 on page A-16
Logical Instructions, Table A-23 on page A-17
Move Instructions, Table A-24 on page A-19
Exchange, Push, and Pop Instructions, Table A-24 on page A-19
Bit Instructions, Table A-26 on page A-23
Control Instructions, Table A-27 on page A-24
"Instruction Descriptions" on page A-26 contains a detailed description of each instruction.

## NOTE

The instruction execution times given in this appendix are for code executing from on-chip code memory and for data that is read from and written to onchip RAM. Execution times are increased by executing code from external memory, accessing peripheral SFRs, accessing data in external memory, using a wait state, or extending the ALE pulse.

For some instructions, accessing the port SFRs, Px, $x=0-3$, increases the execution time. These cases are listed in Table A-18 on page A-12 and are noted in the instruction summary tables and the instruction descriptions.

## A. 1 NOTATION FOR INSTRUCTION OPERANDS

Table A-1. Notation for Register Operands

|  | Register Notation | $\begin{gathered} \text { MCS® }^{\text {Arch. }} 251 \\ \text { A } \end{gathered}$ | MCS 51 Arch. |
| :---: | :---: | :---: | :---: |
| @ Ri | A memory location ( $00 \mathrm{H}-\mathrm{FFH}$ ) addressed indirectly via byte register R0 or R1 |  | $\checkmark$ |
| Rn n rrr r | Byte register R0-R7 of the currently selected register bank <br> Byte register index: $\mathrm{n}=0-7$ <br> Binary representation of $n$ |  | $\checkmark$ |
| Rm <br> Rmd <br> Rms <br> m, md, ms <br> sss <br> SSSS | Byte register R0-R15 of the currently selected register file <br> Destination register <br> Source register <br> Byte register index: $m, m d, m s=0-15$ <br> Binary representation of m or md <br> Binary representation of ms | $\checkmark$ |  |
| WRj <br> WRjd <br> WRjs <br> @WRj <br> @WRj <br> +dis16 <br> j, jd, js <br> ttt <br> TTTT | Word register WRO, WR2, ..., WR30 of the currently selected register file <br> Destination register <br> Source register <br> A memory location ( $00: 0000 \mathrm{H}-00:$ FFFFH) addressed indirectly through word register WRO-WR30 <br> Data RAM location (00:0000H-00:FFFFH) addressed indirectly through a word register (WR0-WR30) + displacement value <br> Word register index: j , jd , js $=0-30$ <br> Binary representation of $j$ or jd <br> Binary representation of js | $\checkmark$ |  |
| DRk <br> DRkd DRks @DRk <br> @DRk +dis24 <br> k, kd, ks uuuu <br> UUUU | Dword register DR0, DR4, ..., DR28, DR56, DR60 of the currently selected register file <br> Destination Register <br> Source Register <br> A memory location ( $00: 0000 \mathrm{H}-\mathrm{FF}:$ FFFFH) addressed Indirectly through dword register DR0-DR28, DR56, DR60 <br> Data RAM location ( $00: 0000 \mathrm{H}-\mathrm{FF}:$ FFFFH ) addressed indirectly through a dword register (DR0-DR28, DR56, DR60) + displacement value <br> Dword register index: $\mathrm{k}, \mathrm{kd}$, $\mathrm{ks}=0,4,8, \ldots, 28,56,60$ <br> Binary representation of $k$ or $k d$ <br> Binary representation of ks | $\checkmark$ |  |

Table A-2. Notation for Direct Addresses

| Direct <br> Address. | Description | MCS® 251 <br> Arch. | MCS 51 <br> Arch. |
| :--- | :--- | :---: | :---: |
| dir8 | An 8-bit direct address. This can be a memory address <br> $(00: 0000 \mathrm{H}-00: 00 \mathrm{FFH}$ ) or an SFR address (S:00H - S:FFH). | $\checkmark$ | $\checkmark$ |
| dir16 | A 16-bit memory address (00:0000H-00:FFFFH) used in direct <br> addressing. | $\checkmark$ |  |

Table A-3. Notation for Immediate Addressing

| Immediate Data | Description | MCS ${ }^{\text {® }} 251$ Arch. | MCS 51 Arch. |
| :---: | :---: | :---: | :---: |
| \#data | An 8-bit constant that is immediately addressed in an instruction. | $\checkmark$ | $\checkmark$ |
| \#data16 | A 16-bit constant that is immediately addressed in an instruction. | $\checkmark$ |  |
| \#Odata16 \#1data16 | A 32-bit constant that is immediately addressed in an instruction. The upper word is filled with zeros (\#0data16) or ones (\#1data16). | $\checkmark$ |  |
| \#short <br> v v | A constant, equal to 1,2 , or 4 , that is immediately addressed in an instruction. <br> Binary representation of \#short. | $\checkmark$ |  |

Table A-4. Notation for Bit Addressing

| Bit Address | Description | $\begin{gathered} \text { MCS® }^{\text {P }} 251 \\ \text { Arch. } \end{gathered}$ | MCS 51 Arch. |
| :---: | :---: | :---: | :---: |
| bit y y y | A directly addressed bit in memory locations 00:0020H-00:007FH or in any defined SFR. <br> A binary representation of the bit number ( $0-7$ ) within a byte. | $\checkmark$ |  |
| bit51 | A directly addressed bit (bit number $=00 \mathrm{H}-\mathrm{FFH}$ ) in memory or an SFR. Bits $00 \mathrm{H}-7 \mathrm{FH}$ are the 128 bits in byte locations $20 \mathrm{H}-2 \mathrm{FH}$ in the on-chip RAM. Bits $80 \mathrm{H}-\mathrm{FFH}$ are the 128 bits in the 16 SFR's with addresses that end in 0 H or $8 \mathrm{H}: \mathrm{S}: 80 \mathrm{H}, \mathrm{S}: 88 \mathrm{H}, \mathrm{S}: 90 \mathrm{H}, \ldots, \mathrm{S}: \mathrm{FOH}, \mathrm{S}: \mathrm{F} 8 \mathrm{H}$. |  | $\checkmark$ |

Table A-5. Notation for Destinations in Control Instructions

| Destination <br> Address | Description | MCS² 251 <br> Arch. | MCS 51 <br> Arch. |
| :--- | :--- | :---: | :---: |
| rel | A signed (two's complement) 8-bit relative address. The destination is <br> -128 to +127 bytes relative to first byte of the next instruction. | $\checkmark$ | $\checkmark$ |
| addr11 | An 11-bit destination address. The destination is in the same 2-Kbyte <br> block of memory as the first byte of the next instruction. | $\checkmark$ | $\checkmark$ |
| addr16 | A 16-bit destination address. A destination can be anywhere within <br> the same 64-Kbyte region as the first byte of the next instruction. | $\checkmark$ | $\checkmark$ |
| addr24 | A 24-bit destination address. A destination can be anywhere within <br> the 16-Mbyte address space. | $\checkmark$ |  |

## A. 2 OPCODE MAP AND SUPPORTING TABLES

Table A-6. Instructions for MCS ${ }^{\circledR} 51$ Microcontrollers

| Bin. | 0 | 1 | 2 | 3 | 4 | 5 | 6-7 | 8-F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Src. | 0 | 1 | 2 | 3 | 4 | 5 | A5x6-A5x7 | A5x8-A5xF |
| 0 | NOP | AJMP addr11 | LJMP addr16 | $\begin{aligned} & \text { RR } \\ & \text { A } \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { A } \end{aligned}$ | INC dir8 | INC <br> @Ri | $\begin{aligned} & \text { INC } \\ & \text { Rn } \end{aligned}$ |
| 1 | JBC bit,rel | ACALL addr11 | LCALL addr16 | $\begin{aligned} & \text { RRC } \\ & \text { A } \end{aligned}$ | $\begin{aligned} & \text { DEC } \\ & \text { A } \end{aligned}$ | $\begin{aligned} & \text { DEC } \\ & \text { dir8 } \end{aligned}$ | $\begin{aligned} & \text { DEC } \\ & \text { @Ri } \end{aligned}$ | $\begin{aligned} & \mathrm{DEC} \\ & \mathrm{Rn} \end{aligned}$ |
| 2 | JB bit,rel | AJMP addr11 | RET | RLA | ADD <br> A,\#data | ADD <br> A,dir8 | $\begin{aligned} & \text { ADD } \\ & \mathrm{A}, @ \mathrm{Ri} \end{aligned}$ | $\begin{aligned} & \text { ADD } \\ & \text { A,Rn } \end{aligned}$ |
| 3 | JNB bit,rel | ACALL addr11 | RETI | RLCA | ADDC <br> A,\#data | ADDC <br> A,dir8 | $\begin{aligned} & \text { ADDC } \\ & \mathrm{A}, @ \mathrm{Ri} \end{aligned}$ | $\begin{aligned} & \text { ADDC } \\ & \text { A,Rn } \end{aligned}$ |
| 4 | $\underset{\text { rel }}{\mathrm{JC}}$ | AJMP addr11 | ORL dir8,A | ORL dir8,\#data | ORL <br> A,\#data | ORL A,dir8 | ORL <br> A, @Ri | ORL A,Rn |
| 5 | JNC rel | ACALL addr11 | ANL dir8,A | ANL dir8,\#data | ANL <br> A,\#data | ANL A,dir8 | ANL <br> A, © Ri | ANL $\mathrm{A}, \mathrm{Rn}$ |
| 6 | $\begin{aligned} & \mathrm{JZ} \\ & \text { rel } \end{aligned}$ | AJMP addr11 | $\begin{aligned} & \text { XRL } \\ & \text { dir8,A } \end{aligned}$ | XRL <br> dir8,\#data | XRL <br> A,\#data | XRL <br> A,dir8 | $\begin{aligned} & \text { XRL } \\ & \text { A, ©Ri } \end{aligned}$ | $\begin{aligned} & \text { XRL } \\ & \text { A,Rn } \end{aligned}$ |
| 7 | $\begin{aligned} & \mathrm{JNZ} \\ & \mathrm{rel} \end{aligned}$ | ACALL addr11 | ORL CY,bit | JMP <br> @ A+DPTR | MOV <br> A,\#data | MOV dir8,\#data | MOV <br> @Ri,\#data | MOV <br> Rn,\#data |
| 8 | SJMP rel | AJMP addr11 | ANL CY,bit | $\begin{aligned} & \text { MOVC } \\ & \text { A,@A+PC } \end{aligned}$ | $\begin{aligned} & \text { DIV } \\ & \text { AB } \end{aligned}$ | MOV dir8,dir8 | MOV dir8,@Ri | MOV dir8,Rn |
| 9 | MOV DPTR,\#data16 | ACALL addr11 | MOV <br> bit,CY | MOVC <br> A, @ A+DPTR | SUBB <br> A,\#data | SUBB A,dir8 | SUBB $\mathrm{A}, @ \mathrm{Ri}$ | SUBB $A, R n$ |
| A | ORL CY,bit | AJMP addr11 | MOV CY,bit | INC DPTR | $\begin{aligned} & \text { MUL } \\ & \text { AB } \end{aligned}$ | ESC | MOV @ Ri,dir8 | MOV Rn, dir8 |
| B | ANL CY,bit | ACALL addr11 | CPL <br> bit | $\begin{aligned} & \mathrm{CPL} \\ & \mathrm{CY} \end{aligned}$ | CJNE <br> A,\#data,rel | CJNE <br> A,dir8,rel | CJNE <br> @ Ri,\#data, rel | CJNE <br> Rn,\#data,rel |
| C | PUSH dir8 | AJMP addr11 | CLR bit | CLR CY | $\begin{aligned} & \text { SWAP } \\ & \text { A } \end{aligned}$ | $\begin{aligned} & \text { XCH } \\ & \text { A,dir8 } \end{aligned}$ | $\begin{aligned} & \mathrm{XCH} \\ & \mathrm{~A}, @ \mathrm{Ri} \end{aligned}$ | $\begin{aligned} & \hline \mathrm{XCH} \\ & \mathrm{~A}, \mathrm{Rn} \end{aligned}$ |
| D | $\begin{aligned} & \mathrm{POP} \\ & \text { dir8 } \end{aligned}$ | ACALL addr11 | SETB bit | $\begin{aligned} & \text { SETB } \\ & \text { CY } \end{aligned}$ | $\begin{aligned} & \text { DA } \\ & \text { A } \end{aligned}$ | DJNZ dir8,rel | $\begin{aligned} & \mathrm{XCHD} \\ & \mathrm{~A}, @ \mathrm{Ri} \end{aligned}$ | DJNZ Rn,rel |
| E | MOVX <br> A, @DPTR | AJMP addr11 |  | $\begin{aligned} & \text { MOVX } \\ & \text { A, @Ri } \end{aligned}$ | $\begin{aligned} & \text { CLR } \\ & \mathrm{A} \end{aligned}$ | MOV <br> A,dir8 | MOV <br> $\mathrm{A}, @ \mathrm{Ri}$ | $\begin{aligned} & \text { MOV } \\ & \text { A,Rn } \end{aligned}$ |
| F | MOV <br> @ DPT,A | ACALL addr11 |  | MOVX <br> @Ri,A | $\begin{aligned} & \mathrm{CPL} \\ & \mathrm{~A} \end{aligned}$ | MOV dir8,A | MOV <br> @Ri,A | MOV Rn,A |

Table A-7. New Instructions for the MCS ${ }^{\circledR} 251$ Architecture

| Bin. | A5x8 | A5x9 | A5xA | A5xB | A5xC | A5xD | A5xE | A5xF |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Src. | $\times 8$ | x9 | $\boldsymbol{x A}$ | xB | $x C$ | xD | xE | XF |
| 0 | $\begin{aligned} & \text { JSLE } \\ & \text { rel } \end{aligned}$ | MOV <br> Rm, @WRj+dis | MOVZ WRj,Rm | INC R,\#short (1) MOV reg, ind |  |  | $\begin{aligned} & \text { SRA } \\ & \text { reg } \end{aligned}$ |  |
| 1 | $\begin{aligned} & \text { JSG } \\ & \text { rel } \end{aligned}$ | MOV <br> @WRj+dis,Rm | MOVS WRj,Rm | DEC R,\#short (1) MOV ind,reg |  |  | SRL reg |  |
| 2 | $\begin{aligned} & \mathrm{JLE} \\ & \mathrm{rel} \end{aligned}$ | MOV <br> Rm, @DRk+dis |  |  | ADD Rm,Rm | ADD <br> WRj,WRj | ADD <br> reg,op2 (2) | ADD DRk,DRk |
| 3 | JG rel | MOV <br> @DRk+dis,Rm |  |  |  |  | $\begin{aligned} & \mathrm{SLL} \\ & \mathrm{reg} \end{aligned}$ |  |
| 4 | JSL <br> rel | MOV <br> WRj, © WRj+dis |  |  | ORL Rm,Rm | ORL WRj,WRj | ORL <br> reg,op2 (2) |  |
| 5 | JSGE rel | MOV <br> @WRj+dis,WRj |  |  | ANL Rm,Rm | ANL WRj,WRj | $\begin{aligned} & \text { ANL } \\ & \text { reg,op2 (2) } \end{aligned}$ |  |
| 6 | $\begin{aligned} & \mathrm{JE} \\ & \mathrm{rel} \end{aligned}$ | MOV WRj, © DRk+dis |  |  | XRL <br> Rm,Rm | XRL WRj,WRj | XRL <br> reg,op2 (2) |  |
| 7 | JNE rel | MOV <br> @ DRk+dis,WRj | MOV <br> op1,reg (2) |  | MOV Rm,Rm | MOV WRj,WRj | MOV <br> reg,op2 (2) | MOV DRk,DRk |
| 8 |  | LJMP @WRj EJMP @ DRk | EJMP addr24 |  | DIV <br> Rm,Rm | DIV WRj,WRj |  |  |
| 9 |  | LCALL@WR ECALL @DRk | ECALL addr24 |  | SUB <br> Rm,Rm | SUB WRj,WRj | $\begin{aligned} & \text { SUB } \\ & \text { reg,op2 (2) } \end{aligned}$ | SUB DRk,DRk |
| A |  | Bit Instructions (3) | ERET |  | MUL Rm,Rm | MUL WRj,WRj |  |  |
| B |  | TRAP |  |  | CMP <br> Rm,Rm | CMP <br> WRj,WRj | CMP reg,op2 (2) | CMP <br> DRk,DRk |
| C |  |  | PUSH op1 (4) MOV DRk,PC |  |  |  |  |  |
| D |  |  | $\mathrm{POP}$ op1 (4) |  |  |  |  |  |
| E |  |  |  |  |  |  |  |  |
| F |  |  |  |  |  |  |  |  |

## NOTES:

1. $\mathrm{R}=\mathrm{Rm} /$ WRj/DRk.
2. op1, op2 are defined in Table A-8 on page A-6.
3. See Tables A-10 and A-11 on page A-7.
4. See Table A-12 on page A-8.

Table A-8. Data Instructions

| Instruction |
| :--- |
| Oper Rmd,Rms |
| Oper WRjd,WRjs |
| Oper DRkd,DRks |
| Oper Rm,\#data |
| Oper WRj,\#data16 |
| Oper DRk,\#data16 |
| MOV DRk(h),\#data16 <br> MOV DRk,\#1data16 <br> CMP DRk,\#1data16 |
| Oper Rm,dir8 |
| Oper WRj,dir8 |
| Oper DRk,dir8 |
| Oper Rm,dir16 |
| Oper WRj,dir16 |
| Oper DRk,dir16 |
| Oper Rm,@WRj |
| Oper Rm,@DRk |


| Byte 0 |  |
| :---: | :---: |
| x | C |
| x | D |
| x | F |
| x | E |
| x | E |
| x | E |
| 7 | A |
| 7 | E |
| B | E |
| x | E |
| x | E |
| x | E |
| x | E |
| x | E |
| x | E |
| x | E |
| x | E |


| Byte 1 |  |
| :---: | :---: |
| md | ms |
| $\mathrm{jd} / 2$ | $\mathrm{js} / 2$ |
| $\mathrm{kd} / 4$ | $\mathrm{ks} / 4$ |
| m | 0000 |
| $\mathrm{j} / 2$ | 0100 |
| $\mathrm{k} / 4$ | 1100 |
| $\mathrm{k} / 4$ | 1000 |
|  |  |
| m | 0001 |
| $\mathrm{j} / 2$ | 0101 |
| $\mathrm{k} / 4$ | 1101 |
| m | 0011 |
| $\mathrm{j} / 2$ | 0111 |
| $\mathrm{k} / 4$ | 1111 |
| $\mathrm{j} / 2$ | 1001 |
| $\mathrm{k} / 4$ | 1011 |


| Byte 2 |
| :---: | Byte 3


| \#data   <br> \#data (high)   <br> \#data (high)   <br> \#data (high)   <br> dir8 addr   <br> dir8 addr   <br> dir8 addr   <br> dir16 addr (high)   <br> dir16 addr (high)   <br> dir16 addr (high)   <br> m  00 <br> m   <br> 00   |
| :--- |


| \#data (low) |
| :--- |
| \#data (low) |
| \#data (low) |


| dir16 addr (low) |
| :--- |
| dir16 addr (low) |
| dir16 addr (low) |

Table A-9. High Nibble, Byte 0 of Data Instructions

| x | Operation | Notes |
| :---: | :---: | :---: |
| 2 | ADD reg,op2 | All addressing modes are supported. |
| 9 | SUB reg,op2 |  |
| B | CMP reg,op2 |  |
| 4 | ORL reg,op2 |  |
| 5 | ANL reg,op2 |  |
| 6 | XRL reg,op2 |  |
| 7 | MOV reg,op2 |  |
| 8 | DIV reg,op2 | Two modes only: reg,op2 $=$ Rmd,Rms reg,op2 $=$ Wjd,Wjs |
| A | MUL reg,op2 |  |

All of the bit instructions in the MCS 251 architecture (Table A-7) have opcode A9, which serves as an escape byte (similar to A5). The high nibble of byte 1 specifies the bit instruction, as given in Table A-10.

Table A-10. Bit Instructions

|  | Instruction |
| :---: | :---: | :---: |
| 1 | Bit $\operatorname{Instr}$ (dir8) |$\quad$| Byte $\mathbf{0}(\mathbf{x})$ |  |
| :---: | :---: | :---: |
| A | 9 |$\quad$| Byte 1 |  |
| :---: | :---: |
| $x x x x$ | 0 | bit | Byte 2 |
| :---: |
| dir8 addr |

Table A-11. Byte 1 (High Nibble) for Bit Instructions

| $\boldsymbol{x x x x}$ | Bit Instruction |
| :--- | :--- |
| 0001 | JBC bit |
| 0010 | JB bit |
| 0011 | JNB bit |
| 0111 | ORL CY,bit |
| 1000 | ANL CY,bit |
| 1001 | MOV bit,CY |
| 1010 | MOV CY,bit |
| 1011 | CPL bit |
| 1100 | CLR bit |
| 1101 | SETB bit |
| 1110 | ORL CY, /bit |
| 1111 | ANL CY, /bit |

Table A-12. PUSH/POP Instructions

| Instruction |  | Byte 0(x) |  | Byte 1 |  | Byte 2 |
| :--- | :--- | :--- | :--- | :--- | :--- | :---: |
| PUSH \#data | C | A | 0000 | 0010 | \#data | Byte 3 |
| PUSH \#data16 | C | A | 0000 | 0110 | \#data16 (high) | \#data16 (low) |
| PUSH Rm | C | A | m | 1000 |  |  |
| PUSH WRj | C | A | $\mathrm{j} / 2$ | 1001 |  |  |
| PUSH DRk | C | A | $\mathrm{k} / 4$ | 1011 |  |  |
| MOV DRk,PC | C | A | $\mathrm{k} / 4$ | 0001 |  |  |
| POP Rm | D | A | m | 1000 |  |  |
| POP WRj | D | A | $\mathrm{j} / 2$ | 1001 |  |  |
| POP DRk | D | A | $\mathrm{k} / 4$ | 1011 |  |  |

Table A-13. Control Instructions

| Instruction | Byte 0(x) |  |
| :---: | :---: | :---: |
| EJMP addr24 | 8 | A |
| ECALL addr24 | 9 | A |
| LJMP @ WRj | 8 | 9 |
| LCALL @WRj | 9 | 9 |
| EJMP @ DRk | 8 | 9 |
| ECALL @DRk | 8 | 9 |
| ERET | A | A |
| JE rel | 8 | 8 |
| JNE rel | 7 | 8 |
| JLE rel | 2 | 8 |
| JG rel | 3 | 8 |
| JSL rel | 4 | 8 |
| JSGE rel | 5 | 8 |
| JSLE rel | 0 | 8 |
| ISG re! | $!$ | 8 |
| TRAP | B | 9 |


| Byte 1 |  |
| :---: | :---: |
| addr[23:16] |  |
| addr[23:16] |  |
| $\mathrm{j} / 2$ | 0100 |
| $\mathrm{j} / 2$ | 0100 |
| $\mathrm{k} / 4$ | 1000 |
| $\mathrm{k} / 4$ | 1000 |


| Byte 2 |
| :---: |
| addr[15:8] |
| addr[15:8] |


| Byte 3 |
| :---: |
| $\operatorname{addr}[7: 0]$ |
| addr[7:0] |

Table A-14. Displacement/Extended MOVs

| Instruction |
| :--- |
| MOV Rm, @WRj+dis |
| MOV WRk, @WRj+dis |
| MOV Rm, @DRk+dis |
| MOV WRj, @DRk+dis |
| MOV @WRj+dis,Rm |
| MOV @WRj+dis,WRk |
| MOV @DRk+dis,Rm |
| MOV @DRk+dis,WRj |
| MOVS WRj,Rm |
| MOVZ WRj,Rm |
| MOV WRj, @WRj |
| MOV WRj, @DRk |
| MOV @WRj,WRj |
| MOV @DRk,WRj |
| MOV dir8,Rm |
| MOV dir8,WRj |
| MOV dir8,DRk |
| MOV dir16,Rm |
| MOV dir16,WRj |
| MOV dir16,DRk |
| MOV @WRj,Rm |
| MOV @DRk,Rm |


| Byte 0 |  |
| :---: | :---: |
| 0 | 9 |
| 4 | 9 |
| 2 | 9 |
| 6 | 9 |
| 1 | 9 |
| 5 | 9 |
| 3 | 9 |
| 7 | 9 |
| 1 | $A$ |
| 0 | $A$ |
| 0 | $B$ |
| 0 | $B$ |
| 1 | $B$ |
| 1 | $B$ |
| 7 | $A$ |
| 7 | $A$ |
| 7 | $A$ |
| 7 | $A$ |
| 7 | $A$ |
| 7 | $A$ |
| 7 | $A$ |
| 7 | $A$ |


| Byte 1 |  |
| :---: | :---: |
| m | $\mathrm{j} / 2$ |
| $\mathrm{j} / 2$ | k 2 |
| m | $\mathrm{k} / 4$ |
| $\mathrm{j} / 2$ | $\mathrm{k} / 4$ |
| m | $\mathrm{j} / 2$ |
| $\mathrm{j} / 2$ | k 2 |
| m | $\mathrm{k} / 4$ |
| $\mathrm{j} / 2$ | $\mathrm{k} / 4$ |
| $\mathrm{j} / 2$ | m |
| $\mathrm{j} / 2$ | m |
| $\mathrm{j} / 2$ | 1000 |
| $\mathrm{k} / 4$ | 1010 |
| $\mathrm{j} / 2$ | 1000 |
| $\mathrm{k} / 4$ | 1010 |
| m | 0001 |
| $\mathrm{j} / 2$ | 0101 |
| $\mathrm{k} / 4$ | 1101 |
| m | 0011 |
| $\mathrm{j} / 2$ | 0111 |
| $\mathrm{k} / 4$ | 1111 |
| $\mathrm{j} / 2$ | 1001 |
| $\mathrm{k} / 4$ | 1011 |


| Byte 2 |
| :---: |
| $\operatorname{dis}[15: 8]$ |
| $\operatorname{dis}[15: 8]$ |
| $\operatorname{dis}[15: 8]$ |
| $\operatorname{dis}[15: 8]$ |
| $\operatorname{dis}[15: 8]$ |
| $\operatorname{dis}[15: 8]$ |
| $\operatorname{dis}[15: 8]$ |
| $\operatorname{dis}[15: 8]$ |


| Byte 3 |
| :---: |
| $\operatorname{dis}[7: 0]$ |
| $\operatorname{dis}[7: 0]$ |
| $\operatorname{dis}[7: 0]$ |
| $\operatorname{dis}[7: 0]$ |
| $\operatorname{dis}[7: 0]$ |
| $\operatorname{dis}[7: 0]$ |
| $\operatorname{dis}[7: 0]$ |
| $\operatorname{dis}[7: 0]$ |



Table A-15. INC/DEC

|  | Instruction |
| :---: | :---: |
| 1 | INC Rm,\#short |
| 2 | INC WRj,\#short |
| 3 | INC DRk,\#short |
| 4 | DEC Rm,\#short |
| 5 | DEC WRj,\#short |
| 6 | DEC DRk,\#short |


| Byte 0 |  |
| :---: | :---: |
| 0 | $B$ |
| 0 | $B$ |
| 0 | $B$ |
| 1 | $B$ |
| 1 | $B$ |
| 1 | $B$ |


| Byte 1 |  |  |
| :---: | :---: | :---: |
| $m$ | 00 | $s s$ |
| $j / 2$ | 01 | $s s$ |
| $k / 4$ | 11 | $s s$ |
| $m$ | 00 | $s s$ |
| $j / 2$ | 01 | $s s$ |
| $k / 4$ | 11 | $s s$ |

Table A-16. Encoding for INC/DEC

| ss | \#short |
| :---: | :---: |
| 00 | 1 |
| 01 | 2 |
| 10 | 4 |

Table A-17. Shifts

|  | Instruction | Byte 0 |  | Byte 1 |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | SRA Rm | 0 | E | m | 0000 |
| 2 | SRA WRj | 0 | E | j/2 | 0100 |
| 3 | SRL Rm | 1 | E | m | 0000 |
| 4 | SRL WRj | 1 | E | j/2 | 0100 |
| 5 | SLL Rm | 3 | E | m | 0000 |
| 6 | SLL WRj | 3 | E | j/2 | 0100 |

## A. 3 INSTRUCTION SET SUMMARY

This section contains tables that summarize the instruction set. For each instruction there is a short description, its length in bytes, and its execution time in states.

## NOTE

The instruction execution times given in the tables are for code executing from on-chip code memory and for data that is read from and written to on-chip
RAM. Execution times are increased by executing code from external memory, accessing peripheral SFRs, accessing data in external memory, using a wait state, or extending the ALE pulse.

For some instructions, accessing the port SFRs, Px, $x=0-3$, increases the execution time. These cases are noted individually in the tables.

## A.3.1 Execution Times for Instructions that Access the Port SFRs

The execution times for some instructions increase when the instruction accesses a port SFR (Px, $x=0-3$ ) as opposed to any other SFR. Table A-18 lists these instructions and the execution times for Case 0:

- Case 0. Code executes from on-chip OTPROM/ROM and accesses locations in on-chip data RAM. The port SFRs are not accessed.

In Cases 1-4, the instructions access a port SFR:

- Case 1. Code executes from on-chip OTPROM/ROM and accesses a port SFR.
- Case 2. Code executes from external memory with no wait state and a short ALE (not extended) and accesses a port SFR.
- Case 3. Code executes from external memory with one wait state and a short ALE (not extended) and accesses a port SFR.
- Case 4. Code executes from external memory with one wait state and an extended ALE, and accesses a port SFR.

The times for Cases 1 through 4 are expressed as the number of state times to add to the state times for given for Case 0 .

Table A-18. State Times to Access the Port SFRs

| Instruction | Case 0 <br> Execution Times |  | Additional State Times |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Binary | Source | Case 1 | Case 2 | Case 3 | Case 4 |
| ADD A,dir8 | 1 | 1 | 1 | 2 | 3 | 4 |
| ADD Rm,dir8 | 3 | 2 | 1 | 2 | 3 | 4 |
| ADDC A,dir8 | 1 | 1 | 1 | 2 | 3 | 4 |
| ANL A,dir8 | 1 | 1 | 1 | 2 | 3 | 4 |
| ANL CY,bit | 3 | 2 | 1 | 2 | 3 | 4 |
| ANL CY,bit51 | 1 | 1 | 1 | 2 | 3 | 4 |
| ANL CY,/bit | 3 | 2 | 1 | 2 | 3 | 4 |
| ANL CY,/bit51 | 1 | 1 | 1 | 2 | 3 | 4 |
| ANL dir8,\#data | 3 | 3 | 2 | 4 | 6 | 8 |
| ANL dir8,A | 2 | 2 | 2 | 4 | 6 | 8 |
| ANL Rm, dir8 | 3 | 2 | 1 | 2 | 3 | 4 |
| CLR bit | 4 | 3 | 2 | 4 | 6 | 8 |
| CLR bit51 | 2 | 2 | 2 | 4 | 6 | 8 |
| CMP Rm,dir8 | 3 | 2 | 1 | 2 | 3 | 4 |
| CPL bit | 4 | 3 | 2 | 4 | 6 | 8 |
| CPL bit51 | 2 | 2 | 2 | 4 | 6 | 8 |
| DEC dir8 | 2 | 2 | 2 | 4 | 6 | 8 |
| INC dir8 | 2 | 2 | 2 | 4 | 6 | 8 |
| MOV A,dir8 | 1 | 1 | 1 | 2 | 3 | 4 |
| MOV bit,CY | 4 | 3 | 2 | 4 | 6 | 8 |
| MOV bit51,CY | 2 | 2 | 2 | 4 | 6 | 8 |
| MOV CY,bit | 3 | 2 | 1 | 2 | 3 | 4 |
| MOV CY,bit51 | 1 | 1 | 1 | 2 | 3 | 4 |
| MOV dir8,\#data | 3 | 3 | 1 | 2 | 3 | 4 |
| MOV dir8,A | 2 | 2 | 1 | 2 | 3 | 4 |
| MOV dir8,Rm | 4 | 3 | 1 | 2 | 3 | 4 |
| MOV dir8,Rn | 2 | 3 | 1 | 2 | 3 | 4 |
| MOV Rm,dir8 | 3 | 2 | 1 | 2 | 3 | 4 |
| MOV Rn, dir8 | 1 | 2 | 1 | 2 | 3 | 4 |
| ORL A,dir8 | 1 | 1 | 1 | 2 | 3 | 4 |
| ORL CY,bit | 3 | 2 | 1 | 2 | 3 | 4 |
| ORL CY,bit51 | 1 | 1 | 1 | 2 | 3 | 4 |
| ORL CY,/bit | 3 | 2 | 1 | 2 | 3 | 4 |

Table A-18. State Times to Access the Port SFRs (Continued)

| Instruction | Case 0 <br> Execution Times |  | Additional State Times |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Binary | Source | Case 1 | Case 2 | Case 3 | Case 4 |
| ORL CY,/bit51 | 1 | 1 | 1 | 2 | 3 | 4 |
| ORL dir8,\#data | 3 | 3 | 1 | 2 | 3 | 4 |
| ORL dir8,A | 2 | 2 | 2 | 4 | 6 | 8 |
| ORL Rm,dir8 | 3 | 2 | 1 | 2 | 3 | 4 |
| SETB bit | 4 | 3 | 2 | 4 | 6 | 8 |
| SETB bit51 | 2 | 2 | 2 | 4 | 6 | 8 |
| SUB Rm,dir8 | 3 | 2 | 1 | 2 | 3 | 4 |
| SUBB A,dir8 | 1 | 1 | 1 | 2 | 3 | 4 |
| XCH A,dir8 | 3 | 3 | 2 | 4 | 6 | 8 |
| XRL A,dir8 | 1 | 1 | 1 | 2 | 3 | 4 |
| XRL dir8,\#data | 3 | 3 | 2 | 4 | 6 | 8 |
| XRL dir8,A | 2 | 2 | 2 | 4 | 6 | 8 |
| XRL Rm,dir8 | 3 | 2 | 1 | 2 | 3 | 4 |

## A.3.2 Instruction Summaries

Table A-19. Summary of Add and Subtract Instructions

| Add <br> Subtract <br> Add with Carry <br> Subtract with Borrow |  | ADD <dest>,<src> SUB <dest>,<src> <br> ADDC <dest>,<src> <br> SUBB <dest>,<src> <br> dest opnd $\leftarrow$ dest opnd + src opnd <br> dest opnd $\leftarrow$ dest opnd - src opnd <br> (A) $\leftarrow(A)+$ src opnd + carry bit <br> (A) $\leftarrow(A)$ - src opnd - carry bit |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | <dest>,<src> | Notes | Binary Mode |  | Source Mode |  |
|  |  |  | Bytes | States | Bytes | States |
| ADD | AIf | Reg to acc | 1 | 1 | 2 | 2 |
|  | A. ifts | Dir byte to acc | 2 | 1 (2) | 2 | 1 (2) |
|  | A, c, $\mathrm{H}_{1}$ | Indir addr to acc | 1 | 2 | 2 | 3 |
|  | A.\#data | Immediate data to acc | 2 | 1 | 2 | 1 |
| ADD; SUB | Rmd,Rms | Byte reg to/from byte reg | 3 | 2 | 2 | 1 |
|  | WRjd,WRjs | Word reg to/from word reg | 3 | 3 | 2 | 2 |
|  | DRkd,DRks | Dword reg to/from dword reg | 3 | 5 | 2 | 4 |
|  | Rm,\#data | Immediate 8-bit data to/from byte reg | 4 | 3 | 3 | 2 |
|  | WRj,\#data16 | Immediate 16-bit data to/from word reg | 5 | 4 | 4 | 3 |
|  | DRk,\#0data16 | 16-bit unsigned immediate data to/from dword reg | 5 | 6 | 4 | 5 |
|  | Rm, dir8 | Dir addr to/from byte reg | 4 | 3 (2) | 3 | 2 (2) |
|  | WRj,dir8 | Dir addr to/from word reg | 4 | 4 | 3 | 3 |
|  | Rm,dir16 | Dir addr (64K) to/from byte reg | 5 | 3 | 4 | 2 |
|  | WRj, dir16 | Dir addr (64K) to/from word reg | 5 | 4 | 4 | 3 |
|  | Rm, @WRj | Indir addr (64K) to/from byte reg | 4 | 3 | 3 | 2 |
|  | Rm, @DRk | Indir addr (16M) to/from byte reg | 4 | 4 | 3 | 3 |
| ADDC; SUBB |  | Reg to/from acc with carry | 1 | 1 | 2 | 2 |
|  | A, dirs........... | Dir byte to/from acc with carry | 2 | 1 (2) | 2 | 1 (2) |
|  | A, @ P\%\%\%\%\%\% | Indir RAM to/from acc with carry | 1 | 2 | 2 | 3 |
|  | A.\#datal | Immediate data to/from acc with carry | 2 | 1 | 2 | 1 |

## NOTES:

1. A shaded cell denotes an instruction in the $M C S^{\circledR} 51$ architecture.
2. If this instruction addresses an l/O port $(P x, x=0-3)$, add 1 to the number of states.

Table A-20. Summary of Compare Instructions

| Compare | CMP <dest>,<src> $\quad$ dest opnd - src op |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | <dest>,<src> | Notes | Binary Mode |  | Source Mode |  |
|  |  |  | Bytes | States | Bytes | States |
| CMP | Rmd,Rms | Reg with reg | 3 | 2 | 2 | 1 |
|  | WRjd,WRjs | Word reg with word reg | 3 | 3 | 2 | 2 |
|  | DRkd,DRks | Dword reg with dword reg | 3 | 5 | 2 | 4 |
|  | Rm,\#data | Reg with immediate data | 4 | 3 | 3 | 2 |
|  | WRj, \#data16 | Word reg with immediate 16-bit data | 5 | 4 | 4 | 3 |
|  | DRk,\#Odata16 | Dword reg with zero-extended 16-bit immediate data | 5 | 6 | 4 | 5. |
|  | DRk,\#1data16 | Dword reg with one-extended 16-bit immediate data | 5 | 6 | 4 | 5 |
|  | Rm, dir8 | Dir addr from byte reg | 4 | $3^{\dagger}$ | 3 | $2{ }^{\dagger}$ |
|  | WRj, dir8 | Dir addr from word reg | 4 | 4 | 3 | 3 |
|  | Rm,dir16 | Dir addr (64K) from byte reg | 5 | 3 | 4 | 2 |
|  | WRj, dir16 | Dir addr (64K) from word reg | 5 | 4 | 4 | 3 |
|  | Rm, @ WRj | Indir addr (64K) from byte reg | 4 | 3 | 3 | 2 |
|  | Rm,@DRk | Indir addr (16M) from byte reg | 4 | 4 | 3 | 3 |

tif this instruction addresses an I/O port ( $\mathrm{P} x, x=0-3$ ), add 1 to the number of states.

Table A-21. Summary of Increment and Decrement Instructions

| Increment Increment Increment Decrement Decrement | INC DPTR <br> INC byte <br> INC <dest>,<src> <br> DEC byte <br> DEC <dest>,<src> |  | ```(DPTR)}\leftarrow(DPTR) + 1 byte \leftarrow - byte + 1 dest opnd }\leftarrow\mathrm{ dest opnd + src opnd byte \leftarrow byte-1 dest opnd }\leftarrow\mathrm{ dest opnd - src opnd``` |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | <dest>,<src> | Notes | Binary Mode |  | Source Mode |  |
|  |  |  | Bytes | States | Bytes | States |
| $\begin{aligned} & \text { INC; } \\ & \text { DEC } \end{aligned}$ | A.W.!. | acc | 1 | 1 | 1 | 1 |
|  | トn! | Reg | 1 | 1 | 2 | 2 |
|  | cirs | Dir byte | 2 | 2 (2) | 2 | 2 (2) |
|  |  | Indir RAM | 1 | 3 | 2 | 4 |
|  | Rm,\#short | Byte reg by 1, 2, or 4 | 3 | 2 | 2 | 1 |
|  | WRj, \#short | Word reg by 1, 2, or 4 | 3 | 2 | 2 | 1 |
|  | DRk,\#short | Double word reg by 1, 2, or 4 | 3 | 4 | 2 | 3 |
| INC | DPTH\%/..... | Data pointer | 1 | 1 | 1 | 1 |

NOTES:

1. A shaded cell denotes an instruction in the MCS ${ }^{\circledR} 51$ architecture.
2. If this instruction addresses an I/O port ( $\mathrm{P} x, x=0-3$ ), add 2 to the number of states.

Table A-22. Summary of Multiply, Divide, and Decimal-adjust Instructions

| Multiply <br> Divide <br> Decimal-adjust ACC for Addition (BCD) |  | MUL <reg1,reg2> MUL AB DIV <reg1>,<reg2> DIV AB DA A | (2) $(B: A)=A \times B$ <br> (2) <br> (A) = Quotient; (B) =Remainder <br> (2) |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | <dest>,<src> | Notes | Binary Mode |  | Source Mode |  |
|  |  |  | Bytes | States | Bytes | States |
| MUL | AB | Multiply A and B | 1 | 5 | 1 | 5 |
|  | Rmd,Rms | Multiply byte reg and byte reg | 3 | 6 | 2 | 5 |
|  | WRid, WRis | Multiply word reg and word reg | 3 | 12 | 2 | 11 |
| DIV | AB . | Divide A by B | 1 | 10 | 1 | 10 |
|  | Rmd,Rms | Divide byte reg by byte reg | 3 | 11 | 2 | 10 |
|  | WRjd,WRjs | Divide word reg by word reg | 3 | 21 | 2 | 20 |
| DA | A | Decimal adjust acc | 1 | 1 | 1 | 1 |

NOTES:

1. A shaded cell denotes an instruction in the MCS ${ }^{\circledR} 51$ architecture.
2. See "Instruction Descriptions" on page A-26

Table A-23. Summary of Logical Instructions

| Logical AND <br> Logical OR <br> Logical Exclusive OR <br> Clear <br> Complement <br> Rotate <br> Shift <br> SWAP |  | ANL <dest>,<src> ORL <dest>,<src> XRL <dest>,<src> CLR A <br> CPL A <br> RXX A SXX Rm or Wj <br> A | dest opnd $\leftarrow$ dest opnd $\Lambda$ src opnd dest opnd $\leftarrow$ dest opnd V src opnd dest opnd $\leftarrow$ dest opnd $\forall$ src opnd <br> (A) $\leftarrow 0$ <br> (Ai) $\leftarrow \varnothing(A i)$ <br> (1) <br> (1) <br> A3:0 $\leftrightarrow$ A7:4 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | <dest>,<src> | Notes | Binary Mode |  | Source Mode |  |
|  |  |  | Bytes | States | Bytes | States |
| ANL; <br> ORL; <br> XRL; |  | Reg to acc | 1 | 1 | 2 | 2 |
|  | A,dirs. | Dir byte to acc | 2 | 1 (3) | 2 | 1 (3) |
|  | A.e Pl\#... | Indir addr to acc | 1 | 2 | 2 | 3 |
|  | A\#data... | Immediate data to acc | 2 | 1 | 2 | 1 |
|  | dira, A \% \% | Acc to dir byte | 2 | 2 (4) | 2 | 2 (4) |
|  | Cir8,\#data... | Immediate data to dir byte | 3 | 3 (4) | 3 | 3 (4) |
|  | Rmd,Rms | Byte reg to byte reg | 3 | 2 | 2 | 1 |
|  | WRjd, WRis | Word reg to word reg | 3 | 3 | 2 | 2 |
|  | Rm,\#data | 8-bit data to byte reg | 4 | 3 | 3 | 2 |
|  | WRj, \#data16 | 16-bit data to word reg | 5 | 4 | 4 | 3 |
|  | Rm, dir8 | Dir addr to byte reg | 4 | 3 (3) | 3 | 2 (3) |
|  | WRj, dir8 | Dir addr to word reg | 4 | 4 | 3 | 3 |
|  | Rm,dir16 | Dir addr ( 64 K ) to byte reg | 5 | 3 | 4 | 2 |
|  | WRj, dir16 | Dir addr (64K) to word reg | 5 | 4 | 4 | 3 |
|  | Rm, @ WRj | Indir addr (64K) to byte reg | 4 | 3 | 3 | 2 |
|  | Rm, @ DRk | Indir addr (16M) to byte reg | 4 | 4 | 3 | 3 |
| CLR | A! N/ \% \% | Clear acc | 1 | 1 | 1 | 1 |
| CPL | A , \% श ${ }^{\text {a }}$ | Complement acc | 1 | 1 | 1 | 1 |
| RL | A\% \% \% | Rotate acc left | 1 | 1 | 1 | 1 |
| RLC | A\%N\%N\%. | Rotate acc left through the carry | 1 | 1 | 1 | 1 |
| RR | A. | Rotate acc right | 1 | 1 | 1 | 1 |
| RRC | $A$ | Rotate acc right through the carry | 1 | 1 | 1 | 1 |
| SLL | Rm | Shift byte reg left | 3 | 2 | 2 | 1 |
|  | WRj | Shift word reg left | 3 | 2 | 2 | 1 |

## NOTES:

1. See "Instruction Descriptions" on page A-26.
2. A shaded cell denotes an instruction in the MCS ${ }^{\circledR} 51$ architecture.
3. If this instruction addresses an l/O port ( $\mathrm{Px}, x=0-3$ ), add 1 to the number of states.
4. If this instruction addresses an I/O port ( $\mathrm{P} x, x=0-3$ ), add 2 to the number of states.

Table A-23. Summary of Logical Instructions (Continued)

| Logical AND <br> Logical OR <br> Logical Exclusive OR <br> Clear <br> Complement <br> Rotate <br> Shift <br> SWAP |  | ANL <dest>,<src> dest 0 ORL <dest>,<src> XRL <dest>,<src> CLR A <br> CPL A <br> RXX A <br> SXX Rm or Wj <br> A | dest opnd $\leftarrow$ dest opnd $\Lambda$ src opnd dest opnd $\leftarrow$ dest opnd V sre opnd dest opnd $\leftarrow$ dest opnd $\forall$ src opnd <br> $(A) \leftarrow 0$ <br> $(A \mathrm{I}) \leftarrow \varnothing(A \mathrm{I})$ <br> (1) <br> (1) $\text { A3:0 } \leftrightarrow A 7: 4$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | <dest>,<src> | Notes | Binary Mode |  | Source Mode |  |
|  |  |  | Bytes | States | Bytes | States |
| SRA | Rm | Shift byte reg right through the MSB | 3 | 2 | 2 | 1 |
|  | WRj | Shift word reg right through the MSB | 3 | 2 | 2 | 1 |
| SRL | Rm | Shift byte reg right | 3 | 2 | 2 | 1 |
|  | WRj | Shift word reg right | 3 | 2 | 2 | 1 |
| SWAP | A! | Swap nibbles within the acc | 1 | 2 | 1 | 2 |

NOTES:

1. See "Instruction Descriptions" on page A-26.
2. A shaded cell denotes an instruction in the $M C S^{\circledR} 51$ architecture.
3. If this instruction addresses an $1 / O$ port $(P x, x=0-3)$, add 1 to the number of states.
4. If this instruction addresses an I/O port ( $\mathrm{P} x, x=0-3$ ), add 2 to the number of states.

Table A-24. Summary of Move Instructions

| Move (2) <br> Move with Sign Extension Move with Zero Extension Move Code Byte Move to External Mem Move from External Mem |  | V <dest>,<src> VS <dest>,<src> VZ <dest>,<src> VC <dest>,<src> VX <dest>,<src> VX <dest>,<src> <br> destination destination destination $\mathrm{A} \leftarrow$ code external m A $\leftarrow$ sourc | destination $\leftarrow$ src opnd <br> destination $\leftarrow$ src opnd with sign extend <br> destination $\leftarrow$ src opnd with zero extend <br> $\mathrm{A} \leftarrow$ code byte <br> external mem $\leftarrow(A)$ <br> $A \leftarrow$ source opnd in external mem |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | <dest>,<src> | Notes | Binary Mode |  | Source Mode |  |
|  |  |  | Bytes | States | Bytes | States |
| MOV | A, Pn \% Cl | Reg to acc | 1 | 1 | 2 | 2 |
|  | A, dir8, | Dir byte to acc | 2 | 1 (3) | 2 | 1 (3) |
|  | A, © Ril | Indir RAM to acc | 1 | 2 | 2 | 3 |
|  | A \# data ${ }^{\text {a }}$ | Immediate data to acc | 2 | 1 | 2 | 1 |
|  | An A ${ }^{\text {a }}$ | Acc to reg | 1 | 1 | 2 | 2 |
|  | Rn, dir8. | Dir byte to reg | 2 | 1 (3) | 3 | 2 (3) |
|  | Rniflata \% | Immediate data to reg | 2 | 1 | 3 | 2 |
|  | $\mathrm{dirB}_{4} \mathrm{~S}$ | Acc to dir byte | 2 | 2 (3) | 2 | 2 (3) |
|  | dir8 Pn 5.4 | Reg to dir byte | 2 | 2 (3) | 3 | 3 (3) |
|  | dir8,dir8 | Dir byte to dir byte | 3 | 3 | 3 | 3 |
|  | dirs, © HI, | Indir RAM to dir byte | 2 | 3 | 3 | 4 |
|  | dir8\# \#data: | Immediate data to dir byte | 3 | 3 (3) | 3 | 3 (3) |
|  | ©RI, A | Acc to indir RAM | 1 | 3 | 2 | 4 |
|  | © Ri,dirs. | Dir byte to indir RAM | 2 | 3 | 3 | 4 |
|  | Q Ri,\#data | Immediate data to indir RAM | 2 | 3 | 3 | 4 |
|  | DPTR\#\#datal6: | Load Data Pointer with a 16-bit const | 3 | 2 | 3 | 2 |
|  | Rmd,Rms | Byte reg to byte reg | 3 | 2 | 2 | 1 |
|  | WRjd,WRjs | Word reg to word reg | 3 | 2 | 2 | 1 |
|  | DRkd,DRks | Dword reg to dword reg | 3 | 3 | 2 | 2 |
|  | Rm,\#data | 8-bit immediate data to byte reg | 4 | 3 | 3 | 2 |
|  | WRj, \#data16 | 16-bit immediate data to word reg | 5 | 3 | 4 | 2 |
|  | DRk,\#Odata16 | zero-extended 16-bit immediate data to dword reg | 5 | 5 | 4 | 4 |
|  | DRk,\#1data16 | one-extended 16-bit immediate data to dword reg | 5 | 5 | 4 | 4 |

## NOTES:

1. A shaded cell denotes an instruction in the $M C S^{\circledR} 51$ architecture.
2. Instructions that move bits are in Table A-26 on page A-23.
3. If this instruction addresses an I/O port ( $\mathrm{P} x, \boldsymbol{x}=0-3$ ), add 1 to the number of states.
4. External memory addressed by instructions in the MCS 51 architecture is in the region specified by

DPXL (reset value $=01 \mathrm{H}$ ). See "Compatibility with the MCS® 51 Architecture" on page 3-2.

Table A-24. Summary of Move Instructions (Continued)

| Move (2) <br> Move with Sign Extension <br> Move with Zero Extension <br> Move Code Byte <br> Move to External Mem <br> Move from External Mem |  | MOV <dest>,<src> MOVS <dest>,<src> MOVZ <dest>,<src> MOVC <dest>,<src> MOVX <dest>,<src> MOVX <dest>,<src> | destination $\leftarrow$ src opnd <br> destination $\leftarrow$ src opnd with sign extend destination $\leftarrow$ src opnd with zero extend <br> A $\leftarrow$ code byte <br> external mem $\leftarrow$ (A) <br> $A \leftarrow$ source opnd in external mem |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | <dest>,<src> | Notes | Binar | Mode | Sourc | Mode |
|  |  |  | Bytes | States | Bytes | States |
| MOV | DRk,dir8 | Dir addr to dword reg | 4 | 6 | 3 | 5 |
|  | DRk, dir16 | Dir addr (64K) to dword reg | 5 | 6 | 4 | 5 |
|  | Rm, dir8 | Dir addr to byte reg | 4 | 3 (3) | 3 | 2 (3) |
|  | WRj, dir8 | Dir addr to word reg | 4 | 4 | 3 | 3 |
|  | Rm,dir16 | Dir addr (64K) to byte reg | 5 | 3 | 4 | 2 |
|  | WRj, dir16 | Dir addr (64K) to word reg | 5 | 4 | 4 | 3 |
|  | Rm, @WRj | Indir addr (64K) to byte reg | 4 | 2 | 3 | 2 |
|  | Rm, @DRk | Indir addr (16M) to byte reg | 4 | 4 | 3 | 3 |
|  | WRid, @ WRjs | Indir addr(64K) to word reg | 4 | 4 | 3 | 3 |
|  | WRj, @ DRk | Indir addr(16M) to word reg | 4 | 5 | 3 | 4 |
|  | dir8,Rm | Byte reg to dir addr | 4 | 4 (3) | 3 | 3 (3) |
|  | dir8,WRj | Word reg to dir addr | 4 | 5 | 3 | 4 |
|  | dir16,Rm | Byte reg to dir addr (64K) | 5 | 4 | 4 | 3 |
|  | dir16,WRj | Word reg to dir addr (64K) | 5 | 5 | 4 | 4 |
|  | @WRj,Rm | Byte reg to indir addr (64K) | 4 | 4 | 3 | 3 |
|  | @ DRk,Rm | Byte reg to indir addr (16M) | 4 | 5 | 3 | 4 |
|  | @WRjd,WRjs | Word reg to indir addr (64K) | 4 | 5 | 3 | 4 |
|  | @ DRk,WRj | Word reg to indir addr (16M) | 4 | 6 | 3 | 5 |
|  | dir8,DRk | Dword reg to dir addr | 4 | 7 | 3 | 6 |
|  | dir16,DRk | Dword reg to dir addr (64K) | 5 | 7 | 4 | 6 |
|  | Rm, @WRj+dis16 | Indir addr with disp (64K) to byte reg | 5 | 6 | 4 | 5 |
|  | WRj, @WRj+dis16 | Indir addr with disp (64K) to word reg | 5 | 7 | 4 | 6 |
|  | Pm, 盛DRK dic24 | Indir addr with disp (1ENA) to byte reg | 5 | 7 | 4 | 6 |
|  | WRj, @ DRk+dis24 | Indir addr with disp (16M) to word reg | 5 | 8 | 4 | 7 |
|  | @WRj+dis16,Rm | Byte reg to Indir addr with disp (64K) | 5 | 6 | 4 | 5 |

## NOTES:

1. A shaded cell denotes an instruction in the MCS ${ }^{\circledR} 51$ architecture.
2. Instructions that move bits are in Table A-26 on page A-23.
3. If this instruction addresses an I/O port ( $\mathrm{P} x, x=0-3$ ), add 1 to the number of states.
4. External memory addressed by instructions in the MCS 51 architecture is in the region specified by DPXL (reset value $=01 \mathrm{H}$ ). See "Compatibility with the MCS® 51 Architecture" on page 3-2.

Table A-24. Summary of Move Instructions (Continued)

| Move (2) <br> Move with Sign Extension Move with Zero Extension Move Code Byte Move to External Mem Move from External Mem |  | V <dest>,<src> destination <br> VS <dest>,<src> destination <br> VZ <dest>,<src> destination <br> VC <dest>,<src> A $\leftarrow$ code <br> VX <dest>,<src> external m <br> VX <dest>,<src> $\mathbf{A} \leftarrow$ sourc | destination $\leftarrow$ src opnd <br> destination $\leftarrow$ src opnd with sign extend destination $\leftarrow$ src opnd with zero extend <br> $\mathrm{A} \leftarrow$ code byte <br> external mem $\leftarrow$ (A) <br> $A \leftarrow$ source opnd in external mem |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | <dest>,<src> | Notes | Binary Mode |  | Source Mode |  |
|  |  |  | Bytes | States | Bytes | States |
| MOV | @ WR ${ }^{\text {+ }}$ dis $16, W R \mathrm{j}$ | Word reg to Indir addr with disp (64K) | 5 | 7 | 4 | 6 |
|  | @ DRk+dis24,Rm | Byte reg to Indir addr with disp (16M) | 5 | 7 | 4 | 6 |
|  | @DRk+dis24,WRj | Word reg to Indir addr with disp (16M) | 5 | 8 | 4 | 7 |
| MOVH | DRk(hi), \#data16 | 16-bit immediate data into upper word of dword reg | 5 | 3 | 4 | 2 |
| MOVS | WRj, Rm | Byte reg to word reg with sign extension | 3 | 2 | 2 | 1 |
| MOVZ | WRj,Rm | Byte reg to word reg with zeros extension | 3 | 2 | 2 | 1 |
| MOVC | A, A A DPTR. | Code byte relative to DPTR to acc | 1 | 6 | 1 | 6 |
|  | A, $C$ A+PC | Code byte relative to PC to acc | 1 | 6 | 1 | 6 |
| MOVX | A.ORI. | External mem (8-bit addr) to acc (4) | 1 | 4 | 2 | 5 |
|  | A, ODPTR. | External mem (16-bit addr) to acc (4) | 1 | 5 | 1 | 5 |
|  | @ R1,A | Acc to external mem (8-bit addr) (4) | 1 | 4 | 1 | 4 |
|  | $\Leftrightarrow \mathrm{DPTR} A, \%$ | Acc to external mem (16-bit addr) (4) | 1 | 5 | 1 | 5 |

## NOTES:

1. A shaded cell denotes an instruction in the MCS ${ }^{\circledR} 51$ architecture.
2. Instructions that move bits are in Table A-26 on page A-23.
3. If this instruction addresses an I/O port ( $\mathrm{P} x, x=0-3$ ), add 1 to the number of states.
4. External memory addressed by instructions in the MCS 51 architecture is in the region specified by DPXL (reset value $=01 \mathrm{H}$ ). See "Compatibility with the MCS® 51 Architecture" on page 3-2.

Table A-25. Summary of Exchange, Push, and Pop Instructions

| Exchange Contents Exchange Digit Push Pop |  | <dest, <src> A $\leftrightarrow$ src opnd <br> $D$ <dest>,<src> A3:0 $\leftrightarrow$ on-chip RAM bits 3:0 <br> $H$ <src> $S P \leftarrow S P+1 ;(S P) \leftarrow$ src <br> <dest> dest $\leftarrow(S P) ; S P \leftarrow S P-1$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | <dest>,<src> | Notes | Binary Mode |  | Source Mode |  |
|  |  |  | Bytes | States | Bytes | States |
| XCH | A.Rn | Acc and reg | 2 | 3 | 2 | 3 |
|  | A,dir8 | Acc and dir addr | 2 | 3 (2) | 2 | 3 (2) |
|  | A.© ${ }^{1}$ | Acc and on-chip RAM (8-bit addr) | 1 | 4 | 1 | 4 |
| XCHD | $A, \oplus P 1$ | Acc and low nibble in on-chip RAM (8-bit addr) | 1 | 4 | 1 | 4 |
| PUSH | dir8 | Push dir byte onto stack | 2 | 2 | 2 | 2 |
|  | \#data | Push immediate data onto stack | 4 | 4 | 3 | 3 |
|  | \#data16 | Push 16-bit immediate data onto stack | 5 | 5 | 4 | 5 |
|  | Rm | Push byte reg onto stack | 3 | 4 | 2 | 3 |
|  | WRj | Push word reg onto stack | 3 | 6 | 2 | 5 |
|  | DRk | Push double word reg onto stack | 3 | 10 | 2 | 9 |
| POP | Dir | Pop dir byte from stack | 2 | 3/3 | 2 | 3/3 |
|  | Rm | Pop byte reg from stack | 3 | 3 | 2 | 2 |
|  | WRj | Pop word reg from stack | 3 | 5 | 2 | 4 |
|  | DRk | Pop double word reg from stack | 3 | 9 | 2 | 8 |

NOTES:

1. A shaded cell denotes an instruction in the MCS® 51 architecture.
2. If this instruction addresses an I/O port ( $\mathrm{P} x, x=0-3$ ), add 2 to the number of states.

Table A-26. Summary of Bit Instructions

| Clear Bit <br> Set Bit <br> Complement Bit <br> AND Carry with Bit <br> AND Carry with Complement of Bit <br> OR Carry with Bit <br> ORL Carry with Complement of Bit <br> Move Bit to Carry <br> Move Bit from Carry |  |  | CLR bit SETB bit CPL bit ANL CY,bit ANL CY,/bit ORL CY,bit ORL CY,/bit MOV CY,bit MOV bit,CY | bit $\leftarrow 0$ <br> bit $\leftarrow 1$ <br> bit $\leftarrow \varnothing$ bit <br> $C Y \leftarrow C Y \Lambda$ bit <br> $C Y \leftarrow C Y \wedge \varnothing$ bit <br> $\mathrm{CY} \leftarrow \mathrm{CY} V$ bit <br> $\mathbf{C Y} \leftarrow$ CY V Øbit <br> $\mathrm{CY} \leftarrow$ bit <br> bit $\leftarrow \mathbf{C Y}$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | <src>,<dest> | Notes |  | Binary Mode |  | Source Mode |  |
|  |  |  |  | Bytes | States | Bytes | States |
| CLR | Cr | Clear carry |  | 1 | 1 | 1 | 1 |
|  | bi51. | Clear dir bit |  | 2 | 2 (2) | 2 | 2 (2) |
|  | bit | Clear dir bit |  | 4 | 4 | 3 | 3 |
| SETB | CY | Set carry |  | 1 | 1 | 1 | 1 |
|  | bit51 \% \% ${ }^{\text {a }}$ | Set dir bit |  | 2 | 2 (2) | 2 | 2 (2) |
|  | bit | Set dir bit |  | 4 | 4 (2) | 3 | 3 (2) |
| CPL | CY) | Complement carry |  | 1 | 1 | 1 | 1 |
|  | bit51\%.5. | Complement dir bit |  | 2 | 2 (2) | 2 | 2 (2) |
|  | bit | Complement dir bit |  | 4 | 4 (2) | 3 | 3 (2) |
| ANL | cYbitst | AND dir bit to carry |  | 2 | 1 (3) | 2 | 1 (3) |
|  | CY,bit | AND dir bit to carry |  | 4 | 3 (3) | 3 | 2 (3) |
| ANL | CY/bit51, | AND complemented dir bit to carry |  | 2 | 1 (3) | 2 | 1 (3) |
|  | CY,/bit | AND complemented dir bit to carry |  | 4 | 3 (3) | 3 | 2 (3) |
| ORL | CY,bit51. | OR dir bit to carry |  | 2 | 1 (3) | 2 | 1 (3) |
|  | CY,bit | OR dir bit to carry |  | 4 | 3 (3) | 3 | 2 (3) |
| ORL | CY/bit5IL | OR complemented dir bit to carry |  | 2 | 1 (3) | 2 | 1 (3) |
|  | CY,/bit | OR complemented dir bit to carry |  | 4 | 3 (3) | 3 | 2 (3) |
| MOV | CYbit51. | Move dir bit to carry |  | 2 | 1 (3) | 2 | 1 (3) |
|  | CY,bit | Move dir bit to carry |  | 4 | 3 (3) | 3 | 2 (3) |
|  | bit51.CY/ | Move carry to dir bit |  | 2 | 2 (2) | 2 | 2 (2) |
|  | bit,CY | Move carry to dir bit |  | 4 | 4 (2) | 3 | 3 (2) |

## NOTES:

1. A shaded cell denotes an instruction in the MCS ${ }^{\circledR} 51$ architecture.
2. If this instruction addresses an I/O port ( $\mathrm{P} x, x=0-3$ ), add 2 to the number of states.
3. If this instruction addresses an I/O port ( $\mathrm{P} x, x=0-3$ ), add 1 to the number of states.

Table A-27. Summary of Control Instructions

| Mnemonic | <dest>,<src> | Notes | Binary Mode |  | Source Mode |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Bytes | States (2) | Bytes | States (2) |
| ACALL | addrı | Absolute subroutine call | 2 | 9 | 2 | 9 |
| ECALL | @DRK | Extended subroutine call, indirect | 3 | 12 | 2 | 11 |
|  | addr24 | Extended subroutine call | 5 | 14 | 4 | 13 |
| LCALL | @WRj | Long subroutine call, indirect | 3 | 9 | 2 | 8 |
|  | aders ${ }^{\text {a }}$ | Long subroutine call | 3 | 9 | 3 | 9 |
| RET |  | Return from subroutine | 1 | 6 | 1 | 6 |
| ERET |  | Extended subroutine return | 3 | 10 | 2 | 9 |
| RETI |  | Return from interrupt | 1 | 6 | 1 | 6 |
| AJMP | acciritm.... | Absolute jump | 2 | 3 | 2 | 3 |
| EJMP | addr24 | Extended jump | 5 | 6 | 4 | 5 |
|  | @DRk | Extended jump, indirect | 3 | 7 | 2 | 6 |
| LJMP | @WRj | Long jump, indirect | 3 | 6 | 2 | 5 |
|  | addri6.. | Long jump | 3 | 4 | 3 | 4 |
| SJMP | rel! | Short jump (relative addr) | 2 | 3 | 2 | 3 |
| JMP | @AMDPTA. | Jump indir relative to the DPTR | 1 | 5 | 1 | 5 |
| JC |  | Jump if carry is set | 2 | 1/4 | 2 | 1/4 |
| JNC | rel\%\%\%\% | Jump if carry not set | 2 | 1/4 | 2 | 1/4 |
| JB | bits miel. | Jump if dir bit is set | 3 | $2 / 5$ | 3 | 2/5 |
|  | bit,rel | Jump if dir bit of 8-bit addr location is set | 5 | 4/7 | 4 | 3/6 |
| JNB | bit5inim......\| | Jump if dir bit is not set | 3 | $2 / 5$ | 3 | 2/5 |
|  | bit,rel | Jump if dir bit of 8-bit addr location is not set | 5 | 4/7 | 4 | 3/6 |
| JBC |  | Jump if dir bit is set \& clear bit | 3 | 4/7 | 3 | 4/7 |
|  | bit,rel | Jump if dir bit of 8-bit addr location is set and clear bit | 5 | 7/10 | 4 | 6/9 |
| JZ |  | Jump if acc is zero | 2 | $2 / 5$ | 2 | 2/5 |
| JN7 | ral. | Jump if acc is not zero | 2 | 2/5 | 2 | 2/5 |
| JE | rel | Jump if equal | 3 | 2/5 | 2 | 1/4 |
| JNE | rel | Jump if not equal | 3 | $2 / 5$ | 2 | 1/4 |
| JG | rel | Jump if greater than | 3 | $2 / 5$ | 2 | 1/4 |
| JLE | rel | Jump if less than or equal | 3 | 2/5 | 2 | 1/4 |

## NOTES:

1. A shaded cell denotes an instruction in the MCS® 51 architecture.
2. For conditional jumps, times are given as not-taken/taken.

INSTRUCTION SET REFERENCE

Table A-27. Summary of Control Instructions (Continued)

| Mnemonic | <dest>,<src> | Notes | Binary Mode |  | Source Mode |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Bytes | States (2) | Bytes | States (2) |
| JSL | rel | Jump if less than (signed) | 3 | 2/5 | 2 | 1/4 |
| JSLE | rel | Jump if less than or equal (signed) | 3 | 2/5 | 2 | 1/4 |
| JSG | rel | Jump if greater than (signed) | 3 | 2/5 | 2 | 1/4 |
| JSGE | rel | Jump if greater than or equal (signed) | 3 | 2/5 | 2 | 1/4 |
| CJNE | A. cirs,rel | Compare dir byte to acc and jump if not equal | 3 | 2/5 | 3 | 2/5 |
|  | A, tedta, | Compare immediate to acc and jump if not equal | 3 | 2/5 | 3 | 2/5 |
|  | Alitidata, | Compare immediate to reg and jump if not equal | 3 | 2/5 | 4 | 3/6 |
|  | Q Fin, teda, rel | Compare immediate to indir and jump if not equal | 3 | 3/6 | 4 | 4/7 |
| DJNZ | Fintrel | Decrement reg and jump if not zero | 3 | 2/5 | 3 | 3/6 |
|  | cliss rel | Decrement dir byte and jump if not zero | 3 | 3/6 | 3 | 3/6 |
| TRAP | - | Jump to the trap interrupt vector | 2 | 10 | 1 | 9 |
| NOP |  | No operation | 1 | 1 | 1 | 1 |

NOTES:

1. A shaded cell denotes an instruction in the MCS ${ }^{\circledR} 51$ architecture.
2. For conditional jumps, times are given as not-taken/taken.

## A. 4 INSTRUCTION DESCRIPTIONS

This section describes each instruction in the MCS 251 architecture. See the note on page A-11 regarding execution times.

Table A-28 defines the symbols ( $-, \checkmark, 1,0, ?$ ) used to indicate the effect of the instruction on the flags in the PSW and PSW1 registers. For a conditional jump instruction, "!" indicates that a flag influences the decision to jump.

Table A-28. Flag Symbols

| Symbol | Description |
| :---: | :--- |
| - | The instruction does not modify the flag. |
| $\checkmark$ | The instruction sets or clears the flag, as appropriate. |
| 1 | The instruction sets the flag. |
| 0 | The instruction clears the flag. |
| $?$ | The instruction leaves the flag in an indeterminate state. |
| 1 | For a conditional jump instruction: The state of the flag before the <br> instruction executes influences the decision to jump or not jump. |

ACALL <addr11>
Function: Absolute call
Description: Unconditionally calls a subroutine at the specified address. The instruction increments the 3byte PC twice to obtain the address of the following instruction, then pushes bytes 0 and 1 of the result onto the stack (byte 0 first) and increments the stack pointer twice. The destination address is obtained by successively concatenating bits $15-11$ of the incremented PC, opcode bits 7-5, and the second byte of the instruction. The subroutine called must therefore start within the same 2-Kbyte "page" of the program memory as the first byte of the instruction following ACALL.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: The stack pointer (SP) contains 07H and the label "SUBRTN" is at program memory location 0345 H . After executing the instruction

ACALL SUBRTN
at location 0123H, SP contains 09 H ; on-chip RAM locations 08 H and 09 H contain 01 H and 25 H , respectively; and the PC contains 0345 H .

|  | Binary Mode So |  | Source Mode |  |
| :---: | :---: | :---: | :---: | :---: |
| Bytes: | 2 |  | 2 |  |
| States: | 9 |  |  |  |
| [Encoding] | a10 a9 a8 1 | 0001 | a7 a6 a5 a4 | a3 a2 a1 a0 |
| Hex Code in: | Binary Mode Source Mode | ncoding ncoding |  |  |
| Operation: | ACALL <br> $(\mathrm{PC}) \leftarrow(\mathrm{PC})$ <br> $(S P) \leftarrow(S P)$ <br> $((S P)) \leftarrow(P C$. <br> $(\mathrm{SP}) \leftarrow(\mathrm{SP})+$ <br> $((S P)) \leftarrow(P C$ <br> (PC. 10:0) $\leftarrow P$ | address |  |  |

## ADD <dest>,<src>

Function: Add
Description: Adds the source operand to the destination operand, which can be a register or the accumulator, leaving the result in the register or accumulator. If there is a carry out of bit 7 (CY), the CY flag is set. If byte variables are added, and if there is a carry out of bit 3 (AC), the AC flag is set. For addition of unsigned integers, the CY flag indicates that an overflow occurred.

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 , the OV flag is set. When adding signed integers, the OV flag 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, register-indirect, and immediate.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |

Example: Register 1 contains 0 C3H (11000011B) and register 0 contains OAAH (10101010B). After executing the instruction

ADD R1,R0
register 1 contains 6DH (01101101B), the AC flag is clear, and the CY and OV flags are set.

## Variations

ADD A,\#data

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | 1 | 1 |

[Encoding] $\square$ immed. data

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode $=$ [Encoding]
Operation: ADD
$(\mathrm{A}) \leftarrow(\mathrm{A})+$ \#data
ADD A,dir8

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | $1 \dagger$ | $1 \dagger$ |

$\dagger$ ff this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state.

[Encoding] | 0010 | 0101 |
| :--- | :--- |

Hex Code in: $\quad$ Binary Mode $=[$ Encoding $]$
Source Mode $=$ [Encoding]
Operation: ADD
$(A) \leftarrow(A)+($ dir $)$
ADD A,@Ri

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 1 | 2 |
| States: | 2 | 3 |

[Encoding]

| 0010 | 011 i |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode = [A5][Encoding]
Operation: ADD
$(A) \leftarrow(A)+((R i))$
ADD A,Rn
Binary Mode Source Mode
Bytes:
12
States:
$1 \quad 2$
[Encoding]

| 0010 | 1 rrr |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding] Source Mode = [A5][Encoding]

Operation: ADD
$(A) \leftarrow(A)+(R n)$

| ADD Rmd,Rms |  |  |
| :--- | :---: | :---: |
|  | Binary Mode | Source Mode |
| Bytes: | 3 | 2 |
| States: | 2 | 1 |



| [Encoding] | 0010 | 1101 | tttt | TTTT |
| :---: | :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |
| Operation: | $\begin{aligned} & \text { ADD } \\ & (\text { WRjd }) \leftarrow(\text { WRjd })+(\text { WRjs }) \end{aligned}$ |  |  |  |

## ADD DRkd,DRks

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 5 | 4 |

[Encoding]

| 0010 | 1111 |
| :--- | :--- |


| uuuu | UUUU |
| :--- | :--- |

Hex Code in: Binary Mode = [A5][Encoding] Source Mode $=$ [Encoding]

Operation: ADD
(DRkd) $\leftarrow($ DRkd $)+($ DRks $)$
ADD Rm,\#data

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | 3 | 2 |

[Encoding]

| 0010 | 1110 |
| :--- | :--- |


| ssss | 0000 |
| :---: | :---: |

Hex Code in: Binary Mode = [A5][Encoding]
Source Mode $=$ [Encoding]
Operation: ADD
$(\mathrm{Rm}) \leftarrow(\mathrm{Rm})+$ \#data
ADD WRJ,\#data16

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 5 | 4 |
| States: | 4 | 3 |

[Encoding]

| 0010 | 1110 | ttt | 0100 | \#data hi | \#data low |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 ][Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | $\begin{aligned} & \text { ADD } \\ & (\mathrm{WRj}) \leftarrow(\mathrm{WR} \mathrm{j})+\text { \#data16 } \end{aligned}$ |  |  |  |  |

ADD DRk,\#Odata16

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 5 | 4 |
| States: | 6 | 5 |
| [Encoding] |  |  |


| 0010 | 1110 | uuuu | 1000 | \#data hi | \#data low |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | $\begin{aligned} & \text { ADD } \\ & (\mathrm{DRk}) \leftarrow(\mathrm{DRk})+\text { \#data16 } \end{aligned}$ |  |  |  |  |
| ADD Rm, dir8 |  |  |  |  |  |
| Binary Mode Source Mode |  |  |  |  |  |
| Bytes: | 4 | 3 |  |  |  |
| States: | $3 \dagger$ | 2 |  |  |  |
| $\dagger$ If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state. |  |  |  |  |  |

[Encoding]

| 0010 | 1110 |
| :--- | :--- |


| ssss | 0001 |
| :---: | :---: | direct addr

Hex Code in: Binary Mode = [A5][Encoding]
Source Mode $=$ [Encoding]
Operation: ADD
$(R m) \leftarrow(R m)+($ dir8)

INSTRUCTION SET REFERENCE

ADD WRj,dir8

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | 4 | 3 |

[Encoding] | 0010 | 1110 | ttt |
| :--- | :--- | :--- |

Hex Code in: Binary Mode $=$ [A5][Encoding]
Source Mode $=[$ Encoding
Operation: ADD
$(W R \mathrm{i}) \leftarrow(\mathrm{WRj})+($ dir8 $)$
ADD Rm,dir16

Bytes:
Binary Mode Source Mode
States: 3
[Encoding]

| 0010 1110 <br> Hex Code in: Binary Mode $=[$ [A5 $]$ [Encoding <br> Source Mode $=\left[\begin{array}{l}\text { Encoding }\end{array}\right.$ |
| :---: | :---: |

Operation: ADD
$(\mathrm{Rm}) \leftarrow(\mathrm{Rm})+(\operatorname{dir} 16)$

## ADD WRj,dir16

## Bytes:

Binary Mode
Source Mode

States:
4
3
[Encoding]

| 0010 | 1110 |
| :--- | :--- |


| ttt | 0111 |
| :--- | :--- |

direct addr
direct addr
$\begin{array}{ll}\text { Hex Code in: } & \begin{array}{l}\text { Binary Mode }=[\text { A5] [Encoding }] \\ \text { Source Mode }=[\text { Encoding }]\end{array}\end{array}$ Source Mode = [Encoding]

Operation: ADD $(W R j) \leftarrow(W R j)+(\operatorname{dir} 16)$

ADD Rm,@WRj
Binary Mode Source Mode

| Bytes: | 4 | 3 |
| :--- | :--- | :--- |
| States: | 3 | 2 |

## [Encoding]

| 0010 | 1110 |
| :--- | :--- | :--- | :--- | :--- | :--- |
| tttt | 1001 |

Hex Code in: Binary Mode = [A5][Encoding] Source Mode $=$ [Encoding]

Operation: ADD
$(\mathrm{Rm}) \leftarrow(\mathrm{Rm})+((\mathrm{WR} \mathrm{j}))$
ADD Rm,@DRk

Bytes:

## Binary Mode Source Mode

States:

## 4

3
[Encoding]

| 0010 | 1110 |
| :---: | :---: | :---: | :---: | :---: |$\quad$| uuuu | 1011 |
| :---: | :---: |

Hex Code in: Binary Mode $=[$ [A5][Encoding $]$
Source Mode = [Encoding]

Operation: ADD
$(\mathrm{Rm}) \leftarrow(\mathrm{Rm})+((\mathrm{DRk}))$

## ADDC A,<src>

Function: Add with carry
Description: Simultaneously adds the specified byte variable, the CY flag, and the accumulator contents, leaving the result in the accumulator. If there is a carry out of bit 7 (CY), the CY flag is set; if there is a carry out of bit 3 (AC), the AC flag is set. When adding unsigned integers, the CY flag indicates that an overflow occurred.

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 , the OV flag is set. When adding signed integers, the OV flag 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, register-indirect, and immediate.
Flags:

| こソ | AC | OV | N | $Z$ |
| :---: | :---: | :---: | :---: | :---: |
| $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |

Example: The accumulator contains 0C3H (11000011B), register 0 contains 0AAH (10101010B), and the CY flag is set. After executing the instruction

ADDC A,RO
the accumulator contains 6EH (01101110B), the AC flag is clear, and the CY and OV flags are set.

Variations
ADDC A,\#data

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | 1 | 1 |

[Encoding]

| 0011 | 0100 |
| :--- | :--- |

immed. data

Hex Code in: Binary Mode = [Encoding]
Source Mode $=$ [Encoding $]$
Operation: ADDC
$(\mathrm{A}) \leftarrow(\mathrm{A})+(\mathrm{CY})+$ \#data
ADDC A,dir8

Bytes:
Binary Mode Source Mode

States:
$1 \dagger \quad 1 \dagger$
†lf this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state.
[Encoding]

| 0011 | 0101 |
| :--- | :--- |

direct addr
Hex Code in: Binary Mode = [Encoding]
Source Mode $=$ [Encoding $]$
Operation: ADDC
$(A) \leftarrow(A)+(C Y)+($ dir8 $)$
ADDC A,@Ri
Binary Mode Source Mode
Bytes:
States:
2
2
[Encoding]

| 0011 | 011 i |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding $]$
Source Mode = [A5][Encoding]
Operation: ADDC
$(A) \leftarrow(A)+(C Y)+((R i))$

ADDC A,Rn

## Binary Mode Source Mode

Bytes:
States:
.
2
2
[Encoding]

| 0011 | 1 rrr |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding] Source Mode $=[$ A5][Encoding]

Operation: ADDC
$(A) \leftarrow(A)+(C Y)+(R n)$

## AJMP addr11

Function: Absolute jump
Description: Transfers program execution to the specified address, which is formed at run time by concatenating the upper five bits of the PC (after incrementing the PC twice), opcode bits 75 , and the second byte of the instruction. The destination must therefore be within the same 2-Kbyte "page" of program memory as the first byte of the instruction following AJMP.
Flags:

| CY | AC | OV | N | $\mathbf{Z}$ |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: The label "JMPADR" is at program memory location 0123H. After executing the instruction
AJMP JMPADR
at location 0345 H , the PC contains 0123 H .

Bytes:
Binary Mode Source Mode
States:
22
3
3
[Encoding] $\square$
a7 a6 a5 a4 $\quad$ a3 a2 a1 a0

Hex Code in: Binary Mode $=$ [Encoding]
Source îiode = [Encodingi
Operation: AJMP
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+2$
(PC. 10:0) $\leftarrow$ page address

## ANL <dest>,<src>

Function: Logical-AND
Description: Performs the bitwise logical-AND ( $\Lambda$ ) operation between the specified variables and stores the results in the destination variable.

The two operands allow 10 addressing mode combinations. When the destination is the register or 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 is read from the output data latch, not the input pins.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | $\checkmark$ | $\checkmark$ |

Example: Register 1 contains 0C3H (11000011B) and register 0 contains 55H (01010101B). After executing the instruction

ANL R1,R0
register 1 contains 41H (01000001B).
When the destination is a directly addressed byte, this instruction clears combinations of bits in any RAM location or hardware register. The mask byte determining the pattern of bits to be cleared would either be an immediate constant contained in the instruction or a value computed in the register or accumulator at run time. The instruction

ANL P1,\#01110011B
clears bits 7,3 , and 2 of output port 1.

## Variations

ANL dir8,A

## Bytes:

Binary Mode

States:
2
Source Mode

2†
2†
$\dagger$ If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 2 states.
[Encoding]

| 0101 | 0010 |
| :--- | :--- | direct addr

Hex Code in: Binary Mode $=[$ Encoding $]$
Source Mode $=$ [Encoding]
Operation: ANL
$($ dir8 $) \leftarrow($ dir8) $\Lambda(A)$

ANL dir8,\#data

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 3 |
| States: | $3 \dagger$ | $3 \dagger$ |

$\dagger \mid f$ this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state.

[Encoding] | 0101 | 0011 |
| :--- | :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode $=$ [Encoding]
Operation:
ANL
(dir8) $\leftarrow$ (dir8) $\Lambda$ \#data

ANL A,\#data

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | 1 | 1 |

[Encoding] $\square$ immed. data
Hex Code in: Binary Mode $=$ [Encoding $]$
Source Mode $=$ [Encoding]
Operation: ANL
$($ A $) \leftarrow(A) \Lambda$ \#data
ANL A,dir8

Bytes:
Binary Mode Source Mode
States:
2
2
$1 \dagger$
$1 \dagger$
$\dagger$ lf this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state.
[Encoding]

| 0101 | 0101 |
| :--- | :--- | direct addr

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode = [Encoding]
Operation: ANL
$(A) \leftarrow(A) \Lambda$ (dir8)

ANL A,@Ri

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 1 | 2 |
| States: | 2 | 3 |

[Encoding] | 0101 | 011 i |
| :---: | :---: |

Hex Code in: Binary Mode $=[$ Encoding $]$
Source Mode = [A5][Encoding]
Operation: ANL
$(\mathrm{A}) \leftarrow(\mathrm{A}) \Lambda((\mathrm{Ri}))$
ANL A,Rn

|  | Binary Mode | Source |
| :--- | :---: | ---: |
| Bytes: | 1 | 2 |
| States: | 1 | 2 |

[Encoding] $\square$
Hex Code in: Binary Mode $=$ [Encoding $]$
Source Mode = [A5][Encoding]
Operation: ANL
$(\mathrm{A}) \leftarrow(\mathrm{A}) \Lambda(\mathrm{Rn})$
ANL Rmd,Rms

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 2 | 1 |

[Encoding]

| 0101 | 1100 |
| :--- | :--- |


| ssss | SSSS |
| :---: | :---: |

Hex Code in: Binary Mode $=[$ A5][Encoding] Source Mode $=$ [Encoding]

Operation: ANL
$(\mathrm{Rmd}) \leftarrow(\mathrm{Rmd}) \Lambda(\mathrm{Rms})$
ANL WRjd,WRjs

|  | Binary Mode | Source Mode |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Bytes: | 3 |  | 2 |  |
| States: | 3 |  |  |  |
| [Encoding] | 0101 | 1101 | tttt | TTTT |



ANL WRj,dir8

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | 4 | 3 |


| [Encoding] | 0101 | 1110 | ttt | 0101 | direct addr |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }] \text { [Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | ANL$(W R \mathrm{j}) \leftarrow(\mathrm{WR} \mathrm{j}) \wedge(\mathrm{dir} 8)$ |  |  |  |  |

ANL Rm,dir16
Binary Mode
Bytes:

States: $\quad$| Source Mode |
| :---: |
| [Encoding] |

Hex Code in: Binary Mode $=[$ A5][Encoding $]$ Source Mode $=$ [Encoding]

Operation: ANL
$(\mathrm{Rm}) \leftarrow(\mathrm{Rm}) \Lambda(\operatorname{dir} 16)$
ANL WRj,dir16

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 5 | 4 |
| States: | 4 | 3 |
| [Encoding] |  |  |



ANL Rm,@WRj

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | 3 | 2 |

[Encoding]

| 0101 | 1110 |
| :--- | :--- | :--- | :--- | :--- |$\quad$| ttt | 1001 |
| :--- | :--- |

Hex Code in: Binary Mode = [A5][Encoding]
Source Mode $=$ [Encoding]
Operation: ANL
$(\mathrm{Rm}) \leftarrow(\mathrm{Rm}) \Lambda((\mathrm{WRj}))$
ANL Rm,@DRk

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | 4 | 3 |

[Encoding]

| 0101 | 1110 |
| :---: | :---: | :---: | :---: | :---: |$\quad$| uuuu | 1011 |
| :---: | :---: |

Hex Code in: Binary Mode = [A5][Encoding] Source Mode $=$ [Encoding]

Operation: ANL
$(\mathrm{Rm}) \leftarrow(\mathrm{Rm}) \Lambda((\mathrm{DRk}))$
ANL CY,<src-bit>
Function: Logical-AND for bit variables
Description: If the Boolean value of the source bit is a logical 0 , clear the CY flag; otherwise leave the CY flag in its current state. A slash ("/") preceding the operand in the assembly language indicates that the logical complement of the addressed bit is used as the source value, but the source bit itself is not affected.

Only direct addressing is allowed for the source operand.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| $\checkmark$ | - | - | - | - |

Example: $\quad$ Set the CY flag if, and only if, $P 1.0=1, A C C .7=1$, and $O V=0$ :
MOV CY.P1.0 :Load carry with input pin state
ANL CY,ACC. 7 ;AND carry with accumulator bit 7
ANL CY,/OV ;AND with inverse of overflow flag

ANL CY,bit51

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | $1 \dagger$ | $1 \dagger$ |

$\dagger$ If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state.

[Encoding] | 1000 | 0010 |
| :---: | :---: |
|  | bit addr |

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode $=$ [Encoding]
Operation: ANL
$(C Y) \leftarrow(C Y) \Lambda($ bit51 $)$

## ANL CY,/bit51

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | $1 \dagger$ | $1 \dagger$ |

$\dagger$ If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state.

[Encoding] \begin{tabular}{|l|l|}
\hline 1011 \& 0000 <br>
\hline

$\quad$

bit addr <br>
\hline
\end{tabular}

Hex Code in: Binary Mode $=$ [Encoding $]$
Source Mode $=$ [Encoding]
Operation: ANL
$(C Y) \leftarrow(C Y) \Lambda \varnothing($ bit51)
ANL CY,bit

Bytes:
States:

## Binary Mode Source Mode

$3 \dagger$
2†
$\dagger$ If this instruction addresses a port ( $\mathrm{P} \boldsymbol{x}, \boldsymbol{x}=0-3$ ), add 1 state.
[Encoding]

| 1010 | 1001 |
| :--- | :--- |$\quad$| 1000 | 0 | y y y |
| :---: | :---: | :---: |$\quad$| dir addr |
| :---: |

Hex Code in: Binary Mode = [A5][Encoding] Source Mode $=$ [Encoding]

Operation: ANL

$$
(\mathrm{CY}) \leftarrow(\mathrm{CY}) \Lambda \text { (bit) }
$$

ANL CY,/bit

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | $3 \dagger$ | $2 \dagger$ |
|  | $\dagger$ lf this instruction addresses a port $(P x, x=0-3)$, add 1 state. |  |

[Encoding]

| 1010 | 1001 |
| :--- | :--- |$\quad$| 1111 | 0 | y y |
| :---: | :---: | :---: |$\quad$| dir addr |
| :---: |

## Hex Code in: Binary Mode $=[$ A5][Encoding $]$ Source Mode $=$ [Encoding] <br> Operation: ANL <br> $(C Y) \leftarrow(C Y) \wedge \varnothing$ (bit)

CJNE <dest>,<src>,rel
Function: Compare and jump if not equal.
Description: Compares the magnitudes of the first two operands and branches if their values are not equal. The branch destination is computed by adding the signed relative displacement in the last instruction byte to the PC, after incrementing the PC to the start of the next instruction. If the unsigned integer value of <dest-byte> is less than the unsigned integer value of <srcbyte>, the CY flag is set. 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.

## Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| $\checkmark$ | - | - | $\checkmark$ | $\checkmark$ |

Example: The accumulator contains 34 H and R7 contains 56 H . After executing the first instruction in the sequence

|  | CJNE | R7,\#60H,NOT_EQ |  |
| :--- | :--- | :--- | :--- |
| $;$ | $\ldots$ | $\ldots$ | $; R 7=60 \mathrm{H}$ |
| NOT_EQ: | JC | REQ_LOW | ;IF R7 < 60H |
| ; | $\ldots$ | $\ldots$ | $; R 7>60 \mathrm{H}$ |

the CY flag is set and program execution continues at labe! noT_EQ. By testing the CY flag, this instruction determines whether R7 is greater or less than 60 H .

If the data being presented to Port 1 is also 34 H , then executing the instruction,
WAIT: CJNE A,P1,WAIT
clears the CY flag and continues with the next instruction in the sequence, since the accumulator does equal the data read from P1. (If some other value was being input on P1, the program loops at this point until the P1 data changes to 34 H .)

## Variations

## CJNE A,\#data,rel

|  | Binary Mode |  | Source Mode |  |
| :--- | :---: | :---: | :---: | :---: |
|  | Not Taken | Taken | Not Taken | Taken |
| Bytes: | 3 | 3 | 3 | 3 |
| States: | 2 | 5 | 2 | 5 |

[Encoding] | 1011 | 0100 |
| :--- | :--- |
|  |  |

| immed. data | rel. addr |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode $=$ [Encoding]
Operation: $\quad(\mathrm{PC}) \leftarrow(\mathrm{PC})+3$
IF (A) $=$ \#data
THEN
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+$ relative offset
IF (A) < \#data
THEN

$$
(C Y) \leftarrow 1
$$

ELSE
$(C Y) \leftarrow 0$
CJNE A,dir8,rel

|  | Binary Mode |  | Source Mode |  |
| :--- | :---: | :---: | :---: | :---: |
|  | Not Taken | Taken | Not Taken | Taken |
| Bytes: | 3 | 3 | 3 | 3 |
| States: | 3 | 6 | 3 | 6 |

[Encoding]

| 1011 | 0101 |
| :--- | :--- |


| direct addr | rel. addr |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode $=$ [Encoding]

```
Operation: \(\quad(\mathrm{PC}) \leftarrow(\mathrm{PC})+3\)
    IF (A) \(=\) dir8
    THEN
        \((P C) \leftarrow(P C)+\) relative offset
    IF (A) < dir8
    THEN
        \((C Y) \leftarrow 1\)
    ELSE
    \((C Y) \leftarrow 0\)
```


## CJNE @Ri,\#data,rel



## CLR A

## Function: Clear accumulator

Description: Clears the accumulator (i.e., resets all bits to zero).
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | $\checkmark$ | $\checkmark$ |

Example: The accumulator contains 5CH (01011100B). The instruction
CLR A
clears the accumulator to $00 \mathrm{H}(00000000 \mathrm{~B})$.
Binary Mode Source Mode
Bytes:
States:
[Encoding]

| 1110 | 0100 |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding $]$
Source Mode $=$ [Encoding]
Operation: CLR
$(\mathrm{A}) \leftarrow 0$
CLR bit
Function: Clear bit
Description: Clears the specified bit. CLR can operate on the CY flag or any directly addressable bit.
Flags: Only for instructions with CY as the operand.

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| $\checkmark$ | - | - | - | - |

Example: Port 1 contains 5DH (01011101B). After executing the instruction
CLR P1.2
port 1 contains 59H (01011001B).

Variations
CLR bit51

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | $2 \dagger$ | $2 \dagger$ |

$\dagger$ If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 2 states.
[Encoding]

| 1100 | 0010 |
| :--- | :--- |

Bit addr
Hex Code in: Binary Mode $=[$ Encoding $]$
Source Mode $=$ [Encoding]
Operation: CLR
(bit51) $\leftarrow 0$
CLR CY

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 1 | 1 |
| States: | 1 | 1 |

[Encoding]

| 1100 | 0011 |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding $]$
Source Mode $=$ [Encoding]
Operation: CLR
$(C Y) \leftarrow 0$
CLR bit

Bytes:

## Binary Mode Source Mode

States:

4
$4 \dagger$
4
$3 \dagger$
$\dagger$ If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 2 states.
[Encoding]

| 1010 | 1001 |
| :--- | :--- | :--- | :--- | :--- | | 1100 | 0 | y y |
| :---: | :---: | :---: |

Hex Code in: Binary Mode $=[$ A5][Encoding $]$
Source Mode $=$ [Encoding]
Operation
CLR
(bit) $\leftarrow 0$

## CMP <dest>,<src>

Function: Compare
Description: Subtracts the source operand from the destination operand. The result is not stored in the destination operand. If a borrow is needed for bit 7 , the CY (borrow) flag is set; otherwise it is clear.

When subtracting signed integers, the OV flag indicates a negative result when a negative value is subtracted from a positive value, or a positive result when a positive value is subtracted from a negative value.

The source operand allows four addressing modes: register, direct, immediate and indirect.

## Flags:

| CY | AC | OV | $N$ | Z |
| :---: | :---: | :---: | :---: | :---: |
| $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |

Example: $\quad$ Register 1 contains $0 \mathrm{C9H}$ (11001001B) and register 0 contains 54 H (01010100B). The instruction

CMP R1,R0
clears the CY and AC flags and sets the OV flag.

## Variations

## CMP Rmd,Rms

|  | Binary Mode So |  | Source Mode |  |
| :---: | :---: | :---: | :---: | :---: |
| Bytes: | 3 |  |  |  |
| States: | 2 |  |  |  |
| [Encoding] | 1011 | 1100 | ssss | S S S S |
| Hex Code in: | Binary Mo Source Mo | 5][Enco ncoding] |  |  |
| Operation: | CMP $(R m d)-(R$ |  |  |  |

CMP WRjd,WRjs

|  | Binary Mode | Source |
| :--- | :---: | ---: |
| Bytes: | 3 | 2 |
| States: | 3 | 2 |

[Encoding]

| 1011 | 1110 |
| :--- | :--- |


| tttt | TTTT |
| :---: | :---: |

Hex Code in: Binary Mode $=[$ A5][Encoding]
Source Mode $=$ [Encoding]
Operation: CMP
(WRjd) - (WRjs)

## CMP DRkd,DRks

## Bytes:

Binary Mode Source Mode
States:
3
2
[Encoding]

| 1011 | 1111 |
| :--- | :--- |


| uuuu | UUUU |
| :---: | :---: |


| Hex Code in: | Binary Mode $=[$ A5 $][$ Encoding $]$ <br> Source Mode $=[$ Encoding $]$ |
| :--- | :--- |

Operation: CMP
(DRkd) - (DRks)

## CMP Rm,\#data

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | 3 | 2 |

[Encoding] | 1011 | 1110 |
| :--- | :--- |

| ssss | 0000 |
| :---: | :---: |


| Hex Code in: | Binary Mode $=[$ A5 $]$ Encoding $]$ |
| :--- | :--- |
|  | Source Mode $=[$ Encoding $]$ |

Operation: CMP
(Rm) - \#data

## CMP WRj,\#data16

Bytes: 5

States:
4
3
[Encoding]

| 1011 | 1110 | tttt | 0100 | \#data hi | \#data low |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | $\begin{aligned} & \text { CMP } \\ & \text { (WRi) - \#data16 } \end{aligned}$ |  |  |  |  |

CMP DRk,\#Odata16

## Binary Mode Source Mode

Bytes:
5
4
States:
6
5
[Encoding]

| 1011 | 1110 |
| :--- | :--- | :--- | :--- |$\quad$| uuuu | 1000 |
| :---: | :---: |
| \#data hi |  |


| Hex Code in: | Binary Mode $=[$ A5 $][$ Encoding $]$ <br> Source Mode $=[$ Encoding $]$ |
| :--- | :--- |
| Operation: | CMP <br>  <br>  <br> (DRk) $-\#$ Odata16 |

CMP DRk,\#1data16

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 5 | 4 |
| States: | 6 | 5 |

[Encoding]

| 1011 | 1110 |
| :--- | :--- | :--- | :--- |$\quad$| uuuu | 1100 |
| :---: | :---: |
| \#datahi |  |

Hex Code in: Binary Mode = [A5][Encoding]
Source Mode $=$ [Encoding]
Operation: CMP
(DRk) - \#1data16
CMP Rm,dir8

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | $3 \dagger$ | $2 \dagger$ |

†If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state.
[Encoding]

| 1011 | 1110 |
| :--- | :--- |


| sss s | 0001 |
| :---: | :--- |

Hex Code in: Binary Mode $=[$ A5][Encoding $]$ Source Mode $=$ [Encoding]

Operation: CMP
(Rm) - (dir8)
CMP WRj,dir8

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | 4 | 3 |

[Encoding]

| 1011 | 1110 |
| :--- | :--- |


| tttt | 0101 |
| :--- | :--- | dir addr

Hex Code in: Binary Mode $=[$ [A5][Encoding $]$ Source Mode = [Encoding]

Operation:

$$
\begin{aligned}
& \text { CMP } \\
& \text { (WRj) - (dir8) }
\end{aligned}
$$

CMP Rm,dir16

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 5 | 4 |
| States: | 3 | 2 |
| [Encoding] |  |  |


| 1011 | 1110 |
| :--- | :--- | :--- |$\quad$| sss s | 0011 |
| :---: | :---: |

$\begin{array}{ll}\text { Hex Code in: } & \text { Binary Mode }=[\text { [55][Encoding }] \\ & \text { Source Mode }=[\text { Encoding }]\end{array}$
Operation: CMP
(Rm) - (dir16)
CMP WRj,dir16

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 5 | 4 |
| States: | 4 | 3 |

[Encoding]

| 1011 | 1110 |
| :--- | :--- | :--- |$\quad$| ttt | 0111 |
| :--- | :--- | :--- |

Hex Code in: Binary Mode = [A5][Encoding] Source Mode $=$ [Encoding]

Operation: CMP
(WRj) - (dir16)

CMP Rm,@WRj
Binary Mode
Bytes:

States: $\quad$| Source Mode |
| :---: |
| [Encoding] |

Hex Code in: Binary Mode $=$ [A5][Encoding]
Source M!ede = [Eneoding]

Operation: CMP

$$
(\mathrm{Rm})-((\mathrm{WR} \mathrm{j}))
$$

## CMP Rm,@DRk

Bytes:
States:

| Binary Mode | Source Mode |
| :---: | :---: |
| 4 | 3 |
| 4 | 3 |

[Encoding]

| 1011 | 1110 | uuuu | 1011 | ssss | 0000 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | $\begin{aligned} & \text { CMP } \\ & (\mathrm{Rm})-((\mathrm{DRk})) \end{aligned}$ |  |  |  |  |

CPL A

## Function: Complement accumulator

Description: Logically complements (Ø) each bit of the accumulator (one's complement). Clear bits are set and set bits are cleared.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | $\checkmark$ | $\checkmark$ |

Example: The accumulator contains 5 CH (01011100B). After executing the instruction
CPL A
the accumulator contains 0A3H (10100011B).

|  | Binary Mode | Source |
| :--- | :---: | ---: |
| Bytes: | 1 | 1 |
| States: | 1 | 1 |

[Encoding]

| 1111 | 0100 |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding $]$ Source Mode $=$ [Encoding]

Operation: CPL
$(A) \leftarrow \varnothing(A)$
CPL bit
Function: Complement bit
Description: Complements (Ø) the specified bit variable. A clear bit is set, and a set bit is cleared. CPL can operate on the CY or any directly addressable bit.

Note: When this instruction is used to modify an output pin, the value used as the original data is read from the output data latch, not the input pin.

Flags: $\quad$ Only for instructions with CY as the operand.

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| $\checkmark$ | - | - | - | - |



| 1010 | 1001 | 1011 | 0 | y y | dir addr |
| :---: | :---: | :---: | :---: | :---: | :---: |

$\begin{array}{ll}\text { Hex Code in: } & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }]\end{array}$

Operation: CPL
(bit) $\leftarrow \varnothing$ (bit)
DA A
Function: Decimal-adjust accumulator for addition
Description: Adjusts the 8 -bit value in the accumulator that resulted from the earlier addition of two variables (each in packed-BCD format), producing two 4 -bit digits. Any ADD or ADDC instruction may have been used to perform the addition.

If accumulator bits 3:0 are greater than nine (XXXX1010-XXXX1111), or if the AC flag is set, six is added to the accumulator, producing the proper BCD digit in the low nibble. This internal addition sets the CY flag if a carry out of the lowest 4 bits propagated through all higher bits, but it does not clear the CY flag otherwise.

If the CY flag is now set, or if the upper four bits now exceed nine (1010XXXX-1111XXXX), these four bits are incremented by six, producing the proper BCD digit in the high nibble. Again, this sets the CY flag if there was a carry out of the upper four bits, but does not clear the carry. The CY flag thus indicates if the sum of the original two BCD variables is greater than 100, allowing multiple-precision decimal addition. The OV flag is not affected.

All of this occurs during one instruction cycle. Essentially, this instruction performs the decimal conversion by adding $00 \mathrm{H}, 06 \mathrm{H}, 60 \mathrm{H}$, or 66 H to the accumulator, depending on initial accumulator and PSW conditions.

Note: DA A cannot simply convert a hexadecimal number in the accumulator to BCD notation, nor does DA A apply to decimal subtraction.

## Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| $\checkmark$ | - | - | $\checkmark$ | $\checkmark$ |

Example: The accumulator contains 56 H ( 01010110 B ), which represents the packed BCD digits of the decimal number 56 . Register 3 contains 67 H ( 01100111 B ), which represents the packed BCD digits of the decimal number 67. The CY flag is set. After executing the instruction sequence

ADDC A,R3
DA A
the accumulator contains OBEH (10111110) and the CY and AC flags are clear. The Decimal Adjust instruction then alters the accumulator to the value 24 H (00100100B), indicating the packed BCD digits of the decimal number 24, the lower two digits of the decimal sum of 56,67 , and the carry-in. The CY flag is set by the Decimal Adjust instruction, indicating that a decimal overflow occurred. The true sum of 56,67 , and 1 is 124 .

BCD variables can be incremented or decremented by adding 01 H or 99 H . If the accumulator contains 30 H (representing the digits of 30 decimal), then the instruction sequence,

ADD A,\#99H
DA A
leaves the CY flag set and 29 H in the accumulator, since $30+99=129$. The low byte of the sum can be interpreted to mean $30-1=29$.


## DEC byte

## Function: Decrement

Description: Decrements the specified byte variable by 1. An original value of 00 H underflows to 0 FFH . Four operands addressing modes are allowed: accumulator, register, direct, or registerindirect.

Note: When this instruction is used to modify an output port, the value used as the original port data is read from the output data latch, not the input pins.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | $\checkmark$ |  |

Example: $\quad$ Register 0 contains 7FH ( 01111111 B). On-chip RAM locations 7EH and 7FH contain 00H and 40 H , respectively. After executing the instruction sequence

DEC @RO
DEC RO
DEC @RO
register 0 contains 7 EH and on-chip RAM locations 7EH and 7 FH are set to OFFH and 3 FH , respectively.

## Variations

DEC A

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 1 | 1 |
| States: | 1 | 1 |

[Encoding]

| 0001 | 0100 |
| :--- | :--- |


| Hex Code in: | $\left.\begin{array}{l}\text { Binary Mode }=[\text { Encoding }] \\ \\ \text { Source Mode }=[\text { Encoding }]\end{array}\right]$ |
| :--- | :--- |

Operation: DEC
$(A) \leftarrow(A)-1$
DEC dir8

Binary Mode Source Mode
Bytes:
States:
$2 \dagger$
$2 \dagger$
$\dagger$ If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 2 states.
[Encoding]

| 0001 | 0101 |
| :--- | :--- | dir addr

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode $=$ [Encoding]
Operation: DEC
(dir8) $\leftarrow($ dir8) -1
DEC @Ri

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 1 | 2 |
| States: | 3 | 4 |

[Encoding]

| 0001 | $011 i$ |
| :--- | :--- |

Hex Code in: $\quad$ Binary Mode $=[$ Encoding $]$ Source Mode = [A5][Encoding]

Operation: DEC
$((\mathrm{Ri})) \leftarrow((\mathrm{Ri}))-1$
DEC Rn

| Bytes: | 1 | 2 |
| :--- | :--- | :--- |
| States: | 1 | 2 |

[Encoding]

| 0001 | 1 rrr |
| :--- | :--- |

Hex Code in: Binary Mode = [Encoding]
Source Mode $=[$ A5] [Encoding $]$
Operation: DEC
$(R n) \leftarrow(R n)-1$

DEC <dest>,<src>
Function: Decrement
Description: Decrements the specified variable at the destination operand by 1,2 , or 4 . An original value of 00 H underflows to 0 FFH .
Flags:

| CY | AC | OV | N | $Z$ |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | $\checkmark$ | $\checkmark$ |

Example: Register 0 contains 7FH (01111111B). After executing the instruction sequence DEC Ro,\#1 register 0 contains 7EH.

## Variations

DEC Rm,\#short

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 2 | 1 |

[Encoding]

| 0001 | 1011 |
| :--- | :--- |


| sss | 01 | vv |
| :---: | :---: | :---: |

Hex Code in: Binary Mode $=$ [A5][Encoding]
Source Mode $=$ [Encoding]
Operation: DEC
$(R m) \leftarrow(R m)$ - \#short
DEC WRj,\#short

Bytes:
Binary Mode Source Mode
States:
3
2
2
1
[Encoding]

| 0001 | 1011 |
| :--- | :--- |


| tttt | 01 | $v v$ |
| :---: | :---: | :---: |

Hex Code in: Binary Mode $=[$ [A5][Encoding $]$
Source Mode = [Encoding]

Operation: DEC
$(W R j) \leftarrow(W R j)-$ \#short

## DEC DRk,\#short

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 5 | 4 |

[Encoding]

| 0001 | 1011 |
| :--- | :--- |


| uuuu | 11 | vv |
| :---: | :---: | :---: |

Hex Code in: Binary Mode $=[$ A5] [Encoding $]$ Source Mode $=[$ Encoding $]$

Operation: DEC
(DRk) $\leftarrow$ (DRk) - \#short
DIV <dest>,<src>
Function: Divide
Description: Divides the unsigned integer in the register by the unsigned integer operand in register addressing mode and clears the CY and OV flags.

For byte operands (<dest>,<src> = Rmd,Rms) the result is 16 bits. The 8 -bit quotient is in $\mathrm{R}(\mathrm{md}+1)$, and the 8 -bit remainder is in Rmd. For example: Register 1 contains 251 (0FBH or 11111011B) and register 5 contains 18 ( 12 H or 00010010B). After executing the instruction

DIV R1,R5
register 0 contains 13 (0DH or 00001101B); register 1 contains 17 (11H or 00010001B), since $251=(13 X 18)+17$; and the CY and OV bits are clear (see Flags).

Flags: $\quad$ The CY flag is cleared. The $\mathbf{N}$ flag is set if the MSB of the quotient is set. The $\mathbf{Z}$ flag is set if the quotient is zero.:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| 0 | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |

Exception: if <src> contains 00 H , the values returned in both operands are undefined; the CY flag is cleared, OV flag is set, and the rest of the flags are undefined.:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| 0 | $?$ | 1 | $?$ | $?$ |

Variations
DIV Rmd Rms


Hex Code in: Binary Mode = [A5][Encoding] Source Mode $=$ [Encoding]

Operation:
DIV (16-bit operands)
(WRjd) $\leftarrow$ quotient (WRjd) / (WRjs) if <dest> jd =0, 4, 8, ... 28
(WRjd +2 ) $\leftarrow$ remainder (WRjd) / (WRjs)
(WRjd-2) $\leftarrow$ quotient (WRjd) / (WRjs) if <dest> jd $=2,6,10, \ldots 30$
(WRjd) $\leftarrow$ remainder (WRjd) / (WRis)
For word operands (<dest>,<src> = WRjd,WRjs) The 16-bit quotient is in WR(jd+2), and the 16-bit remainder is in WRjd. For example, for a destination register WR4, assume the quotient is 1122 H and the remainder is 3344 H . Then, the results are stored in these register file locations:

| Locaiion | 4 | 5 | 6 | 7 |
| :---: | :---: | :---: | :---: | :---: |
| Contents | 33 H | 44 H | 11 H | 22 H |

INSTRUCTION SET REFERENCE

DIV AB

## Function: Divide

Description: Divides the unsigned 8-bit integer in the accumulator by the unsigned 8-bit integer in register $B$. The accumulator receives the integer part of the quotient; register $B$ receives the integer remainder. The CY and OV flags are cleared.

Exception: if register B contains 00 H , the values returned in the accumulator and register B are undefined; the CY flag is cleared and the OV flag is set.

## Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| 0 | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |

For division by zero:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| 0 | $?$ | 1 | $?$ | $?$ |

Hex Code in: Binary Mode $=$ [Encoding] Source Mode $=$ [Encoding]

Example: The accumulator contains 251 (OFBH or 11111011B) and register B contains 18 (12H or 00010010B). After executing the instruction

DIV AB
the accumulator contains 13 ( 0 DH or 00001101B); register B contains 17 ( 11 H or $00010001 \mathrm{~B})$, since $251=(13 \times 18)+17$; and the CY and OV flags are clear.

Bytes:
Binary Mode Source Mode

States:
1
1
10
10
[Encoding]

| 1000 | 0100 |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding $]$ Source Mode $=$ [Encoding]

Operation: DIV
$(A) \leftarrow$ quotient $(A) /(B)$
$(B) \leftarrow \operatorname{remainder}(A) / B)$

DJNZ <byte>,<rel-addr>
Function: Decrement and jump if not zero
Description: Decrements the specified location by 1 and branches to the address specified by the second operand if the resulting value is not zero. An original value of 00 H underflows to OFFH. The branch destination is 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 is read from the output data latch, not the input pins.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | $\checkmark$ | $\checkmark$ |

Example: The on-chip RAM locations $40 \mathrm{H}, 50 \mathrm{H}$, and 60 H contain $01 \mathrm{H}, 70 \mathrm{H}$, and 15 H , respectively. After executing the instruction sequence

DJNZ 40H,LABEL1
DJNZ 50H,LABEL2
DJNZ 60H,LABEL
on-chip RAM locations $40 \mathrm{H}, 50 \mathrm{H}$, and 60 H contain $00 \mathrm{H}, 6 \mathrm{FH}$, and 14 H , respectively, and program execution continues at label LABEL2. (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
toggles P1.7 eight times, causing four output pulses to appear at bit 7 of output Port 1. Each pulse lasts three states: two for DJNZ and one to alter the pin.

## Variations

DJNZ dir8,rel

|  | Binary Mode |  | Source Mode |  |
| :--- | :---: | :---: | :---: | :---: |
|  | Not Taken | Taken | Not Taken | Taken |
| Bytes: | 3 | 3 | 3 | 3 |
| States: | 3 | 6 | 3 | 6 |

[Encoding]

| 1101 | 0101 |
| :--- | :--- |


| direct addr | rel. addr |
| :--- | :--- |

INSTRUCTION SET REFERENCE

| Hex Code in: | Binary Mode $=[$ Encoding $]$ <br> Source Mode $=[$ Encoding $]$ |
| :--- | :--- |
| Operation: |  |
|  | DJNZ |
|  | $(\mathrm{PC}) \leftarrow(\mathrm{PC})+2$ |
|  | $($ dir8 $) \leftarrow($ dir8 -1 |
|  | IF $($ dir8 $>0$ or $($ dir8 $)<0$ |
|  |  |
|  | THEN |
|  | $(\mathrm{PC}) \leftarrow(\mathrm{PC})+$ rel |

DJNZ Rn,rel

|  | Binary Mode |  | Source Mode |  |
| :--- | :---: | :---: | :---: | :---: |
|  | Not Taken | Taken | Not Taken | Taken |
| Bytes: | 3 | 3 | 3 | 3 |
| States: | 2 | 5 | 3 | 6 |
| [Encoding] | 1101 | 1 rrr |  |  |
|  |  |  |  |  |

## Hex Code in: Binary Mode = [Encoding]

Source Mode $=[$ A5][Encoding]
Operation: DJNZ
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+2$
$(R n) \leftarrow(R n)-1$
IF (Rn) $>0$ or (Rn) $<0$
THEN

$$
(\mathrm{PC}) \leftarrow(\mathrm{PC})+\mathrm{rel}
$$

ECALL <dest>

## Function: Extended call

Description: Calls a subroutine located at the specified address. The instruction adds four to the program counter to generate the address of the next instruction and then pushes the 24-bit result onto the stack (high byte first), incrementing the stack pointer by three. The 8 bits of the high word and the 16 bits of the low word of the PC are then loaded, respectively, with the second, third and fourth bytes of the ECALL instruction. Program execution continues with the instruction at this address. The subroutine may therefore begin anywhere in the full 16Mbyte memory space.

## Flags:

| CY | AC | OV | $\mathbf{N}$ | $\mathbf{Z}$ |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: The stack pointer contains 07 H and the label "SUBRTN" is assigned to program memory location 123456 H . After executing the instruction

ECALL SUBRTN
at location $012345 \mathrm{H}, \mathrm{SP}$ contains 09 H ; on-chip RAM locations $08 \mathrm{H}, 09 \mathrm{H}$ and 0 AH contain $01 \mathrm{H}, 23 \mathrm{H}$ and 45 H , respectively; and the PC contains 123456 H .

## Variations

ECALL addr24

|  | Binary Mode |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Bytes: | 5 |  | 4 |  |  |
| States: | 14 |  | 13 |  |  |
| [Encoding] | 1001 | 1010 | addr23addr16 | addr15-addr8 | addr7-addr0 |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | ECALL <br> $(\mathrm{PC}) \leftarrow(\mathrm{PC})$ <br> $(S P) \leftarrow(S P$ <br> $((S P)) \leftarrow(P$ <br> $(S P) \leftarrow(S P$ <br> $((\mathrm{SP})) \leftarrow(\mathrm{P}$ <br> $(\mathrm{SP}) \leftarrow(\mathrm{SP}$ <br> $((\mathrm{SP})) \leftarrow(\mathrm{P}$ <br> $(\mathrm{PC}) \leftarrow(\mathrm{ad}$ |  |  |  |  |

ECALL @DRk

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 12 | 11 |

[Encoding]

| 1001 | 1001 |
| :--- | :--- |

Hex Code in: Binary Mode $=[$ [A5][Encoding $]$
Source Mode $=$ [Encoding]
Operation: ECALL
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+4$
$(S P) \leftarrow(S P)+1$
$((S P)) \leftarrow(P C .23: 16)$
$(\mathrm{SP}) \leftarrow(\mathrm{SP})+1$
$((\mathrm{SP})) \leftarrow(\mathrm{PC.15:8)}$
$(\mathrm{SP}) \leftarrow(\mathrm{SP})+1$
$((S P)) \leftarrow(P C .7: 0)$
$(\mathrm{PC}) \leftarrow((\mathrm{DRk}))$
EJMP <dest>
Function: Extended jump
Description: Causes an unconditional branch to the specified address by loading the 8 bits of the high order and 16 bits of the low order words of the PC with the second, third, and fourth instruction bytes. The destination may be therefore be anywhere in the full 16-Mbyte memory space.

Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: $\quad$ The label "JMPADR" is assigned to the instruction at program memory location 123456 H .
The instruction is
EJMP JMPADR
Variations
EJMP addr24

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 5 | 4 |
| States: | 6 | 5 |

[Encoding]

| 1000 | 1010 |
| :--- | :--- |


| addr23- <br> addr16 |
| :---: |

addr15-addr8
addr7-addr0

Hex Code in: Binary Mode $=$ [A5][Encoding]
Source Mode = [Encoding]
Operation: EJMP
$(\mathrm{PC}) \leftarrow$ (addr.23:0)
EJMP @DRk

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 7 | 6 |

[Encoding]

| 1000 | 1001 |
| :--- | :--- |

uuuu
Hex Code in: Binary Mode $=$ [Encoding]
Source Mode $=$ [Encoding]
Operation:
EJMP
$(\mathrm{PC}) \leftarrow((\mathrm{DRk}))$

## ERET

Function: Extended return
Description: Pops byte 2, byte 1, and byte 0 of the 3-byte PC successively from the stack and decrements the stack pointer by 3 . Program execution continues at the resulting address, which normally is the instruction immediately following ECALL.

Flags: $\quad$ No flags are affected.
Example: The stack pointer contains 0BH. On-chip RAM locations 08H, 09H and 0AH contain 01H, 23 H and 49 H , respectively. After executing the instruction

ERET
the stack pointer contains 07 H and program execution continues at location 012349 H .

Binary Mode Source Mode

| Bytes: | 3 | 2 |
| :--- | :--- | :--- |
| States: | 10 | 9 |

[Encoding]

| 1010 | 1010 |
| :--- | :--- |

Hex Code in: Binary Mode $=[$ [A5][Encoding $]$
Source Mode $=$ [Encoding]
Operation: ERET
(PC.7:0) $\leftarrow((S P))$
$(\mathrm{SP}) \leftarrow(\mathrm{SP})-1$
$(\mathrm{PC} .15: 8) \leftarrow((\mathrm{SP}))$
$(\mathrm{SP}) \leftarrow(\mathrm{SP})-1$
(PC.23:16) $\leftarrow((\mathrm{SP}))$
$(S P) \leftarrow(S P)-1$

## INC <Byte>

Function: Increment
Description: Increments the specified byte variable by 1. An original value of FFH overflows to 00 H . Three addressing modes are allowed for 8 -bit operands: register, direct, or register-indirect.

Note: When this instruction is used to modify an output port, the value used as the original port data is read from the output data latch, not the input pins.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | $\checkmark$ | $\checkmark$ |




INC <dest>,<src>
Function: Increment
Description: Increments the specified variable by 1,2, or 4 . An original value of 0 FFH overflows to 00 H .
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | $\checkmark$ | $\checkmark$ |

Example: Register 0 contains 7EH (011111110B). After executing the instruction
INC R0,\#1
register 0 contains 7 FH .
Variations
INC Rm,\#short

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 2 | 1 |

[Encoding]

| 0000 | 1011 |
| :--- | :--- |


| ssss | 00 | $\mathrm{v} v$ |
| :---: | :---: | :---: |

Hex Code in: Binary Mode $=[$ [A5][Encoding]
Source Mode $=$ [Encoding]
Operation: INC
$(R m) \leftarrow(R m)+$ \#short
INC WRj,\#short

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 2 | 1 |

[Encoding] | 0000 | 1011 |  |  |
| :---: | :---: | :---: | :---: |
|  | tttt | 01 | vv |

Hex Code in: $\quad$ Binary Mode $=[$ A5][Encoding $]$
Source Mode $=$ [Encoding]
Operation:
INC
$(\mathrm{WR} \mathrm{j}) \leftarrow(\mathrm{WRj})+$ \#short
INC DRk,\#short

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 4 | 3 |

[Encoding]

| 0000 | 1011 |
| :--- | :--- |


| uuuu | 11 | vv |
| :---: | :---: | :---: |

Hex Code in: Binary Mode $=$ [A5][Encoding] Source Mode $=$ [Encoding]

## Operation: INC

(DRk) $\leftarrow$ (DRk) + \#shortdata pointer

## INC DPTR

Function: Increment data pointer
Description: Increments the 16 -bit data pointer by one. A 16 -bit increment (modulo $2^{16}$ ) is performed; an overflow of the low byte of the data pointer (DPL) from OFFH to OOH increments the high byte of the data pointer (DPH) by one. An overflow of the high byte (DPH) does not increment the high word of the extended data pointer (DPX = DR56).
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | $\checkmark$ | $\checkmark$ |

Example: Registers DPH and DPL contain 12H and OFEH, respectively. After the instruction sequence

INC DPTR
INC DPTR
INC DPTR
DPH and DPL contain 13 H and 01 H , respectively.
Binary Mode Source Mode

Bytes:
States:

| 1 | 1 |
| :--- | :--- |
| 1 | 1 |

[Encoding]

| 1010 | 0011 |
| :--- | :--- |

Hex Code in: Binary Mode = [Encoding]
Source Mode $=$ [Encoding]
Operation: INC
$($ DPTR $) \leftarrow($ DPTR $)+1$
JB bit51,rel
JB bit,rel
Function: Jump if bit set
Description: If the specified bit is a one, jump to the address specified; otherwise proceed with the next instruction. 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. The bit tested is not modified.
Flags:

| CY | AC | OV | N | $\mathbf{Z}$ |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |


| Example: $\quad$Input port 1 contains 11001010B and the accumulator contains 56 (01010110B). After the <br> instruction sequence |  |
| :--- | :--- |
|  | JB P1.2,LABEL1 <br> JB ACC.2,LABEL2 |
|  | program execution continues at label LABEL2. |
| Variations $\quad$ JB bit51,rel |  |


|  | Binary Mode |  | Source Mode |  |
| :--- | :---: | :---: | :---: | :---: |
|  | Not Taken | Taken | Not Taken | Taken |
| Bytes: | 3 | 3 | 3 | 3 |
| States: | 2 | 5 | 2 | 5 |

[Encoding] | 0010 | 0000 |
| :---: | :---: |

bit addr rel. addr

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode $=$ [Encoding]
Operation: JB
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+3$
IF (bit51) =1
THEN
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+\mathrm{rel}$
JB bit,rel

Bytes:
States:
[Encoding]

| 1010 | 1001 |
| :--- | :--- | :--- | :--- | :--- | | 0010 | 0 | yy |
| :--- | :--- | :--- | | direct addr |
| :--- | :--- |
| rel. addr |

Hex Code in: Binary Mode $=[$ [A5][Encoding $]$ Source Mode $=$ [Encoding]

Operation: JB
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+3$
IF (bit) $=1$
THEN
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+\mathrm{rel}$

Function: Jump if bit is set and clear bit
Description: If the specified bit is one, branch to the specified address; otherwise proceed with the next instruction. The bit is not cleared if it is already a zero. 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.

Note: When this instruction is used to test an output pin, the value used as the original data is read from the output data latch, not the input pin.

Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| $!$ | - | - | - | - |

Example: The accumulator contains 56 H ( 01010110 B ). After the instruction sequence
JBC ACC.3,LABEL1
JBC ACC.2,LABEL2
the accumulator contains 52 H ( 01010010 B ) and program execution continues at label LABEL2.
Variations
JBC bit51,rel

Binary Mode

|  | Not Taken | Taken |
| :--- | :---: | :---: |
| Bytes: | 3 | 3 |
| States: | 4 | 7 |

Source Mode

| Not Taken | Taken |
| :---: | :---: |
| 3 | 3 |
| 4 | 7 |

[Encoding]

| 0001 | 0000 |
| :--- | :--- |

$\square$
Hex Code in: Binary Mode $=$ [Encoding $]$
Source Mode = [Encoding]
Operation: JBC
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+3$
IF (bit51) = 1
THEN
(bit51) $\leftarrow 0$
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+\mathrm{rel}$
JBC bit,rel

|  | Binary Mode |  | Source Mode |  |
| :--- | :---: | :---: | :---: | :---: |
|  | Not Taken | Taken | Not Taken | Taken |
| Bytes: | 5 | 5 | 4 | 4 |
| States: | 4 | 7 | 3 | 6 |

[Encoding]

| 1010 | 1001 |
| :--- | :--- | :--- | :--- | :--- | | 0001 | 0 | yyy |
| :--- | :--- | :--- | | direct addr |
| :--- | :--- |
| rel. addr |

Hex Code in: Binary Mode $=[$ [A5][Encoding]
Source Mode $=$ [Encoding $]$
Operation: JBC
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+3$
IF (bit51) $=1$
THEN
(bit51) $\leftarrow 0$
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+$ rel
JC rel
Function: Jump if carry is set
Description: If the CY flag is set, branch to the address specified; otherwise proceed with the next instruction. The branch destination is computed by adding the signed relative displacement in the second instruction byte to the PC, after incrementing the PC twice.
Flags:

| CY | AC | OV | N | $\mathbf{Z}$ |
| :---: | :---: | :---: | :---: | :---: |
| $!$ | - | - | - | - |

Example: The CY flag is clear. After the instruction sequence
JC LABEL1
CPLCY
JC LABEL 2
the CY flag is set and program execution continues at label LABEL2.

Binary Mode

|  | Not Taken | Taken |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | 1 | 4 |

Source Mode

| Not Taken | Taken |
| :---: | :---: |
| 2 | 2 |
| 1 | 4 |

[Encoding] $\square$ rel. addr

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode = [Encoding]
Operation: JC
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+2$
IF (CY) $=1$
THEN
$(P C) \leftarrow(P C)+$ rel

INSTRUCTION SET REFERENCE

JE rel

## Function: Jump if equal

Description: If the $Z$ flag is set, branch to the address specified; otherwise proceed with the next instruction. The branch destination is computed by adding the signed relative displacement in the second instruction byte to the PC, after incrementing the PC twice.

## Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $!$ |

Example: The $\mathbf{Z}$ flag is set. After executing the instruction
JE LABEL1
program execution continues at label LABEL1.

Binary Mode
Not Taken
Bytes:
States:

3
2

Taken
3
5

Source Mode
Not Taken
2
1

Taken
2
4
[Encoding]

| 1010 | 1000 |
| :--- | :--- | rel. addr

Hex Code in: Binary Mode $=[$ A5][Encoding] Source Mode = [Encoding]

Operation: JE
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+2$
IF (Z) = 1

$$
\text { THEN }(\mathrm{PC}) \leftarrow(\mathrm{PC})+\mathrm{rel}
$$

JG rel
Function: Jump if greater than
Description: If the $Z$ flag and the CY flag are both clear, branch to the address specified; otherwise proceed with the next instruction. The branch destination is computed by adding the signed relative displacement in the second instruction byte to the PC, after incrementing the PC twice.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | $!$ | - |

Example: The instruction
JG LABEL1
causes program execution to continue at label LABEL1 if the $Z$ flag and the $C Y$ flag are both clear.

|  | Binary Mode |  | Source Mode |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Not Taken | Taken | Not Taken |  | Taken |  |
| Bytes: | 3 | 3 | 2 |  | 2 |  |
| States: | 2 | 5 | 1 |  | 4 |  |
| [Encoding] | 0011 | 1000 | rel. addr |  |  |  |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |  |
| Operation: | $\begin{aligned} & \mathrm{JG} \\ & \begin{array}{l} (\mathrm{PC}) \end{array} \leftarrow(\mathrm{PC})+2 \\ & \mathrm{IF}(\mathrm{Z})=0 \text { AND }(\mathrm{CY})=0 \\ & \quad \text { THEN }(P C) \leftarrow(\mathrm{PC})+\text { rel } \end{aligned}$ |  |  |  |  |  |
| JLE rel |  |  |  |  |  |  |
| Function: | Jump if less than or equal |  |  |  |  |  |
| Description: | If the $\mathbf{Z}$ flag or the $\mathbf{C Y}$ flag is set, branch to the address specified; otherwise proceed next instruction. The branch destination is computed by adding the signed relative displacement in the second instruction byte to the PC, after incrementing the PC tw |  |  |  |  |  |
| Flags: |  |  |  |  |  |  |
|  | CY | AC | OV | N |  | Z |
|  | - | - | - | $!$ |  | $!$ |
| Example: | The instruction |  |  |  |  |  |
|  | JLE LABEL1 |  |  |  |  |  |
|  | causes program execution to continue at LABEL1 if the $Z$ flag or the CY flag is set. |  |  |  |  |  |
|  | Binary Mode |  | Source Mode |  |  |  |
|  | Not Taken | Taken | Not Taken |  | Taken |  |
| Bytes: | 3 | 3 | 2 |  | 2 |  |
| States: | 2 | 5 | 1 |  | 4 |  |
| [Encoding] | 0010 | 1000 | rel. addr |  |  |  |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |  |

Operation: JLE

$$
\begin{aligned}
& (\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \\
& \mathrm{IF}(\mathrm{Z})=1 \mathrm{OR}(\mathrm{CY})=1 \\
& \mathrm{THEN}(\mathrm{PC}) \leftarrow(\mathrm{PC})+\mathrm{rel}
\end{aligned}
$$

JMP @A+DPTR
Function: Jump indirect
Description: Add the 8 -bit unsigned contents of the accumulator with the 16 -bit data pointer and load the resulting sum into the lower 16 bits of the program counter. Load FFH into bits 16-23 of the program counter. This is the address for subsequent instruction fetches. The contents of the accumulator and the data pointer are not affected.

Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: The accumulator contains an even number from 0 to 6 . The following sequence of instructions branch to one of four AJMP instructions in a jump table starting at JMP_TBL:

|  | MOV | DPTR,\#JMP_TBL |
| :--- | :--- | :--- |
|  | JMP | @A+DPTR |
| JMP_TBL: | AJMP | LABELO |
|  | AJMP | LABEL1 |
|  | AJMP | LABEL2 |
|  | AJMP | LABEL3 |

If the accumulator contains 04 H at the start this sequence, execution jumps to LABEL2. Remember that AJMP is a two-byte instruction, so the jump instructions start at every other address.

## Binary Mode Source Mode

Bytes:
States:
5
1
5
[Encoding]

| 0111 | 0011 |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding $]$ Source Mode $=$ [Encoding]

Operation: JMP
$($ PC. 15:0) $\leftarrow(A)+(D P T R)$
$(P C .23: 16) \leftarrow \mathrm{FFH}$

JNB bit51,rel
JNB bit,rel
Function: Jump if bit not set
Description: If the specified bit is clear, branch to the specified address; otherwise proceed with the next instruction. 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. The bit tested is not modified.
Flags:

| CY | AC | OV | N | $\mathbf{Z}$ |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: Input port 1 contains 11001010B and the accumulator contains 56 H (01010110B). After executing the instruction sequence

JNB P1.3,LABEL1
JNB ACC.3,LABEL2
program execution continues at label LABEL2.

## Variations

JNB bit51,rel

|  | Binary Mode |  | Source Mode |  |
| :--- | :---: | :---: | :---: | :---: |
|  | Not Taken | Taken | Not Taken | Taken |
| Bytes: | 3 | 3 | 3 | 3 |
| States: | 2 | 5 | 2 | 5 |

[Encoding]

| 0011 | 0000 |
| :--- | :--- |

$\square$ rel. addr

Hex Code in: Binary Mode $=$ [Encoding $]$ Source Mode $=$ [Encoding]

Operation: JNB
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+3$
IF (bit51) $=0$
THEN $(\mathrm{PC}) \leftarrow(\mathrm{PC})+$ rel
JNB bit,rel

|  | Binary Mode |  | Source Mode |  |
| :--- | :---: | :---: | :---: | :---: |
|  | Not Taken | Taken | Not Taken | Taken |
| Bytes: | 5 | 5 | 4 | 4 |
| States: | 4 | 7 | 3 | 6 |

[Encoding]

| 1010 | 1001 |
| :--- | :--- | :--- | :--- | :--- | | 0011 | 0 | y y |
| :--- | :--- | :--- | | direct addr |
| :--- | :--- |
| rel. addr |

$\begin{array}{ll}\text { Hex Code in: } & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }]\end{array}$
Operation: JNB
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+3$
IF (bit) $=0$
THEN

$$
(\mathrm{PC}) \leftarrow(\mathrm{PC})+\text { rel }
$$

JNC rel

## Function: Jump if carry not set

Description: If the CY flag is clear, branch to the address specified; otherwise proceed with the next instruction. The branch destination is computed by adding the signed relative displacement in the second instruction byte to the PC, after incrementing the PC twice to point to the next instruction. The CY flag is not modified.

## Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| $!$ | - | - | - | - |

Example: The CY flag is set. The instruction sequence
JNC LABEL1
CPL CY
JNC LABEL2
clears the CY flag and causes program execution to continue at label LABEL2.

|  | Binary Mode |  | Source Mode |  |
| :--- | :---: | :---: | :---: | :---: |
|  | Not Taken | Taken | Not Taken | Taken |
| Bytes: | 2 | 2 | 2 | 2 |
| States: | 1 | 4 | 1 | 4 |
|  |  |  |  |  |
| [Encoding] | 0101 | 0000 | rel. addr |  |

$\begin{array}{ll}\text { Hex Code in: } & \begin{array}{l}\text { Binary Mode }=[\text { Encoding }] \\ \text { Source Mode }=[\text { Encoding }]\end{array}\end{array}$
Operation: JNC
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+2$
IF (CY) $=0$
THEN $(\mathrm{PC}) \leftarrow(\mathrm{PC})+$ rel
JNE rel
Function: Jump if not equal
Description: If the $Z$ flag is clear, branch to the address specified; otherwise proceed with the next instruction. The branch destination is computed by adding the signed relative displacement in the second instruction byte to the PC, after incrementing the PC twice.

Flags:

| CY | AC | OV | N | $\mathbf{Z}$ |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $!$ |

Example: The instruction
JNE LABEL1
causes program execution to continue at LABEL1 if the $\mathbf{Z}$ flag is clear.

|  | Binary Mode |  | Source Mode |  |
| :--- | :---: | :---: | :---: | :---: |
|  | Not Taken | Taken | Not Taken | Taken |
| Bytes: | 3 | 3 | 2 | 2 |
| States: | 2 | 5 | 1 | 4 |

[Encoding]

| 0111 | 1000 |
| :--- | :--- |

rel. addr
Hex Code in: Binary Mode $=$ [A5][Encoding] Source Mode $=$ [Encoding]

Operation: JNE
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+2$
IF (Z) $=0$
THEN $(\mathrm{PC}) \leftarrow(\mathrm{PC})+$ rel
JNZ rel
Function: Jump if accumulator not zero
Description: If any bit of the accumulator is set, branch to the specified address; otherwise proceed with the next instruction. The branch destination is computed by adding the signed relative displacement in the second instruction byte to the PC, after incrementing the PC twice. The accumulator is not modified.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $!$ |

Example: The accumulator contains 00 H . After executing the instruction sequence
JNZ LABEL1
INC A
JNZ LABEL2
the accumulator contains 01H and program execution continues at label LABEL2.

Binary Mode

|  | Not Taken | Taken |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | 2 | 5 |

Source Mode

| Not Taken | Taken |
| :---: | :---: |
| 2 | 2 |
| 2 | 5 |

[Encoding] $\square$
$0111 \quad 0000$ rel. addr

Hex Code in: Binary Mode $=$ [Encoding] Source Mode = [Encoding]

Operation: JNZ
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+2$
IF $(A) \neq 0$
THEN $(P C) \leftarrow(P C)+$ rel
JSG rel
Function: Jump if greater than (signed)
Description: If the $Z$ flag is clear AND the $N$ flag and the OV flag have the same value, branch to the address specified; otherwise proceed with the next instruction. The branch destination is computed by adding the signed relative displacement in the second instruction byte to the PC, after incrementing the PC twice.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | $!$ | $!$ | $!$ |

Example: The instruction
JSG LABEL1
causes program execution to continue at LABEL1 if the $Z$ flag is clear AND the $N$ flag and the OV flag have the same value.

|  | Binary Mode |  | Source Mode |  |
| :--- | :---: | :---: | :---: | :---: |
|  | Not Taken | Taken | Not Taken | Taken |
| Bytes: | 3 | 3 | 2 | 2 |
| States: | 2 | 5 | 1 | 4 |

[Encoding]

| 0001 | 1000 |
| :--- | :--- | rel. addr

Hex Code in: Binary Mode = [A5][Encoding] Source Mode $=$ [Encoding]

Operation:
JSG

$$
\begin{aligned}
& (\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \\
& \mathrm{IF}[(\mathrm{~N})=0 \mathrm{AND}(\mathrm{~N})=(\mathrm{OV})] \\
& \mathrm{THEN}(\mathrm{PC}) \leftarrow(\mathrm{PC})+\text { rel }
\end{aligned}
$$

JSGE rel
Function: Jump if greater than or equal (signed)
Description: If the N flag and the OV flag have the same value, branch to the address specified; otherwise proceed with the next instruction. The branch destination is computed by adding the signed relative displacement in the second instruction byte to the PC, after incrementing the PC twice.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | $!$ | $!$ | $!$ |

Example: The instruction
JSGE LABEL1
causes program execution to continue at LABEL1 if the N flag and the OV flag have the same value.

|  | Binary Mode |  | Source Mode |  |
| :--- | :---: | :---: | :---: | :---: |
|  | Not Taken | Taken | Not Taken | Taken |

JSL rel
Function: Jump if less than (signed)
Description: If the N flag and the OV flag have different values, branch to the address specified; otherwise proceed with the next instruction. The branch destination is computed by adding the signed relative displacement in the second instruction byte to the PC, after incrementing the PC twice.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | $!$ | $!$ | $!$ |

Example: The instruction
JSL LABEL1
causes program execution to continue at LABEL1 if the $N$ flag and the OV flag have different values.

|  | Binary Mode |  |
| :--- | :---: | :---: |
|  | Not Taken | Taken |
| Bytes: | 3 | 3 |
| States: | 2 | 5 |

[Encoding]

| 0100 | 1000 |
| :--- | :--- |

rel. addr

Hex Code in: Binary Mode = [A5][Encoding] Source Mode $=$ [Encoding]

Operation: JSL
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+2$
IF (N) $=(\mathrm{OV})$
THEN $(P C) \leftarrow(P C)+$ rel
JSLE rel
Function: Jump if less than or equal (signed)
Description: If the $Z$ flag is set $O R$ if the the $N$ flag and the $O V$ flag have different values, branch to the address specified; otherwise proceed with the next instruction. The branch destination is computed by adding the signed relative displacement in the second instruction byte to the PC , after incrementing the PC twice.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | $!$ | $!$ | $!$ |

Example: The instruction
JSLE LABEL1
causes program execution to continue at LABEL1 if the $\mathbf{Z}$ flag is set $\mathbf{O R}$ if the the $\mathbf{N}$ flag and the OV flag have different values.

Binary Mode
Not Taken Taken
Bytes:
States:
3
2
5
Source Mode

| Not Taken | Taken |
| :---: | :---: |
| 2 | 2 |
| 1 | 4 |

rel. addr
Hex Code in: Binary Mode $=$ [A5][Encoding]
Source Mode = [Encoding]

| Operation: | JSLE <br> $(\mathrm{PC}) \leftarrow(\mathrm{PC})+2$ <br>  <br>  <br> $\mathrm{IF}\{(\mathrm{Z})=1 \mathrm{OR}[(\mathrm{N}) \neq(\mathrm{OV})]\}$ <br>  <br>  <br>  <br> $\quad$THEN $(\mathrm{PC}) \leftarrow(\mathrm{PC})+$ rel |
| :--- | :--- |

JZ rel

## Function: Jump if accumulator zero

Description: If all bits of the accumulator are clear (zero), branch to the address specified; otherwise proceed with the next instruction. The branch destination is computed by adding the signed relative displacement in the second instruction byte to the PC, after incrementing the PC twice. The accumulator is not modified.

## Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $!$ |

Example: The accumulator contains 01 H . After executing the instruction sequence
JZ LABEL1
DEC A
JZ LABEL2
the accumulator contains 00 H and program execution continues at label LABEL2.

|  | Binary Mode |  | Source Mode |  |
| :---: | :---: | :---: | :---: | :---: |
|  | Not Taken | Taken | Not Taken | Taken |
| Bytes: | 2 | 2 | 2 | 2 |
| States: | 2 | 5 | 2 | 5 |
| [Encoding] | 0110 | 0000 | rel. addr |  |
| Hex Code in: | Binary Mode = [Encoding] <br> Source Mode = [Encoding] |  |  |  |
| Operation: | $\begin{aligned} & \mathrm{JZ} \\ & (\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \\ & \mathrm{IF}(\mathrm{~A})=0 \\ & \quad \text { THEN }(\mathrm{PC}) \leftarrow(\mathrm{PC})+\text { rel } \end{aligned}$ |  |  |  |
| LCALL <dest> |  |  |  |  |
| Function: | Long call |  |  |  |
| Description: | Calls a subroutine located at the specified 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). The stack pointer is incremented by two. The high and low 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 64-Kbyte region of memory where the next instruction is located. |  |  |  |

Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: The stack pointer contains 07 H and the label "SUBRTN" is assigned to program memory location 1234 H . After executing the instruction

LCALL SUBRTN
at location 0123H, the stack pointer contains 09H, on-chip RAM locations 08 H and 09 H contain 01 H and 26 H , and the PC contains 1234 H .

## LCALL addr16

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 3 |
| States: | 9 | 9 |

[Encoding] | 0001 | 0010 |
| :--- | :--- |
|  | addr15-addr8 |
|  | addr7-addr0 |

## Hex Code in: Binary Mode = [Encoding] <br> Source Mode $=$ [Encoding]

Operation: LCALL
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+3$
$(\mathrm{SP}) \leftarrow(\mathrm{SP})+1$
$((S P)) \leftarrow(P C .7: 0)$
$(S P) \leftarrow(S P)+1$
$((S P)) \leftarrow(P C .15: 8)$
(PC) $\leftarrow$ (addr. 15:0)
LCALL @WRj

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 9 | 8 |

[Encoding]

| 1001 | 1001 |
| :--- | :--- |


| ttt | 0100 |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [A5][Encoding]
Source Mode = [Encoding]
Operation: LCALL
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+3$
$(\mathrm{SP}) \leftarrow(\mathrm{SP})+1$
$((\mathrm{SP})) \leftarrow(\mathrm{PC.7:0)}$
$(S P) \leftarrow(S P)+1$
$((S P)) \leftarrow(P C .15: 8)$
$(\mathrm{PC}) \leftarrow((\mathrm{WRj}))$

LJMP <dest>
Function: Long Jump
Description: Causes an unconditional branch to the specified address, by loading the high and low bytes of the PC (respectively) with the second and third instruction bytes. The destination may therefore be anywhere in the 64-Kbyte memory region where the next instruction is located.
Flags:

| CY | AC | OV | $\mathbf{N}$ | $\mathbf{Z}$ |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: The label "JMPADR" is assigned to the instruction at program memory location 1234H. After executing the instruction

LJMP JMPADR
at location 0123 H , the program counter contains 1234 H .
LJMP addr16

|  | Binary Mode | Source |
| :--- | :---: | ---: |
| Bytes: | 3 | 3 |
| States: | 5 | 5 |

[Encoding]

| 0000 | 0010 |
| :--- | :--- |

addr15-addr8 addr7-addr0
$\begin{array}{ll}\text { Hex Code in: } & \left.\begin{array}{l}\text { Binary Mode }=[\text { Encoding }] \\ \\ \text { Source Mode }=[\text { Encoding }]\end{array}\right]\end{array}$
Operation: LJMP
$(\mathrm{PC}) \leftarrow$ (addr. 15:0)
LJMP @WRj

|  | Binary Mode3 |  | Source Mode |  |
| :---: | :---: | :---: | :---: | :---: |
| Bytes: |  |  | 2 |  |
| States: | 6 |  |  |  |
| [Encoding] | 1000 | 1001 | tttt | 0100 |
| Hex Code in: | Binary Mode $=[$ Encoding $]$ Source Mode $=[$ Encoding $]$ <br> Source Mode $=$ [Encoding] |  |  |  |
| Operation: | $\begin{aligned} & \text { LJMP } \\ & (\mathrm{PC}) \leftarrow((\mathrm{WRj})) \end{aligned}$ |  |  |  |

MOV <dest>,<src>
Function: Move byte variable
Description: Copies the byte variable specified by the second operand into the location specified by the first operand. The source byte is not affected.

This is by far the most flexible operation. Twenty-four combinations of source and destination addressing modes are allowed.

Flags:

| CY | AC | OV | N | $\mathbf{Z}$ |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: On-chip RAM location 30 H contains 40 H , on-chip RAM location 40 H contains 10 H , and input port 1 contains 11001010B (OCAH). After executing the instruction sequence

| MOV | RO,\#3OH | ;RO $<=30 \mathrm{H}$ |
| :--- | :--- | :--- |
| MOV | A,@RO | ;A $<=40 \mathrm{H}$ |
| MOV | R1,A | ;R1 $<=40 \mathrm{H}$ |
| MOV | B,@R1 | ;B $<=10 \mathrm{H}$ |
| MOV | @R1,P1 | ;RAM (40H $)<=0 \mathrm{CAH}$ |
| MOV | P2,P1 | ;P2 \#OCAH |

register 0 contains 30 H , the accumulator and register 1 contain 40 H , register B contains 10 H , and on-chip RAM location 40H and output port 2 contain OCAH (11001010B).
Variations
MOV A,\#data

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | 1 | 1 |

[Encoding] | 0111 | 0100 |
| :---: | :---: |

$\begin{array}{ll}\text { Hex Code in: } & \text { Binary Mode }=[\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }]\end{array}$
Operation: MOV
(A) $\leftarrow$ \#data

MOV dir8,\#data

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 3 |
| States: | $3 \dagger$ | $3 \dagger$ |

$\dagger$ If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state.
[Encoding]

| 0111 | 0101 |
| :--- | :--- | direct addr immed. data


| Hex Code in: | Binary Mode $=[$ Encoding $]$ |
| :--- | :--- |
|  | Source Mode $=[$ Encoding $]$ |


| Operation: | MOV <br> (dir8) \#data |
| :--- | :--- |

MOV @Ri,\#data

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 3 |
| States: | 3 | 4 |

[Encoding]

| 0111 | 011 i |
| :--- | :--- |

immed. data

| Hex Code in: | Binary Mode $=$ <br> Source Mode $=$ <br> Operation: |
| :--- | :--- |
|  | MOV |
| $(($ Ri) $) \leftarrow$ \#data |  |

MOV Rn,\#data

|  | Binary Mode So |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Bytes: | 2 |  |  |  |
| States: | 1 |  |  |  |
| [Encoding] | 0111 | 1 rrr | immed. data |  |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { Encoding }] \\ & \text { Source Mode }=[\text { A5][Encoding }] \end{aligned}$ |  |  |  |
| Operation: | $\begin{aligned} & \text { MOV } \\ & (\mathrm{Rn}) \leftarrow \text { \#data } \end{aligned}$ |  |  |  |
| MOV dir8,dir8 |  |  |  |  |
|  | Binary Mode Source Mode |  |  |  |
| Bytes: | 3 |  |  |  |
| States: | 3 |  |  |  |
| [Encoding] | 1000 | 0101 | direct addr | direct addr |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |
| Operation: | $\begin{aligned} & \text { MOV } \\ & \text { (dir8) } \leftarrow \text { (dir8) } \end{aligned}$ |  |  |  |

## MOV dir8,@Ri

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 3 |
| States: | 3 | 4 |


| [Encoding] | 1000 | 011 i | direct addr |
| :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { Encoding }] \\ & \text { Source Mode }=[\text { A5 }][\text { Encoding }] \end{aligned}$ |  |  |
| Operation: | $\begin{aligned} & \text { MOV } \\ & (\text { dir8 }) \leftarrow((\mathrm{R} \end{aligned}$ |  |  |

MOV dir8,Rn

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 3 |
| States: | $2 \dagger$ | $3 \dagger$ |
|  | $\dagger$ lf this instruction addresses a port $(P x, x=0-3)$, add 1 state. |  |



| [Encoding] | 1010 | 011 i | direct addr |
| :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { Encoding }] \\ & \text { Source Mode }=[\text { A5 }][\text { Encoding }] \end{aligned}$ |  |  |
| Operation: | MOV $((\mathrm{Ri})) \leftarrow(\operatorname{dir}$ |  |  |

## MOV Rn,dir8

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 3 |
| States: | $1 \dagger$ | $2 \dagger$ |

$\dagger \dagger$ lf this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state.
[Encoding]

| 1010 | 1 rrr |
| :--- | :--- | direct addr


| Hex Code in: | Binary Mode $=[$ Encoding $]$ <br> Source Mode $=[$ A5] [Encoding $]$ |
| :--- | :--- |
| Operation: | MOV <br> $(R n) \leftarrow($ dir8) |
| MOV A,dir8 |  |
| Bynary Mode | Source Mode |
| Bytes: | 2 |

$\dagger \dagger$ lf this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state.

| [Encoding] 1110 <br>  0101 <br> Hex Code in: Birect addr <br> Boury Mode $=[$ Encoding $]$ <br> Source Mode $=[$ Encoding $]$ <br> Operation: MOV <br> (A) $\leftarrow$ (dir8) |
| :--- | :--- | :--- |

MOV A,@Ri

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 1 | 2 |
| States: | 2 | 3 |

[Encoding]

| 1110 | 011 i |
| :--- | :--- |

Hex Code in: Binary Mode = [Encoding] Source Mode = [A5][Encoding]

Operation: MOV
$(\mathrm{A}) \leftarrow((\mathrm{Ri}))$
MOV A,Rn

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 1 | 2 |
| States: | 1 | 2 |

[Encoding]

| 1110 | 1 rrr |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding $]$
Source Mode = [A5][Encoding]
Operation: MOV
$(\mathrm{A}) \leftarrow(\mathrm{Rn})$

MOV dir8,A

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | $2 \dagger$ | $2 \dagger$ |

$\dagger$ If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state.

[Encoding] | 1111 | 0101 |
| :--- | :--- |

$\begin{array}{ll}\text { Hex Code in: } & \left.\begin{array}{l}\text { Binary Mode }=[\text { Encoding }] \\ \text { Source Mode }=[\text { Encoding }]\end{array}\right]\end{array}$
Operation: MOV
(dir8) $\leftarrow(A)$
MOV @Ri,A

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 1 | 2 |
| States: | 3 | 4 |

[Encoding] $\square$
Hex Code in: Binary Mode $=$ [Encoding $]$
Source Mode = [A5][Encoding]
Operation: MOV
$((\mathrm{Ri})) \leftarrow(\mathrm{A})$
MOV Rn,A


[Encoding] | 0111 | 1100 |
| :--- | :--- | :--- | :--- |

| Hex Code in: | Binary Mode $=[$ A5 $]$ [Encoding $]$ <br> Source Mode $=[$ Encoding $]$ |
| :--- | :--- |
| Operation: | MOV <br> $($ Rmd $) \leftarrow($ Rms $)$ |
| MOV WRjd,WRjs |  |


|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 2 | 1 |

[Encoding] \begin{tabular}{|l|l|l|}
\hline 0111 \& 1101 <br>
\hline

$\quad$

\hline ttt \& TTTT <br>
\hline
\end{tabular}

| Hex Code in: | Binary Mode $=[$ [A5][Encoding $]$ <br> Source Mode $=[$ Encoding $]$ |
| :--- | :--- |
| Operation: | MOV |
|  | $($ WRjd $) \leftarrow($ WRjs $)$ |

MOV DRkd,DRks

|  | Binary Mode So |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Bytes: | 3 |  |  |  |  |
| States: | 3 |  |  |  |  |
| [Encoding] | 0111 | 1111 | unue | UUUU |  |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5][Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | MOV <br> (DRkd) $\leftarrow$ (DRks) |  |  |  |  |
| MOV Rm,\#data |  |  |  |  |  |
|  | Binary Mode Source Mode |  |  |  |  |
| Bytes: | 4 |  |  |  |  |
| States: | 3 |  |  |  |  |
| [Encoding] | 0111 | 1110 | ssss | 0000 | \#data |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | MOV <br> $(\mathrm{Rm}) \leftarrow \#$ |  |  |  |  |

MOV WRj,\#data16
Binary Mode Source Mode
Bytes:
5
4
States:
3
2
[Encoding]

| 0111 | 1110 |
| :--- | :--- |


| tttt | 0100 |
| :--- | :--- |

\#data hi
\#data low
Hex Code in: Binary Mode $=$ [A5][Encoding] Source Mode $=$ [Encoding]

Operation: MOV
$($ WRj $) \leftarrow$ \#data16
MOV DRk,\#Odata16

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 5 | 4 |
| States: | 5 | 4 |

[Encoding]

| 0111 | 1110 |
| :--- | :--- | :--- | | uuuu | 1000 |
| :---: | :---: |

Hex Code in: Binary Mode = [A5][Encoding] Source Mode = [Encoding]

Operation:
MOV
(DRk) $\leftarrow$ \#Odata16
MOV DRk,\#1data16

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 5 | 4 |
| States: | 5 | 4 |

[Encoding]

| 0111 | 1110 |
| :--- | :---: | :---: | :---: | | uuuu | 1100 |
| :---: | :---: |

Hex Code in: Binary Mode = [A5][Encoding]
Source Mode = [Encoding]
Operation:
MOV
(DRk) $\leftarrow$ \#1data16

## MOV Rm,dir8

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | $3 \dagger$ | $2 \dagger$ |

$\dagger$ If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state.

[Encoding] \begin{tabular}{|l|l|l|}
\hline 0111 \& 1110 <br>
\hline

$\quad$

\hline sss s <br>
\hline
\end{tabular}

| Hex Code in: | Binary Mode $=[$ A5 $][$ Encoding $]$ |
| :--- | :--- |
|  | Source Mode $=[$ Encoding $]$ |

Operation: MOV
$(\mathrm{Rm}) \leftarrow$ (dir8)
MOV WRj,dir8

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | 4 | 3 |

[Encoding] | 0111 | 1110 |  |
| :--- | :--- | :--- |
|  | $\mathbf{t t t t}$ | 0101 |

Hex Code in: Binary Mode $=[$ [A5][Encoding]
Source Mode $=$ [Encoding]
$\begin{array}{ll}\text { Operation: } & \text { MOV } \\ & \text { (WRj) } \leftarrow(\text { dir8) }\end{array}$
MOV DRk,dir8

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | 6 | 5 |

[Encoding] | 0111 | 1110 |  |
| :---: | :---: | :---: |
|  | uuuu | 1101 |

Hex Code in: Binary Mode $=[$ A5][Encoding $]$
Source Mode $=$ [Encoding]
Operation: MOV
$(\mathrm{DRk}) \leftarrow($ dir 8$)$
MOV Rm,dir16

## Bytes:

Binary Mode Source Mode

States:
[Encoding]

| 0111 | 1110 | ssss | 0011 | direct addr | direct addr |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | $\begin{aligned} & \text { MOV } \\ & (\text { Rm }) \leftarrow(\text { dir16 }) \end{aligned}$ |  |  |  |  |
| MOV WRj,dir16 |  |  |  |  |  |
| Binary Mode Source Mode |  |  |  |  |  |
| Bytes: | 4 |  |  |  |  |
| States: | 43 |  |  |  |  |
| [Encoding] |  |  |  |  |
| 0111 |  |  |  | 1110 | ttt | 0111 | direct addr | direct addr |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5][Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | $\begin{aligned} & \text { MOV } \\ & (\text { WRj }) \leftarrow(\text { dir16 }) \end{aligned}$ |  |  |  |  |
| MOV DRk,dir16 |  |  |  |  |  |
| Binary Mode Source Mode |  |  |  |  |  |
| Bytes: | 4 |  |  |  |  |
| States: | 65 |  |  |  |  |
| [Encoding] |  |  |  |  |  |
| 0111 | 1110 | uuuu | 1111 | direct addr | direct addr |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }] \text { [Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | $\begin{aligned} & \text { MOV } \\ & \text { (DRk) } \leftarrow(\operatorname{dir} 16) \end{aligned}$ |  |  |  |  |

MOV Rm, @WRj

Bytes:
States:
[Encoding]

| 0111 | 1110 |
| :--- | :--- |


| tttt | 1001 |
| :--- | :--- |


| ssss | 0000 |
| :---: | :---: |

Operation: MOV
$(R m) \leftarrow((W R \mathrm{j}))$
MOV Rm,@DRk

## Binary Mode Source Mode

Bytes:
4
3
States:
4
3
[Encoding]

| 0111 | 1110 | uuuu | 1011 | ssss | 0000 |
| :---: | :---: | :---: | :---: | :---: | :---: |


| Hex Code in: | Binary Mode $=[$ A5 $]$ [Encoding $]$ <br> Source Mode $=[$ Encoding $]$ |
| :--- | :--- |
| Operation: | MOV <br> $(\mathrm{Rm}) \leftarrow((\mathrm{DRK}))$ |

MOV WRjd, @WRjs

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | 4 | 3 |
| [Encoding] |  |  |


| 0000 | 1011 |
| :--- | :--- | :--- | :--- | :--- |$\quad$| TTTT | 1000 |
| :---: | :---: |$\quad$| ttt |
| :---: |


| Hex Code in: | Binary Mode $=[$ A5] [Encoding $]$ <br> Source Mode $=[$ Encoding $]$ |
| :--- | :--- |
| Operation: | MOV <br> $($ WRjd $) \leftarrow(($ WRjs $))$ |

MOV WRj,@DRk

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | 5 | 4 |
| [Encoding] |  |  |


| 0000 | 1011 |
| :--- | :--- | :--- | :--- | :--- |
| uuun | 1010 | | ttt | 0000 |
| :---: | :---: |

Hex Code in: Binary Mode $=$ [A5][Encoding] Source Mode $=$ [Encoding]

Operation: MOV
$(\mathrm{WRj}) \leftarrow((\mathrm{DRk}))$


| 0111 | 1010 |
| :--- | :--- | :--- |$\quad$| ss s | 0011 |
| :---: | :---: |$\quad$ direct addr $\quad$| direct addr |
| :---: |


| Hex Code in: | Binary Mode $=[$ A5] [Encoding $]$ <br> Source Mode $=[$ Encoding $]$ |
| :--- | :--- |
| Operation: | MOV <br> $($ dir16 $) \leftarrow($ Rm $)$ |

MOV dir16,WRj
Binary Mode Source Mode
Bytes: 5

States: 5
[Encoding]

| 0111 | 1010 | ttt | 0111 | direct addr | direct addr |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5][Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | $\begin{aligned} & \text { MOV } \\ & (\text { dir16 }) \leftarrow(\mathrm{WRj}) \end{aligned}$ |  |  |  |  |
| MOV dir16,DRk |  |  |  |  |  |
| Binary Mode Source Mode |  |  |  |  |  |
| Bytes: | 54 |  |  |  |  |
| States: | $7 \quad 6$ |  |  |  |  |
| [Encoding] |  |  |  |  |  |
| 0111 | 1010 | uuuu | 1111 | direct addr | direct addr |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5][Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | $\begin{aligned} & \text { MOV } \\ & (\text { dir16 }) \leftarrow(\text { DRk }) \end{aligned}$ |  |  |  |  |
| MOV @WRj,R |  |  |  |  |  |

Binary Mode Source Mode
Bytes:
States:
4
3
[Encoding]

| 0111 | 1010 |
| :--- | :--- | :--- | :--- | :--- |
| tttt | 1001 |$\quad$|  | ssss | 0000 |
| :---: | :---: | :---: |

Hex Code in: Binary Mode $=$ [A5][Encoding] Source Mode = [Encoding]

Operation:
MOV
$((W R \mathrm{j})) \leftarrow(\mathrm{Rm})$

MOV @DRk,Rm

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | 5 | 4 |
| [Encoding] |  |  |


| 0111 | 1010 |
| :--- | :--- | :--- | :--- | :--- |$\quad$| uuuu | 1011 |
| :---: | :---: | :---: |

$\begin{array}{ll}\text { Hex Code in: } & \text { Binary Mode }=[\text { A5] [Encoding }] \\ & \text { Source Mode }=[\text { Encoding }]\end{array}$
Operation: MOV
$(($ DRk $)) \leftarrow($ Rm $)$
MOV @WRjd,WRjs

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | 5 | 4 |

[Encoding]

| 0001 | 1011 |
| :--- | :--- | :--- | :--- | :--- |$\quad$| ttt | 1000 |
| :--- | :--- | :--- |

Hex Code in: Binary Mode = [A5][Encoding]
Source Mode = [Encoding]
Operation: MOV
$((W R j d)) \leftarrow(W R j s)$
MOV @DRk,WRj

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | 6 | 5 |

[Encoding]

| 0001 | 1011 |
| :--- | :--- | :--- | :--- | :--- |$\quad$| uuuu | 1010 |
| :---: | :---: | :---: |

Hex Code in: Binary Mode $=$ [A5][Encoding] Source Mode $=$ [Encoding]

Operation: MOV
$((\mathrm{DRk})) \leftarrow(\mathrm{WRj})$
MOV Rm,@WRj + dis16

|  | Binary Mode | Source |
| :--- | :---: | ---: |
| Bytes: | 5 | 4 |
| States: | 6 | 5 |

[Encoding]

| 0000 | 1001 | ssss | $t \mathrm{tt}$ | dis hi | dis low |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | MOV <br> $(\mathrm{Rm}) \leftarrow((\mathrm{WR} \mathrm{j}))+($ dis $)$ |  |  |  |  |
| MOV WRj, @WRj + dis16 |  |  |  |  |  |
| Binary Mode Source Mode |  |  |  |  |  |
| Bytes: | 5 | 4 |  |  |  |
| States: | 7 | 6 |  |  |  |
| [Encoding] |  |  |  |  |  |


| 0100 | 1001 |
| :--- | :--- | :--- |
| tttt | TTTT | | dis hi |
| :---: |$\quad$| dis low |
| :---: |


| Hex Code in: | Binary Mode $=[$ A5][Encoding $]$ <br> Source Mode $=[$ Encoding] $]$ |  |  |
| :--- | :--- | :---: | :---: |
| Operation: | MOV <br> $($ WRj $) \leftarrow(($ WRj $))+($ dis $)$ |  |  |
| MOV Rm, ©DRk + dis24 |  |  |  |
| Binary Mode |  |  | Source Mode |
| Bytes: | 5 |  |  |
| States: | 7 |  |  |

[Encoding]

| 0010 | 1001 |
| :--- | :--- | :--- | :--- |$\quad$| ssss | uuuu |
| :--- | :--- |

Hex Code in: Binary Mode = [A5][Encoding] Source Mode $=$ [Encoding]

Operation: MOV
$(R m) \leftarrow((D R k))+($ dis $)$
MOV WRj, @DRk + dis24

## Binary Mode Source Mode

Bytes: 5
$\begin{array}{lll}\text { States: } & 8 & 7\end{array}$
[Encoding]

| 0110 | 1001 |
| :--- | :--- | :--- | :--- |$\quad$| ttt | uuun |
| :---: | :---: |

Hex Code in: Binary Mode $=[$ A5][Encoding]
Source Mode = [Encoding]
\(\left.\begin{array}{lcc}Operation: \begin{array}{l}MOV <br>

(WRj)\end{array} \leftarrow((DRk))+(dis)\end{array}\right]\)|  |  |  |
| :--- | :--- | :---: |
| MOV @WRj + dis16,Rm |  |  |
|  |  |  |
| Bytes: | Binary Mode | Source Mode |
| States: | 5 | 4 |
| [Encoding] | 6 | 5 |

| 0001 | 1001 | $t \mathrm{tt}$ | ssss | dis hi | dis low |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Operation: | $/ R j))+(d i$ |  |  |  |  |

MOV @WRj + dis16,WRj
Binary Mode Source Mode
Bytes: 5
States:
7
6
[Encoding]

| 0101 | 1001 | $t \mathrm{tt}$ | T T T | dis hi | dis low |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5][Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | $\begin{aligned} & \text { MOV } \\ & ((\mathrm{WRj}))+(\mathrm{dis}) \leftarrow(\mathrm{WRj}) \end{aligned}$ |  |  |  |  |
| MOV @DRk + dis24,Rm |  |  |  |  |  |
| Binary Mode Source Mode |  |  |  |  |  |
| Bytes: | 5 |  |  |  |  |
| States: | 7 |  |  |  |  |
| [Encoding] |  |  |  |  |  |


| 0011 | 1001 |
| :--- | :--- | :--- |$\quad$| uuuu | ssss |
| :---: | :---: |$\quad$| dis hi |
| :---: |

$\begin{array}{ll}\text { Hex Code in: } & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }]\end{array}$
Operation: MOV
$(($ DRk $))+($ dis $) \leftarrow($ Rm $)$

MOV @DRk + dis24,WRj
Binary Mode Source Mode
Bytes: 5

States: 8
[Encoding]

| 0111 | 1001 uuuu | tttt | dis hi | dis low |
| :---: | :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |
| Operation: | MOV$((\mathrm{DRk}))+(\text { dis }) \leftarrow(\mathrm{WRj})$ |  |  |  |
| MOV <dest-bit>,<src-bit> |  |  |  |  |
| Function: | Move bit data |  |  |  |
| Description: | Copies the Boolean variable specified by the second operand into the location specified by the first operand. One of the operands must be the CY flag; the other may be any directly addressable bit. Does not affect any other register. |  |  |  |

Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| $\checkmark$ | - | - | - | - |

Example: The CY flag is set, input Port 3 contains 11000101B, and output Port 1 contains 35H (00110101B). After executing the instruction sequence

MOV P1.3,CY
MOV CY,P3.3
MOV P1.2,CY
the CY flag is clear and Port 1 contains 39 H (00111001B).

## Variations

MOV bit51,CY

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | $2 \dagger$ | $2 \dagger$ |

$\dagger$ If this instruction addresses a port ( $\mathrm{Px}, \mathrm{x}=0-3$ ), add 2 states.
[Encoding]

| 1001 | 0010 |
| :--- | :--- |

$\square$
bit addr
Hex Code in: Binary Mode $=$ [Encoding $]$
Source Mode $=$ [Encoding]
Operation: MOV
(bit51) $\leftarrow$ (CY)

MOV CY,bit51

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | $1 \dagger$ | $1 \dagger$ |
|  | $\dagger$ If this instruction addresses a port $(P x, x=0-3)$, add 1 state. |  |

[Encoding]

| 1010 | 0010 |
| :--- | :--- | bit addr

Hex Code in: Binary Mode = [Encoding] Source Mode = [Encoding]

Operation: MOV
$(C Y) \leftarrow($ bit51 $)$
MOV bit,CY

## Bytes:

Binary Mode Source Mode

States:
43

4 $\dagger$
$3 \dagger$
$\dagger$ If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 2 states.
[Encoding]

| 1010 | 1001 | 1001 | 0 | y y | direct addr |
| :---: | :---: | :---: | :---: | :---: | :---: |

$\begin{array}{ll}\text { Hex Code in: } & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }]\end{array}$
Operation: MOV
(bit) $\leftarrow(C Y)$
MOV CY,bit

Bytes:
States:
Binary Mode Source Mode
$3 \dagger \quad 2 \dagger$
$\dagger$ If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state.
[Encoding]

| 1010 | 1001 |
| :--- | :--- | :--- | :--- | :--- |$\quad$| 1010 | 0 | y y |
| :--- | :--- | :--- |

Hex Code in: Binary Mode = [A5][Encoding]
Source Mode $=$ [Encoding]
Operation:
MOV
(CY) $\leftarrow$ (bit)

## MOV DPTR,\#data16

Function: Load data pointer with a 16-bit constant
Description: Loads the 16 -bit data pointer (DPTR) with the specified 16 -bit constant. The high byte of the constant is loaded into the high byte of the data pointer (DPH). The low byte of the constant is loaded into the low byte of the data pointer (DPL).
Flags:

| CY | AC | OV | N | $\mathbf{Z}$ |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: After executing the instruction
MOV DPTR,\#1234H
DPTR contains 1234H (DPH contains 12H and DPL contains 34H).
Binary Mode Source Mode
Bytes:
States:
3 3
States: 2
[Encoding]

| 1001 | 0000 |
| :--- | :--- |

$\square$ data low

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode $=$ [Encoding]
Operation: MOV
(DPTR) $\leftarrow$ \#data16
MOVC A,@A+<base-reg>

## Function: Move code byte

Description: Loads the accumulator with a code byte or constant from program memory. The address of the byte fetched is the sum of the original unsigned 8 -bit accumulator contents and the contents of a 16 -bit base register, which may be the 16 LSBs of the data pointer or 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.
Flags:

| CY | AC | OV | N | $\mathbf{Z}$ |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: The accumulator contains a number between 0 and 3. The following instruction sequence translates the value in the accumulator to one of four values defined by the DB (define byte) directive.

RELPC: INC A
MOVC A, @A+PC
RET
DB 66H
DB $\quad 77 \mathrm{H}$
DB $\quad 88 \mathrm{H}$
DB 99H
If the subroutine is called with the accumulator equal to 01 H , it returns with 77 H 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.
Variations
MOVC A, @A+PC

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 1 | 1 |
| States: | 6 | 6 |

[Encoding]

| 1000 | 0011 |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode $=$ [Encoding]
Operation: MOVC
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+1$
$(A) \leftarrow((A)+(P C))$
MOVC A, @A+DPTR

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 1 | 1 |
| States: | 6 | 6 |

[Encoding]

| 1001 | 0011 |
| :--- | :--- |

Hex Code in: Binary Mode = [Encoding]
Source Mode = [Encoding]
Operation: MOVC
$(A) \leftarrow((A)+(D P T R))$

## MOVH DRk,\#data16

Function: Move immediate 16-bit data to the high word of a dword (double-word) register.
Description: Moves 16-bit immediate data to the high word of a dword (32-bit) register. The low word of the dword register is unchanged.
Flags:

| CY | AC | OV | N | $\mathbf{Z}$ |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: The dword register DRk contains 5566 7788H. After the instruction
MOVH DRk,\#1122H
executes, DRk contains 1122 7788H.

## Variations

MOVH DRk,\#data16

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 5 | 4 |
| States: | 3 | 2 |
| [Encoding] |  |  |


| 0111 | 1010 | uuuu | 1100 | \#data hi | \#data low |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | MOVH <br> (DRk).31:16 |  |  |  |  |

## MOVS WRj,Rm

Function: Move 8-bit register to 16 -bit register with sign extension
Description: Moves the contents of an 8-bit register to the low byte of a 16-bit register. The high byte of the 16 -bit register is filled with the sign extension, which is obtained from the MSB of the 8bit source register.
Flags:

| CY | AC | OV | N | $\mathbf{Z}$ |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: Eight-bit register Rm contains 055 H ( 01010101 B ) and the 16-bit register WRj contains OFFFFH (11111111 11111111B). The instruction

MOVSE WRj,Rm
moves the contents of register Rm (01010101B) to register WRj (i.e., WRj contains 0000000001010101 B ).

## Variations

MOVS WRj,Rm


## MOVX <dest>,<src>

Function: Move external
Description: Transfers data between the accumulator and a byte in external data RAM. There are two types of instructions. One provides an 8-bit indirect address to external data RAM; the second provides a 16 -bit indirect address to external data RAM.

In the first type of MOVX instruction, the contents of R0 or R1 in the current register bank provides an 8 -bit address on port 0 . Eight bits are sufficient for external I/O expansion decoding or for a relatively small RAM array. For larger arrays, any port pins can be used to output higher 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 16-bit address. Port 2 outputs the upper eight address bits (from DPH) while port 0 outputs the lower eight address bits (from DPL).

For both types of moves in nonpage mode, the data is multiplexed with the lower address bits on port 0 . In page mode, the data is multiplexed with the contents of P2 on port 2 (8-bit address) or with the upper address bits on port 2 (16-bit address).

It is possible in some situations to mix the two MOVX types. A large RAM array with its upper address lines driven by P2 can be addressed via the data pointer, or with code to output upper address bits to P2 followed by a MOVX instruction using R0 or R1.
Flags:

| CY | AC | OV | N | $\mathbf{Z}$ |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: The MCS 251 controller is operating in nonpage mode. An external 256-byte RAM using multiplexed address/data lines (e.g., an Intel 8155 RAM $/ / / \mathrm{O} / \mathrm{Timer}$ ) is connected to port 0. Port 3 provides control lines for the external RAM. ports 1 and 2 are used for normal I/O. RO and R1 contain 12 H and 34 H . Location 34 H of the external RAM contains 56 H . After executing the instruction sequence

MOVX A, @R1
MOVX @R0,A
the accumulator and external RAM location 12 H contain 56 H .
Variations
MOVX A,@ DPTR

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 1 | 1 |
| States: | 4 | 4 |

[Encoding] | 1110 | 0000 |
| :---: | :---: |

$\begin{array}{ll}\text { Hex Code in: } & \text { Binary Mode }=[\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }]\end{array}$

Operation: MOVX
$(A) \leftarrow((D P T R))$
MOVX A,@Ri

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 1 | 1 |
| States: | 3 | 3 |

[Encoding]

| 1110 | $001 i$ |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode $=[$ A5] [Encoding]
Operation: MOVX
$(A) \leftarrow((R i))$
MOVX @DPTR,A

Bytes:
States:
Binary Mode Source Mode

5
,
[Encoding]

| 1111 | 0000 |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode = [Encoding]
Operation: MOVX
$(($ DPTR $)) \leftarrow(A)$

MOVX @Ri,A

Bytes:
States:
Binary Mode Source Mode
[Encoding]

| 1111 | 001 i |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode = [A5][Encoding]
Operation: MOVX
$(($ Ri) $) \leftarrow(A)$
MOVZ WRj,Rm
Function: Move 8-bit register to 16 -bit register with zero extension
Description: Moves the contents of an 8-bit register to the low byte of a 16-bit register. The upper byte of the 16 -bit register is filled with zeros.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: Eight-bit register Rm contains 055H (01010101B) and 16-bit register WRj contains OFFFFH (11111111 11111111B). The instruction

MOVZ WRj,Rm
moves the contents of register Rm (01010101B) to register WRj. At the end of the operation, WRj contains 0000000001010101 B .

## Variations

MOVZ WRj,Rm

## Binary Mode Source Mode

Bytes:
$3 \quad 2$
States:
2
1
[Encoding]

| 0000 | 1010 |
| :--- | :--- |


| tttt | ssss |
| :---: | :---: |

Hex Code in: Binary Mode $=[$ [A5][Encoding]
Source Mode = [Encoding]
Operation: MOVZ
(WRi) $7-0 \leftarrow($ Rm $) 7-0$
(WRj) $15-8 \leftarrow 0$

MUL <dest>,<src>

## Function: Multiply

Description: Multiplies the unsigned integer in the register with the other unsigned integer operand. Only register addressing mode is allowed. For 8 -bit operands, the result is 16 bits with the low byte stored in low byte of the destination register and high byte of the result stored in the following byte register. The OV flag is set if the product is greater than 255 (OFFH), otherwise it is cleared. If both operands are 16 bit, the result is 32 bit with the low word stored in the low word of the destination register and high word of the result stored in the following word register. In this operation, the OV flag is set if the product is greater than OFFFFH, otherwise it is cleared. The CY flag is always cleared. The $\mathbf{N}$ flag is set when the MSB of the result is set. The $\mathbf{Z}$ flag is set when the result is zero.

## Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| 0 | - | $\checkmark$ | $\checkmark$ | $\checkmark$ |

Example: Register 1 contains $80(50 \mathrm{H}$ or 10010000 B$)$ and register 0 contains $160(0 \mathrm{AOH}$ or 10010000B). After executing the instruction

MUL R1,R0
which gives the product $12,800(3200 \mathrm{H})$, register 1 contains 32 H (00110010B), register 0 contains 00 H , the OV flag is set, and the CY flag is clear.

## MUL Rmd,Rms

|  | Binary Mode | Source |
| :--- | :---: | ---: |
| Bytes: | 3 | 2 |
| States: | 6 | 5 |

[Encoding] | 1010 | 1100 | ssss |
| :---: | :---: | :---: |
|  | SSSS |  |

Hex Code in: Binary Mode $=$ [A5][Encoding]
Source Mode $=$ [Encoding]
Operation: MUL (8-bit operands)
if <dest> $\mathrm{md}=0,2,4, \ldots, 14$
Rmd $\leftarrow$ low byte of the Rmd X Rms
Rmd $+1 \leftarrow$ high byte of the Rmd $X$ Rms
if <dest> $m d=1,3,5, \ldots, 15$
Rmd-1 $\leftarrow$ low byte of the Rmd X Rms
Rmd $\leftarrow$ high byte of the Rmd X Rms
MUL WRjd,WRjs

## Binary Mode Source Mode

Bytes:
States:
3
2
11
[Encoding] $\square$
$\square$

| Hex Code in: | Binary Mode $=[$ A5 $]$ [Encoding $]$ Source Mode $=[$ Encoding $]$ <br> Source Mode $=$ [Encoding] |
| :---: | :---: |
| Operation: | MUL (16-bit operands) <br> if <dest> jd = 0, 4, 8, .., 28 <br> WRjd $\leftarrow$ low byte of the WRjd $X$ WRjs <br> WRjd $+2 \leftarrow$ high byte of the WRjd $\times$ WRjs <br> if <dest> jd = 2, 6, 10, .., 30 <br> WRjd-2 $\leftarrow$ low byte of the WRjd X WRjs <br> WRjd $\leftarrow$ high byte of the WRjd $\times$ WRjs |

MUL AB
Function: Multiply
Description: Multiplies the unsigned 8 -bit integers in the accumulator and register B . The low byte of the 16 -bit product is left in the accumulator, and the high byte is left in register in B. If the product is greater than 255 (OFFH) the OV flag is set; otherwise it is clear. The CY flag is always clear.

Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| 0 | - | $\checkmark$ | $\checkmark$ | $\checkmark$ |

Example: The accumulator contains $80(50 \mathrm{H})$ and register B contains $160(\mathrm{OAOH})$. After executing the instruction

MUL AB
which gives the product $12,800(3200 \mathrm{H})$, register B contains $32 \mathrm{H}(00110010 \mathrm{~B})$, the accumulator contains 00 H , the OV flag is set, and the CY flag is clear.

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 1 | 1 |
| States: | 5 | 5 |

[Encoding]

| 1010 | 0100 |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode $=$ [Encoding]
Operation: MUL
(A) $\leftarrow$ low byte of $(A) X(B)$
$(B) \leftarrow$ high byte of $(A) \times(B)$
NOP
Function: No operation
Description: Execution continues at the following instruction. Affects the PC register only.
Flags:

| CY | AC | OV | N | Z |
| :--- | :--- | :--- | :--- | :--- |



Example: You want to produce a low-going output pulse on bit 7 of Port 2 that lasts exactly 11 states. A simple CLR-SETB sequence generates an eight-state pulse. (Each instruction requires four states to write to a port SFR.) You can insert three additional states (if no interrupts are enabled) with the following instruction sequence:

CLR P2.7
NOP
NOP
NOP
SETB P2.7

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 1 | 1 |
| States: | 1 | 1 |

[Encoding]

| 0000 | 0000 |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding $]$
Source Mode $=$ [Encoding]
Operation: NOP
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+1$
ORL <dest> <src>
Function: Logical-OR for byte variables
Description: Performs the bitwise logical-OR operation (V) between the specified variables, storing the results in the destination operand.

The destination operand can be a register, an accumulator or direct address.
The two operands allow twelve addressing mode combinations. When the destination is the accumulator, the source can be register, direct, register-indirect, or immediate addressing; when the destination is a direct address, the source can be the accumulator or immediate data. When the destination is register the source can be register, immediate, direct and indirect addressing.

Note: When this instruction is used to modify an output port, the value used as the original port data is read from the output data latch, not the input pins.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | $\checkmark$ | $\checkmark$ |

Example: $\quad$ The accumulator contains 0 C3H (11000011B) and RO contains 55H (01010101B). After executing the instruction,

ORL A,RO
the accumulator contains 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 a constant data value in the instruction or a variable computed in the accumulator at run time. After executing the instruction

ORL P1,\#00110010B
sets bits 5,4 , and 1 of output Port 1.

## Variations

ORL dir8,A

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | $2 \dagger$ | $2 \dagger$ |
|  | $\dagger$ If this instruction addresses a port $(P x, x=0-3)$, add 2 states. |  |

[Encoding]

| 0100 | 0010 |
| :--- | :--- |

direct addr
$\begin{array}{ll}\text { Hex Code in: } & \text { Binary Mode }=[\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }]\end{array}$
Operation: ORL
$($ dir8) $\leftarrow($ dir8) $\vee(A)$
ORL dir8,\#data

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 3 |
| States: | $3 \dagger$ | $3 \dagger$ |
|  | $\dagger$ lf this instruction addresses a port $(P x, x=0-3)$, add 1 state. |  |

[Encoding] | 0100 | 0011 |  |
| :--- | :--- | :--- |
|  | direct addr | immed. data |

$\begin{array}{ll}\text { Hex Code in: } & \text { Binary Mode }=[\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }]\end{array}$
Operation: ORL
(dir8) $\leftarrow$ (dir8) V \#data
ORL A,\#data

|  | Binary Mode | Source |
| :--- | :---: | ---: |
| Bytes: | 2 | 2 |
| States: | 1 | 1 |

[Encoding]

| 0100 | 0100 |
| :--- | :--- |

Operation: ORL
$(A) \leftarrow(A)$ V \#data
ORL A,dir8

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | $1 \dagger$ | $1 \dagger$ |

$\dagger$ ff this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state.

[Encoding] | 0100 | 0101 |
| :--- | :--- |
|  | direct addr |

| Hex Code in: | Binary Mode $=[$ Encoding $]$ |
| :--- | :--- |
|  | Source Mode $=[$ Encoding $]$ |

Operation: ORL
$(A) \leftarrow(A) \vee($ dir $)$
ORL A,@Ri

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 1 | 2 |
| States: | 2 | 3 |

[Encoding] | 0100 | $011 i$ |
| :---: | :---: |

Hex Code in: Binary Mode = [Encoding] Source Mode = [A5][Encoding]

Operation: ORL
$(A) \leftarrow(A) \vee((R i))$
ORL A,Rn

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 1 | 2 |
| States: | 1 | 2 |

[Encoding]

| 0100 | 1 rrr |
| :--- | :--- |

Hex Code in: Binary Mode = [Encoding] Source Mode = [A5][Encoding]

Operation:
ORL
$(A) \leftarrow(A) \vee(R n)$

INSTRUCTION SET REFERENCE

ORL Rmd,Rms

|  | Binary Mode So |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Bytes: | 3 |  |  |  |  |
| States: | 2 |  |  |  |  |
| [Encoding] | 0100 | 1100 | ssss | SSSS |  |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | ORL <br> $(R m d) \leftarrow(R m d) \vee(R m s)$ |  |  |  |  |
| ORL WRjd,WRjs |  |  |  |  |  |
|  | Binary Mode Source Mode |  |  |  |  |
| Bytes: | 3 |  |  |  |  |
| States: | 3 |  |  |  |  |
| [Encoding] | 0100 | 1101 | ttt | TTTT |  |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | ORL <br> $(W R j d) \leftarrow(W R j d) \vee(W R j s)$ |  |  |  |  |
| ORL Rm,\#data |  |  |  |  |  |
|  | Binary Mode Source Mode |  |  |  |  |
| Bytes: | 4 |  |  |  |  |
| States: | 3 |  |  |  |  |
| [Encoding] | 0100 | 1110 | ssss | 0000 | \#data |
| Hex Code in | $\text { Binary Mode }=[\text { A5] [Encoding }]$Source Mode = [Encoding] |  |  |  |  |
| Operation: | ORL <br> $(R m) \leftarrow(R m) V$ \#data |  |  |  |  |

ORL WRj,\#data16

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 5 | 4 |
| States: | 4 | 3 |

## [Encoding]

| 0100 | 1110 tttt | 0100 | \#data hi | \#data low |
| :---: | :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |
| Operation: | ORL <br> $(\mathrm{WRj}) \leftarrow(\mathrm{WRj}) \mathrm{V}$ \#data16 |  |  |  |


|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | $3 \dagger$ | $2 \dagger$ |

$\dagger$ If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state.

| [Encoding] | 0100 |  | 10 |
| :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |
| Operation: | $\begin{aligned} & \mathrm{ORL} \\ & (\mathrm{Rm}) \leftarrow(\mathrm{Rm}) \vee(\mathrm{dir} 8) \end{aligned}$ |  |  |
| ORL WRj,dir8 |  |  |  |
|  | Binary Mode |  | Source |
| Bytes: | 4 |  | 3 |
| States: | 4 |  | 3 |

[Encoding] | 0100 | 1111 |  |
| :--- | :--- | :--- |
|  | tttt | 0101 |

Hex Code in: Binary Mode = [A5][Encoding]
Source Mode $=$ [Encoding]

Operation: ORL
$(\mathrm{WRj}) \leftarrow(\mathrm{WRj}) \vee($ dir $)$
ORL Rm,dir16

Bytes:
Binary Mode Source Mode

States:
$5 \quad 4$
[Encoding]

| 0100 | 1110 |
| :--- | :--- | :--- |$\quad$| sss s | 0011 |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [A5][Encoding]
Source Mode = [Encoding]

| Operation: | ORL <br> $(\mathrm{Rm}) \leftarrow(\mathrm{Rm}) \mathrm{V}($ dir16 $)$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| ORL WRj, dir16 |  |  |  |  |
| Binary Mode Source Mode |  |  |  |  |
| Bytes: | 4 |  |  |  |
| States: | 43 |  |  |  |
| [Encoding] |  |  |  |  |
| 0100 | 1110 tttt | 0111 | direct addr | direct addr |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |
| Operation: | ORL <br> $($ WRj $) \leftarrow($ WRj $) V($ dir16) |  |  |  |

## Binary Mode Source Mode

Bytes:
4
3
States:
3
2
[Encoding]

| 0100 | 1110 |
| :--- | :--- | :--- | :--- | :--- |$\quad$| ttt | 1001 |
| :---: | :---: | :---: |

Hex Code in: $\quad$ Binary Mode $=[$ [A5][Encoding] Source Mode $=$ [Encoding]

Operation: ORL $(\mathrm{Rm}) \leftarrow(\mathrm{Rm}) \vee((\mathrm{WR} \mathrm{j}))$
ORL Rm,@DRk

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | 4 | 3 |

[Encoding]

| 0100 | 1110 |
| :--- | :--- |


| uuuu | 1011 |
| :---: | :---: |


| ssss | 0000 |
| :---: | :---: |

Hex Code in: Binary Mode $=[A 5][$ Encoding $]$ Source Mode = [Encoding]

Operation: ORL

$$
(\mathrm{Rm}) \leftarrow(\mathrm{Rm}) \vee((\mathrm{DRk}))
$$

ORL CY,<src-bit>
Function: Logical-OR for bit variables
Description: Sets the CY flag if the Boolean value is a logical 1; leaves the CY flag in its current state otherwise. A slash ("/") preceding the operand in the assembly language indicates that the logical complement of the addressed bit is used as the source value, but the source bit itself is not affected.

Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| $\checkmark$ | - | - | - | - |

Example: $\quad$ Set the CY flag if and only if $\mathrm{P} 1.0=1, \mathrm{ACC} 7=$.1 , or $\mathrm{OV}=0$ :
MOV CY,P1.0 ;LOAD CARRY WITH INPUT PIN P10
ORL CY,ACC. 7 ;OR CARRY WITH THE ACC. BIT 7
ORL CY,/OV ;OR CARRY WITH THE INVERSE OF OV.

## Variations

ORL CY,bit51

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | $1 \dagger$ | $1 \dagger$ |

$\dagger$ If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state.

[Encoding] | 0111 | 0010 |
| :---: | :---: |

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode $=$ [Encoding]
Operation: ORL
$(C Y) \leftarrow(C Y) \vee($ bit51)

ORL CY,/bit51

Bytes:
States:
Binary Mode
Source Mode
$1 \dagger \quad 1 \dagger$
$\dagger$ If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state.
[Encoding]

| 1010 | 0000 |
| :--- | :--- | bit addr

Hex Code in: Binary Mode $=$ [Encoding $]$ Source Mode $=$ [Encoding]

Operation: ORL
$(C Y) \leftarrow(C Y) \vee \neg(b i t 51)$

ORL CY,bit

Binary Mode Source Mode
Bytes:
States:
4
3
$3 \dagger$
$2 \dagger$
$\dagger$ If this instruction addresses a port ( $\mathrm{Px}, x=0-3$ ), add 1 state.
[Encoding]

| 1010 | 1001 | 0 | y y y |
| :--- | :--- | :--- | :--- |
| Hex Code in: | Binary Mode $=[$ [A5][Encoding $]$ <br> Source Mode $=[$ [Encoding $]$ | direct addr |  |

ORL CY,/bit

Bytes:
Binary Mode Source Mode

States:
$3 \dagger$ 2 $\dagger$
$\dagger$ If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state.
[Encoding]

| 1010 | 1001 |
| :--- | :--- |


| 1110 | 0 | yyy |
| :---: | :---: | :---: |

Hex Code in: Binary Mode $=$ [A5][Encoding] Source Mode = [Encoding]

Operation: ORL
$(\mathrm{CY}) \leftarrow(\mathrm{CY}) \vee \neg$ (bit)
POP <src>
Function: Pop from stack.
Description: Reads the contents of the on-chip RAM location addressed by the stack pointer, then decrements the stack pointer by one. The value read at the original RAM location is transferred to the newly addressed location, which can be 8 -bit or 16 -bit.
Flags:

| CY | AC | OV | N | $\mathbf{Z}$ |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: The stack pointer contains 32 H and on-chip RAM locations 30 H through 32 H contain 01 H , 23 H , and 20 H , respectively. After executing the instruction sequence

POP DPH
POP DPL
the stack pointer contains 30 H and the data pointer contains 0123 H . After executing the instruction

POP SP
the stack pointer contains 20 H . Note that in this special case the stack pointer was decremented to 2 FH before it was loaded with the value popped (20H).

## Variations

POP dir8

|  | Binary Mode |  | Source Mode |  |
| :---: | :---: | :---: | :---: | :---: |
| Bytes: |  |  | 2 |  |
| States: | 3 |  | 3 |  |
| [Encoding] | 1101 |  | 00 | direct addr |
| Hex Code in: | Binary Mode $=[$ Encoding $]$ <br> Source Mode $=$ [Encoding] |  |  |  |
| Operation: | $\begin{aligned} & \text { POP } \\ & (\text { dir8 }) \leftarrow((S P)) \\ & (S P) \leftarrow(S P)-1 \end{aligned}$ |  |  |  |

POP Rm

|  | Binary Mode |  | Source Mode |  |
| :---: | :---: | :---: | :---: | :---: |
| Bytes: | 3 |  | 2 |  |
| States: | 3 |  |  |  |
| [Encoding] | 1101 | 1010 | ssss | 1000 |

Hex Code in: Binary Mode $=$ [A5][Encoding]
Source Mode $=$ [Encoding]
Operation:
POP
$(\mathrm{Rm}) \leftarrow((\mathrm{SP}))$
$(S P) \leftarrow(S P)-1$
POP WRj

| Bytes: | 3 | 2 |
| :--- | :--- | :--- |
| States: | 5 | 4 |

[Encoding]

| 1101 | 1010 |
| :--- | :--- |


| tttt | 1001 |
| :--- | :--- |

Hex Code in: Binary Mode = [A5][Encoding]
Source Mode = [Encoding]

| Operation: | POP <br> $(W R \mathrm{j}) \leftarrow((\mathrm{SP}))$ <br>  <br>  <br>  <br> $(\mathrm{SP}) \leftarrow(\mathrm{SP})-2$ |  |
| :--- | :--- | :--- |
| POP DRk |  |  |
|  |  |  |
|  |  | Binary Mode | Source Mode


| [Encoding] | 1101 | 1010 | uuuu | 1101 |
| :---: | :---: | :---: | :---: | :---: |

Hex Code in: Binary Mode $=[$ A5][Encoding $]$
Source Mode $=$ [Encoding]
Operation: POP
(DRk) $\leftarrow((S P))$
$(\mathrm{SP}) \leftarrow(\mathrm{SP})-2$
PUSH <dest>
Function: Push onto stack
Description: Increments the stack pointer by one. The contents of the specified variable are then copied into the on-chip RAM location addressed by the stack pointer.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: On entering an interrupt routine, the stack pointer contains 09 H and the data pointer contains 0123 H . After executing the instruction sequence

PUSH DPL
PUSH DPH
the stack pointer contains OBH and on-chip RAM locations OAH and OBH contain 01H and 23 H , respectively.
Variations
PUSH dir8
Binary Mode Source Mode
Bytes:
States:
2
2
4 4
[Encoding] $\square$

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode $=$ [Encoding]

| Operation: | PUSH <br> $(\mathrm{SP}) \leftarrow(\mathrm{SP})+1$ <br> $((\mathrm{SP})) \leftarrow($ dir 8$)$ |  |
| :---: | :---: | :---: |
| PUSH \#data |  |  |
|  | Binary Mode | Source Mode |
| Bytes: | 4 | 3 |
| States: | 4 | 3 |

[Encoding] \begin{tabular}{|l|l|l|}
\hline 1100 \& 1010 <br>
\hline

$\quad$

\hline 0000 <br>
\hline
\end{tabular}

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode = [Encoding]
Operation: PUSH
$(S P) \leftarrow(S P)+1$
$((S P)) \leftarrow$ \#data

## PUSH \#data16

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 5 | 4 |
| States: | 6 | 5 |

[Encoding]

| 1100 | 1010 |
| :--- | :--- | :--- | :--- |$\quad$| 0000 | 0110 |
| :--- | :--- | \#data hi  \#data lo

Hex Code in: Binary Mode = [A5][Encoding]
Source Mode = [Encoding]
Operation: PUSH
$(S P) \leftarrow(S P)+2$
$((\mathrm{SP})) \leftarrow$ \#data16
PUSH Rm

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 4 | 3 |

[Encoding]

| 1100 | 1010 |
| :--- | :--- |


| ssss | 1000 |
| :---: | :---: |

$\begin{array}{ll}\text { Hex Code in: } & \text { Binary Mode }=[\text { [55][Encoding }] \\ & \text { Source Mode }=[\text { Encoding }]\end{array}$
Operation: PUSH
$(S P) \leftarrow(S P)+1$
$((S P)) \leftarrow(R m)$

## PUSH WRj

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 5 | 4 |

[Encoding] | 1100 | 1010 |  |
| :--- | :--- | :--- |
|  | tttt | 1001 |

## Hex Code in: Binary Mode = [A5][Encoding]

 Source Mode $=$ [Encoding $]$Operation: PUSH
$(S P) \leftarrow(S P)+2$
$((S P)) \leftarrow(W R \mathrm{j})$
PUSH DRk

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 9 | 8 |

[Encoding]

| 1100 | 1010 |
| :--- | :--- |


| uuuu | 1101 |
| :---: | :---: |

Hex Code in: Binary Mode = [A5][Encoding] Source Mode $=$ [Encoding]

Operation: PUSH
$(\mathrm{SP}) \leftarrow(\mathrm{SP})+4$
$((S P)) \leftarrow(D R k)$

## RET

Function: Return from subroutine
Description: Pops the high and low bytes of the PC successively from the stack, decrementing the stack pointer by two. Program execution continues at the resulting address, which normally is the instruction immediately following ACALL or LCALL.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: The stack pointer contains 0BH and on-chip RAM locations OAH and OBH contain 01H and 23 H , respectively. After executing the instruction,

RET
the stack pointer contains 09 H and program execution continues at location 0123 H .

|  | Binary Mode1 |  | Sour |
| :---: | :---: | :---: | :---: |
| Bytes: |  |  |  |
| States: | 7 |  |  |
| [Encoding] | 0010 |  | 10 |
| Hex Code in: | Binary Mode $=[$ Encoding $]$Source Mode $=[$ Encoding $]$ |  |  |
| Operation: | RET <br> (PC). 15-8 <br> $(\mathrm{SP}) \leftarrow(\mathrm{S}$ <br> (PC).7-8 <br> $(\mathrm{SP}) \leftarrow(\mathrm{S}$ |  |  |

RETI
Function: Return from interrupt
Description: This instruction pops two or four bytes from the stack, depending on the INTR bit in the CONFIG1 register.

If INTR $=0$, RETI pops the high and low bytes of the PC successively from the stack and uses them as the 16 -bit return address in region FF:.The stack pointer is decremented by two. No other registers are affected, and neither PSW nor PSW1 is automatically restored to its pre-interrupt status.

If INTR $=1$, RETI pops four bytes from the stack: PSW1 and the three bytes of the PC. The three bytes of the PC are the return address, which can be anywhere in the 16-Mbyte memory space. The stack pointer is decremented by four. PSW1 is restored to its preinterrupt status, but PSW is not restored to its pre-interrupt status. No other registers are affected.

For either value of INTR1, hardware restores the interrupt logic to accept additional interrupts at the same priority level as the one just processed. Program execution continues at the return address, which normally is the instruction immediately after the point at which the interrupt request was detected. If an interrupt of the same or lower priority is pending when the RETI instruction is executed, that one instruction is executed before the pending interrupt is processed.
Flags:

| CY | AC | OV | N | $\mathbf{Z}$ |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: $\quad$ INTR1 $=0$. The stack pointer contains $O B H$. An interrupt was detected during the instruction ending at location 0122H. On-chip RAM locations 0AH and OBH contain 01H and 23H, respectively. After executing the instruction,

RETI
the stack pointer contains 09 H and program execution continues at location 0123H.

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 1 | 1 |
| States (INTR = 0): | 9 | 9 |
| States (INTR = 1): | 12 | 12 |

[Encoding]

| 0011 | 0010 |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding $]$
Source Mode = [Encoding]
Operation for for INTR1 $=\mathbf{0}$ :
RETI
(PC).7:0 $\leftarrow((\mathrm{SP}))$
$(\mathrm{SP}) \leftarrow(\mathrm{SP})-1$
(PC). $15: 8 \leftarrow((\mathrm{SP}))$
$(S P) \leftarrow(S P)-1$
Operation for INTR1 = $\mathbf{1}$ :
RETI
$\mathrm{X} \leftarrow((\mathrm{SP}))$
$(\mathrm{SP}) \leftarrow(\mathrm{SP})-1$
$\mathrm{X} \leftarrow((\mathrm{SP}))$
$(S P) \leftarrow(S P)-1$
$\mathrm{X} \leftarrow((\mathrm{SP}))$
$(\mathrm{SP}) \leftarrow(\mathrm{SP})-1$
$\mathrm{X} \leftarrow((\mathrm{SP}))$
$(S P) \leftarrow(S P)-1$
RL A
Function: Rotate accumulator left
Description: Rotates the eight bits in the accumulator one bit to the left. Bit 7 is rotated into the bit 0 position.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | $\checkmark$ | $\checkmark$ |

Example: The accumulator contains 0C5H (11000101B). After executing the instruction,
RLA
the accumulator contains 8BH (10001011B); the CY flag is unaffected.

## Bytes:

Binary Mode Source Mode
States:
$1 \quad 1$
$1 \quad 1$
[Encoding]

| 0010 | 0011 |
| :--- | :--- |

Hex Code in: Binary Mode $=[$ Encoding $]$
Source Mode $=$ [Encoding]
Operation: RL
(A). $a+1 \leftarrow(A) \cdot a$
(A). $0 \leftarrow$ (A). 7

## RLC A

Function: Rotate accumulator left through the carry flag
Description: Rotates the eight bits in the accumulator and the CY flag one bit to the left. Bit 7 moves into the CY flag position and the original state of the CY flag moves into bit 0 position.

## Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| $\checkmark$ | - | - | $\checkmark$ | $\checkmark$ |

Example: The accumulator contains 0C5H (11000101B) and the CY flag is clear. After executing the instruction

RLC A
the accumulator contains 8AH (10001010B) and the CY flag is set.
Binary Mode Source Mode
Bytes:
States:
$1 \quad 1$
[Encoding]

| 0011 | 0011 |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode $=$ [Encoding]
Operation: RLC
(A). $\mathrm{a}+1 \leftarrow(\mathrm{~A}) \cdot \mathrm{a}$
(A). $0 \leftarrow$ (CY)
$(C Y) \leftarrow(A) .7$
RR A
Function: Rotate accumulator right
Description: Rotates the 8 or 16 bits in the accumulator one bit to the right. Bit 0 is moved into the bit 7 or 15 position.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | $\checkmark$ | $\checkmark$ |

Example: The accumulator contains 0C5H (11000101B). After executing the instruction, RR A
the accumulator contains OE2H (11100010B) and the CY flag is unaffected.

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 1 | 1 |
| States: | 1 | 1 |

[Encoding]

| 0000 | 0011 |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode $=$ [Encoding]
Operation: RR
(A). $a \leftarrow(A) \cdot a+1$
(A). $7 \leftarrow(A) .0$

RRC A
Function: Rotate accumulator right through carry flag
Description: Rotates the eight bits in the accumulator and the CY flag one bit to the right. Bit 0 moves into the CY flag position; the original value of the CY flag moves into the bit 7 position.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| $\checkmark$ | - | - | $\checkmark$ | $\checkmark$ |

Example: The accumulator contains 0 C 5 H (11000101B) and the CY flag is clear. After executing the instruction

RRC A
the accumulator contains 62 ( 01100010 B ) and the CY flag is set.

Bytes:
Binary Mode Source Mode

States:
$1 \quad 1$
[Encoding]

| 0001 | 0011 |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding] Source Mode $=$ [Encoding]

Operation: RRC
(A). $a \leftarrow(A) \cdot a+1$
(A). $7 \leftarrow$ (CY)
(CY) $\leftarrow(A) .0$

## SETB <bit>

## Function: Set bit

Description: Sets the specified bit to one. SETB can operate on the CY flag or any directly addressable bit.

Flags: $\quad$ No flags are affected except the CY flag for instruction with CY as the operand.

| CY | AC | OV | $N$ | $Z$ |
| :---: | :---: | :---: | :---: | :---: |
| $J$ | - | - | - | - |

Example: The CY flag is clear and output Port 1 contains 34H (00110100B). After executing the instruction sequence,

SETB CY
SETB P1.0
the CY flag is set and output Port 1 contains 35H (00110101B).

## SETB bit51

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | $2 \dagger$ | $2 \dagger$ |
|  | $\dagger$ If this instruction addresses a port (Px, $x=0-3)$, add 2 states. |  |

[Encoding]

| 1101 | 0010 |
| :--- | :--- | bit addr

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode $=$ [Encoding]
Operation: SETB
$($ bit51) $\leftarrow 1$
SETB CY

|  | Binary Mode | Source |
| :--- | :---: | ---: |
| Bytes: | 1 | 1 |
| States: | 1 | 1 |

[Encoding]

| 1101 | 0011 |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding]
Source Mode $=$ [Encoding]
Operation: SETB
$(C Y) \leftarrow 1$

SETB bit

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | $4 \dagger$ | $3 \dagger$ |

$\dagger$ If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 2 states.
[Encoding]

| 1010 | 1001 | 1101 0 y y y <br> Hex Code in: Binary Mode $=[$ [A5 $]$ [Encoding $]$ <br> Source Mode $=[$ [Encoding $]$  <br> Operation: SETB addr <br> (bit) $\leftarrow 1$  |
| :---: | :---: | :---: | :---: |

SJMP rel
Function: Short jump
Description: Program control branches unconditionally to the specified address. 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.
Flags:

| CY | AC | OV | N | $\mathbf{Z}$ |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: The label "RELADR" is assigned to an instruction at program memory location 0123H. The instruction

## SJMP RELADR

assembles into location 0100 H . After executing the instruction, the PC contains 0123 H .
(Note: In the above example, the instruction following SJMP is located at 102H. Therefore, the displacement byte of the instruction is the relative offset $(0123 \mathrm{H}-0102 \mathrm{H})=21 \mathrm{H}$. Put another way, an SJMP with a displacement of OFEH would be a one-instruction infinite loop.)

Bytes:

## Binary Mode Source Mode

## States:

2
2
[Encoding]

| 1000 | 0000 |
| :--- | :--- |

rel. addr
$\begin{array}{ll}\text { Hex Code in: } & \left.\begin{array}{l}\text { Binary Mode }=[\text { Encoding }] \\ \text { Source Mode }=[\text { Encoding }\end{array}\right]\end{array}$

Operation: SJMP
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+2$
$(\mathrm{PC}) \leftarrow(\mathrm{PC})+\mathrm{rel}$
SLL <src>
Function: Shift logical left by 1 bit
Description: Shifts the specified variable to the left by 1 bit, replacing the LSB with zero.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| $\checkmark$ | - | - | $\checkmark$ | $\checkmark$ |

Example: Register 1 contains 0C5H (11000101B). After executing the instruction
SLL register 1
Register 1 contains 8AH (10001010B).
Variations
SLL Rm

| Bytes: | 3 | 2 |
| :--- | :--- | :--- |
| States: | 2 | 1 |

[Encoding]

| 0011 | 1110 |
| :--- | :--- |


| ssss | 0000 |
| :--- | :--- |

Hex Code in: Binary Mode $=[$ [A5][Encoding] Source Mode $=$ [Encoding]

Operation: SLL
$(\mathrm{Rm}) \cdot \mathrm{a}+1 \leftarrow(\mathrm{Rm}) . \mathrm{a}$
$(\mathrm{Rm}) .0 \leftarrow 0$
SLL WRj

Bytes:
Binary Mode
Source Mode
States:
2
2
1
[Encoding]

| 0011 | 1110 |
| :--- | :--- |


| tttt | 0100 |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [A5][Encoding]
Source Mode $=$ [Encoding]
Operation: SLL
(WRj). $\mathrm{b}+1 \leftarrow(\mathrm{WR} \mathrm{j}) . \mathrm{b}$
(WRj). $0 \leftarrow 0$

## SRA <src>

## Function: $\quad$ Shift arithmetic right by 1 bit

Description: Shifts the specified variable to the arithmetic right by 1 bit. The MSB is unchanged.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| $\checkmark$ | - | - | $\checkmark$ | $\checkmark$ |

Example: Register 1 contains 0C5H (11000101B). After executing the instruction
SRA register 1
Register 1 contains 0E2H (11100010B).
Variations
SRA Rm

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 2 | 1 |

[Encoding] | 0000 | 1110 |
| :--- | :--- | :--- |

| Hex Code in: | Binary Mode $=[$ A5 $][$ Encoding $]$ |
| :--- | :--- |
|  | Source Mode $=[$ Encoding $]$ |

Operation: SRA
$(R m) .7 \leftarrow(R m) .7$
$(R m) \cdot a \leftarrow(R m) \cdot a+1$
SRA WRj

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 2 | 1 |

[Encoding]

| 0000 | 1110 |
| :--- | :--- |


| $t t t t$ | 0100 |
| :--- | :--- |

Hex Code in: Binary Mode = [A5][Encoding] Source Mode $=$ [Encoding]

Operation:
SRA
(WRj). $15 \leftarrow$ (WRj). 15
$(W R \mathrm{j}) \cdot \mathrm{b} \leftarrow(\mathrm{WRj}) \cdot \mathrm{b}+1$

SRL <src>
Function: Shift logical right by 1 bit
Description: SRL shifts the specified variable to the right by 1 bit, replacing the MSB with a zero.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| $\checkmark$ | - | - | $\checkmark$ | $\checkmark$ |

Example: Register 1 contains 0C5H (11000101B). After executing the instruction
SRL register 1
Register 1 contains 62H (01100010B).
Variations
SRL Rm

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 2 | 1 |

[Encoding] | 0001 | 1110 | ssss |
| :--- | :--- | :--- |

Hex Code in: $\quad$ Binary Mode $=[$ [A5][Encoding $]$
Source Mode $=$ [Encoding]
Operation: SRL
$(\mathrm{Rm}) .7 \leftarrow 0$
$(\mathrm{Rm}) . \mathrm{a} \leftarrow(\mathrm{Rm}) \cdot \mathrm{a}+1$
SRL WRj

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 2 | 1 |

[Encoding]

| 0001 | 1110 |
| :--- | :--- |


| tttt | 0100 |
| :--- | :--- |

Hex Code in: Binary Mode $=[$ [A5][Encoding]
Source Mode $=$ [Encoding]
Operation: SRL
(WRj). $15 \leftarrow 0$
$(\mathrm{WR}) . \mathrm{b} \leftarrow(\mathrm{WRj}) . \mathrm{b}+1$

## SUB <dest>,<src>

Function: Subtract
Description: Subtracts the specified variable from the destination operand, leaving the result in the destination operand. SUB sets the CY (borrow) flag if a borrow is needed for bit 7. Otherwise, CY is clear.

When subtracting signed integers, the OV flag indicates a negative number produced when a negative value is subtracted from a positive value, or a positive result when a positive number is subtracted from a negative number.

The source operand allows four addressing modes: immediate, indirect, register and direct.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| $\checkmark$ | $\checkmark \dagger$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |

$\dagger$ For word and dword subtractions, AC is not affected.
Example: $\quad$ Register 1 contains 0 C 9 H (11001001B) and register 0 contains 54H (01010100B). After executing the instruction

SUB R1,R0
register 1 contains 75 H (01110101B), the CY and AC flags are clear, and the OV flag is set.
Variations
SUB Rmd,Rms

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 2 | 1 |

[Encoding]

| 1001 | 1100 |
| :--- | :--- |

$\square$
Hex Code in: Binary Mode $=[$ A5][Encoding $]$
Source Mode = [Encoding]
Operation: SUB
$($ Rmd $) \leftarrow($ Rmd $)-($ Rms $)$

## SUB WRjd,WRjs

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 3 | 2 |

[Encoding]

| 1001 | 1101 |
| :--- | :--- |


| tttt | TTTT |
| :--- | :--- |


| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5][Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |
| :---: | :---: | :---: |
| Operation: | $\begin{aligned} & \text { SUB } \\ & (\text { WRjd }) \leftarrow(\text { WRjd })-(\text { WRjs }) \end{aligned}$ |  |
| SUB DRkd,DRks |  |  |
|  | Binary Mode | Source Mode |
| Bytes: | 3 | 2 |
| States: | 5 | 4 |

[Encoding] | 1001 | 1111 |
| :--- | :--- | :--- |

| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |
| :---: | :---: | :---: |
| Operation: | $\begin{aligned} & \text { SUB } \\ & (\text { DRkd }) \leftarrow(\text { DRkd })- \end{aligned}$ |  |
| SUB Rm,\#data |  |  |
|  | Binary Mode | Source |
| Bytes: | 4 | 3 |
| States: | 3 | 2 |

[Encoding] | 1001 | 1110 | sss |
| :--- | :--- | :--- |

| Hex Code in: | Binary Mode $=[$ A5 $][$ Encoding $]$ |
| :--- | :--- |
|  | Source Mode $=[$ Encoding $]$ |

Operation: SUB
$(R m) \leftarrow(R m)-$ \#data
SUB WRj,\#data16

Bytes:
Binary Mode Source Mode
States:
54
[Encoding]

| 1001 | 1110 |
| :--- | :--- | :--- | :--- | :--- | :--- |$\quad$| ttt | 0100 |
| :--- | :--- | :--- |

Hex Code in: Binary Mode $=$ [A5][Encoding] Source Mode $=$ [Encoding]

Operation: SUB
$(\mathrm{WRj}) \leftarrow(\mathrm{WR} \mathrm{j})-$ \#data16

SUB DRk,\#data16

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 5 | 4 |
| States: | 6 | 5 |
| [Encoding] |  |  |


| 1001 | 1110 |
| :--- | :--- | :--- |
| uuuu | 1000 | | \#data hi | \#data low |
| :---: | :---: | :---: |

$\begin{array}{ll}\text { Hex Code in: } & \text { Binary Mode }=[\text { [A5] [Encoding }] \\ & \text { Source Mode }=[\text { Encoding }]\end{array}$
Operation: SUB
$(\mathrm{DRk}) \leftarrow(\mathrm{DRk})-$ \#data16
SUB Rm,dir8

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | $3 \dagger$ | $2 \dagger$ |

$\dagger$ If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state.

[Encoding] \begin{tabular}{|l|l|l|}
\hline 1001 \& 1110 <br>
\hline

$\quad$

\hline sss s <br>
\hline
\end{tabular}

## Hex Code in: Binary Mode = [A5][Encoding] <br> Source Mode $=$ [Encoding]

Operation: SUB
$(\mathrm{Rm}) \leftarrow(\mathrm{Rm})-($ dir8 $)$
SUB WRj,dir8

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | 4 | 3 |

[Encoding] | 1001 | 1110 | tttt |
| :--- | :--- | :--- |

Hex Code in: Binary Mode $=$ [A5][Encoding]
Source Mode $=$ [Encoding]
Operation: SUB
$(\mathrm{WRj}) \leftarrow(\mathrm{WR} \mathrm{j})-($ dir8 $)$
SUB Rm,dir16

Bytes:
Binary Mode Source Mode
States: 3
[Encoding]

| 1001 | 1110 |
| :--- | :--- |


| ssss | 0011 |
| :---: | :---: |

direct addr
direct addr

Hex Code in: Binary Mode $=$ [A5][Encoding] Source Mode $=$ [Encoding]

Operation: SUB
$(\mathrm{Rm}) \leftarrow(\mathrm{Rm})-($ dir16 $)$

## SUB WRJ,dir16

Bytes:
Binary Mode Source Mode

States: 5

4
[Encoding]

| 1001 | 1110 | ttt | 0111 | direct addr | direct addr |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | $\begin{aligned} & \text { SUB } \\ & (\text { WRj }) \leftarrow(\text { WRi })-(\text { dir16 }) \end{aligned}$ |  |  |  |  |

SUB Rm, @WRj

Bytes:
Binary Mode Source Mode

States:
4
3
[Encoding]

| 1001 | 1110 |
| :--- | :--- | :--- | :--- |$\quad$| ttt | 1001 |
| :---: | :---: | :---: |

Hex Code in: Binary Mode $=[$ [A5][Encoding]
Source Mode = [Encoding]

Operation: SUB
$(R m) \leftarrow(R m)-((W R \mathrm{j}))$

## SUB Rm, @DRk

Bytes:
States:
[Encoding]

| 1001 | 1110 |
| :---: | :---: | :---: | | uuuu | 1011 |
| :---: | :---: |


| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }] \text { [Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |
| :---: | :---: |
| Operation: | $\begin{aligned} & \text { SUB } \\ & (\mathrm{Rm}) \leftarrow(\mathrm{Rm})-((\mathrm{DRk})) \end{aligned}$ |
| SUBB A,<src-byte> |  |
| Function: | Subtract with borrow |
| Description: | SUBB subtracts the specified variable and the CY flag together from the accumulator, leaving the result in the accumulator. SUBB sets the CY (borrow) flag if a borrow is needed for bit 7, and clears CY otherwise. (If CY was set before executing a SUBB instruction, this indicates that a borrow was needed for the previous step in a multiple precision subtraction, so the CY flag is subtracted from the accumulator along with the source operand.) AC is set if a borrow is needed for bit 3 , and cleared otherwise. OV is set if a borrow is needed into bit 6 , but not into bit 7 , or into bit 7 , but not bit 6 . <br> When subtracting signed integers the OV flag indicates a negative number produced when a negative value is subtracted from a positive value, or a positive result when a positive number is subtracted from a negative number. |
|  | The source operand allows four addressing modes: register, direct, register-indirect, or immediate. |

Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |

Example: $\quad$ The accumulator contains 0 C 9 H (11001001B), register 2 contains 54 H (01010100B), and the CY flag is set. After executing the instruction

SUBB A,R2
the accumulator contains 74 H ( 01110100 B ), the CY and AC flags are clear, and the OV flag is set.

Notice that 0 C 9 H minus 54 H is 75 H . The difference between this and the above result is due to the CY (borrow) flag being set before the operation. If the state of the carry is not known before starting a single or multiple-precision subtraction, it should be explicitly cleared by a CLR CY instruction.

## Variations

SUBB A,\#data

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | 1 | 1 |

[Encoding]

| 1001 | 0100 |
| :--- | :--- |

immed. data

Hex Code in: Binary Mode = [Encoding]
Source Mode $=$ [Encoding]

| Operation: | SUBB $(A) \leftarrow(A)-(C Y)-\text { \#data }$ |
| :---: | :---: |
| SUBB A,dir8 |  |
|  | Binary Mode Source Mode |
| Bytes: | 22 |
| States: | $1 \dagger$ 1 $\dagger$ |
|  | $\dagger$ If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 1 state. |
| [Encoding] | 1001 0101 ${ }^{\text {l }}$ direct addr |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |
| Operation: | SUBB $(A) \leftarrow(A)-(C Y)-(\text { dir8) }$ |
| SUBB A,@Ri |  |
|  | Binary Mode Source Mode |
| Bytes: | 2 |
| States: | 23 |
| [Encoding] | 1001 011i |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { Encoding }] \\ & \text { Source Mode }=[\text { A5][Encoding }] \end{aligned}$ |
| Operation: | SUBB $(A) \leftarrow(A)-(C Y)-((R i))$ |
| SUBB A,Rn |  |
|  | Binary Mode Source Mode |
| Bytes: | 12 |
| States: | 12 |
| [Encoding] | 1001 1rrr |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { Encoding }] \\ & \text { Source Mode }=[\text { [5] }] \text { Encoding }] \end{aligned}$ |
| Operation: | SUBB $(A) \leftarrow(A)-(C Y)-(R n)$ |

$(A) \leftarrow(A)-(C Y)-(R n)$

## SWAP A

Function: Swap nibbles within the accumulator
Description: Interchanges the low and high nibbles (4-bit fields) of the accumulator (bits 3-0 and bits 74). This operation can also be thought of as a 4-bit rotate instruction.

## Flags:

| CY | AC | OV | N | $\mathbf{Z}$ |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: The accumulator contains 0C5H (11000101B). After executing the instruction
SWAP A
the accumulator contains 5CH (01011100B).

|  | Binary Mode | Source |
| :--- | :---: | ---: |
| Bytes: | 1 | 1 |
| States: | 2 | 2 |

[Encoding]

| 1100 | 0100 |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding] Source Mode $=$ [Encoding]

Operation:
SWAP
(A).3:0 $\rightarrow \leftarrow$ (A).7:4

TRAP
Function: Causes interrupt call
Description: Causes an interrupt call that is vectored through location 0FF007BH. The operation of this instruction is not affected by the state of the interrupt enable flag in PSW0 and PSW1. Interrupt calls can not occur immediately following this instruction. This instruction is intended for use by Intel-provided development tools. These tools do not support user application of this instruction.
Flags:

| CY | AC | OV | N | $\mathbf{Z}$ |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: The instruction
TRAP
causes an interrupt call to location OFF007BH during normal operation.

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 1 |
| States (2 bytes): | 11 | 10 |
| States (4 bytes): | 16 | 15 |

[Encoding] | 1011 | 1001 |
| :--- | :--- |
|  |  |

Hex Code in: Binary Mode $=$ [A5][Encoding] Source Mode $=$ [Encoding]

Operation: TRAP
$S P \leftarrow S P-2$
$(S P) \leftarrow P C$
$\mathrm{PC} \leftarrow(0 \mathrm{FF} 007 \mathrm{BH})$
XCH A,<byte>
Function: Exchange accumulator with byte variable
Description: Loads the accumulator with the contents of the specified variable, at the same time writing the original accumulator contents to the specified variable. The source/destination operand can use register, direct, or register-indirect addressing.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: $\quad$ RO contains the address 20H, the accumulator contains 3FH (00111111B) and on-chip RAM
location 20 H contains $75 \mathrm{H}(01110101 \mathrm{~B})$. After executing the instruction

XCH A, @RO
RAM location 20 H contains 3 FH ( 00111111 B ) and the accumulator contains 75 H (01110101B).
Variations
XCH A,dir8

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | $3 \dagger$ | $3 \dagger$ |
|  | $\dagger \mid f$ this instruction addresses a port $(P x, x=0-3)$, add 2 states. |  |

[Encoding]

| 1100 | 0101 |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding $]$ Source Mode $=$ [Encoding]

Operation: XCH
(A) $\rightarrow \leftarrow$ (dir8)
$\mathbf{X C H} \mathbf{A , @ R i}$

|  | Binary Mode <br> Bytes: |  |
| :--- | :--- | ---: |
| States: | 1 |  |
| Source Mode |  |  |

[Encoding] | 1100 | 1 rrr |
| :---: | :---: |

Hex Code in: Binary Mode $=$ [Encoding $]$ Source Mode = [A5][Encoding]

Operation: XCH
(A) $\rightarrow \leftarrow(\mathrm{Rn})$

Variations
XCHD A,@Ri
Function: Exchange digit
Description: Exchanges the low nibble of the accumulator (bits 3-0), generally representing a hexadecimal or BCD digit, with that of the on-chip RAM location indirectly addressed by the specified register. Does not affect the high nibble (bits 7-4) of either register.
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - |

Example: $\quad$ RO contains the address 20 H , the accumulator contains 36 H (00110110B), and on-chip RAM location 20 H contains 75 H ( 01110101 B ). After executing the instruction,

XCHD A, @RO
on-chip RAM location 20 H contains 76 H ( 01110110 B ) and 35H ( 00110101 B ) in the accumulator.

## Binary Mode Source Mode

| Bytes: | 1 | 2 |
| :--- | :--- | :--- |
| States: | 4 | 5 |

[Encoding] | 1101 | 011 i |
| :---: | :---: |

Hex Code in: Binary Mode = [Encoding] Source Mode $=$ [Encoding]

Operation: XCHD
$(\mathrm{A}) .3: 0 \rightarrow \leftarrow((\mathrm{Ri})) .3: 0$
XRL <dest>,<src>
Function: Logical Exclusive-OR for byte variables
Description: Performs the bitwise logical Exclusive-OR operation $(\forall)$ between the specified variables, storing the results in the destination. The destination operand can be the accumulator, a register, or a direct address.

The two operands allow 12 addressing mode combinations. When the destination is the accumulator or a register, the source addressing can be register, direct, register-indirect, or immediate; 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 is read from the output data latch, not the input pins.)
Flags:

| CY | AC | OV | N | Z |
| :---: | :---: | :---: | :---: | :---: |
| - | - | - | $\checkmark$ | $\checkmark$ |

Example: The accumulator contains OC3H (11000011B) and RO contains OAAH (10101010B). After executing the instruction,

XRL A,RO
the accumulator contains 69H (01101001B).
When the destination is a directly addressed byte, this instruction can complement combinations of bits in any RAM location or hardware register. The pattern of bits to be complemented is then determined by a mask byte, either a constant contained in the instruction or a variable computed in the accumulator at run time. The instruction

XRL P1,\#00110001B
complements bits 5, 4, and 0 of output Port 1.

Variations
XRL dir8,A

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | $2 \dagger$ | $2 \dagger$ |

$\dagger$ If this instruction addresses a port ( $\mathrm{P} x, x=0-3$ ), add 2 states.
[Encoding]

| 0110 | 0010 |
| :--- | :--- |

direct addr

Hex Code in: Binary Mode $=$ [Encoding $]$
Source Mode $=$ [Encoding]
Operation: XRL
$($ dir8) $\leftarrow($ dir8) $\forall(A)$
XRL dir8,\#data

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 3 |
| States: | $3 \dagger$ | $3 \dagger$ |
|  | $\dagger \mid$ this instruction addresses a port $(P x, x=0-3)$, add 1 state. |  |

[Encoding] | 0110 | 0011 |
| :--- | :--- | :--- |

| Hex Code in: | $\left.\begin{array}{l}\text { Binary Mode }=[\text { Encoding }] \\ \\ \text { Source Mode }=[\text { Encoding }]\end{array}\right]$ |
| :--- | :--- |

Operation: XRL
$($ dir8) $\leftarrow($ dir8) $\forall$ \#data
XRL A,\#data

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | 1 | 1 |

[Encoding] | 0110 | 0100 |
| :--- | :--- |$\quad$ immed. data

Hex Code in: Binary Mode $=$ [Encoding $]$
Source Mode $=$ [Encoding]
Operation: XRL
$(A) \leftarrow(A) \forall$ \#data

XRL A,dir8

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 2 | 2 |
| States: | $1 \dagger$ | $1 \dagger$ |
|  | $\dagger$ lf this instruction addresses a port $(\mathrm{P} x, x=0-3)$, add 1 state. |  |

[Encoding] | 0110 | 0101 |
| :--- | :--- |

## Hex Code in: Binary Mode $=$ [Encoding] Source Mode = [Encoding]

Operation: XRL
$(A) \leftarrow(A) \forall($ dir 8$)$
XRL A,@Ri

Bytes:
Binary Mode Source Mode
States:
23
[Encoding]

| 0110 | $011 i$ |
| :--- | :--- |

Hex Code in: Binary Mode $=$ [Encoding $]$
Source Mode = [A5][Encoding]
Operation: XRL
$(A) \leftarrow(A) \forall((\mathrm{Ri}))$
XRL A,Rn

## Bytes:

States:

Binary Mode
Source Mode
1
2
2
[Encoding]

| 0110 | 1 rrr |
| :--- | :--- |

Hex Code in: Binary Mode $=[$ Encoding $]$
Source Mode = [A5][Encoding]
Operation: XRL
$(A) \leftarrow(A) \forall(R n)$
XRL Rmd,Rms

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 3 | 2 |
| States: | 2 | 1 |

[Encoding]

| 0110 | 1100 |
| :--- | :--- |


| ssss | ssss |
| :---: | :---: |


| Hex Code in: | Binary Mode $=[$ A5][Encoding $]$ <br> Source Mode $=[$ Encoding $]$ |
| :--- | :--- |
| Operation: | XRL <br> $($ Rmd $) \leftarrow($ Rmd $) \forall($ Rms $)$ |
| XRL WRjd,WRjs |  |
|  |  |
| Bytes: | Binary Mode |


| [Encoding] | 0110 | 1101 | ttt | TTTT |
| :---: | :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |
| Operation: | $\begin{aligned} & \text { XRL } \\ & (\text { WRds }) \leftarrow(\text { WRjd) } \forall(W R \mathrm{js}) \end{aligned}$ |  |  |  |

XRL Rm,\#data

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | 3 | 2 |

[Encoding] | 0110 | 1110 |  |
| :--- | :--- | :--- |
|  | ssss | 0000 |

Hex Code in: Binary Mode $=[$ [A5][Encoding]
Source Mode = [Encoding]

Operation: XRL
$(\mathrm{Rm}) \leftarrow(\mathrm{Rm}) \forall$ \#data

## XRL WRj,\#data16

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 5 | 4 |
| States: | 4 | 3 |
| [Encoding] |  |  |


| 0110 | 1110 tttt | 0100 | \#data hi | \#data low |
| :---: | :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5] [Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |
| Operation: | XRL <br> $(\mathrm{WRj}) \leftarrow(\mathrm{WRj}) \forall$ \#data16 |  |  |  |

XRL Rm,dir8

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | $3 \dagger$ | $2 \dagger$ |

$\dagger$ tf this instruction addresses a port ( $\mathbf{P} x, x=0-3$ ), add 1 state.

| [Encoding] | 0110 | 1110 | ssss | 0001 | direct addr |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | XRL $(R m) \leftarrow(R n$ |  |  |  |  |

XRL WRj,dir8

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | 4 | 3 |


| [Encoding] | 0110 | 1110 | tttt | 0101 | direct addr |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |  |
| Operation: | XRL <br> $(\mathrm{WRj}) \leftarrow(\mathrm{WRj}) \forall($ dir8 $)$ |  |  |  |  |

XRL Rm,dir16

## Bytes:

Binary Mode Source Mode

States:
54
[Encoding]

| 0110 | 1110 | sss | 0011 |
| :--- | :--- | :--- | :--- |

$\begin{array}{ll}\text { Hex Code in: } & \begin{array}{l}\text { Binary Mode }=[\text { A5][Encoding }] \\ \\ \text { Source Mode }=[\text { Encoding }]\end{array}\end{array}$ Source Mode = [Encoding]

Operation: XRL
$(R m) \leftarrow(R m) \forall($ dir16 $)$

XRL WRj,dir16

Binary Mode
Bytes:
States:

5
4

Source Mode
4
3
[Encoding]

| 0110 | $1110 \quad \mathrm{tttt}$ | 0111 | direct addr | direct addr |
| :---: | :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5] [Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |
| Operation: | $\begin{aligned} & \mathrm{XRL} \\ & (\mathrm{WR} \mathrm{j}) \leftarrow(\mathrm{WR} \mathrm{j}) \forall(\operatorname{dir} 16) \end{aligned}$ |  |  |  |

XRL Rm, @Wrj

Bytes:
Binary Mode Source Mode

States:

4
3

3
2
[Encoding]

| 0110 | 1110 tttt | 1001 | ssss | 0000 |
| :---: | :---: | :---: | :---: | :---: |
| Hex Code in: | $\begin{aligned} & \text { Binary Mode }=[\text { A5 }][\text { Encoding }] \\ & \text { Source Mode }=[\text { Encoding }] \end{aligned}$ |  |  |  |
| Operation: | XRL $(\mathrm{Rm}) \leftarrow(\mathrm{Rm}) \forall((\mathrm{WR} \mathrm{j}))$ |  |  |  |

## XRL Rm,@Drk

|  | Binary Mode | Source Mode |
| :--- | :---: | :---: |
| Bytes: | 4 | 3 |
| States: | 4 | 3 |

[Encoding]

| 0110 | 1110 |
| :---: | :---: | :---: | :---: |$\quad$| uuuu | 1011 |
| :---: | :---: |

Hex Code In: Binary Mode $=$ [A5][Encoding]
Source Mode $=$ [Encoding]
Operation: XRL
$(R m) \leftarrow(R m) \forall((D R k))$

## inted.



## Signal Descriptions

## APPENDIX B SIGNAL DESCRIPTIONS

This appendix provides reference information for the pin functions of the 8XC251SB. Table B-1 lists the signals, grouped by function. Table B-2 defines the columns used in Table B-3, which describes the signals.

Table B-1. Signals Arranged by Functional Categories

| Address \& Data |
| :--- |
| Name |
| AD0/P0.0 |
| AD1/P0.1 |
| AD2/P0.2 |
| AD3/P0.3 |
| AD4/P0.4 |
| AD5/P0.5 |
| AD6/P0.6 |
| AD7/P0.7 |
| A8/P2.0 |
| A9/P2.1 |
| A10/P2.2 |
| A11/P2.3 |
| A12/P2.4 |
| A13/P2.5 |
| A14/P2.6 |
| A15/P2.7 |


| Input/Output |
| :--- |
| Name |
| T2/P1.0 |
| T2EX/P1.1 |
| ECI/P1.2 |
| CEX0/P1.3 |
| CEX1/P1.4 |
| CEX2/P1.5 |
| CEX3/P1.6 |
| CEX4/P1.7 |
| RXD/P3.0 |
| TXD/P3.1 |
| T0/P3.4 |
| T1/P3.5 |


| Processor Control |
| :--- |
| Name |
| INTO\#/P3.2 |
| INT1\#/P3.3 |
| EA\# $N_{\text {PP }}$ |
| RST |
| XTAL1 |
| XTAL2 |


| Power \& Ground |
| :--- |
| Name |
| $\mathrm{V}_{\mathrm{cc}}$ |
| $\mathrm{V}_{\mathrm{cc} 2}$ |
| $\mathrm{~V}_{\mathrm{ss}}$ |
| $\mathrm{V}_{\mathrm{ss} 1}$ |
| $\mathrm{~V}_{\mathrm{ss} 2}$ |


| Bus Control \& Status |
| :--- |
| Name |
| WR\#/P3.6 |
| RD\#/P3.7 |
| ALE/PROG\# |
| PSEN\# |

Table B-2. Description of Columns of Table B-3

| Column Heading | Description |
| :--- | :--- |
| Signal Name | Lists the signals, arranged alphabetically. Many pins have two functions, so <br> there are more entries in this column than there are pins. Every signal is <br> listed in this column; for each signal, the alternate function that shares the <br> pin is listed in the Multiplexed With column. |
| Type | Identifies the pin function listed in the Signal Name column as an input (I), <br> output (O), bidirectional (I/O), power (PWR), or ground (GND). <br> Note that all inputs except RESET\# are sampled inputs. RESET\# is a level- <br> sensitive input. During powerdown mode, the powerdown circuitry uses <br> EXTINTxas a level-sensitive input. |
| Description | Briefly describes the function of the pin for the specific signal listed in the <br> Signal Name column. |
| Multiplexed With | Lists the multiplexed signal name for the alternate function that the pin <br> provides (if applicable). |

Table B-3. Signal Descriptions

| Signal <br> Name | Type | $\quad$Description | Multiplexed <br> With |
| :--- | :---: | :--- | :--- |
| A16 | O | Address Line 16. See RD\#. | N.A. |
| A15:8t | O | Address Lines. Upper address lines for the external bus. | P2.7:0 |
| AD7:0† | I/O | Address/Data Lines. Multiplexed lower address lines and data lines for <br> external memory. | P0.7:0 |
| ALE | O | Address Latch Enable. ALE signals the start of an external bus cycle <br> and indicates that valid address information is available on lines A15:8 <br> and AD7:0. An external latch can use ALE to demultiplex the address <br> from the address/data bus. | PROG\# |
| CEX4:0 | I/O | Programmable Counter Array (PCA) Input/Output Pins. These are <br> input signals for the PCA capture mode and output signals for the PCA <br> compare mode and PCA PWM mode. | P1.7:3 |
| EA\# | I | External Access. Directs program memory accesses to on-chip or off- <br> chip code memory. For EA\# = 0, all program memory accesses are off- <br> chip. For EA\# = 1, an access is to on-chip OTPROM/ROM if the <br> address is within the range of the on-chip OTPROM/ROM; otherwise <br> the access is off-chip. The value of EA\# is latched at reset. For a <br> ROMless part, EA\# must be strapped to ground. |  |
| EC1 | I | PCA External Clock Input. External clock input to the 16-bit PCA timer. | P1.2 |
| INT1:0\# | I | External Interrupts 0 and 1. These inputs set bits IE1:0 in the TCON <br> register. If bits IT1:0 in the TCON register are set, bits IE1:0 are set by a <br> falling edge on INT1\#/NTO\#. If bits INT1:0 are clear, bits IE1:0 are set <br> by a low level on INT1:O\#. | P3.3:2 |

†The descriptions of A15:8/P2.7:0 and AD7:0/P0.7:0 are for the nonpage-mode chip configuration (compatible with PLCC MCS 51 microcontrollers). If the chip is configured for page-mode operation, port 0 carries the lower address bits (A0-A7), and port 2 carries the upper address bits (A8-A15) and the data (D0-D7).

SIGNAL DESCRIPTIONS

Table B-3. Signal Descriptions (Continued)

| Signal Name | Type | Description | Multiplexed With |
| :---: | :---: | :---: | :---: |
| P0.7:0 | I/O | Port 0 . This is an 8 -bit, open-drain, bidirectional I/O port. | AD7:0 |
| P1.0 <br> P1. 1 <br> P1.2 <br> P1.7:3 | I/O | Port 1. This is an 8-bit, bidirectional I/O port with internal pullups. | T2 <br> T2EX ECI CEX4:0 |
| P2.7:0 | 1/0 | Port 2. This is an 8-bit, bidirectional I/O port with internal pullups. | A15:8 |
| P3.0 <br> P3. 1 <br> P3.3:2 <br> P3.5:4 <br> P3.6 <br> P3. 7 | I/O | Port 3. This is an 8-bit, bidirectional I/O port with internal pullups. | RXD <br> TXD <br> INT1:0\# <br> T1:0 <br> WR\# <br> RD\# |
| PROG\# | 1 | Programming Pulse. The programming pulse is applied to this pin for programming the on-chip OTPROM. | ALE |
| PSEN\# | 0 | Program Store Enable. Read signal output. This output is asserted for a memory address range that depends on bits RD0 and RD1 in configuration byte CONFIG1 (see also RD\#): <br> RD1RDOAddress Range for Assertion <br> 00Reserved <br> 01All addresses <br> 10All addresses <br> 11All addresses $\geq 80: 0000 \mathrm{H}$ | - |
| RD\# | 0 | Read or 17th Address Bit (A16). Read signal output to external data memory or 17th external address bit (A16), depending on the values of bits RD0 and RD1 in configuration byte CONFIG1. (See also PSEN\#): <br> RD1RD0Function <br> 00Reserved <br> 01The pin functions as A16 only. <br> 10The pin functions as P3.7 only. <br> 11RD\#: asserted for reads at all addresses $\leq 7 F$ :FFFFH | P3.7 |
| RST | 1 | Reset. Reset input to the chip. Holding this pin high for 64 oscillator periods while the oscillator is running resets the device. The port pins are driven to their reset conditions when a voltage greater than $\mathrm{V}_{\mathrm{IH}_{1}}$ is applied, whether or not the oscillator is running. This pin has an internal pulldown resistor, which allows the device to be reset by connecting a capacitor between this pin and $\mathrm{V}_{\mathrm{CC}}$. <br> Asserting RST when the chip is in idle mode or powerdown mode returns the chip to normal operation. | - |
| RXD | 1/0 | Receive Serial Data. RXD sends and receives data in serial I/O mode 0 and receives data in serial I/O modes 1,2 , and 3 . | P3.0 |
| T1:0 | 1 | Timer 1:0 External Clock Inputs. When timer 1:0 operates as a counter, a falling edge on the $\mathrm{T} 1: 0$ pin increments the count. | P3.5:4 |

${ }^{\dagger}$ The descriptions of A15:8/P2.7:0 and AD7:0/P0.7:0 are for the nonpage-mode chip configuration (compatible with PLCC MCS 51 microcontrollers). If the chip is configured for page-mode operation, port 0 carries the lower address bits (A0-A7), and port 2 carries the upper address bits (A8-A15) and the data (D0-D7).

Table B-3. Signal Descriptions (Continued)

| Signal Name | Type | Description | Multiplexed With |
| :---: | :---: | :---: | :---: |
| T2 | I/O | Timer 2 Clock Input/Output. For the timer 2 capture mode, this signal is the external clock input. For the clock-out mode, it is the timer 2 clock output. | P1.0 |
| T2EX | 1 | Timer 2 External Input. In timer 2 capture mode, a falling edge initiates a capture of the timer 2 registers. In auto-reload mode, a falling edge causes the timer 2 registers to be reloaded. In the up-down counter mode, this signal determines the count direction: $1=u p, 0=$ down. | P1.1 |
| TXD | 0 | Transmit Serial Data. TXD outputs the shift clock in serial I/O mode 0 and transmits serial data in serial I/O modes 1,2 , and 3 . | P3.1 |
| $\mathrm{V}_{\mathrm{cc}}$ | PWR | Supply Voltage. Connect this pin to the +5 V supply voltage. | - |
| $\mathrm{V}_{\text {cc2 }}$ | PWR | Secondary Supply Voltage 2. This supply voltage connection is provided to reduce power supply noise. Connection of this pin to the +5 V supply voltage is recommended. However, when using the 8XC251SB as a pin-for-pin replacement for the $8 \mathrm{XC} 51 \mathrm{FX}, \mathrm{V}_{\text {ss2 }}$ can be unconnected without loss of compatibility. | - |
| $\mathrm{V}_{\mathrm{PP}}$ | 1 | Programming Supply Voltage. The programming supply voltage is applied to this pin for programming the on-chip OTPROM. | EA\# |
| $\mathrm{V}_{\text {ss }}$ | GND | Circuit Ground. Connect this pin to ground. | - |
| $\mathrm{V}_{\text {ss1 }}$ | GND | Secondary Ground. This ground is provided to reduce ground bounce and improve power supply bypassing. Connection of this pin to ground is recommended. However, when using the 8XC251SB as a pin-for-pin replacement for the $8 \mathrm{XC} 51 \mathrm{BH}, \mathrm{V}_{\mathrm{ss} 1}$ can be unconnected without loss of compatibility. | - |
| $\mathrm{V}_{\text {ss2 }}$ | GND | Secondary Ground 2. This ground is provided to reduce ground bounce and improve power supply bypassing. Connection of this pin to ground is recommended. However, when using the 8XC251SB as a pin-for-pin replacement for the $8 \mathrm{XC} 51 \mathrm{FX}, \mathrm{V}_{\text {ss2 }}$ can be unconnected without loss of compatibility. | - |
| WR\# | 0 | Write. Write signal output to external memory. For configuration bits RD1 $=$ RD0 $=1$, WR\# is strobed only for writes to locations $000000 \mathrm{H}-$ 01 FFFFH. For other values of RD1 and RD0, WR\# is strobed for writes to all memory locations. | P3.6 |
| XTAL1 | 1 | Input to the On-chip, Inverting, Oscillator Amplifier. To use the internal oscillator, a crystal/resonator circuit is connected to this pin. If an external oscillator is used, its output is connected to this pin. XTAL1 is the clock source for internal timing. | - |
| XTAL2 | 0 | Output of the On-chip, Inverting, Oscillator Amplifier. To use the internal oscillator, a crystal/resonator circuit is connected to this pin. If an external oscillator is used, leave XTAL2 unconnected. | - |

${ }^{\dagger}$ The descriptions of A15:8/P2.7:0 and AD7:0/P0.7:0 are for the nonpage-mode chip configuration (compatible with PLCC MCS 51 microcontrollers). If the chip is configured for page-mode operation, port 0 carries the lower address bits (A0-A7), and port 2 carries the upper address bits (A8-A15) and the data (D0-D7).

## inte.

Registers

REGISTERS
APPENDIX C REGISTERS

Table C-1. 8XC251SB Special Function Registers (SFRs)

| SFR <br> Mnemonic | SFR Name | Hex Address | Binary Reset Value |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | High | Low |
| ACC ${ }^{\dagger}$ | Accumulator | S:EOH | 0000 | 0000 |
| ${ }^{\text {¢ }}$ | B Register | S:FOH | 0000 | 0000 |
| CCAPOH | PCA Module 0 Compare/Capture Register High Byte | S:FAH | XXXX | XXXX |
| CCAPOL | PCA Module 0 Compare/Capture Register Low Byte | S:EAH | XXXX | XXXX |
| CCAP1H | PCA Module 1 Compare/Capture Register High Byte | S:FBH | XXXX | XXXX |
| CCAP1L | PCA Module 1 Compare/Capture Register Low Byte | S:EBH | XXXX | XXXX |
| CCAP2H | PCA Module 2 Compare/Capture Register High Byte | S:FCH | XXXX | XXXX |
| CCAP2L | PCA Module 2 Compare/Capture Register Low Byte | S:ECH | XXXX | XXXX |
| CCAP3H | PCA Module 3 Compare/Capture Register High Byte | S:FDH | XXXX | XXXX |
| CCAP3L | PCA Module 3 Compare/Capture Register Low Byte | S:EDH | XXXX | XXXX |
| CCAP4H | PCA Module 4 Compare/Capture Register High Byte | S:FEH | XXXX | XXXX |
| CCAP4L | PCA Module 4 Compare/Capture Register Low Byte | S:EEH | XXXX | XXXX |
| CCAPM0 | PCA Compare/Capture Module 0 Mode Register | S:DAH | X000 | 0000 |
| CCAPM 1 | PCA Compare/Capture Module 1 Mode Register | S:DBH | X000 | 0000 |
| CCAPM2 | PCA Compare/Capture Module 2 Mode Register | S:DCH | X000 | 0000 |
| CCAPM3 | PCA Compare/Capture Module 3 Mode Register | S:DDH | X000 | 0000 |
| CCAPM4 | PCA Compare/Capture Module 4 Mode Register | S:DEH | X000 | 0000 |
| CCON | PCA Timer/Counter Control Register | S:D8H | 00X0 | 0000 |

${ }^{\dagger}$ This register resides in the register file. It can also be accessed as an SFR.

Table C-1. 8XC251SB Special Function Registers (SFRs)

| SFR <br> Mnemonic | SFR Name | Hex Address | Binary Reset Value |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | High | Low |
| CH | PCA Timer/Counter High Byte | S:F9H | 0000 | 0000 |
| CL | PCA Timer/Counter Low Byte | S:E9H | 0000 | 0000 |
| CMOD | PCA Timer/Counter Mode Register | S:D9H | 00XX | X000 |
| $\mathrm{DPH}^{\dagger}$ | Data Pointer High | S:83H | 0000 | 0000 |
| DPL ${ }^{\text { }}$ | Data Pointer Low | S:82H | 0000 | 0000 |
| DPXL ${ }^{\dagger}$ | Data Pointer Extended Low | S:84H | 0000 | 0001 |
| IEO | Interrupt Enable Control Register 0 | S:A8H | 0000 | 0000 |
| IPHO | Interrupt Priority High Control Register 0 | $\mathrm{S}: \mathrm{B7H}$ | X000 | 0000 |
| IPLO | Interrupt Priority Low Control Register 0 | $\mathrm{S}: \mathrm{B8H}$ | X000 | 0000 |
| P0 | Port 0 | $\mathrm{S}: 80 \mathrm{H}$ | 1111 | 1111 |
| P1 | Port 1 | $\mathrm{S}: 90 \mathrm{H}$ | 1111 | 1111 |
| P2 | Port 2 | $\mathrm{S}: \mathrm{AOH}$ | 1111 | 1111 |
| P3 | Port 3 | $\mathrm{S}: \mathrm{BOH}$ | 1111 | 1111 |
| PCON | Power Control Register | S:87H | 00XX | 0000 |
| PSW | Program Status Word | $\mathrm{S}: \mathrm{DOH}$ | 0000 | 0000 |
| PSW1 | Program Status Word 1 | S:D1H | 0000 | 0000 |
| RCAP2H | Timer 2 Reload/Capture Register High Byte | S :CBH | 0000 | 0000 |
| RCAP2L | Timer 2 Reload/Capture Register Low Byte | S:CAH | 0000 | 0000 |
| SADDR | Slave Individual Address Register | S:A9H | 0000 | 0000 |
| SADEN | Mask Byte Register | $\mathrm{S}: \mathrm{B9H}$ | 0000 | 0000 |
| SBUF | Serial Data Buffer | S:99H | XXXX | XXXX |
| SCON | Serial Control Register | $\mathrm{S}: 98 \mathrm{H}$ | 0000 | 0000 |
| SP ${ }^{\dagger}$ | Stack Pointer - LS byte of SPX | $\mathrm{S}: 81 \mathrm{H}$ | 0000 | 0111 |
| SPH ${ }^{+}$ | Stack Pointer High - MSB of SPX | S:BDH | 0000 | 0000 |
| T2CON | Timer 2 Control Register | $\mathrm{S}: \mathrm{C8H}$ | 0000 | 0000 |
| T2MOD | Timer 2 Mode Control Register | $\mathrm{S}: \mathrm{C9H}$. | XXXX | XX00 |
| TCON | Timer 0/1 Control Register | $\mathrm{S}: 88 \mathrm{H}$ | 0000 | 0000 |
| TMOD | Timer 0/1 Mode Control Register | S:89H | 0000 | 0000 |
| THO | Timer 0 Timer Register High Byte | $\mathrm{S}: 8 \mathrm{CH}$ | 0000 | 0000 |
| TLO | Timer 0 Timer Register Low Byte | S:8AH | 0000 | 0000 |

[^3]REGISTERS

Table C-1. 8XC251SB Special Function Registers (SFRs)

| SFR Mnemonic | SFR Name | Hex Address | Binary Reset Value |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | High | Low |
| TH1 | Timer 1 Timer Register High Byte | S:8DH | 0000 | 0000 |
| TL1 | Timer 1 Timer Register Low Byte | S:8BH | 0000 | 0000 |
| TH2 | Timer 2 Timer Register High Byte | S:CDH | 0000 | 0000 |
| TL2 | Timer 2 Timer Register Low Byte | $\mathrm{S}: \mathrm{CCH}$ | 0000 | 0000 |
| WDTRST | Watchdog Timer Reset Register | S:A6H | XXXX | XXXX |

${ }^{\dagger}$ This register resides in the register file. It can also be accessed as an SFR.

$$
\begin{array}{rr}
\hline \text { Address: } & \text { EOH } \\
\text { Reset State: } & 0000 \text { 0000B }
\end{array}
$$

Accumulator. ACC provides SFR access to the accumulator, which resides in the register file as byte register R11 (also named ACC). Instructions in the MCS ${ }^{\circledR} 51$ architecture use the accumulator as both source and destination for calculations and moves. Instructions in the MCS 251 architecture assign no special significance to R11. These instructions can use byte registers Rm ( $m=0-15$ ) interchangeably. 7

| name. 7 | name. 6 | name. 5 | name. 4 | name. 3 | name. 2 | name. 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | name. 0


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :--- | :---: | :--- |
| $7: 0$ | ACC.7:0 | Accumulator. |

B | Address: | FOH |
| ---: | :--- |
| Reset State: |  |
| 00000000 B |  |

$B$ Register. The B register provides SFR access to byte register R10 (also named B) in the register file. The B register is used as both a source and destination in multiply and divide operations. For all other operations, the $B$ register is available for use as one of the byte registers $\mathrm{Rm}, \mathrm{m}=0-15$.
7

| name. 7 | name. 6 | name. 5 | name. 4 | name. 3 | name. 2 | name. 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | name. 0


| Bit <br> Number | Bit <br> Mnemonic |  | Function |
| :--- | :--- | :--- | :--- |
| $7: 0$ | B.7:0 | B Register. |  |

CCAPxH, CCAPxL ( $x=0-4$ )
Address: CCAPOH,L S:FAH, S:EAH CCAP1H,L S:FBH, S:EBH CCAP2H,L S:FCH, S:ECH
CCAP3H,L S:FDH, S:EDH
CCAP4H,L S:FEH, S:EEH
Reset State: XXXX XXXXB
PCA Module Compare/Capture Registers. These five register pairs store the 16 -bit comparison value or captured value for the corresponding compare/capture modules. In the PWM mode, the low-byte register controls the duty cycle of the output waveform.


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :--- | :---: | :--- |
| 7:0 | CCAPxH.7:0 <br> CCAPXL.7:0 | High byte of PCA comparison or capture values. <br> Low byte of PCA comparison or capture values. |

PCA Compare/Capture Module Mode Registers. These five registers select the operating mode of the corresponding compare/capture module. Each register also contains an enable interrupt bit (ECCFx) for generating an interrupt request when the module's compare/capture flag (CCFx in the CCON register) is set. See Table 8-3 on page 8-15 for mode select bit combinations.

7
0


| Bit Number | Bit Mnemonic | Function |
| :---: | :---: | :---: |
| 7 | - | Reserved: <br> The value read from this bit is indeterminate. Do not write a " 1 " to this bit. |
| 6 | ECOM $x$ | Compare Modes: <br> ECOMx $=1$ enables the module comparator function. The comparator is used to implement the software timer, high-speed output, pulse width modulation, and watchdog timer modes. |
| 5 | CAPP $x$ | Capture Mode (Positive): <br> CAPPx $=1$ enables the capture function with capture triggered by a positive edge on pin CEXx. |
| 4 | CAPN $X$ | Capture Mode (Negative): <br> CAPN $x=1$ enables the capture function with capture triggered by a negative edge on pin CEXX. |
| 3 | MATX | Match: <br> Set ECOM $x$ and MAT $x$ to implement the software timer mode. When MATx $=1$, a match of the PCA timer/counter with the compare/capture register sets the CCF $x$ bit in the CCON register, flagging an interrupt. |
| 2 | TOGX | Toggle: <br> Set ECOM $x$, MAT $x$, and TOG $x$ to implement the high-speed output mode. When TOG $x=1$, a match of the PCA timer/counter with the compare/capture register toggles the CEXX pin. |
| 1 | PWM $x$ | Pulse Width Modulation Mode: <br> PWM $x=1$ configures the module for operation as an 8-bit pulse width modulator with output waveform on the CEXx pin. |
| 0 | ECCFX | Enable CCFx Interrupt: <br> Enables compare/capture flag CCFx in the CCON register to generate an interrupt request. |




CMOD | Address: |
| ---: |
| Reset State: $00 \times \mathrm{S}: \mathrm{D9H}$ |
| X000B |

PCA Timer/Counter Mode Register. Contains bits for selecting the PCA timer/counter input, disabling the PCA timer/counter during idle mode, enabling the PCA WDT reset output (module 4 only), and enabling the PCA timer/counter overflow interrupt.


| Bit Number | Bit Mnemonic | Function |
| :---: | :---: | :---: |
| 7 | CIDL | PCA Timer/Counter Idle Control: <br> CIDL $=1$ disables the PCA timer/counter during idle mode. $\mathrm{CIDL}=0$ allows the PCA timer/counter to run during idle mode. |
| 6 | WDTE | Watchdog Timer Enable: <br> WDTE $=1$ enables the watchdog timer output on PCA module 4. <br> WDTE $=0$ disables the PCA watchdog timer output. |
| 5:3 | - | Reserved: <br> The values read from these bits are indeterminate. Do not write a " 1 " to these bits. |
| 2:1 | CPS1:0 | PCA Timer/Counter Input Select: <br> CPS1 CPS0 |
| 0 | ECF | PCA Timer/Counter Interrupt Enable: <br> $E C F=1$ enables the CF bit in the CCON register to generate an interrupt request. |

DPH
Address: $\quad \mathrm{S}: 83 \mathrm{H}$ Reset State: 0000 0000B
Data Pointer High. DPH provides SFR access to register file location 58 (also named DPH). DPH is the upper byte of the 16 -bit data pointer, DPTR. Instructions in the MCS ${ }^{\circledR} 51$ architecture use DPTR for data moves, code moves, and for a jump instruction (JMP @A+DPTR). See also DPL and DPXL.


| name. 7 | name. 6 | name. 5 | name. 4 | name 3 | name. 2 | name. 1 | name. 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :--- | :---: | :--- |
| $7: 0$ | DPH.7:0 | Data Pointer High: <br> Bits 8-15 of the extended data pointer, DPX (DR56). |

DPL

$$
\begin{array}{rr}
\text { Address: } & \mathrm{S}: 82 \mathrm{H} \\
\text { Reset State: } & 0000 \\
00000 \mathrm{~B}
\end{array}
$$

Data Pointer Low. DPL provides SFR access to register file location 59 (also named DPL). DPL is the low byte of the 16-bit data pointer, DPTR. Instructions in the MCS ${ }^{\circledR} 51$ architecture use the 16 -bit data pointer for data moves, code moves, and for a jump instruction (JMP @A+DPTR). See also DPH and DPXL.

| 7 |
| :--- |
| name. 7 name. 6 name. 5 name.4name. 3 name. 2 name. 1 name. 0 |


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :--- | :---: | :--- |
| $7: 0$ | DPL.7:0 | Data Pointer Low: <br> Bits 0-7 of the extended data pointer, DPX (DR56). |

REGISTERS

DPXL

$$
\begin{array}{rr}
\text { Address: } & \mathrm{S}: 84 \mathrm{H} \\
\text { Reset State: } & 00000001 \mathrm{~B}
\end{array}
$$

Data Pointer Extended Low. DPXL provides SFR access to register file location 57 (also named DPXL). Location 57 is the lower byte of the upper word of the extended data pointer, DPX = DR56, whose lower word is the 16 -bit data pointer, DPTR. See also DPH and DPL.

7
0

| name. 7 | name. 6 | name. 5 | name. 4 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | | name. 3 | name. 2 | name. 1 |
| :---: | :---: | :---: | name. 0 .


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :--- | :---: | :--- |
| $7: 0$ | DPL.7:0 | Data Pointer Extended Low: <br> Bits 16-23 of the extended data pointer, DPX (DR56). |



| Bit <br> Number | Bit <br> Mnemonic | EA |
| :--- | :--- | :--- |
| 7 | EC | Global Interrupt Enable: <br> Setting this bit enables all interrupts that are individually enabled by bits <br> $0-6$. Clearing this bit disables all interrupts, except the TRAP interrupt, <br> which is always enabled. |
| 6 | PCA Interrupt Enable: <br> Setting this bit enables the PCA interrupt. |  |
| 5 | ET2 | Timer 2 Overflow Interrupt Enable: <br> Setting this bit enables the timer 2 overflow interrupt. |
| 4 | ET1 | Serial I/O Port Interrupt Enable: <br> Setting this bit enables the serial I/O port interrupt. |
| 3 | Timer 1 Overflow Interrupt Enable: <br> Setting this bit enables the timer 1 overflow interrupt. |  |
| 2 | EX1 | External Interrupt 1 Enable: <br> Setting this bit enables external interrupt 1. |
| 1 | ETO | Timer 0 Overflow Interrupt Enable: <br> Setting this bit enables the timer 0 overflow interrupt. |
| 0 | EX0 | External Interrupt 0 Enable: <br> Setting this bit enables external interrupt 0. |

```
IPHO
                                    Address: S:B7H
                                    Reset State: X000 0000B
```

Interrupt Priority High Control Register 0. IPHO, together with IPLO, assigns each interrupt a priority level from 0 (lowest) to 3 (highest):

| IPHO.x | IPLO. $\boldsymbol{x}$ | Priority Level |
| :---: | :---: | :---: |
| 0 | 0 | 0 (lowest priority) |
| 0 | 1 | 1 |
| 1 | 0 | 2 |
| 1 | 1 | 3 (highest priority) |

7

| - | IPH0.6 | IPH0.5 | IPH0.4 $\quad$ IPH0.3 | IPH0.2 | IPH0.1 | IPH0.0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :--- | :--- | :--- |
| 7 | - | Reserved. The value read from this bit is indeterminate. Do not write a <br> "1" to this bit. |
| 6 | IPH0.6 | PCA Interrupt Priority Bit High |
| 5 | IPH0.5 | Timer 2 Overflow Interrupt Priority Bit High |
| 4 | IPH0.4 | Serial I/O Port Interrupt Priority Bit High |
| 3 | IPH0.3 | Timer 1 Overflow Interrupt Priority Bit High |
| 2 | IPH0.2 | External Interrupt Priority Bit High |
| 1 | IPH0.1 | Timer 0 Overflow Interrupt Priority Bit High |
| 0 | IPH0.0 | External Interrupt 0 Priority Bit High |



P0 | Address: | S:80H |
| ---: | ---: |
|  | Reset State: |

Port 0. P0 is the SFR that contains data to be driven out from the port 0 pins. Read-modify-write instructions that read port 0 read this register. The other instructions that read port 0 read the port 0 pins. When port 0 is used for an external bus cycle, the CPU always writes FFH to P0, and the former contents of PO are lost.

7

| name. 7 | name.6 | name.5 | name.4 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | | name. 3 | name. | name. 1 |
| :---: | :---: | :---: | name. 0


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :--- | :--- | :--- |
| $7: 0$ | P0.7:0 | Port O Register: <br> Write data to be driven onto the port 0 pins to these bits. |


| Address: | $\mathrm{S}: 90 \mathrm{H}$ |
| ---: | ---: |
| Reset State: | 1111 1111B |

Port 1. P1 is the SFR that contains data to be driven out from the port 1 pins. Read-write-modify instructions that read port 1 read this register. Other instructions that read port 1 read the port 1 pins.

| 7 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| name. 7 | name.6 | name. 5 | name.4 | | name. | name. 2 | name. 1 | name. 0 |
| :---: | :---: | :---: | :---: |


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :--- | :--- | :--- |
| $7: 0$ | P1.7:0 | Port 1 Register: <br> Write data to be driven onto the port 1 pins to these bits. |


| P2 |  |  |  |  | Address: Reset State: |  | $\begin{array}{r} \text { S:AOH } \\ 1111 \text { 1111B } \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Port 2. P2 is the SFR that contains data to be driven out from the port 2 pins. Read-modify-write instructions that read port 2 read this register. Other instructions that read port 2 read the port 2 pins. |  |  |  |  |  |  |  |
| 7 ( 0 |  |  |  |  |  |  |  |
| name. 7 | name. 6 | name. 5 | name. 4 | name. 3 | name. 2 | name. 1 | name. 0 |
| Bit Number | Bit Mnemonic | Function |  |  |  |  |  |
| 7:0 | P2.7:0 | Port 2 Register: |  |  |  |  |  |

P3 $\quad$\begin{tabular}{r}
Address: <br>
Reset State:

 

S: BOH <br>
1111 <br>
R
\end{tabular}

Port 3. P3 is the SFR that contains data to be driven out from the port 3 pins. Read-modify-write instructions that read port 3 read this register. Other instructions that read port 3 read the port 3 pins.
7
0

| name. 7 | name. 6 | name. 5 | name. 4 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | | name. | name. | name. 1 | name. 0 |
| :---: | :---: | :---: | :---: |


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :--- | :--- | :--- |
| $7: 0$ | P3.7:0 | Port 3 Register: <br> Write data to be driven onto the port 3 pins to these bits. |


#### Abstract

PCON $$
\begin{array}{rr} \text { Address: } & \mathrm{S}: 87 \mathrm{H} \\ \text { Reset State: } & 00 \times \mathrm{O} \\ 0000 \mathrm{~B} \end{array}
$$


Power Control Register. Contains the power off flag (POF) and bits for enabling the idle and powerdown modes. Also contains two general-purpose flags and two bits that control serial I/O functions-the double baud rate bit and a bit that selects whether accesses to SCON. 7 are to the FE bit or the SMO bit.

7 0

| SMOD1 | SMODO | - | POF | GF1 | GFO | PD | IDL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |


| $\begin{gathered} \text { Bit } \\ \text { Number } \end{gathered}$ | Bit Mnemonic | Function |
| :---: | :---: | :---: |
| 7 | SMOD1 | Double Baud Rate Bit: <br> When set, doubles the baud rate when timer 1 is used and mode 1,2 , or 3 is selected in the SCON register. See "Baud Rates" on page 9-10. |
| 6 | SMODO | SCON. 7 Select: <br> When set, read/write accesses to SCON. 7 are to the FE bit. When clear, read/write accesses to SCON. 7 are to the SMO bit. See Figure 9-2 on page 9-3. |
| 5 | - | Reserved: <br> The value read from this bit is indeterminate. Do not write a " 1 " to this bit. |
| 4 | POF | Power Off Flag: <br> Set by hardware as $\mathrm{V}_{\mathrm{CC}}$ rises above 3 V to indicate that power has been off or $\mathrm{V}_{\mathrm{CC}}$ had fallen below 3 V and that on-chip volatile memory is indeterminate. Set or cleared by software. |
| 3 | GF1 | General Purpose Flag: <br> Set or cleared by software. One use is to indicate whether an interrupt occurred during normal operation or during idle mode. |
| 2 | GFO | General Purpose Flag: <br> Set or cleared by software. One use is to indicate whether an interrupt occurred during normal operation or during idle mode. |
| 1 | PD | Powerdown Mode Bit: <br> When set, activates powerdown mode. Cleared by hardware when an interrupt or reset occurs. |
| 0 | IDL | Idle Mode Bit: <br> When set, activates idle mode. <br> Cleared by hardware when an interrupt or reset occurs. If IDL and PD are both set, PD takes precedence. |



## PSW1

$$
\begin{array}{rr}
\text { Address: } & \text { S:D1H } \\
\text { Reset State: } & 0000 \text { 00000 }
\end{array}
$$

Program Status Word 1. PSW1 contains bits that reflect the results of operations and bits that select the register bank for registers R0-R7.

7
0

| CY | AC | N | RS1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :--- | :--- | :--- |
| 7 | CY | Carry Flag: <br> Identical to the CY bit in the PSW register on page C-26. |
| 6 | AC | Auxiliary Carry Flag: <br> Identical to the AC bit in the PSW register on page C-26. |
| 5 | N | Negative Flag: <br> This bit is set if the result of the last logical or arithmetic operation was <br> negative. Otherwise it is cleared. |
| $4: 3$ | OV | Register Bank Select Bits 0 and 1: <br> Identical to the RS1:0 bits in the PSW register on page C-26. |
| 2 | Overflow Flag: <br> Identical to the OV bit in the PSW register page C-26. |  |
| 1 | Zero Flag: <br> This flag is set if the result of the last logical or arithmetic operation is <br> zero. Otherwise it is cleared. |  |
| 0 | - | Reserved: <br> The value read from this bit is indeterminate. Do not write a " 1 " to this bit. |

Timer 2 Reload/Capture Registers. This register pair stores 16 -bit values to be loaded into or captured from the timer register (TH2/TL2) in timer 2.

7 0

| name. 7 | name. 6 | name. 5 | name. 4 | name. 3 | name. 2 | name. 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | name. 0


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :--- | :---: | :--- |
| 7:0 | RCAP2H.7:0 <br> RCAP2L.7:0 | High byte of the timer 2 reload/recapture register <br> Low byte of the timer 2 reload/recapture register |

## SADDR Address: S:A9H <br> Reset State: 0000 0000B

Slave Individual Address Register. SADDR contains the device's individual address for multiprocessor communication.

| name. 7 | name. 6 | name. 5 | name. 4 | name. 3 | name. 2 | name. 1 | name. 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :---: | :---: | :--- |
| $7: 0$ | SADDR.7:0 |  |


| SADEN |  |  |  |  | R | dress: State: | $\begin{array}{r} \text { S:B9H } \\ 000000 \mathrm{O} \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mask Byte Register. This register masks bits in the SADDR register to form the device's given address for multiprocessor communication. |  |  |  |  |  |  |  |
| 7 |  |  |  |  |  |  |  |
| name. 7 | name. 6 | name. 5 | name. 4 | name. 3 | name. 2 | name. 1 | name. 0 |
| $\begin{gathered} \text { Bit } \\ \text { Number } \end{gathered}$ | Bit Mnemonic |  |  |  | tion |  |  |
| 7:0 | SADEN.7:0 |  |  |  |  |  |  |

## SBUF <br> Address: $\quad \mathrm{S}: 99 \mathrm{H}$ Reset State: XXXX XXXXB

Serial Data Buffer. Writing to SBUF loads the transmit buffer of the serial I/O port. Reading SBUF reads the receive buffer of the serial I/O port.

| $\mathbf{7}$ |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| name. 7 | name. 6 | name. 5 | name.4 | | name. 3 | name. 2 | name. 1 | name. 0 |
| :--- | :--- | :--- | :--- |


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :--- | :---: | :--- |
| $7: 0$ | SBUF.7:0 |  |

Address:
98 H
Reset State: 0000 0000B
Serial Port Control Register. SCON contains serial I/O control and status bits, including the mode select bits and the interrupt flag bits.

$$
7 \text { 0 }
$$

| FE/SM0 | SM1 | SM2 | REN | TB8 | RB8 | TI |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |


| Bit Number | Bit Mnemonic | Function |
| :---: | :---: | :---: |
| 7 | FE | Framing Error Bit: <br> To select this function, set the SMODO bit in the PCON register. Set by hardware to indicate an invalid stop bit. Cleared by software, not by valid frames. <br> Serial Port Mode Bit 0: <br> To select this function, clear the SMODO bit in the PCON register. Software writes to bits SM0 and SM1 to select the serial port operating mode. Refer to the SM1 bit for the mode selections. |
| 6 | SM1 | Serial Port Mode Bit 1: <br> Software writes to bits SM1 and SM0 (above) to select the serial port operating mode. <br> tSelect by programming the SMOD bit in the PCON register (see "Baud Rates" on page 9-10). |
| 5 | SM2 | Serial Port Mode Bit 2: <br> Software writes to bit SM2 to enable and disable the multiprocessor communication and automatic address recognition features. This allows the serial port to differentiate between data and command frames and to recognize slave and broadcast addresses. |
| 4 | REN | Receiver Enable Bit: To enable reception, set this bit. To enable transmission, clear this bit. |
| 3 | TB8 | Transmit Bit 8: <br> In modes 2 and 3, software writes the ninth data bit to be transmitted to TB8. Not used in modes 0 and 1. |
| 2 | RB8 | Receiver Bit 8: <br> Mode 0: Not used. <br> Mode 1 (SM2 clear): Set or cleared by hardware to reflect the stop bit received. <br> Modes 2 and 3 (SM2 set): Set or cleared by hardware to reflect the ninth data bit received. |

Serial Port Control Register. SCON contains serial I/O control and status bits, including the mode select bits and the interrupt flag bits.

| 7 | 0 |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| FE/SM0 | SM1 | SM2 | REN | | TB8 | RB8 | TI |
| :--- | :--- | :--- |


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :--- | :--- | :--- |
| 1 | TI | Transmit Interrupt Flag Bit: <br> Set by the transmitter after the last data bit is transmitted. Cleared by <br> software. |
| 0 | RI | Receive Interrupt Flag Bit: <br> Set by the receiver after the last data bit of a frame has been received. <br> Cleared by software. |


| Address: | $\mathrm{S}: 81 \mathrm{H}$ |
| ---: | ---: |
| Reset State: | 0000 0111B |

Stack Pointer. SP provides SFR access to location 63 in the register file (also named SP). SP is the lowest byte of the extended stack pointer (SPX = DR60). The extended stack pointer points to the current top of stack. When a byte is saved (PUSHed) on the stack, SPX is incremented, and then the byte is written to the top of stack. When a byte is retrieved (POPped) from the stack, it is copied from the top of stack, and then SPX is decremented.

7 0

| name. 7 | name. 6 | name. | name.4 | name. 3 | name. 2 | name. 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | name. 0


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :--- | :--- | :--- |
| $7: 0$ | SP.7:0 | Stack Pointer: <br> Bits 0-7 of the extended stack pointer, SPX (DR60). |

SPH
$\begin{array}{rr}\text { Address: } & \text { S:BDH } \\ \text { Reset State: } & 0000 \text { 0000B }\end{array}$
Stack Pointer High. SPH provides SFR access to location 62 in the register file (also named SPH). SPH is the upper byte of the lower word of DR60, the extended stack pointer (SPX). The extended stack pointer points to the current top of stack. When a byte is saved (PUSHed) on the stack, SPX is incremented, and then the byte is written to the top of stack. When a byte is retrieved (POPped) from the stack, it is copied from the top of stack, and then SPX is decremented.
7

| name. 7 | name. 6 | name. 5 | name. 4 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| name. 3 | name. 2 | name. 1 | name. 0 |


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :--- | :--- | :--- |
| $7: 0$ | SPH.7:0 | Stack Pointer High: <br> Bits 8-15 of the extended stack pointer, SPX (DR(60)). |

T2CON | Address: |
| ---: |
| Reset State: |
| 0000 S:C8H |

Timer 2 Control Register. Contains the receive clock, transmit clock, and capture/reload bits used to configure timer 2. Also contains the run control bit, counter/timer select bit, overflow flag, external flag, and external enable for timer 2.
7

| TF2 | EXF2 | RCLK | TCLK |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |


| Bit Number | Bit Mnemonic | Function |
| :---: | :---: | :---: |
| 7 | TF2 | Timer 2 Overflow Flag: <br> Set by timer 2 overflow. Must be cleared by software. TF2 is not set if RCLK $=1$ or TCLK = 1 . |
| 6 | EXF2 | Timer 2 External Flag: <br> If EXEN2 $=1$, capture or reload caused by a negative transition on T2EX sets EFX2. EXF2 does not cause an interrupt in up/down counter mode ( $\mathrm{DCEN}=1$ ) |
| 5 | RCLK | Receive Clock Bit: <br> Selects timer 2 overflow pulses (RCLK = 1) or timer 1 overflow pulses <br> $($ RCLK $=0)$ as the baud rate generator for serial port modes 1 and 3. |
| 4 | TCLK | Transmit Clock Bit: <br> Selects timer 2 overflow pulses (TCLK = 1) or timer 1 overflow pulses (TCLK $=0$ ) as the baud rate generator for serial port modes 1 and 3. |
| 3 | EXEN2 | Timer 2 External Enable Bit: <br> Setting EXEN2 causes a capture or reload to occur as a result of a negative transition on T2EX unless timer 2 is being used as the baud rate generator for the serial port. Clearing EXEN2 causes timer 2 to ignore events at T2EX. |
| 2 | TR2 | Timer 2 Run Control Bit: Setting this bit starts the timer. |
| 1 | C/T2\# | Timer 2 Counter/Timer Select: <br> C/T2\# $=0$ selects timer operation: timer 2 counts the divided-down system clock. C/T2\# = 1 selects counter operation: timer 2 counts negative transitions on external pin T2. |
| 0 | CP/RL2\# | Capture/Reload Bit: <br> When set, captures occur on negative transitions at T2EX if EXEN2 $=1$. When cleared, auto-reloads occur on timer 2 overflows or negative transitions at T2EX if EXEN2 $=1$. The CP/RL2\# bit is ignored and timer 2 forced to auto-reload on timer 2 overflow, if RCLK $=1$ or TCLK $=1$. |

## T2MOD

Timer 2 Mode Control Register. Contains the timer 2 down count enable and clock-out enable bits for timer 2.


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :--- | :--- | :--- |
| $7: 2$ | - | Reserved: <br> The values read from these bits are indeterminate. Do not write a "1" to <br> these bits. |
| 1 | T2OE | Timer 2 Output Enable Bit: <br> In the timer 2 clock-out mode, connects the programmable clock output <br> to external pin T2. |
| 0 | DCEN | Down Count Enable Bit: <br> Configures timer 2 as an up/down counter. |



## TMOD

| Address: | $\mathrm{S}: 89 \mathrm{H}$ |
| ---: | ---: |
| Reset State: | 0000 0000B |

Timer/Counter Mode Control Register. Contains mode select, run control select, and counter/timer select bits for controlling timer 0 and timer 1 .
7
0

| GATE1 | C/T1\# | M11 | M01 |
| :--- | :--- | :--- | :--- |


| GATE0 | C/T0\# | M01 | M00 |
| :--- | :--- | :--- | :--- |


| Bit Number | Bit Mnemonic | Function |
| :---: | :---: | :---: |
| 7 | GATE1 | Timer 1 Gate: <br> When GATE1 $=0$, run control bit TR1 gates the input signal to the timer register. When GATE1 = 1 and TR1 = 1, external signal INT1 gates the timer input. |
| 6 | C/T1\# | Timer 1 Counter/Timer Select: <br> C/T1\# = 0 selects timer operation: timer 1 counts the divided-down system clock. C/T1\# = 1 selects counter operation: timer 1 counts negative transitions on external pin T1. |
| 5, 4 | M11, M01 | Timer 1 Mode Select:   <br> M11 M01   <br> 0 0 Mode 0: <br> 8-bit timer/counter (TH1) with 5-bit prescalar (TL1)   <br> 0 1 Mode 1: <br> 1 1-bit timer/counter  <br> 1 0 Mode 2: <br> 8-bit auto-reload timer/counter (TL1). Reloaded   <br> 1 1 Mode 3: <br> from TH1 Timer 1 halted. Retains count.   |
| 3 | GATEO | Timer 0 Gate: <br> When GATE $0=0$, run control bit TR0 gates the input signal to the timer register. When GATEO $=1$ and TRO $=1$, external signal INTO gates the timer input. |
| 2 | C/TO\# | Timer 0 Counter/Timer Select: <br> C/TO\# $=0$ selects timer operation: timer 0 counts the divided-down system clock. С/TO\# = 1 selects counter operation: timer 0 counts negative transitions on external pin TO. |
| 1, 0 | M01, M00 |  |

## THO, TLO

Address: $\quad$ THO S:8CH TLO S:8AH

Reset State: 0000 0000B
THO, TLO Timer Registers. These registers operate in cascade to form the 16 -bit timer register in timer 0 or separately as 8 -bit timer/counters.

| 7 | 0 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| name. 7 | name. 6 | name. 5 | name.4 | | name. 3 | name. 2 | name. 1 | name. 0 |
| :---: | :---: | :---: | :---: |


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :--- | :--- | :--- |
| $7: 0$ | TH0.7:0 <br> TL0.7:0 | High byte of the timer 0 timer register. <br> Low byte of the timer 0 timer register. |

Reset State: 0000 0000B
TH1, TL1 Timer Registers. These registers operate in cascade to form the 16 -bit timer register in timer 1 or separately as 8 -bit timer/counters.
7 0

| name. 7 | name. 6 | name. 5 | name. 4 | name. 3 | name. 2 | name. 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | name. 0


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :--- | :--- | :--- |
| $7: 0$ | TH1.7:0 <br> TL1.7:0 | High byte of the timer 1 timer register. <br> Low byte of the timer 1 timer register. |

## TH2, TL2

Address: TH2 S:CDH TL2 S:CCH

Reset State: 0000 0000B
TH2, TL2 Timer Registers. These registers operate in cascade to form the 16 -bit timer register in timer 2.

| name. 7 | name. 6 | name. 5 | name. $4 \quad$ name. 3 | name. 2 | name. 1 | name. 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :--- | :--- | :--- |
| 7:0 | TH2.7:0 <br> TL2.7:0 | High byte of the timer 2 timer register. <br> Low byte of the timer 2 timer register. |


| WDTRST | s: | H |
| :---: | :---: | :---: |
|  | Reset State | XXXX XXXXB |

Watchdog Timer Reset Register. Writing the two-byte sequence 1EH-E1H to the WDTRST register clears and enables the hardware WDT. The WDTRST register is a write-only register. Attempts to read it return FFH. The WDT itself is not read or write accessible. See "Watchdog Timer" on page 7-16.
7 0

| name. 7 | name. 6 | name. 5 | name. 4 | name. 3 | name. 2 | name. 1 | name. 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |


| Bit <br> Number | Bit <br> Mnemonic | Function |
| :--- | :---: | :--- |
| $7: 0$ | WDTRST.7:0 | Provides user control of the hardware WDT. |

## inte.

## Glossary

## GLOSSARY

This glossary defines acronyms, abbreviations, and terms that have special meaning in this manual. (Chapter 1, "Guide to this Manual," discusses notational conventions and general terminology.)
\#0data16
\#1data16
\#data
\#data16
\#short
accumulator
addr11
addr16
addr24

ALU
assert

A 32-bit constant that is immediately addressed in an instruction. The upper word is filled with zeros.

A 32-bit constant that is immediately addressed in an instruction. The upper word is filled with ones.

An 8-bit constant that is immediately addressed in an instruction.

A 16-bit constant that is immediately addressed in an instruction.

A constant, equal to 1,2 , or 4 , that is immediately addressed in an instruction.

A register or storage location that forms the result of an arithmetic or logical operation.

An 11-bit destination address. The destination can be anywhere in the same 2 -Kbyte block of memory as the first byte of the next instruction.

A 16-bit destination address. The destination can be anywhere within the same 64-Kbyte region as the first byte of the next instruction.

A 24-bit destination address. The destination can be anywhere within the 16 -Mbyte address space.

Arithmetic-logic unit. The part of the CPU that processes arithmetic and logical operations.

The term assert refers to the act of making a signal active (enabled). The polarity (high/low) is defined by the signal name. Active-low signals are designated by a pound symbol (\#) suffix; active-high signals have no suffix. To assert RD\# is to drive it low; to assert ALE is to drive it high.

| binary-code compatibility | The ability of an $\mathrm{MCS}^{\circledR} 251$ microcontroller to execute, without modification, binary code written for an MCS 51 microcontroller. |
| :---: | :---: |
| binary mode | An operating mode, selected by a configuration bit, that enables an MCS 251 microcontroller to execute, without modification, binary code written for an MCS 51 microcontroller. |
| bit | A binary digit. |
| bit (operand) | An addressable bit in the MCS 251 architecture. |
| bit51 | An addressable bit in the MCS 51 architecture. |
| byte | Any 8-bit unit of data. |
| clear | The term clear refers to the value of a bit or the act of giving it a value. If a bit is clear, its value is " 0 "; clearing a bit gives it a " 0 " value. |
| code memory | See program memory. |
| configuration bytes | Bytes, residing in on-chip OTPROM/ROM, that determine a set of operating parameters for the 8XC251SB. |
| dir8 | An 8-bit direct address. This can be a memory address or an SFR address. |
| dir16 | A 16-bit memory address ( $00: 0000 \mathrm{H}-00: \mathrm{FFFFH}$ ) used in direct addressing. |
| DPTR | The 16 -bit data pointer. In MCS 251 microcontrollers, DPTR is the lower 16 bits of the 24 -bit extended data pointer, DPX. |
| DPX | The 24 -bit extended data pointer in MCS 251 microcontrollers. See also DPTR. |
| deassert | The term deassert refers to the act of making a signal inactive (disabled). The polarity (high/low) is defined by the signal name. Active-low signals are designated by a pound symbol (\#) suffix; active-high signals have no suffix. To deassert RD\# is to drive it high; to deassert ALE is to drive it low. |


| doping | The process of introducing a periodic table Group III or Group V element into a Group IV element (e.g., silicon). A Group III impurity (e.g., indium or gallium) results in a p-type material. A Group V impurity (e.g., arsenic or antimony) results in an $n$ type material. |
| :---: | :---: |
| double word | A 32-bit unit of data. In memory, a double word comprises four contiguous bytes. |
| dword | See double word. |
| edge-triggered | The mode in which a device or component recognizes a falling edge (high-to-low transition), a rising edge (low-to-high transition), or a rising or falling edge of an input signal as the assertion of that signal. See also level-triggered. |
| encryption array | An array of key bytes used to encrypt user code in the on-chip code memory as that code is read; protects against unauthorized access to user's code. |
| external address | A 16-bit or 17-bit address presented on the device pins. The address decoded by an external device depends on how many of these address bits the external system uses. See also internal address. |
| FET | Field-effect transistor. |
| idle mode | The power conservation mode that freezes the core clocks but leaves the peripheral clocks running. |
| input leakage | Current leakage from an input pin to power or ground. |
| integer | Any member of the set consisting of the positive and negative whole numbers and zero. |
| internal address | The 24-bit address that the device generates. See also external address. |
| interrupt handler | The module responsible for handling interrupts that are to be serviced by user-written interrupt service routines. |
| interrupt latency | The delay between an interrupt request and the time when the first instruction in the interrupt service routine begins execution. |
| interrupt response time | The time delay between an interrupt request and the resulting break in the current instruction stream. |


| interrupt service routine (ISR) | The software routine that services an interrupt. |
| :---: | :---: |
| level-triggered | The mode in which a device or component recognizes a high level (logic one) or a low level (logic zero) of an input signal as the assertion of that signal. See also edge-triggered. |
| LSB | Least-significant bit of a byte or least-significant byte of a word. |
| maskable interrupt | An interrupt that can be disabled (masked) by its individual mask bit in an interrupt enable register. All 8XC251SB interrupts, except the software trap (TRAP), are maskable. |
| MSB | Most-significant bit of a byte or most-significant byte of a word. |
| multiplexed bus | A bus on which the data is time-multiplexed with (some of) the address bits. |
| $n$-channel FET | A field-effect transistor with an $n$-type conducting path (channel). |
| $n$-type material | Semiconductor material with introduced impurities (doping) causing it to have an excess of negatively charged carriers. |
| nonmaskable interrupt | An interrupt that cannot be disabled (masked). The software trap (TRAP) is the 8 XC 251 SB 's only nonmaskable interrupt. |
| $n p n$ transistor | A transistor consisting of one part $p$-type material and two parts $n$-type material. |
| OTPROM | One-time-programmable read-only memory, a version of EPROM. |
| $p$-channel FET | A field-effect transistor with a p-type conducting path. |
| p-type material | Semiconductor material with introduced impurities (doping) causing it to have an excess of positively charged carriers. |
| PC | Program counter |
| program memory | A part of memory where instructions can be stored for fetching and execution. |


| powerdown mode | The power conservation mode that freezes both the core clocks and the peripheral clocks. |
| :---: | :---: |
| PWM | Pulse-width modulated (outputs). |
| rel | A signed (two's complement) 8-bit, relative destination address. The destination is -128 to +127 bytes relative to the first byte of the next instruction. |
| reserved bits | Register bits that are not used in this device but may be used in future implementations. Avoid any software dependence on these bits. In the 8XC251SB, the value read from a reserved bit is indeterminate; do not write a " 1 " to a reserved bit. |
| set | The term set refers to the value of a bit or the act of giving it a value. If a bit is set, its value is " 1 "; setting a bit gives it a " 1 " value. |
| SFR | Special-function register. |
| sign extension | A method for converting data to a larger format by filling the extra bit positions with the value of the sign. This conversion preserves the positive or negative value of signed integers. |
| sink current | Current flowing into a device to ground. Always a positive value. |
| source-code compatibility | The ability of an MCS 251 microcontroller to execute recompiled source code written for an MCS 51 microcontroller. |
| source current | Current flowing out of a device from $\mathrm{V}_{\mathrm{CC}}$. Always a negative value. |
| source mode | An operating mode that is selected by a configuration bit. In source mode, an MCS 251 microcontroller can execute recompiled source code written for an MCS 51 microcontroller. In source mode, the MCS 251 microcontroller cannot execute unmodified binary code written for an MCS 51 microcontroller. See binary mode. |
| SP | Stack pointer. |
| SPX | Extended stack pointer. |

## state time (or state)

UART

WDT
word
wraparound

The basic time unit of the device; the combined period of the two internal timing signals, PH 1 and PH2. (The internal clock generator produces PH1 and PH2 by halving the frequency of the signal on XTAL1.) With a $16-\mathrm{MHz}$ crystal, one state time equals 125 ns . Because the device can operate at many frequencies, this manual defines time requirements in terms of state times rather than in specific units of time.

Universal asynchronous receiver and transmitter. A part of the serial I/O port.

Watchdog timer, an internal timer that resets the device if the software fails to operate properly.

A 16-bit unit of data. In memory, a word comprises two contiguous bytes.

The result of interpreting an address whose hexadecimal expression uses more bits than the number of available address lines. Wraparound ignores the upper address bits and directs access to the value expressed by the lower bits.

## intel.

## Index

\#0data16, A-3
\#1data16, A-3
\#data
definition, A-3
\#data16, A-3
\#short, A-3
80C251SB, 13-1
configuration byte values, 13-9
83C251SB, 13-1
See also ROM
87C251SB, 13-1
See also OTPROM
8XC251SB, 2-1
applications, 2-1
block diagram, 2-2
features, 2-4
on-chip peripherals, 2-1, 2-3
8XC51FX, 2-1

## A

A15:8, 6-1, B-2
description, 12-1
A16, B-2
configuring for, 13-6
description, 12-1
AC flag, 4-19, 4-20
ACALL instruction, 4-16, A-24, A-26
ACC, 3-10, 3-13, 3-14, C-4
Accumulator, 3-12
in register file, 3-10
See also ACC
AD7:0, 6-1, B-2
description, 12-1
ADD instruction, 4-10, A-14
ADDC instruction, 4-10, A-14
addr11, 4-14, A-3
addr16, 4-14, A-3
addr24, 4-14, A-3
Address spaces See Memory space, SFRs, Register file, External memory, Compatibility
Addresses
internal vs external, 12-3
Addressing modes, 3-5, 4-5
See also Data instructions, Bit instructions, Control instructions
AJMP instruction, 4-16, A-24
ALE, B-2
caution, 10-6
description, 12-1
extended, 12-6
following reset, 10-6
idle mode, 11-4
programming for extension, 13-6
programming on-chip OTPROM, 13-3
ANL instruction, 4-11, 4-12
for bits, A-23
ANL/instruction, 4-12
for bits, A-23
Arithmetic instructions, 4-10, 4-11
table of, A-14, A-15, A-16

## B

B register, 3-12, C-5
as SFR, 3-13, 3-14
in register file, 3-10
Base address, 4-5
Baud rate See Serial I/O port, Timer 1, Timer 2
Binary and source modes, 2-3, 4-1-4-3
opcode maps, 4-1
selection guidelines, 2-3, 4-2
Bit address
addressing modes, 4-14
definition, A-3
examples, 4-13
Bit instructions, 4-4, 4-12-4-14
addressing modes, 4-6, 4-12
bit51, 4-13, A-3
Broadcast address See Serial I/O port

## C

Call instructions, 4-16
Capacitors
bypass, 10-2
CCAP1H-CCAP4H, CCAP1L-CCAP4L, 3-13, 3-16, C-6
CCAPM1-4, 3-13, 3-15, C-7
interrupts, 5-5
CCON, 3-13, 3-15, C-8
Ceramic resonator, 10-4
CEX4:0, 6-1, B-2
CH, CL, 3-13, 3-16, C-9
CJNE instruction, A-25
Clock, 2-5
external, 10-4
external source, 10-3
idle and powerdown modes, 11-5
idle mode, 11-4
powerdown mode, 11-5, 11-6
sources, 10-3
CLR instruction, 4-11, 4-12, A-17, A-23
CMOD, 3-13, 3-15, C-10
interrupts, 5-5
CMP instruction, 4-10, 4-15, A-15
Code constants, 12-7
Code fetches
external, 12-10
internal, 12-10
page hit and page miss, 12-11
page mode, 12-11
Code memory
MCS 51 architecture, 3-5
See also On-chip code memory, External code memory
Compatibility (MCS 251 and MCS 51
architectures), 2-1, 3-2-3-5
address spaces, 3-2, 3-4
external memory, 3-5
memory configuration for, 12-5
on-chip RAM, 3-5
SFR space, 3-5
See also Binary and source modes
CONFIG0
bit definitions, 13-7
CONFIG1
bit definitions, 13-8
Configuration bytes
programming, 13-1
programming and verifying, 13-6
setup for programming and verifying, 13-2-13-3
Control instructions, 4-4, 4-14-4-17
addressing modes, 4-14, 4-15
table of, A-24
Core, 2-4
SFRs, 3-14
CPL instruction, 4-11, 4-12, A-17, A-23
CPU, 2-4
block diagram, 2-5
Crystal
for on-chip oscillator, 10-3
CY flag, 4-19, 4-20

## D

DA instruction, A-16
Data instructions, 4-4, 4-6-4-12
addressing modes, 4-6
Data pointer See DPH, DPL, DPTR, DPX, DPXL
Data transfer instructions, 4-11-4-12
table of, A-22
See also Move instructions
Data types, 4-4
DEC instruction, 4-10, A-16
Destination register, 4-5
dir16, A-3
dir8, A-3
Direct addressing, 4-5
in control instructions, 4-14
Displacement addressing, 4-5, 4-9
DIV instruction, 4-10, A-16
Division, 4-10
DJNZ instruction, A-25
Documents, related, 1-5
DPH, DPL, 3-12, C-11, C-12
as SFRs, 3-13, 3-14
DPTR, 3-12
in jump instruction, 4-14
DPX, 3-5, 3-10, 3-12, 4-7
DPXL, 3-12, C-13
as SFR, 3-13, 3-14
external data memory mapping, 3-5, 4-7, 4-11
reset value, 3-5

## E

EA\#, 3-6, B-2
description, 12-1
ECALL instruction, 4-16, A-24
ECI, 6-1, B-2
EJMP instruction, 4-16, A-24
EMAP bit, 3-6, 12-7
Encryption, 13-1
Encryption array
key bytes, 13-10
programming and verifying, $13-1,13-10$
setup for programming, 13-2-13-3
ERET instruction, 4-17, A-24
Escape prefix (A5H), 4-2
Extended stack pointer See SPX
External address lines
number of, 12-3
See also External bus
External bus
AC timing definitions, 12-28
AC timing specifications, 12-24-12-27
bus-idle condition, 12-7
inactive, 12-7
pin status, 12-15, 12-16
structure in page mode, nonpage mode, 12-10
External bus cycles, 12-7
definitions, 12-8
extended ALE wait state, 12-14
extended PSEN\#/RD\#/WR\# wait state, 12-13
nonpage mode, 12-8, 12-9
page hit vs page miss, $12-10$
page mode, $12-10-12-12$
External code memory, 12-4, 12-5
example, $12-16,12-21,12-22$
idle mode, 11-4
powerdown mode, 11-5
External memory, 3-8
design examples, 12-16-12-24
MCS 51 architecture, 3-3, 3-4, 3-5
External memory interface, 12-1-12-30
configuring, 12-2-12-7
signals, 12-1
External RAM, 12-4, 12-5
example, $12-16,12-19,12-21,12-22$
exiting idle mode, 11-5

## F

F0 flag, 4-19
Flash memory
example, 12-21, 12-22

## G

Given address See Serial I/O port
Ground bounce, 10-2

## H

Hardware
application notes, 1-6

I
I/O ports, 6-1-6-8
external memory access, 6-7, 6-8
latches, 6-2
loading, 6-7
pullups, 6-6
quasi-bidirectional, 6-5
SFRs, 3-14
See also Ports 0-3
Idle mode, 2-3, 11-1, 11-4-11-5
entering, 11-4
exiting, $10-5,11-5$
external bus, 12-7
IE, 5-3, 5-5
IE0, 3-13, 3-14, 5-14, 9-11, C-14
Immediate addressing, 4-5
INC instruction, 4-10, A-16
Indirect addressing, 4-5
in control instructions, 4-14
in data instructions, 4-9
Input pins
level-sensitive, B-2
sampled, B-2
INT1:0\#, 5-1, 6-1, 7-1, 7-3, B-2
pulse width measurements, 7-10
Interrupt request, 5-1
cleared by hardware, 5-4
Interrupt service routine
exiting idle mode, 11-5
exiting powerdown mode, 11-6
Interrupts, 5-1-5-15
blocking conditions, 5-14
detection, 5-3
edge-triggered, 5-4
enable/disable, 5-5
exiting idle mode, 11-5
exiting powerdown mode, 11-6
external, 5-3, 5-11
global enable, 5-5
instruction completion time, 5-10
latency, 5-9-5-13
level-triggered, 5-4
PCA, 5-5
polling, 5-9, 5-10
priority, 5-1, 5-3, 5-4, 5-6-5-8
priority within level, 5-7
processing, 5-9-5-15
request See Interrupt request
response time, 5-9, 5-10
sampling, 5-3, 5-10
serial port, 5-5
service routine (ISR), 5-4, 5-9, 5-14, 5-15
sources, 5-3
timer/counters, 5-4
vector cycle, 5-14
vectors, 3-5, 5-4
INTR bit
and RETI instruction, 4-17
IPHO, 3-13, 3-14, 5-3, 5-6, 5-14, C-15
bit definitions, 5-7
IPL0, 3-13, 3-14, 5-3, 5-6, 5-14, C-16
bit definitions, 5-7
ISR See Interrupts, service routine

## J

JB instruction, 4-15, A-24
JBC instruction, 4-15, A-24
JC instruction, A-24
JE instruction, A-24
JG instruction, A-24
JLE instruction, A-24
JMP instruction, A-24
JNB instruction, 4-15, A-24
JNC instruction, A-24
JNE instruction, A-24
JNZ instruction, A-24
JSG instruction, A-25
JSGE instruction, A-25
JSL instruction, A-25
JSLE instruction, A-25
Jump instructions
bit-conditional, 4-15
compare-conditional, 4-15, 4-16
unconditional, 4-16
JZ instruction, A-24

## K

Key bytes See Encryption array

## L

LCALL instruction, 4-16, A-24
Level-sensitive input, B-2
LJMP instruction, 4-16, A-24
Lock bits
programming and verifying, 13-1, 13-9
protection types, 13-9
setup for programming and verifying, 13-2-13-3

Logical instructions, 4-11
table of, A-17

## M

MCS 251 microcontroller, 2-1
features, 2-1
MCS 51 microcontroller, 2-1
Memory space, 2-3, 3-1, 3-5-3-8
compatibility See Compatibility (MCS 251 and MCS 51 architectures)
hardware implementation, 3-5
internal vs external, 12-4-12-6
regions, 3-2, 3-5
reserved locations, 3-5
Miller effect, 10-4
MOV instruction, 4-11, A-19, A-20, A-21
for bits, 4-12, A-23
MOVC instruction, 3-3, 4-11, A-21
Move instructions
table of, A-19
MOVH instruction, 4-12, A-21
MOVS instruction, 4-12, A-21
MOVX instruction, 3-3, 4-11, A-21
MOVZ instruction, 4-12, A-21
MUL instruction, 4-10
Multiplication, 4-10

## N

N flag, 4-11, 4-20
Noise reduction, 10-2, 10-3, 10-4
Nonpage mode
bus cycles See External bus cycles, Nonpage mode
bus structure, 12-1
configuring for, 12-3
design example, 12-16, 12-19
port pin status, $12-15$
Nonvolatile memory
programming and verifying, 13-1-13-12
See also On-chip code memory, Configuration bytes, Lock bits, Encryption array, Signature bytes
NOP instruction, 4-16, A-25

## 0

ONCE mode, 11-1, 11-7
entering, 11-7
exiting, 11-7
On-chip code memory, 3-2, 12-4, 12-13
accessing in data memory, 12-7
accessing in region 00 :, 3-6
idle mode, 11-4
powerdown mode, 11-5
programming and verifying, $13-1,13-5$
remapping, 13-6
setup for programming and verifying, 13-2-13-3
starting address, 3-6, 13-1, 13-2
top eight bytes, 3-6, 13-2
See also OTPROM, ROM
On-chip oscillator
hardware setup, 10-1
On-chip RAM, 3-2, 3-6
bit addressable, 3-6, 4-13
bit addressable in MCS 51 architecture, 4-13
idle mode, 11-4
MCS 51 architecture, 3-2, 3-4
reset, 10-6
Opcodes
for binary and source modes, 4-1
map, A-4
See also Binary and source modes
ORL instruction, 4-11, 4-12
for bits, A-23
ORL/ instruction, 4-12
for bits, A-23
Oscillator, 2-5
at startup, 10-7
during reset, $10-5$
ONCE mode, 11-7
on-chip, 10-3
powerdown mode, 11-5, 11-6
programming and verifying on-chip
OTPROM/ROM, 13-3
OTPROM (on-chip), 13-1
programming algorithm, 13-4
programming and verifying, 13-1-13-12
programming waveforms, 13-4
timing for programming and verifying, 13-11
verify algorithm, 13-5
See also On-chip code memory, Configuration bytes, Lock bits, Encryption array, Signature bytes
OV bit, 4-19, 4-20
Overflow See OV bit

## P

P bit, 4-19
P0, 3-13, 3-14, 6-2, C-17
P1, 3-13, 3-14, 6-2, C-18
P2, 3-13, 3-14, 6-2, C-19
P3, 3-13, 3-14, 6-2, C-20
PAGE bit, 12-3
Page mode, 2-4
address access time, 12-11
bus cycles See External bus cycles, page mode
configuring for, 12-3, 13-6
design example, 12-21, 12-22
port pin status, 12-16
Parity See P bit
PCA
idle mode, 11-4
SFRs, 3-15
PCON, 3-13, 3-14, 9-7, 11-1, 11-2, 11-5, C-21
idle mode, 11-4
powerdown mode, 11-6
reset, 10-5
Peripheral cycle, 2-5
Phase 1 and phase 2, 2-5
Pin conditions, 11-3
Pins
unused inputs, 10-2
Pipeline, 2-4
POP instruction, 3-11, 4-12, A-22
Port 0, 6-2, B-3
and top of on-chip code memory, 13-2
pullups, 6-7
structure, 6-3
See also External bus
Port 1, 6-2, B-3
structure, 6-3
Port 2, 6-2, B-3
and top of on-chip code memory, 13-2
structure, 6-4
See also External bus
Port 3, 6-2, B-3
structure, 6-3
Ports
at power on, 10-7
exiting idle mode, 11-5
exiting powerdown mode, 11-5
extended execution times, $4-1, \mathrm{~A}-1, \mathrm{~A}-11$
programming and verifying on-chip OTPROM/ROM, 13-3, 13-4, 13-5
Power supply, 10-2
Powerdown mode, 2-3, 11-1, 11-5-11-6
accidental entry, 11-4
entering, 11-6
exiting, $10-5,11-6$
external bus, 12-7
PROG\#, 13-1, B-3
Program status word See PSW, PSW1
PSEN\#, 13-6, B-3
caution, 10-6
description, 12-2
idle mode, 11-4
programming on-chip OTPROM, 13-3
regions for strobe, 12-3
PSW, A-26
PSW, PSW1, 3-13, 3-14, 4-17-4-18, C-22, C-23
conditional jumps, 4-15
effects of instructions on flags, 4-18
PSW1, A-26
Pullups, 6-7
ports $1,2,3,6-5$
Pulse width measurements, 7-10
PUSH instruction, 3-11, 4-12, A-22

## Q

Quick-pulse algorithm, 13-1

## R

RCAP2H, RCAP2L, 3-13, 3-15, 7-2, 9-12, C-24
RD\#, 6-1, 13-6, B-3
as 17 th address bit, $12-3,12-4$
described, 12-2
regions for strobe, 12-3
RD1:0 configuration bits, 12-3-12-6
table, 12-3
Read-modify-write instructions, 6-2, 6-5
Register addressing, 4-5, 4-8
Register banks, 3-2, 3-8
accessing in memory address space, 4-6
implementation, 3-8, 3-9
MCS 51 architecture, 3-2
selection bits (RS1:0), 4-19, 4-20
Register file, 2-4, 3-1, 3-5, 3-8-3-12
address space, 3-2
addressing locations in, 3-9
and reset, 10-6
MCS 51 architecture, 3-4
naming registers, 3-8
register types, 3-8
Registers See Register addressing, Register banks, Register file
rel, A-3
Relative addressing, 4-6, 4-14
Reset, 10-5-10-7
cold start, 10-5, 11-1
entering ONCE mode, 11-7
exiting idle mode, 11-5
exiting powerdown mode, 11-6
externally initiated, $10-5$
need for, 10-6
operation, 10-6
power on, 10-6
power-on setup, 10-1
timing sequence, $10-6,10-7$
warm start, 10-5, 11-1
RET instruction, 4-17, A-24
RETI instruction, 5-1, 5-14, 5-15, A-24
Return instructions, 4-16
RL instruction, A-17
RLC instruction, A-17
ROM (on-chip), 13-1
verifying, 13-1-13-12
See also On-chip code memory, Configuration bytes, Lock bits, Encryption array, Signature bytes
Rotate instructions, 4-11
RR instruction, A-17
RRC instruction, A-17
RST, $10-5,10-6$, B-3
exiting idle mode, 11-5
exiting powerdown mode, 11-6
ONCE mode, 11-7
power-on reset, 10-6
programming and verifying on-chip
OTPROM/ROM, 13-3
RXD, 6-1, 9-1, B-3
mode 0, 9-4
modes 1, 2, 3, 9-6

## S

SADDR, 3-13, 3-15, 9-2, 9-8, 9-9, 9-10, C-25
SADEN, 3-13, 3-15, 9-2, 9-8, 9-9, 9-10, C-26

INDEX

Sampled input, B-2
SBUF, 3-13, 3-15, 9-2, 9-4, 9-5, C-27
SCON, 3-13, 3-15, 9-2, 9-4, 9-5, 9-6, 9-7, C-28, C-29
bit definitions, 9-3
interrupts, 5-5
Security, 13-1
Serial I/O port, 9-1-9-14
asynchronous modes, 9-6
automatic address recognition, 9-7-9-10
baud rate generator, 7-9
baud rate, mode 0, 9-4, 9-10
baud rate, modes $1,2,3,9-6,9-10-9-14$
broadcast address, 9-9.
data frame, modes 1, 2, 3, 9-6
framing bit error detection, 9-7
full-duplex, 9-6
given address, 9-8
half-duplex, 9-4
interrupts, 9-1, 9-8
mode 0, 9-4-9-5
modes 1, 2, 3, 9-6
multiprocessor communication, 9-7
SFRs, 3-15, 9-1, 9-2
synchronous mode, 9-4
timer 1 baud rate, 9-11, 9-12
timer 2 baud rate, 9-12-9-14
timing, mode 0, 9-5
SETB instruction, 4-12, A-23
SFRs
accessing, 3-12
address space, 3-1, 3-2
idle mode, 11-4
map, 3-13
MCS 51 architecture, 3-4
powerdown mode, 11-5
reset initialization, 10-6
reset values, 3-12
tables of, 3-14
unimplemented, 3-2, 3-12
Shift instruction, 4-11
Signal descriptions, 8-4
Signature bytes
setup for verifying, 13-2-13-3
values, 13-10
verifying, 13-1, 13-10
SJMP instruction, 4-16, A-24
SLL instruction, 4-11, A-17

Software
application notes, 1-6
Source register, 4-5
SP, 3-11, 3-12, 3-13, 3-14, C-30
Special function registers See SFRs
SPH, 3-11, 3-12, 3-13, 3-14, C-31
SPX, 3-10, 3-11, 3-12
SRA instruction, 4-11, A-18
SRL instruction, 4-11, A-18
State time, 2-5
SUB instruction, 4-10, A-14
SUBB instruction, 4-10, A-14
SWAP instruction, 4-11, A-18

## T

T1:0, 6-1, 7-3, B-3
T2, 6-1, 7-3, B-4
T2CON, 3-13, 3-15, 7-1, 7-2, 7-10, 9-13, C-32
baud rate generator, 9-12
bit definitions, 7-17
T2EX, 6-1, 7-3, 7-11, 9-12, B-4
T2MOD, 3-13, 3-15, 7-1, 7-2, 7-10, C-33 bit definitions, 7-16
Target address, 4-6
TCON, 3-13, 3-15, 7-1, 7-2, 7-4, 7-6, C-34
bit definitions, 7-8
interrupts, 5-1
TH2, TL2
baud rate generator, 9-14
baud-rate generator, 9-12
THx, TLx ( $\mathrm{x}=0,1,2$ ), 3-13, 3-15, 7-2, C-36, C-37, C-38
Timer 0, 7-4-7-8
applications, 7-9
auto-reload, 7-5
counter/timer select, 7-7
interrupt, 7-4, 7-8
mode 0, 7-4
mode 1, 7-5
mode 2, 7-5
mode 3, 7-5
mode selection, 7-7
pulse width measurements, 7-10
Timer 1
applications, 7-9
auto-reload, 7-9
baud rate generator, 7-6
counter/timer select, 7-7
interrupt, 7-6, 7-8
mode 0, 7-6
mode 1, 7-9
mode 2, 7-9
mode 3, 7-9
mode selection, 7-7
pulse width measurements, 7-10
Timer 2, 7-10-7-17
auto-reload mode, 7-12
baud rate generator, 7-14
capture mode, 7-11
clock out mode, 7-14
interrupt, 7-11
mode select, 7-15
Timer/counters, 7-1-7-17
external input sampling, 7-3
internal clock, 7-3
interrupts, 7-1
overview, 7-1-7-3
registers, 7-2
SFRs, 3-15
signal descriptions, 7-3
See also Timer 0, Timer 1, Timer 2
Timing
symbol definitions, 12-28
TMOD, 3-13, 3-15, 7-1, 7-2, 7-4, 7-6, 9-11, C-35
bit definitions, 7-7
Tosc, 2-5, 2-6
See also Oscillator
TRAP instruction, 4-17, 5-3, 5-5, 5-15, A-25
TXD, 6-1, 9-1, B-4
mode 0, 9-4
modes 1, 2, 3, 9-6

## U

UART, 9-1
UD flag, 4-19

## V

Vcc, 10-2, B-4
during reset, 10-5
power off flag, 11-1
powerdown mode, 11-5, 11-6
power-on reset, 10-7
See also Power supply
Vcc2, 10-2, B-4

Vpp, 13-1, B-4
requirements, 13-3
Vss, B-4
Vss1, 10-2, B-4
Vss2, 10-2, B-4

## W

Wait state, 12-6
configuring for, 13-6
extended ALE, 12-6
PSEN\#/RD\#/WR\#, 4-1, 12-6, A-1, A-11
Watchdog timer
SFRs, 3-15
Watchdog timer (hardware), 7-16-7-18
enabling, disabling, 7-16
in idle mode, 7-18
in powerdown mode, 7-18
overflow, 7-16
WDT
initiating reset, $10-5$
WDTRST, 3-13, 3-15, 7-2, 7-16, C-39
WR\#, 6-1, B-4
described, 12-2
WSA, WSB bits, 12-6

## X

XALE bit, 12-6
XCH instruction, 4-12, A-22
XCHD instruction, 4-12, A-22
XRL instruction, 4-11
XTAL1, B-4
XTAL1, XTAL2, 10-3
capacitance loading, 10-4
XTAL2, B-4

## Z

Z flag, 4-11, 4-20

## NORTH AMERICAN SALES OFFICES

## ALABAMA <br> Intel Corp.

 4024 Medford Drive Huntsville 35802 Tel: (205) 883-6137 FAX: (205) 883-4826
## ARIZONA

†Intel Corp.
410 North 44th Street Suite 500
Phoenix 85008
Tel: ( 800 ) 628-8686
FAX: (602) 244-0446

## CALIFORNIA

Intel Corp.
3550 Watt Avenue
Suite 140
Sacramento 95821 Fel: (800) 628-8686
† Intel Corp.
9655 Granite Ridge Drive
3rd Floor, Suite 4A
San Diego 92123
Tel: (800) 628-8686
FAX: (619) 467-2460
Intel Corp.
1781 Fox Drive
Tel: (800) 628-8686 FAX: (408) 441-9540
*intel Corp.
1551 N. Tustin Avenue Suite 800
Santa Ana 92701
Tel: (800) 628-8686
TWX: 910-595-1114
FAX: (714) 541-9157
†Intel Corp.
15260 Ventura Boulevard
Suite 360
Sherman Oaks 91403
FAX: (818) 995-6624
Intel Corp.
120 Birmingham
Suite 110-114
Cardiff, CA 92007
Tel: (619) 942-8938
FAX: (619) $942-2849$
Intel Corp.
300 N. Continental Blvd.
Suite 100
El Segundo 90245
Tel: (800) 628-8686
FAX: (310) 640-7133
COLORADO

* $\dagger$ Intel Corp.

600 S . Cherry St.
Suite 700
Denver 80222
Tel: (800) 628-8686
FAX: (303) 322-8670
CONNECTICUT
†Intel Corp.
40 Old Ridgebury Road
Suite 311
Danbury 06877
FAX: ( 200 ) 628-8686

## FLORIDA

tIntel Corp.
800 Fairway Drive
Suite 160
Deerfield Beach 33441
Tel: (800) 628-8686
FAX: (305) 421-244 (305) 42124

Intel Corp.
Suite Lucien Way
Suite 100, Room
Tel: (800) 628-8686
FAX: (407) 660-1283GEORGIA
$\dagger$ Intel Corp.
20 Technology Park
Suite 150
Norcross 30092
Tel: (800) 628-8686
FAX: (404) 448-0875
IDAHO
Intel Corp.
9456 Fairview Ave., Suite C
Boise 83704
Tel: (800) 628-8686
FAX: (208) 377-1052
ILLNOIS
*tintel Corp
Woodfield Corp. Center III 300 N. Martingale Road
Suite 400
Schaumburg 60173
Tell: (800) 628-8686
FAX: (708) 605-9762

## INDIANA

$\dagger$ Intel Corp.
8041 Knue Road
Indianapolis 46250
Tel: (800) 628-8686
FAX: (317) 577-4939

## MARYLAND

*intel Corp.
10010 Junction Dr.
Suite 200
Annapolis Junction 20701
Tel: (800) 628-8686
FAX: (301) 206-3678
MASSACHUSETTS
*intel Corp.
Westford Corp. Center
5 Carlisle Road
2nd Floor
Westford 01886
Tel: (800) 628-8686
TWX: 710-343-6333

## MICHIGAN

†Intel Corp.
7071 Orchard Lake Road
Suite 100
West Bloomfield 48322
Tel: (800) 628-8686
FAX: (313) 851-8770
Intel Corp.
32255 N. Western Hwy.
Suite 212, Tri Atria
Farmington Hills 48334
Tel: (800) 628-8686
FAX: (313) 851-8770

## MINNESOTA

† Intel Corp.
3500 W. 80th St
Suite 360
Bloomington 55431
Tel: (800) 628-8686
FAX: (612) 831-6497

## NEW JERSEY

Intel Corp
2001 Route 46, Suite 310
Parsippany 07054-1315
Tel: (800) 628-8686
FAX: (201) 402-4893
-
*intel Corp.
125 Half Mile Road
125 Half Mile Road
Red Bank 07701
Tel: (800) 628-8686
FAX: (908) 747-0983NEW YORK

## 850 Cross Keys Office Park <br> Fairport 14450 <br> Tel: (800) 628-8686 <br> TWX: 510-253-7391 FAX: 716 ) $223-2561$ <br> * + Intel Corp. <br> 2950 Express Dr. South <br> Suite 130 <br> Islandia 11722 <br> Tel: (800) 628-8686 <br> TWX: 510-227-6236 <br> FAX: (516) 348-7939 <br> OHIO <br> *Intel Corp. <br> 56 Milford Dr., Suite 205 <br> Hudson 44236 <br> Tel: (800) 628-8686 <br> FAX: (216) 528-1026 <br> * + Intel Corp. <br> 3401 Park Center Drive <br> Suite 220 <br> Tel: (800) 628-8686 <br> TWX: 810-450-2528 <br> FAX: (513) 890-8658

OKLAHOMA
Intel Corp.
6801 N. Broadway
Suite 115
Oklahoma City 73162
Tel: ( 800 ) 628-8686
FAX: (405) 840-9819

## OREGON

Intel Corp.
15254 NW Greenbrier Pkwy.
Building B
Beaverton 97006
Tel: (800) 628-8686
TWX: 910-467-8741
FAX: (503) 645-8181
PENNSYLVANIA

* $\dagger$ Intel Corp.

925 Harvest Drive
Suite 200
Blue Bell 19422
Tel: (800) 628-8686
FAX: (215) 641-0785
SOUTH CAROLINA
7403 Parklane Rd., Suite 4
7403 Parklane
Columbia 29223
Tel: (800) 628-8686
Tel: (800) 628-8686
FAX: (803) 788-7999
Intel Corp.
100 Executive Center Drive
Suite 109, B183
Greenville 29615
Tel: (800) 628-8686
FAX: (803) 297-3401

TEXAS
$\dagger$ Intel Corp.
8911 N. Capital of Texas Hwy.
Suite 4230
Austin 78759
FAX: (512) 338-933
: (512) 338-9335
*tintel Corp.
5000 Quorum Drive
Suite 750
Dallas 75240
Tel: (800) 628-8686
FAX: (214) 233-1325

* $\dagger$ Intel Corp.

20515 SH 249
Suite 401
Houston 77070
Tel: (800) 628-8686
TWX: 910-881-2490
FAX: (713) 376-2891
UTAH
IIntel Corp.
428 East 6400 South
Suite 135
Murray 84107
FAX: (801) 268-1457
Intel Corp.
2581 E. Cobblestone Way
Sandy, UT 84093
Tel: (801) 942-8820
FAX: (801) $942-8815$
WASHINGTON
$\dagger$ Intel Corp.
2800 156th Avenue SE
Suite 105
Bellevue 98007
Tel: (800) 628-8686
FAX: (206) 746-4495
WISCONSIN
Intel Corp.
Intel Corp.
400 N. Executive Dr.
Suite 401
Brookfield 53005
Tel: (800) 628-8686
FAX: (414) 789-2746
CANADA
BRITISH COLUMBIA
Intel Semiconductor of
Canada, Ltd.
999 Canada Place
Suite 404, \#11
Vancouver V6C 3E2
Tel: (800) 628-8686
FAX: (604) 844-2813
ONTARIO
$\dagger$ Intel Semiconductor of
Canada, Ltd.
2650 Queensview Drive
Suite 250
Ottawa K2B 8H6
FAX: $(800) 628-8686$
FAX: (613) 820-5936
$\dagger$ Intel Semiconductor of
Canada, Ltd.
190 Attwell Drive
Suite 500
Rexdale M9W $6 \mathrm{H8}$
Tel: (800) 628-8686
FAX: (416) 675-2438

## QUEBEC

$\dagger$ Intel Semiconductor of
Canada, Ltd
1 Rue Holiday, Tour West
Suite 320
Pt. Claire H9R 5N3
Tel: (800) 628-8686

FAX: 514-694-0064
(103004

+ TAX:514

[^4]




NORTH AMERICAN DISTRIBUTORS

| ALABAMA | Arrow/Schweber Electronics |
| :---: | :---: |
| Arrow/Schweber Electronics | Calabasas 91302 |
| 1015 Henderson Road | Tel: (818) 880-9686 |
| Huntsville 35806 | FAX: (818) 772-8930 |
| Tel: (205) 837-6955 FAX: (205) 721-1581 | Arrow/Schweber Electronics |
| Hamilton Hallmark | 48834. Kato Rd., Suite 103 |
| 4890 University Square, \#1 | Tel: (510) 490-9477 |
| $\begin{aligned} & \text { Huntsville } 35816 \\ & \text { Tel: (205) } 837-8700 \\ & \text { FAX: (205) } 830-2565 \end{aligned}$ | Arrow/Schweber Electronics 6 Cromwell, \#100 |
| MTI Systems 4950 Corporate Dr., \#120 | $\begin{aligned} & \text { Tel: (714) 838-5422 } \\ & \text { FAX: (714) 454-4206 } \end{aligned}$ |
| Huntsville 35805 <br> Tel: (205) 830-9526 <br> FAX: (205) 830-9557 | Arrow/Schweber Electronics 9511 Ridgehaven Court |
| Pioneer Technologies Group 4835 University Square, \#5 | $\begin{aligned} & \text { Tel: (619) 565-4800 } \\ & \text { FAX: (619) 279-8062 } \end{aligned}$ |
| Huntsville 35805 <br> Tel: (205) 837-9300 <br> FAX: (205) 837-9358 | Arrow/Schweber Electronics 1180 Murphy Avenue |
| Wyle Laboratories | Tel: (408) 441-9700 |
| 7800 Govemers Drive | FAX: (408) 453-4810 |
| Tower Building, 2nd Floor |  |
| Huntsville 35806 | Avnet Computer |
| Tel: (205) 830-1119 | 3170 Pullman Street |
| FAX: (205) 830-1520 | Costa Mesa 92626 |
| ARIZONA | Tel: (714) 641-4150 |
| Anthem Electronics |  |
| 1555 W. 10th Place, \#101 | Avnet Computer |
| Tempe 85281 | 1361B West 190th Street |
| Tel: (602) 966-6600 | Gardena 90248 |
| FAX: (602) 966-4826 | Tel: (800) 426-7999 |
| Arrow/Schweber Electronics |  |
| 2415 W. Erie Drive | Avnet Computer |
| Tempe 85282 | 755 Sunrise Blvd, \#150 |
| Tel: (602) 431-0030 | Roseville 95661 |
| FAX: (602) 252-9109 | Tel: (916) 781-2521 |
| Avnet Computer | FAX: (916) 781-3819 |
| 1626 S. Edwards Drive | Avnet Computer |
| Tempe 85281 | 1175 Bordeaux Drive, \#A |
| Tel: (602) 902-4600 | Sunnyvale 94089 |
| FAX: (602) 902-4640 | Tel: (408) 743-3454 |
| Hamilton Hallmark | FAX: (408) 743-3348 |
| 4637 S. 36th Place | Avnet Computer |
| Phoenix 85040 | 21150 Califa Street |
| Tel: (602) 437-1200 | Woodland Hills 91376 |
| FAX: (602) 437-2348 | Tel: (818) 594-8301 |
| Wyle Laboratories | FAX: (818) 594-8333 |
| 4141 E. Raymond | Hamilton Hallmark |
| Phoenix 85040 | 3170 Pullman Street |
| Tel: (602) 437-2088 | Costa Mesa 92626 |
| FAX: (602) 437-2124 | Tel: (714) 641-4100 |
| CALIFORNIA | FAX: (714) 641-4122 |
|  | Hamilton Hallmark |
| Anthem Electronics | 1175 Bordeaux Drive, \#A |
| 9131 Oakdale Avenue | Sunnyvale 94089 |
| Chatsworth 91311 | Tel: (408) 435-3500 |
| Tel: (818) 775-1333 | FAX: (408) 745-6679 |
| FAX: (818) 775-1302 |  |
| Anthem Electronics | 4545 Viewridge Avenue |
| 1 Oldfield Drive | San Diego 92123 |
| Irvine 92718-2809 | Tel: (619) 571 -7540 |
| Tel: (714) 768-4444 | FAX: (619) 277-6136 |
| FAX: (714) 768-6456 |  |
| Anthem Electronics | Hamilton Hallmark 21150 Califa St |
| 580 Menlo Drive, \#8 | Woodland Hills 91367 |
| Rocklin 95677 |  |
| Tel: (916) 624-9744 | FAX: (818) 594-8234 |
| FAX: (916) 624-9750 |  |
| Anthem Electronics |  |
| ${ }^{\text {Anthem }}$ 9369 Carroll Park Drive | 580 Menlo Drive, \#2 Rocklin 95762 |
| San Diego 92121 | Tel: (916) 624-9781 |
| Tel: (619) 453-9005 | FAX: (916) 961-0922 |
| FAX: (619) 546-7893 |  |
| Anthem Electronics | Pioneer Standard 5850 Canoga Blvd \#400 |
| 1160 Ridder Park Drive | Woodland Hills 91367 |
| San Jose 95131 |  |
| Tel: (408) 452-2219 |  |
| FAX: (408) 441-4504 | Pioneer Standard |
| Arrow Commercial Systems Group 1502 Crocker Avenue | 217 Technology Dr.; \#110 <br> Invine 92718 |
| Hayward 94544 | Tel: (714) 753-5090 |
| $\begin{aligned} & \text { Tel: (510) 489-5371 } \\ & \text { FAX: (510) 489-9393 } \end{aligned}$ | Pioneer Technologies Group 134 Rio Robles |
| Arrow Commercial Systems Group | San Jose 95134 <br> Tel. (408) 954-9100 |
| 14242 Chambers Road | Tel: (408) 954-9100 |
| Tustin 92680 |  |
| Tel: (714) 544-0200 FAX: (714) 731-8438 |  |


| Wyle Laboratories 15370 Barranca Pkwy Invine 92713 <br> Tel: (714) 753-9953 <br> FAX: (714) 753-9877 | Hamilton Halimark <br> 125 Commerce Court, Unit 6 <br> Cheshire 06410 <br> Tel: (203) 271-2844 <br> FAX: (203) 272-1704 |
| :---: | :---: |
| Wyle Laboratories 15360 Barranca Pkwy, \#200 Invine 92713 <br> Tel: (714) 753-9953 FAX: (714) 753-9877 | Pioneer Standard 2 Trap Falls Road Shelton 06484 Tel: (203) 929-5600 |
| Wyle Laboratories 2951 Sunrise Blvd., \#175 Rancho Cordova 95742 Tel: (916) 638-5282 FAX: (916) 638-1491 | FLORIDA <br> Anthem Electronics 598 South Northlake Blvd., \#1024 Altamonte Springs 32701 <br> Tel: (813) 797-2900 <br> FAX: (813) 796-4880 |
| 9525 Chesapeake Drive <br> San Diego 92123 <br> Tel: (619) 565-9171 <br> FAX: (6t9) 365-0512 | Arrow/Schweber Electronics 400 Fairway Drive, \#102 Deerfield Beach 33441 <br> Tel: (305) 429-8200 FAX: (305) 428-3991 |
| 3000 Bowers Avenue <br> Santa Clara 95051 <br> Tel: (408) 727-2500 <br> FAX: (408) 727-5896 | Arrow/Schweber Electronics 37 Skyline Drive, \#3101 <br> Lake Mary 32746 <br> Tel: (407) 333-9300 <br> FAX: (407) 333-9320 |
| 17872 Cowan Avenue <br> Invine 92714 <br> Tel: (714) 863-9953 <br> FAX: (714) 263-0473 | Avnet Computer 3343 W. Commercial Boulevard Bldg. C/D, Suite 107 Ft. Lauderdale 33309 |
| Wyle Laboratories 26010 Mureau Road, \#150 | FAX: (305) 730-0368 |
| Calabasas 91302 <br> Tel: (818) 880-9000 <br> FAX: (818) 880-5510 | Avnet Computer 3247 Tech Drive North St. Petersburg 33716 |
| Zeus Arrow Electronics 6276 San Ignacio Ave., \#E | Tel: (813) 573-5524 FAX: (813) $572-4324$ |
| San Jose 95119 <br> Tel: (408) 629-4789 <br> FAX: (408) 629-4792 | Hamilton Hallmark 3350 N.W. 53rd St., \#105-107 Ft. Lauderdale 33309 |
| Zeus Arrow Electronics 22700 Savi Ranch Pkwy. | Tel: (305) 484-5482 FAX: $(305)$ 484-2995 |
| Yorba Linda 92687-4613 <br> Tel: (714) 921-9000 FAX: (714) 921-2715 <br> COLORADO | Hamilton/Avnet 10491 72nd St. North Largo 34647 <br> Tel: (813) 541-7440 <br> FAX: (813) 544-4394 |
| Anthem Electronics 373 Inverness Drive South Englewood 80112 Tel: (303) 790-4500 FAX: (303) 790-4532 | Hamilton/Avnet 7079 University Boulevard Winter Park 32792 Tel: (407) 657-3300 FAX: (407) 678-4414 |
| Arrow/Schweber Electronics 61 Inverness Dr. East, \#105 Englewood 80112 <br> Tel: (303) 799-0258 <br> FAX: (303) 373-5760 | Pioneer Technologies Group 337 Northlake Blvd., \#1000 Alta Monte Springs 32701 Tel: (407) 834-9090 FAX: (407) 834-0865 |
| Hamilton Hallmark 12503 E. Euclid Drive, \#20 Englewood 80111 Tel: (303) 790-1662 FAX: (303) 790-4991 | Pioneer Technologies Group 674 S. Military Trail <br> Deerfield Beach 33442 <br> Tel: (305) 428-8877 <br> FAX: (305) 481-2950 |
| Hamilton Hallmark 710 Wooten Road, \#102 Colorado Springs 80915 Tel: (719) 637-0055 | Pioneer Technologies Group 8031-2 Phillips Highway Jacksonville 32256 <br> Tel: (904) 730-0065 |
| FAX: (719) 637-0088 | Wyle Laboratories 1000112 Circle North |
| Wyle Laboratories 451 E. 124th Avenue Thomton 80241 Tel: (303) 457-9953 | St. Petersburg 33716 <br> Tel: (813) 530-3400 <br> FAX: (813) 579-1518 |
| FAX: (303) 457-4831 | GEORGIA |
| CONNECTICUT <br> Anthem Electronics 61 Mattatuck Heights Road Waterburg 06705 | Arrow Commercial Systems Group 3400 C. Corporate Way Duluth 30136 <br> Tel: (404) 623-8825 <br> FAX: (404) 623-8802 |
| Tel: (203) $575-1575$ FAX: (203) $596-3232$ | Arrow/Schweber Electronics 4250 E. Rivergreen Pkwy., \#E |
| Arrow/Schweber Electronics <br> 12 Beaumont Road <br> Wallingford 06492 <br> Tel: (203) 265-7741 <br> FAX: (203) 265-7988 | Duluth 30136 <br> Tel: (404) 497-1300 <br> FAX: (404) 476-1493 |
| Avnet Computer 55 Federal Road, \#103 Danbury 06810 Tel: (203) 797-2880 FAX: (203) 791-9050 | 3425 Corporate Way, \#G Duluth 30136 <br> Tel: (404) 623-5452 <br> FAX: (404) 476-0125 |

## NORTH AMERICAN DISTRIBUTORS (Contd.)



KENTUCKY
Hamilton Hallmark
1847 Mercer Rd., \#G
Lexington 40511
Tel: (800) 235-6039
FAX: (606) 288-4936
MARYL.AND
Anthem Electronics
7168A Columbia Gateway Drive
Columbia 21046
Tel: (410) 995-6640
FAX: (410) 290-9862
Arrow Commercial Systems Group 200 Perry Parkway
Tel. (301) 670.1600 FAX: (301) 670-0188

Arrow/Schweber Electronics 9800 J Patuxent Woods Dr.
Columbia 21046
Tel: (301) 596-7800
FAX: (301) 995-6201
Avnet Computer
7172 Columbia Gateway Dr., \#G
Columbia 21045
FAX: (301) ${ }^{\text {(301) }}$ 995-3515
Hamilton Hallmark
10240 Old Columbia Road
Columbia 21046
Tel: (410) 988-9800
FAX: (410) 381-2036
North Atlantic Industries
Systems Division
7125 River Wood Dr.
Columbia 21046
Tel: (301) $312-5800$
FAX: (301) $312-5850$
Pioneer Technologies Group 9100 Gaither Road
Gaithersburg 2087
Tel: (301) 921-0660
FAX: (301) 670-6746
Wyle Laboratories
7180 Columbia Gateway Dr
Columbia 21046
Columbia 21046
Tel
(110)
$312-4844$
Tel: (410) $312-4844$
FAX: (410) 312-4953

## MASSACHUSETTS

Anthem Electronics
36 Jonspin Road Wilmington 01887
Tel: (508) 657-5170
FAX: $(508) 657-6008$
Arrow/Schweber Electronics
25 Upton Drive
Wilmington 01887
Tel: (508) 658-0900
FAX: (508) 694-1754
Avnet Computer
10 D Centennial Drive
Peabody 01960
FAX: (508) 532-9660
Hamilton Hallmark
10 D Centennial Drive
Peabody 01960
Tel: (508) 531-7430
FAX: (508) 532-9802
Pioneer Standard
44 Hartwell Avenue
Lexington 02173
FAX: (617) 863-1547
Wyle Laboratories
15 Third Avenue
Burlington 01803
Tel: (617) 272-7300
FAX: (617) 272-6809

## MICHIGAN

Arrow/Schweber Electronics
19880 Haggerty Road
Livonia 48152
Tel: (800) 231-7902
FAX: (313) 462-2686

Avnet Computer
2876 28th Street, S.W., \#5
Grandvilie 49418
FAX: (616) 531-0059
Avnet Compute
41650 Garden Brook Rd. \#120
Novi 48375
Tel: (313) 347-1820
FAX: (313) 347-4067
Hamilton Hallmark
44191 Plymouth Oaks Blvd., \#1300
Plymouth 48170
Tel: (313) 416-5800
FAX: (313) 416-581
Hamilton Hallmark
41650 Garden Brook Rd., \#100
Novi 49418
el: (313) 347-4271

Pioneer Standard
4505 Broadmoor S.E.
Grand Rapids 49512
FAX: (616) 698-1831
Pioneer Standard
13485 Stamford Ct.
ivonia 48150
Tel: (313) 525-1800
FAX: (313) 427-3720
MINNESOTA
Anthem Electronics
7646 Golden Triangle Drive
Eden Prairie 55344
Tel: (612) 944-5454
FAX: (612) 944-3045
Arrow/Schweber Electronics
10100 Viking Drive, \#100
Eden Prairie 55344
FAX: (612) 942-7803
Avnet Computer
10000 West 76th Street
Eden Prairie 55344
Tel: (812) 829-0025
FAX: (612) 944-2781
Hamilton Hallmark
9401 James Ave. South, \#140
loomington 55431
FAX: (612) 881-9461
Pioneer Standard
7625 Golden Triangle Dr., \#G
den Prairie 55344
Tel: (612) 944-3355
FAX: (612) 944-3794
Wyle Laboratories
1325 E. 79th Street, \#1
Bloomington 55425
el: (612) 853-2280

## MISSOURI

Arrow/Schweber Electronics
2380 Schuetz Road
t. Louis 63141
el: (314) 567-6888
FAX: (314) 567-1164
Avnet Computer
741 Goddard Avenue
Chesterfield 63005
Tel: (314) 537-2725
FAX: (314) 537-4248
Hamilton Hallmark
3783 Rider Trail South
Earth City 63045
Tel: (314) 291-5350
FAX: (314) 291-0362
NEW HAMPSHIRE
Avnet Computer
2 Executive Park Drive
Bedford 03102
Tel: (800) 442-8638
FAX: (603) 624-2402

NEW JERSEY
Anthem Electronics
26 Chapin Road, Unit K
Pine Brook 07058
Tel: (201) 227-7960
FAX: (201) 227-9246
Arrow/Schweber Electronics
4 East Stow Rd., Unit 1
Marlton 08053
Tel: (609) 596-8000
FAX: (609) 596-9632
Arrow/Schweber Electronics
43 Route 46 East
Pine Brook 07058
Tel: (201) 227-7880
FAX: (201) 538-4962
Avnet Computer
1-B Keystone Ave., Bldg. 36
Cherry Hill 08003
Tel: (609) 424-8961
FAX: (609) 751-2502
Hamilton Hallmark
1 Keystone Ave., Bldg. 36
Chery Hill 08003
FAX: (609) 751-2552
Hamilton Hallmark
10 Lanidex Plaza West
Parsippany 07054
Tel: (201) 515-5300
FAX: (201) 515-1601
MTI Systems
43 Route 46 East
Pinebrook 07058
Tel: (201) 882-8780
FAX: (201) 539-6430
Anthem Electronics
19017-120th Ave., N.E. \#102
Bothell 98011
Tel: (206) 483-1700
FAX: (206) 486-0571
Avnet Computer
17761 N.E. 78th Place
Redmond 98052
Tel: (206) 867-0160
FAX: (206) 867-0161
Hamilton Hallmark
8630 154th Avenue
Redmond 98052
FAX: (206) 867-0159
Wyle Laboratories
15385 N.E. 90th Street
Redmond 98052
Tel: (206) 881-1150
FAX: (206) 881-1567
PioneerStandard
14-A Madison Rd
Fairfield 07006
Tel: (201) 575-3510
FAX: (201) 575-3454
Wyle Laboratories
20 Chapin Road, Bidg. 10-13
Pinebrook 07058
Tel: (201) 882-8358
FAX: 201 ) $882-9109$
FAX: (201) 882-9109
NEW MEXICO
Alliance Electronics, Inc
10510 Research Ave.
Albuquerque 87123
Tel: (505) 292-3360
FAX: (505) 275-6392
Avnet Computer
7801 Academy Rd.
Aldg. 1, Suite 204
Tel: (505) 828-9725
FAX: (505) 828-0360
NEW YORK
Anthem Electronics
47 Mall Drive
Commack 11725
FAX: (516) 493-2244

# NORTH AMERICAN DISTRIBUTORS (Contd.) 

Arrow/Schweber Electronics 3375 Brighton Henrietta Townline Rd.
Rochester 14623
FAX: (716) 427-0735
Arrow/Schweber Electronics 20 Oser Avenue Hauppauge 11788 Tel: $(516) 231-1000$
FAX: (516) 231-1072

Avnet Computer 933 Motor Parkway el: (516) 434-7443 FAX: (516) 434-7426
Avnet Computer O60 Townline Rd
ochester 14623 FAX: (716) 272-9685

Hamilton/Avnet 933 Motor Parkway el: (516) 434-7470 FAX: (516) 434-7491
Hamilton Hallmark 057 E. Henrietta Road Rochester 14623 FAX: (716) 475-9119

Hamilton Halimark 075 Veterans Memorial Hwy Ronkonkoma 11779 el: (516) 737-0600 FAX: (516) 737-0838

MTI Systems
Penn Plaza
150 W. 34th Stree
New York 10119
Tel: (212) 643-1280 FAX: (212) 643-1288

Pioneer Standard 68 Corporate Drive
Binghamton 13904
el: (607) 722-9300
FAX: (607) 722-9562
Pioneer Standard 0 Crossway Park West Woodbury, Long Island 11797 Tel: (516) 921-8700 FAX: (516) 921-2143

Pioneer Standard 840 Fairport Park Fairport 14450 Tel: (716) 381-7070
FAX: (716) 381-5955
Zeus Arrow Electronics
00 Midland Avenue
Port Chester 10573
FAX: (914) 937-2553

## NORTH CAROLINA

Arrow/Schweber Electronic
240 Greensdairy Road
Raleigh 27604
el: (919) 876-3132
FAX: (919) 878-9517
Avnet Computer
725 Millbrook Rd., \#123
Raleigh 27604
el: (919) 790-1735
Hamilton Hallmark
5234 Greensdairy Road
Raleigh 27604
(1). (919) 07819

Pioneer Technologies Group
200 Gateway Ctr. Blvd., \#21
Morrisville 27560
el: (919) 460-1530
FAX: (919) 460-1540
OHIO
Arrow Commercial Systems Group 84 Cramer Creek Court
Dublin 43017
el: (614) 889-9347
FAX: (614) 889-9680

Arrow/Schweber Electronics 6573 Cochran Road, \#E Solon 44139
Tel: (216) 248-3990
FAX: (216) 248-1106
Arrow/Schweber Electronics 8200 Washington Village Dr Centerville 45458
Tel: (513) 435-5563
FAX: 513 ) 435-2049
Avnet Computer
7764 Washington Village Dr.
Dayton 45459
Tel: (513) 439-6756
FAX: (513) 439-6719
Avnet Computer
30325 Bainbridge Rd., Bldg. A Solon 44139
FAX. (210) 349-2505
Hamilton Hallmark
7760 Washington Village Dr.
Dayton 45459
Tel: (513) 439-6735
FAX: (513) 439-6711
Hamilton Hallmark
5821 Harper Road
Solon 44139
FAX: (210)
Hamilton Hallmark
777 Dearborn Park Lane, \#L
Worthington 43085
Tel: (614) 888-3313
FAX: (614) 888-0767
MTI Systems
23404 Commerce Park Rd. Beachwood 44122 FAX: (216) 464-3564

Pioneer Standard 4433 Interpoint Boulevard
Dayton 45424
Tel: (513) 236-9900
FAX: (513) 236-8133
Pioneer Standard
4800 E. 131 st Street
Cleveland 44105
Tel: (216) 587-3600
FAX: (216) 663-1004

## OKLAHOMA

Arrow/Schweber Electronics
12101 East 51st Street, \#106
Tulsa 74146
Tel: (918) 252-7537
FAX: (918) 254-0917
Hamilton Hallmark
5411 S. 125th E. Ave., \#305
Tulsa 74146
FAX. (918) 254110
Pioneer Standard
9717 E. 42nd St., \#105
Tulsa 74146
Tel: (918) 665-7840
FAX: (918) 665-1891
OREGON
AlmacArrow Electronics
1885 N.W. 169th Place
Beaverton 97006
Tel: (503) 629-8090
FAX: (503) 645-0611
Anthem Electronics
9090 S.W. Gemini Drive
Beaverton 97005
Tel: (503) 643-1114
FAX: (503) 626-7928
Avnet Computer
9750 Southwest Nimbus Ave.
Beaverton 97005
Tel: (503) 627-0900
FAX: (503) 526-6242
Hamilton Hallmark 9750 Southwest Nimbus Ave
Beaverton 97005
Tel: (503) 526-6200
FAX: (503) 641-5939

Wyle Laboratories
9640 Sunshine Court
Bldg. G, Suite 200 Beaverton 97005 Tel: (503) 643-7900 FAX: (503) 646-5466

## PENNSYLVANIA

Anthem Electronics
355 Business Center Dr
355 Business Ce
Horsham 19044
Horsham 19044
Tel: (215) 443-5150
FAX: (215) 675-9875
Avnet Computer
213 Executive Drive, \#320
Mars 16046
Tel: (412) 772-1888
FAX: (412) 772-1890
Pioneer Technologies Group 259 Kappa Drive Pittsburgh 15238 FAX: (412) 963 -8255

Pioneer Technologies Group 500 Enterprise Road Keith Valley Business Center Horsham 19044 Tel: (215) 530-4700
Wyle Laboratories
1 Eves Drive, \#111
Marton 08053-3185
Tel: (609) 985-7953
FAX)
985-8757

## TEXAS

Anthem Electronics
651 N. Plano Road, \#401
Richardson 75081
Tel: (214) 238-7100
FAX: (214) 238-0237
Arrow/Schweber Electronics
11500 Metric Blvd., \#160
Austin 78758
Tel: (512) 835-4180
FAX: (512) 832-5921
Arrow/Schweber Electronic
3220 Commander Drive
Carrollton 75006
Tel: (214) 380-6464
FAX: (214) 248-7208
Arrow/Schweber Electronics
10899 Kinghurst Dr., \#100
Houston 77099
Tel: (713) 530-4700
Avnet Computer
4004 Beltine, Suite 200
Dallas 75244
Tel: (214) 308-8181
FAX: (214) 308-8129
Avnet Computer
1235 North Loop West, \#525
Houston 77008
Tel: (713) 867-8572
FAX: (713) 861-6851
Hamilton Hallmark 12211 Technology Blvd
Austin 78727
Tel: (512) 258-8848
FAX: (512) 258-3777
Hamilton Hallmark
11420 Page Mill Road
Dallas 75234
Tel: (214) 553-4300
FAX: (214) 553-4395
Hamilton Hallmark
8000 Westglen
Tel: (713) 781-6100
FAX: (713) 953-8420
Pioneer Standard
1826D Kramer Lane
Austin 78758
Tel: (512) 835-4000
FAX: (512) 835-9829
Pioneer Standard
13765 Beta Road
Dallas 75244
Tel: (214) 263-3168
FAX: (214) 490-6419

Pioneer Standard
10530 Rockley Road, \#100
Houston 77099
Tel: (713) 495-4700
FAX: (713) 495-5642
Wyle Laboratories
1810 Greenville Avenue
Richardson 75081
Tel: (214) 235-9953
FAX: (214) 644-5064
Wyle Laboratories
4030 West Braker Lane, \#330
Austin 78758
Tel: (512) 345-8853
FAX: (512) 345-9330
Wyle Laboratories
11001 South Wilcrest, \#100
Houston 77099
Tel: (713) 879-9953
FAX: (713) 879-6540

## UTAH

Anthem Electronics
1279 West 2200 South
Salt Lake City 84119
Tel: (801) 973-8555
FAX: (801) 973-8909
Arrow/Schweber Electronics
1946 W. Parkway Blvd.
Salt Lake City 84119
Tel: (801) 973-6913
FAX: (801) 972-0200
Avnet Computer
100 E. 6600 South, \#150
Salt Lake City 84121
Tel: (801) 266-1115
FAX: (801) 266-0362
Hamilton Hallmark
1100 East 6600 South, \#120
Salt Lake City 84121
FAX: (801) 263-0104
Wyle Laboratories
1325 West 2200 South, \#E
West Valley 84119
Tel: (801) 974-9953
FAX: (801) 972-2524

## WASHINGTON

AlmacArrow Electronics
14360 S.E. Eastgate Way
Bellevue 98007
Tel: (206) 643-9992
FAX: (206) 643-9709
WISCONSIN
Arrow/Schweber Electronics
200 N. Patrick, \#100
Brookfield 53045
Tel: : (414) 792-0150
FAX: (414) 792-0156
Avnet Computer
20875 Crossroads Circle, \#400
Waukesha 53186
Tel: (414) 784-8205
FAX: (414) 784-6006
Hamilton Hallmark
2440 S. 179th Street
New Berlin 53146

Pioneer Standard
20 Bishop Way \#163
Brookfield 53005
Tel: (414) 784-3480
FAX: (414) 780-3613
Wyle Laboratories
W226 N555 Eastmound Drive
Waukesha 53186
Tel: (414) 521-9333
FAX: (414) 521-9498

## ALASKA

Avnet Computer
1400 West Benson Blvd., \#400
Anchorage 99503
Tel: (907) 274-9899
FAX: (907) 277-2639

Tel: (414) 797-7844
FAX: (414) 797-9259

NORTH AMERICAN DISTRIBUTORS (Contd.)

## CANADA

alberta
Avnet Computer
2816 21st Street, Northeast
Calgary T2E 6Z2
Tel: (403) 291-3284
FAX: (403) 250-1591
Zentronics
6815 8th Street N.E., \#100
Calgary T2E 7H
AX: (403)
BRITISH COLUMBIA
AlmacArrow Electronics
B44 Baxter Place
Bumaby V5A 4T8
el: (604) 421-2333
AX: (604) 421-5030
Hamilton Halimark
8610 Commerce Court
Burnaby V5A 4N6
Tel: (604) 420-4101
FAX: (604) 420-5376

Zentronics
11400 Bridgeport Rd., \#108
Richmond V6X 1 T2
Tel: (604) 273-5575
FAX: (604) 273-2413
ONTARIO
Arrow/Schweber Electronics 1093 Meyerside, Unit 2 Mississauga L5T 1M4 Tel: (416) 670-7769
FAX: (416) 670-7781
Arrow/Schweber Electronics
36 Antares D Unit 100
36 Antares Dr.,
Nepean K2E 7W5 Nepean K2E 7W5 FAX: (613) 723-2018

Avnet Computer
Canada System Engineering Group 151 Superior Blvd.
Mississuaga LST 2L1
Tel: (416) 795-3835
Tel: (416) 795-3835
FAX: (416) 677-5091

Avnet Computer
190 Colonade Road Nepean K2E 7J5 Nepean K2E 7J5 FAX: (613) 226-1184
Hamilton Hallmark 151 Superior Blvd., Unit 1-6 Mississauga L5T 2L1 Tel: (416) 564-6060 FAX: (416) 564-6033
Hamilton Hallmark 190 Colonade Road Nepean K2E 7J5 Nepl: (613) 226-1700 FAX: (613) 226-1184
Zentronics
5600 Keaton Crescent, \# Mississauga L5R 3S5 Tel: (416) 507-2600 FAX: (416) 507-2831

Zentronics
155 Colonnade Rd., South \#17 Nepean K2E 7K1
Tel: (613) 226-8840
FAX: (613) 226-6352

QUEBEC
Arrow/Schweber Electronics
100 St. Regis Blvd.
Dorval H9P 2T5
el: (514) 421-7411
FAX: (514) 421-7430
Arrow Schweber Electronics 500 Boul. St.-Jean-Baptiste Ave.
Quebec H2E 5R9
FAX: (418) 871-6816
Avnet Computer 2795 Rue Halpern
St. Laurent H4S 1P8
Tel: (514) 335-2483
FAX: (514) 335-2481
Hamilton Hallmark
7575 Transcanada Highway \#600
7575 Transcanada H
St. Laurent H4T 2 V 6
Tel: (514) 335-1000
Tel:
FAX: (514) 335-2481
Zentronics
520 McCaffrey Streel
St. Laurent H4T 1N3
Tel: (514) 737-9700
FAX: (514), 737-5212

## EUROPEAN SALES OFFICES

## FINLAND

Intel Finland OY
Ruosilantie 2
0390 Helsinki
el: (358) 0544644
FAX: (358) 0544030

## FRANCE

Intel Corporation S.A.R.L
Corporation S.A.R.
78054 St. Quentin-en-Yvelines Cedex
Tel: (33) (1) 30577000 FAX: (33) (1) 30646032
GERMANY
Intel GmbH
Dornacher Strasse
35622 Feldkirchen/Muenchen
Tel: (49) 089/90992-0
FAX. (49) 089/90430

ISRAEL
Intel Semiconductor Ltd. Atidim Industrial Park-Neve Sharet P.O. Box 43202 Tel-Aviv 61430 Tel: (972) 03498080 FAX: (972) 03491870

ITALY
Intel Corporation Italia S.p.A Milanofiori Palazzo E 20094 Assago Milano Tel: (39) (2) 575441 FAX: (39) (2) 3498464 NETHERLANDS
Intel Semiconductor B.V. Postbus 84130 Postbus 84130
3009 CC Rotterdam 3009 CC Rotterdam Tel: (31) 104071111
FAX: (31) 104554688

RUSSIA
Intel Technologies, Inc Krementshugskaya 6/7 121357 Moscow
Tel: 007-095-4439785 FAX: 007-095-4459420 TLX: 612092 smail su.

## SPAIN

Intel Iberia S.A.
Zubaran, 28
28010 Madrid
FAX: (34) (1) 4107570

## SWEDEN

Intel Sweden A.B.
Dalvagen 24
17136 Solna
Tel: (46) 87055600
FAX: (46) 8278085
UNITED KINGDOM
Intel Corporation (U.K.) Ltd. Pipers Way
Swindon, Wiltshire SN3 1RJ
Tel: (44) (0793) 696000
FAX: (44) (0793) 641440

## EUROPEAN DISTRIBUTORS/REPRESENTATIVES

AUSTRIA
$\dagger$ *Elbatex GmbH
Eitnergasse 6
Tel: (43) 1816020
FAX: (43) 181602201
Omnilogic
-imbergerstrasse 10-12
A-1100 Wien
Tel: (43) 168464
FAX: (43) 168420482
$\dagger$ *Spoerle Elektronik
Heiligentstadter Str. 52
A-1190 Wien
Tel: (43) 131872700
AX: (43) 13692273

## BELGIUM

†*inelco
Avenue des Croix de Guerre 94
120 Bruxelles
AX. (32) 22442811
*Diode
Keiberg 2
Minervastraat, 14/B2
1930 Zaventem
Tel: (32) 27254660
FAX: (32) 27254511
Omnilogic
Budasteenweg 2
1830 Machelen
Tel: (32) 22525600
FAX: (32) 22525900
CZECH REPUBLIC
Elbatex
Prechodni 11/1600
CS-140 00 Praha 4-Krc
Tel: (42) 26928087
FAX: (42) 24718203

## DENMARK

*Avnet Nortec A/S Transformervej 17 DK-2730 Herlev Tel: (45) 42842000 FAX: (45) 44921552
*Famell Electronic Services AS Naverland 29
K-2600 Glostrup
Tel: (45) 42451822
FAX: (45) 42450786

## ESTONIA

*Avnet Baltronic AS
Akadsemia tee 21F, EE0026
Tallinn
T이: (327) 2527349
FAX: (372) 2527556

## FINLAND

$\dagger{ }^{*}$ C2000 Finland
Pyyntitie, 3
P.O. Box 44
F-02231 Espo
el: (358) 0887331
FAX: (358) 088733343
Avnet Nortec OY
talahdenkatu 22
F-00210 Helsinki
FAX: (358) 06922326

Farnell Electronic Services O.Y Tyopajakatu 5
Tr-0. 581 Helsinki
Tel: (358) 0739100

## FRANCE

Arrow Electronique Silic 585
94663 Rungis Cedex
Tel: (33) (1) 49784978
FAX: (33) (1) 49780596
Avnet EMG SA
79, Rue Pierre Semard
Tel: (33) (1) 49652500 FAX: (33) (1) 4965-2769

## $\dagger$ Metrologie

Tour d'Asniere
4, Avenue Laurent Cely
92606 Asnieres Cedex
Tel: (33) (1) 40809000
FAX: (33) (1) 47910561

EUROPEAN DISTRIBUTORS/REPRESENTATIVES (Cont'd)

$\dagger$ Metrologia
Rua Dr. Faria de Vasconcelos 3A
1900 Lisboa
Tel: (351) (1) 8472202
FAX: (351) (1) 8472197
RUSSIA
Merisel
3 Kroutitskiy Val St.
Section 2
109044 Moscow
Tel: (7) 0952764718
FAX: (7) 0952764714

## sLOVAKIA

Elbatex
Topol Cianska 23
SR 85105 Bratislava
Tel: (42) 7831320
SOUTH AFRICA
t*EBE
OO Box 912-1222
Silverton 0127
Meyerspark
Pretoria 184
Tel: (27) 128037680
FAX: (27) 128038294

## SPAIN

Arrow/ATD Electronica
Avenue de la Industria, 32-2B
28100 Alconbendas
Madrid
Tel: (34) (1) 6616551
FAX: (34) (1) 6616300
$\dagger$ Metrologia
Avda. Industria, 32-2
28100 Alconbendas
Madrid
Tel: (34) (1) 6611142
FAX: (34) (1) 6615755

## SWEDEN

$\dagger$ Avnet Computer AB
Box 184
S-123 23 Farsta
Tel: (46) 8930550
FAX: (46) B 949083
Avnet Nortec AB
Box 1830
S-17127 Solna
Tel: (46) 87051800
FAX: (46) 8836918
*Famell Electronic Services AB Ankdammsgatan 32
Ankdammsgatan
Box 1330
S-171 26 Solna
Tel: (46) 8830020
Tel: (46) 8830020
SWITZERLAND
tElbatex AG
Hardstrasse 72
CH-5430 Wettingen
FAX. (41) 56271240
$\dagger$ Fabrimex AG
Kirchenweg 5
CH-8032 Zurich
Tel: (41) 13868686
FAX: (41) 13832379
$\dagger$ IMITEC
Zurichstrasse
CH-8185 Winkel-Ruti FAX. (41) (1) 8620266
† ${ }^{\text {Ind }}$ dustrade A.G.
Hertistrasse 31
$\mathrm{CH}-8304$ Wallisellen
el: (41) (1) 8328111
FAX: (41) (1) 8307550

TURKEY
*Empa Electronic
Besyol Mah E-5 Karayolu Yani
Florya is Merkezi
No. 534630 Sefakoy Istanbul
Tel: (90) 2125993050
FAX: (90) 2125985353
Info
Buyukdere Cad. 107/3
Bangun Han Gayertepe
80300 Istanbu
Fel: (90) 2122750780
UNITED KINGDOM
*Arrow/MMD
3 Bennet Cour
Bennet Road
Reading RG2 OQX
Tel: (44) 734313232
FAX: (44) 734313255
*Avnet Access
Jubilee House
Letchworth SG6 1QH
Tel: (44) 462488500
FAX: (44) 462488567
*Bytech Electronics
12a Cedarwood
Chineham Business Park
Crockford Lane
Basingstoke RG12 1RW
FAX: (44) 256707162
Bytech On Board
12a Cedarwood
Chineham Business Park
Basingstoke RG24 OWD
Tel: (44) 256707386
FAX: (44) 256707486
$\dagger$ Bytech Systems
5 The Sterling Centre
Eastern Road
Bracknell RG12 2PW
FAX: (44) 344867270
*Datrontech PLC
42-44 Birchett Road
Aldershot
Hants-GU11 1LU
Tel: (44) 252313155
FAX: (44) 252341939
$\dagger$ Metrologie UK Ltd.
Metrologie Hous
Oxford Road
High Wycombe HP11 2EE
Tel: (44) 494526271
FAX: (44) 494421860
Omnilogic CPU PLC
Copse Road, St. Johns, Woking
Surrey GU21 1SX
Tel: (44) 483723411
FAX: (44) 483729974
UKRAINE
Kvasar Micro
Popudrenko Str. 52
253094 Kiev
Tel: (7) 0445168496
FAX: (7) 0445168608
UNITED ARAB EMIRATES
Graytech
POBox 50718
Dubai
Tel: (971) 4346952
FAX: (971) 4346546
UNITED STATES
Intel Corporation
2200 Mission College Boulevard ..... P.O. Box 58119Santa Clara, CA 95052-8119
JAPANIntel Japan K.K.
5-6 Tokodai
Tsukuba-shiIbaraki-ken, 300-26
FRANCE
Intel Corporation S.A.R.L.1. Rue Edison - BP 303
78054 Saint-Quentin-en-Yvelines, Cedex
UNITED KINGDOM
Intel Corporation (U.K.) Ltd.
Pipers Way
Swindon, SN3 1RJ WiltshireEngland
GERMANY
Intel GmbH
Dornacher Strasse 1
D-85622 Feldkirchen bei Muenchen
HONG KONGIntel Semiconductor Ltd.32/F, Two Pacific Place88 Queensway, Central
CANADA
Intel Semiconductor of Canada, Ltd.
190 Attwell Drive, Suite 500
Rexdale, Ontario M9W 6H8


[^0]:    $\dagger$ MCS ${ }^{\circledR} 51$ Microcontroller Family User's Manual (Order Number: 272383)

[^1]:    $\dagger$ Bits in the PSW and PSW1 registers reflect the status of the accumulator. There are no equivalent status indicators for the other registers.

[^2]:    $\dagger$ A page rollover occurs when the address increments from the top of one 256-byte page to the bottom of the next (e.g., from FF:FAFFH to FF:FB00H).

[^3]:    ${ }^{\dagger}$ This register resides in the register file. It can also be accessed as an SFR.

[^4]:    

