



1992

Personal Computer Microprocessors Data Book Advanced Micro Devices





## Personal Computer Microprocessors

Data Book

ADVANCED MICRO DEVICES

Д

© 1991 Advanced Micro Devices, Inc.

Advanced Micro Devices reserves the right to make changes in its products without notice in order to improve design or performance characteristics.

This publication neither states nor implies any warranty of any kind, including but not limited to implied warrants of merchantability or fitness for a particular application. AMD® assumes no responsibility for the use of any circuitry other than the circuitry in an AMD product.

The information in this publication is believed to be accurate in all respects at the time of publication, but is subject to change without notice. AMD assumes no responsibility for any errors or omissions, and disclaims responsibility for any consequences resulting from the use of the information included herein. Additionally, AMD assumes no responsibility for the functioning of undescribed features or parameters.

#### Trademarks

AMD, PAL, and PALASM are registered trademarks of Advanced Micro Devices, Inc.

AMD 80C287, AMD 80EC287, Am286, Am386, Am29000, Am29005, Am29050, 29K, Digital Subscriber Controller, ExpressROM, and MACH are trademarks of Advanced Micro Devices, Inc.

FusionPLD is a servicemark of Advanced Micro Devices, Inc.

Postscript is a registered trademark of Adobe Systems

TapePak is a registered trademark of National Semiconductor

Product names used in this publication are for identification purposes only and may be trademarks of their respective companies.



Advanced Micro Devices provides high-performance microprocessors for personal computer manufacturers.

This data book details all 80X86 processors and coprocessors produced by AMD, including the 32-bit Am386<sup>™</sup> Microprocessor Family, NMOS and CMOS 16-bit 80286 Family, Am286<sup>™</sup> ZX/LX integrated microprocessors, 8-bit 8086 and 8088, and CMOS 80287 math coprocessors. Also included in this book is a system integration guide highlighting other AMD PC-related products.

Am386 microprocessors are the fastest available, with 40 MHz on the Am386DXL microprocessor and 25 MHz on the Am386SXL microprocessor. We also offer microprocessors optimized for notebook applications.

Remember, our partnership helps you gain and keep the competitive edge. We are not your competition.

Bob McConnell Vice President Personal Computer Products Division

## PERSONAL COMPUTER MICROPROCESSORS DATA BOOK TABLE OF CONTENTS

## Chapter 1

## Microprocessors

| 8086 Data Sheet               |
|-------------------------------|
| 8088 Data Sheet               |
| 80286 Data Sheet              |
| 80C286 Data Sheet 1-125       |
| 80L286 Data Sheet 1-137       |
| Am286ZX/LX Data Sheet 1-150   |
| Am386DXL Data Sheet 1-196     |
| Am386SXL Data Sheet 1-333     |
| Am386DXLV Data Sheet 1-427    |
| Am386SXLV Data Sheet 1-450    |
| Am386DX Data Sheet 1-472      |
| Am386SX Data Sheet 1-495      |
| AMD 80C287™ Data Sheet 1-511  |
| AMD 80EC287™ Data Sheet 1-522 |

## Chapter 2 General Information

| Thermal Characteristics  | . 2-3 |
|--------------------------|-------|
| TapePak Application Note | . 2-4 |
| Physical Dimensions      | 2-11  |
| Support Literature       | 2-23  |

## SYSTEM INTEGRATION

The Am386DX and Am386SX microprocessors are 32-bit microprocessors that form the basis for high-performance 32-bit systems. Both processors incorporate multitasking support, memory management, pipelined architecture, address translation caches, and a high-speed bus interface on a single chip.

The low-power versions of these microprocessors, the Am386DXL CPU and Am386SXL CPU, offer innovations in performance and battery life. These devices have higher clock speeds than the Intel i386DX and Intel i386SX—up to 40 MHz for the Am386DXL CPU and up to 25 MHz for the Am386SXL CPU. Their true static design offers near-zero power consumption in standby mode as well as low-operating power consumption at maximum clock speeds. These power-saving features allow designers to improve the battery life in portable systems as well as facilitate the reduction or elimination of the system cooling fan for cost-savings and size/noise reduction in desktop PCs.

While the Am386 microprocessor represents a significant improvement over previous generations of microprocessors, compatibility with the earlier processors is preserved. Software compatibility at the object-code level is provided, so that an existing investment in 8086 and 80286 software can be maintained. New software can be built upon existing routines, reducing the time-to-market for new products. Hardware compatibility is preserved through the dynamic bus-sizing feature.

The Am386 microprocessor is fully supported by peripherals and performance enhancement components from AMD as well as third party manufacturers. The major components of an Am386 microprocessor system and their functions are described throughout this section.

### Am386DX Microprocessor

The Am386 microprocessor is a compatible implementation of the Intel i386DX. It is an advanced 32-bit microprocessor designed for applications needing high performance. The 32-bit registers and data paths support 32-bit addresses and data types. The processor addresses up to 4 Gb of physical memory and 64 tb of virtual memory. The integrated memory management and protection architecture allow high-performance execution of operating systems including DOS, Windows, OS/2, and UNIX.

A pipelined architecture enables the Am386DX microprocessor to perform instruction fetching, decoding, execution, and memory management functions in parallel. Because the Am386DX microprocessor prefetches instructions and queues them internally, instruction fetch and decode times are absorbed in the pipeline; the processor rarely has to wait for an instruction to execute.

## Am386DXL Microprocessor

The Am386DXL microprocessor is a high-speed, true static implementation of the Intel i386DX microprocessor. It is ideal for both desktop and battery-powered portable computers. For desktop PCs, the Am386DXL microprocessor offers a 21% performance increase in maximum operating speed from 33 MHz to 40 MHz. Also, this device offers lower heat dissipation allowing system designers to remove or reduce the size and cost of the system cooling fan.

For portable systems, the Am386DXL microprocessor's true static design allows longer battery life by offering lowoperating power consumption and a standby mode. At 33 MHz, this device has 40% lower operating lcc than the Intel i386DX. Standby mode allows the Am386 microprocessor to be clocked down to 0 MHz (DC) and retain full register contents. In standby mode, typical current draw is less than 0.02 mA; nearly a 1000× reduction in power consumption over the Intel i386DX or Intel i386SX at minimum frequency.

Additionally, the Am386DXL microprocessor offers a cost- and space-saving 132-pin plastic quad flat pack (PQFP) package. This surface mount package is 40% smaller than a PGA package, allowing smaller board designs without the need for a socket.

## Am386DXLV Microprocessor

The Am386DXLV microprocessor is a low-voltage, true static implementation of the Intel i386DX microprocessor. The operating voltage range is 3.0 V to 5.5 V. The low-voltage operation makes it ideal for both desktop and battery-powered portable personal computers. For desktop PCs, low heat dissipation allows the system designers to remove or reduce the size and cost of the system cooling fan. The Am386DXLV microprocessor operates at a maximum speed of 25 MHz from 3.0 to 5.5 V and at a maximum speed of 33 MHz from 4.5 to 5.5 V.

The Am386DXLV microprocessor's lower operating voltage and true static design enable longer battery life and/or lower weight for portable applications. At 25 MHz, this device has 80% lower operating lcc than the Intel i386DX. Lowering typical operating voltage from 5.0 V to 3.3 V doubles the battery life. Standby Mode allows the Am386DXLV

microprocessor to be clocked down to 0 MHz (DC) and retain full register contents. In Standby Mode, typical current draw is 0.01 mA, a greater than 1000X reduction in power consumption versus the Intel i386DX or Intel i386SX.

Additionally, the Am386DXLV processor comes with SMM for system and power management. SMI is a non-maskable, higher priority interrupt than NMI and has its own code space (1 Mb). SMI can be coupled with the I/O instruction break feature to implement transparent power management of peripherals. SMM can be used by system designers to implement system and power management code independent of the operating system or the Processor Mode.

## Am386SX Microprocessor

The Am386SX microprocessor is a compatible implementation of the Intel i386SX. It is a 32-bit CPU with a 16-bit external data bus, and a 24-bit external address bus. It provides the performance and compatibility benefits of the 386 internal 32-bit architecture with the cost savings associated with 16-bit external hardware.

## Am386SXL Microprocessor

The Am386SXL microprocessor is a high-speed, true static implementation of the Intel i386SX. It is ideal for both desktop and battery-powered portable personal computers. For notebooks, the Am386SXL microprocessor's true static design allows longer battery life by offering low operating power consumption and a standby mode. At 20 MHz, this device offers 22% lower current than the Intel i386SX. Standby mode allows the Am386SXL microprocessor to be clocked down to 0 MHz (DC) and retain internal register contents. Typical current in standby mode is reduced to less than 0.02 mA; nearly a 1000x reduction in power consumption over the Intel i386SX at 25 MHz.

For desktop PCs, the Am386SXL microprocessor offers a 25% increase in the maximum operating speed, from 20 to 25 MHz. This device also offers lower heat dissipation, allowing system designers to remove or reduce the size and cost of the system cooling fan.

## Am386SXLV Microprocessor

The Am386SXLV microprocessor is a low-voltage, true static implementation of the Intel i386SX microprocessor. With the operating range of 3.0 V to 5.5 V, it is ideal for both desktop and battery-powered notebook personal computers. For desktop PCs, this device offers lower heat dissipation, allowing system designers to remove or reduce the size and cost of the cooling fan.

At 20 MHz, this device has 60% lower operating lcc than the Intel i386SX. Lowering typical operating voltage from 5.0 V to 3.3 V enables battery life to increase by a factor of two. In Standby Mode, typical current draw is less than 0.01 mA, a greater than 1000X reduction in power consumption versus the Intel i386SX, while retaining full register contents.

Additionally, the Am386SXLV microprocessor comes with System Management Mode (SMM) for system and power management. SMI (System Management Interrupt) is a non-maskable, higher priority interrupt than NMI and has its own code space (1 Mb). SMI can be coupled with the I/O instruction break feature to implement transparent power management of peripherals. SMM can be used by system designers to implement system and power management code independent of the operating system or the Processor Mode.

## **Math Coprocessors**

The performance of many numeric-intensive applications can be enhanced by the use of math coprocessors. A math coprocessor provides the hardware to perform floating point functions that would otherwise be performed by software. Coprocessors extend the instruction set of the microprocessor to include floating point operations.

The Am386DX and Am386SX microprocessors allow an interface to a 387-compatible math coprocessor. For applications that benefit from high-precision integer and floating point calculations (such as CAD, spreadsheet, graphics, data base, font generation, and statistics), the math coprocessor provides full support of the IEEE standard for floating point operations.

## **Cache Controllers**

Low-speed memory systems (<= 20 MHz) have traditionally been implemented with dynamic RAMs (DRAMs) using a direct or page-interleaved approach. Page-interleaving is a memory design technique for achieving near-zero wait state system performance with inexpensive DRAMs. However, as the speed of processors increases these methods may become inadequate. With increased processor speed, the speed of the DRAM memory increases as well as the cost. In order to reduce cost and improve performance, cache controllers are used. A cache-based memory system contains a small amount of fast SRAM memory and a large amount of slower DRAM memory. This provides the performance of SRAMs at a cost approaching that of DRAMs.

#### Personal Computer Microprocessors

Many cache controllers are available from third party manufactures for both the Am386DX and Am386SX microprocessors.

## **Integrated Peripheral Chip Sets**

Many discrete features such as memory, I/O, and bus control for Am386 processors have become integrated into chip sets. These chip sets have become the standard for cost-effective designs for desktop and portable personal computers. A wide variety of chip sets are available from third party manufacturers to support both the Am386DX and Am386SX microprocessors in high-speed desktop and long battery life portable designs.

## **Programmable Logic**

With over a decade of PLD leadership, AMD manufactures a broad line of programmable logic to improve time-to-market when designing systems around Am386 microprocessors. The MACH™ (Macro Array CMOS High-Density) Family fills the system design gap between high-density field programmable gate arrays and high-speed PAL® device ICs.

The MACH Family offers a breakthrough combination of high density (900 to 3600 gates) and high performance (15 ns and 50 MHz). AMD offers proven production methods and the right technology for attractive pricing on high-density programmable logic. MACH Family devices are manufactured with EE CMOS technology offering the following benefits.

- -Reprogrammable in low-cost plastic packages
- -Quick design revisions
- -Insurance on production programmed parts
- -Quick market entry

The MACH Family is supported by major third party PLD design software packages through AMD's FusionPLD<sup>SM</sup> program. It is also supported by AMD's own PALASM® software. Several of these software packages run on 286- and 386-based systems and provide low-cost computer aided design (CAD) capability while easing the important phases of the designer's task: design entry, implementation, verification, programming, and testing. The MACH Family devices can be programmed on conventional PAL device programmers with appropriate personality and socket adapter modules.

AMD also offers several zero-power PAL devices for power-conscious designs. These devices' ultra-low standby power is ideal for laptop, notebook, and hand-held PC designs where faster time-to-market and longer battery life are required.

## **EPROMs and Flash**

AMD is a leading supplier of EPROMs (Erasable Programmable Read Only Memory) to the personal computer market. EPROMs are traditionally used to store BIOS in one or two chips on the motherboard. AMD offers higher density, lower power, and faster EPROMs than any other manufacturer in the world. AMD's 1 Mb EPROM, for example, runs as fast as 45 ns.

This 1 Mb high-speed EPROM could be used with the 40-MHz Am386DXL microprocessor to execute the BIOS and keyboard code directly from EPROM with no wait states and no shadowing of the EPROM. EPROM shadowing traditionally allowed designers to run slow EPROM code from faster DRAM. However, with AMD's high-performance EPROMs, the DRAM is freed up for use by operating systems such as DOS, OS/2, and UNIX.

AMD's EPROMs are offered in UV-erasable windowed ceramic versions as well as in lower cost plastic "one-time programmable" DIP and PLCC packages. For medium- to high-volume stable code, AMD offers the ExpressROM™ memory, a factory-programmed plastic packaged EPROM.

AMD also offers the highest densities and speeds in Flash memories. Flash memories may be reprogrammed in systems and allow the user to reconfigure the BIOS without system disassembly. Hand-held and application specific personal computers can also use Flash memories as a read-write solid state hard disk. A silicon disk is ideal for battery operated portable PCs since they are fast, rugged, economical, and drain little current from the system battery.

## **Networking Solutions**

AMD provides a wide range of networking solutions to be designed into PC add-in cards or integrated onto the motherboard. The AMD Am7900 Ethernet/Cheapernet chip set provides a low component count, minimum board space, low-cost Ethernet interface. AMD also offers solutions for 10BASE-T and FDDI standards.

In addition, AMD manufactures the Am79C30 Digital Subscriber Controller™ circuit. This device may be used for voice annotation through electronic mail systems across networks. This feature allows users to electronically attach voice dialog to Email messages.

## Serial Controllers/SCSI

Some of the newest portable personal computers offer pen-based operating systems such as GO Computer's Pen-Point and Microsoft's PenWindows. These systems are designed to recognize a light pen or other stylus as the input device. One of the features offered with these new notebook systems is handwriting recognition—the user prints the characters with the pen and the system converts it to ASCII characters. The AMD Am85C80 is being used to perform handwriting character recognition as well as provide an integrated SCSI interface. The Am85C80 integrates an 85C30 dual serial communication controller as well as a 5380 SCSI controller. The sleep-mode feature of the Am85C80 makes it particularly well suited for notebook applications.

SCSI adapters offer tremendous flexibility as a standard for personal computer peripherals such as hard disks, CD ROMs, optical drives, laser printers, and scanners, many of which are very useful for the emerging multimedia market.

## **Keyboard Controllers**

AMD's 80C51-based 8-bit microcontrollers offer a cost-effective solution for both desktop and portable personal computers. These devices may be used for keyboard scanning as well as power management. The 87C51 EPROM-based microcontroller can replace separate 8042/80C42 and 8048/8049 controllers and is supported by the major BIOS manufacturers.

## **Bus Interface Products**

The Am29C800A High-Performance CMOS Bus Interface Family is ideal for Am386 CPU based bus interface applications. Typically, these devices are used with integrated peripheral chip sets to drive extra I/O bus slots for peripheral add-in cards and large DRAM arrays. Their low ground-bounce outputs are particularly well suited for systems with clock speeds greater than 25 MHz.

The Am29C800A family provides bipolar-comparable performance while consuming much less power than bipolar devices. Pin-for-pin compatible with the Am29800A/Am29C800 families, these devices offer lower propagation delays and consume less power than their predecessors. They offer the necessary output drive for driving heavily loaded buses while achieving the fast switching speeds required for high-performance systems.

## Graphics

AMD's 29K<sup>™</sup> Family of general-purpose 32-bit RISC microprocessors is meeting the needs of today's distributed graphics display systems. The Am29000<sup>™</sup> microprocessor can be found in graphics applications ranging from Apple Macintosh QuickDraw accelerators to X Window System terminals (X terminals). In addition, the 29K Family is the heart of a wide range of PostScript-based laser printer products.

The 29K Family represents the broadest range of pin- and software-compatible 32-bit RISC microprocessors on the market today. The low-end Am29005 processor provides 6–9 MIPS performance for cost-sensitive applications. The Am29000 processor provides 12–23 MIPS performance for mainstream 2D graphics. The Am29050 microprocessor, with its tightly integrated on-chip floating point unit, provides up to 32 MIPS and 34 MFLOPS sustained performance (80 MFLOPS peak) for demanding 3D graphics and imaging applications. AMD's Embedded Processor Division regularly introduces new members of the 29K Family to support the embedded graphics, laser printer, and network controller markets.

The IBM PC-compatible market has entered the age of Graphical User Interfaces (GUIs) with the introduction of Microsoft Windows 3.0, joining Apple and the UNIX world. The 29K Family provides a flexible architecture for providing high-speed acceleration for the Application Programming Interfaces (APIs) associated with each GUI.

The power of the 29K Family of microprocessors ensures that the entire graphics library of well-distributed GUIs can be offloaded to a graphics accelerator. This not only provides graphics horsepower, but also frees the central processor to devote more time to executing the PC user's applications—increasing the speed of the entire system. The Am386 Family and the 29K Family can work together to provide high-performance, cost-effective solutions for the latest GUIs, including Windows and the emerging Display PostScript standard.

For more information on any of AMD's products, contact your AMD sales representative.

## **Chapter 1**

Microprocessors

## CHAPTER 1 Microprocessors

| 8086 Data Sheet              |
|------------------------------|
| 8088 Data Sheet              |
| 80286 Data Sheet             |
| 80C286 Data Sheet            |
| 80L286 Data Sheet            |
| Am286ZX/LX Data Sheet 1-150  |
| Am386DXL Data Sheet 1-196    |
| Am386SXL Data Sheet 1-333    |
| Am386DXLV Data Sheet         |
| Am386SXLV Data Sheet         |
| Am386DX Data Sheet 1-472     |
| Am386SX Data Sheet 1-495     |
| AMD 80C287 Data Sheet 1-511  |
| AMD 80EC287 Data Sheet 1-522 |

## 8086 16-Bit Microprocessor iAPX86 Family **FINAL**

### DISTINCTIVE CHARACTERISTICS

- Directly addresses up to 1 Mbyte of memory
- 24 operand addressing modes •
- Efficient implementation of high level languages
- Instruction set compatible with 8080 software
- Bit, byte, word, and block operations .
- 8 and 16-bit signed and unsigned arithmetic in binary or • decimal
- MULTIBUS<sup>®</sup> system interface
  - Three speed options
  - 5MHz for 8086
  - 8MHz for 8086-2
  - 10MHz for 8086-1

#### **GENERAL DESCRIPTION**

The 8086 is a general purpose 16-bit microprocessor CPU. Its architecture is built around thirteen 16-bit registers and nine 1-bit flags. The CPU operates on 16-bit address spaces and can directly address up to 1 megabyte using offset addresses within four distinct memory segments, designated as code, data, stack and extra code. The 8086 implements a powerful instruction set with 24 operand addressing modes. This instruction set is compatible with that of the 8080 and 8085. In addition, the 8086 is particularly effective in executing high level languages.

The 8086 can operate in minimum and maximum modes. Maximum mode offloads certain bus control functions to a peripheral device and allows the CPU to operate efficiently in a multi-processor system. The CPU and its high performance peripherals are MULTIBUS compatible. The 8086 is implemented in N-channel, depletion load, silicon gate technology and is contained in a 40-pin CERDIP package, Molded DIP package, or Plastic Leaded Chip Carrier.







|         | 8086    |  |
|---------|---------|--|
| P, D, N | 8086-2  |  |
|         | 8086-1  |  |
| D, ID   | 8086-2B |  |
| D       | 8086-1  |  |
| ID      | 8086B   |  |
|         |         |  |

Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations, to check on newly released valid combinations, and to obtain additional data on AMD's standard military grade products.



Group A tests consist of Subgroups 1, 2, 3, 7, 8, 9, 10, 11.

## PIN DESCRIPTION

The following pin function descriptions are for 8086 systems in either minimum or maximum mode. The "Local Bus" in these descriptions is the direct multiplexed bus interface connection to the 8086 (without regard to additional bus buffers).

| Pin No.* | Name                                    | 1/0 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                       | De                                                                                                                                       | scription                                                                                                                                                                                                                                                                                                                                                               |  |
|----------|-----------------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 39, 2–16 | AD <sub>15</sub> -AD <sub>0</sub>       | 1/0 | Address Data Bus. These lines constitute the time multiplexed memory/IO address (T <sub>1</sub> ) and data (T <sub>2</sub> , T <sub>3</sub> , T <sub>W</sub> , T <sub>4</sub><br>bus. A <sub>0</sub> is analogous to BHE for the lower byte of the data bus, pins D <sub>7</sub> -D <sub>0</sub> . It is LOW during T <sub>1</sub> when a byte is to<br>be transferred on the lower portion of the bus in memory or I/O operations. Eight-bit oriented devices tied to th<br>lower half would normally use A <sub>0</sub> to condition chip select functions. (See BHE) These lines are active HIGH and<br>float to three-state OFF during interrupt acknowledge and local bus "hold acknowledge." |                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                         |  |
| 35-38    | A19/S6,<br>A18/S5,<br>A17/S4,<br>A16/S3 | 0   | operations these lines<br>during T <sub>2</sub> , T <sub>3</sub> , T <sub>W</sub> , and<br>cycle. A <sub>17</sub> /S <sub>4</sub> and<br>This information in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | are L(<br>  T <sub>4</sub> . Th<br>  A <sub>16</sub> /<br>dicate                                                                                                                                                                                                                                                                                                                                                      | DW. During memory and<br>the status of the interrupt<br>/S3 are encoded as<br>s which relocation re                                      | significant address lines for memory operations. During I/C<br>I/O operations, status information is available on these lines<br>enable FLAG bit (Sc) is updated at the beginning of each CL's<br>a shown.<br>agister is presently being used for data accessing.<br>bus "hold acknowledge."                                                                            |  |
|          |                                         |     | A17/S4 A16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | -S3                                                                                                                                                                                                                                                                                                                                                                                                                   | Characteristics                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                         |  |
|          |                                         |     | 0 (LOW) 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                       | Alternate Data                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                         |  |
|          |                                         |     | 0 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                       | Stack                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                         |  |
|          |                                         |     | 1 (HIGH) 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                       | Code or None                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                         |  |
|          |                                         |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                       | Data                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                         |  |
|          |                                         |     | Seis 0<br>(LOW)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                         |  |
| 34       | BHE/S7                                  | 0   | the most significant h<br>the bus would norma<br>and interrupt acknowl<br>status information is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | nalf of<br>illy use<br>ledge<br>availat                                                                                                                                                                                                                                                                                                                                                                               | the data bus, pins D <sub>13</sub><br>BHE to condition chip<br>cycles when a byte is<br>ble during T <sub>2</sub> , T <sub>3</sub> , and | enable signal (BHE) should be used to enable data onto $s_{5}$ -Da. Eight-bit oriented devices tied to the upper half of $p$ select functions. BHE is LOW during T <sub>1</sub> for read, write to be transferred on the high portion of the bus. The S <sub>7</sub> T <sub>4</sub> . The signal is active LOW and floats to $r$ the first interrupt acknowledge cycle. |  |
|          |                                         |     | BHE A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0                                                                                                                                                                                                                                                                                                                                                                                                                     | Characteristics                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                         |  |
|          |                                         |     | 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                       | Whole word                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                         |  |
|          |                                         |     | 0 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                       | Upper byte from/<br>to odd address                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                         |  |
|          |                                         |     | 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | <b>`</b>                                                                                                                                                                                                                                                                                                                                                                                                              | Lower byte from/<br>to even address                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                         |  |
|          | 1                                       |     | 1 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                       | None                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                         |  |
| 32       | RD                                      | 0   | the state of the S <sub>2</sub> p<br>active LOW during T<br>6086 local bus has f                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Read. Read strobe indicates that the processor is performing a memory of I/O read cycle, depending on<br>the state of the S2 pin. This signal is used to read devices which reside on the 8086 local bus. RD is<br>active LOW during T2, T3, and Tw of any read cycle and is guaranteed to remain HIGH in T2 until the<br>8086 local bus has floated.<br>This signal floats to three-state OFF in "hold acknowledge." |                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                         |  |
| 22       | READY                                   | 1   | READY. Is the acknowledgment from the addressed memory or I/O device that it will complete the data<br>transfer. The READY signal from memory/IO is synchronized by the 8284A Clock Generator to form<br>READY. This signal is active HIGH. The 8006 READY input is not synchronized. Correct operation is not<br>guaranteed if the set-up and hold times are not met.                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                         |  |
| 18       | INTR                                    | 1   | guaranteed in the service and inductions are not inter-<br>tion to determine if the processor should enter into an interrupt acknowledge operation. A subroutine is<br>vectored to via an interrupt vector lookup table located in system memory. It can be internally masked by<br>software resetting the interrupt reaction be bit. INTR is internally synchronized. This signal is active HIGH.                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                         |  |
| 23       | TEST                                    | '   | TEST. Input is exami<br>wise, the processor v<br>on the leading edge                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | waits ii                                                                                                                                                                                                                                                                                                                                                                                                              | n an "Idle" state. This                                                                                                                  | n. If the TEST input is LOW, execution continues; other-<br>input is synchronized internally during each clock cycle                                                                                                                                                                                                                                                    |  |
| 17       | NMI                                     | 1   | to via an interrupt ve                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | from                                                                                                                                                                                                                                                                                                                                                                                                                  | okup table located in<br>a LOW to HIGH initiat                                                                                           | thich causes a type 2 interrupt. A subroutine is vectored<br>system memory. NMI is not maskable internally by<br>es the interrupt at the end of the current instruction. Thi                                                                                                                                                                                            |  |
| 21       | RESET                                   | 1   | for at least four clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | k cycle                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                          | nate its present activity. The signal must be active HIGH<br>, as described in the Instruction Set description, when<br>nized.                                                                                                                                                                                                                                          |  |
| 19       | CLK                                     | 1   | Clock. Provides the b<br>cycle to provide optim                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                          | and bus controller. It is asymmetric with a 33% duty                                                                                                                                                                                                                                                                                                                    |  |
| 40       | Vcc                                     |     | V <sub>CC</sub> . The + 5 V powe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                       | ply pin.                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                         |  |
| 1, 20    | GND                                     | ļ   | Ground. The ground                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                         |  |
| 33       | MN/MX                                   | 1 1 | Minimum/Maximum, I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ndicate                                                                                                                                                                                                                                                                                                                                                                                                               | es what mode the proc                                                                                                                    | essor is to operate in. The two modes are discussed in                                                                                                                                                                                                                                                                                                                  |  |

| Pin No.* | Name                                       | Description                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28–26    | \$2. \$1. \$0                              | 0                                                                                                                                                                                     | Status. Active during T <sub>4</sub> , T <sub>1</sub> , and T <sub>2</sub> and is returned to the passive state (1, 1, 1) during T <sub>3</sub> or during T <sub>W</sub> when READY is HIGH. This status is used by the 8288 Bus Controller to generate all memory and I/O access control signals. Any change by S <sub>2</sub> , S <sub>1</sub> , or S <sub>2</sub> during T <sub>4</sub> is used to indicate the beginning of a bus cycle, and the return to the passive state in T <sub>3</sub> or T <sub>W</sub> is used to indicate the end of a bus cycle. These signals float to three-state OFF in "hold acknowledge." These status lines are encoded as shown. |
|          |                                            |                                                                                                                                                                                       | \$\overline{S}_2\$     \$\overline{S}_1\$     \$\overline{S}_0\$     Characteristics                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|          |                                            |                                                                                                                                                                                       | 0 (LOW) 0 0 Interrupt<br>Acknowledge                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|          |                                            |                                                                                                                                                                                       | 0 0 1 Read I/O Port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|          |                                            |                                                                                                                                                                                       | 0 1 0 Write I/O Port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|          |                                            |                                                                                                                                                                                       | 0 1 1 Halt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|          |                                            |                                                                                                                                                                                       | 1 (HIGH) 0 0 Code Access                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|          |                                            |                                                                                                                                                                                       | 1 0 1 Read Memory                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|          |                                            |                                                                                                                                                                                       | 1 1 0 Write Memory                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|          |                                            |                                                                                                                                                                                       | 1 1 Passive                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31, 30   | RO/GT <sub>0</sub> .<br>RO/GT <sub>1</sub> | 1/0                                                                                                                                                                                   | Request/Grant. Pins are used by other local bus masters to force the processor to release the local bus<br>at the end of the processor's current bus cycle. Each pin is bidirectional with RO/GT <sub>0</sub> having higher<br>priority than RO/GT <sub>1</sub> . RO/GT has an internal pull-up resistor so it may be left unconnected. The request<br>grant sequence is as follows:<br>1. A pulse of 1 CLK wide from another local bus master indicates a local bus request ("hold") to the                                                                                                                                                                            |
|          |                                            |                                                                                                                                                                                       | <ul> <li>8086 (pulse 1).</li> <li>2. During a T<sub>4</sub> or T<sub>1</sub> clock cycle, a pulse 1 CLK wide from the 8086 to the requesting master (pulse 2), indicates that the 8086 has allowed the local bus to float and that it will enter the "hold acknowledge state at the next CLK. The CPU's bus interface unit is disconnected logically from the local bus during "hold acknowledge."</li> </ul>                                                                                                                                                                                                                                                           |
|          |                                            | 3. A pulse 1 CLK wide from the requesting master indicates to the 8086 (pulse 3) that the "hold" request is about to end and that the 8086 can reclaim the local bus at the next CLK. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|          |                                            |                                                                                                                                                                                       | Each master-master exchange of the local bus is a sequence of 3 pulses. There must be one dead CLK cycle after each bus exchange. Pulses are active LOW.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|          |                                            |                                                                                                                                                                                       | If the request is made while the CPU is performing a memory cycle, it will release the local bus during T<br>of the cycle when all the following conditions are met:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|          |                                            |                                                                                                                                                                                       | <ol> <li>Request occurs on or before T<sub>2</sub>.</li> <li>Current cycle is not the low byte of a word (on an odd address).</li> <li>Current cycle is not the first acknowledge of an interrupt acknowledge sequence.</li> <li>A locked instruction is not currently executing.</li> </ol>                                                                                                                                                                                                                                                                                                                                                                            |
|          |                                            |                                                                                                                                                                                       | If the local bus is idle when the request is made, two possible events will follow:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|          |                                            |                                                                                                                                                                                       | <ol> <li>Local bus will be released during the next clock.</li> <li>A memory cycle will start within 3 clocks. Now the four rules for a currently active memory cycle appl<br/>with condition number 1 already satisfied.</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 29       | LOCK                                       | 0                                                                                                                                                                                     | LOCK. Output indicates that other system bus masters are not to gain control of the system bus while<br>LOCK is active LOW. The LOCK signal is activated by the "LOCK" prefix instruction and remains active<br>until the completion of the next instruction. This signal is active LOW, and floats to three-state OFF in<br>"hold acknowledge."                                                                                                                                                                                                                                                                                                                        |
| 24, 25   | QS <sub>1</sub> , QS <sub>0</sub>          | 0                                                                                                                                                                                     | Queue Status. The queue status is valid during the CLK cycle after which the queue operation is per-<br>formed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 28       | M/IO                                       | 0                                                                                                                                                                                     | QS1 and QS0 provide status to allow external tracking of the internal 8086 instruction queue.<br>Status line. Logically equivalent to S2 in the maximum mode. It is used to distinguish a memory access<br>from an I/O access. MI/O becomes valid in the T4 preceding a bus cycle and remains valid until the fin                                                                                                                                                                                                                                                                                                                                                       |
| 29       | WR                                         | 0                                                                                                                                                                                     | Ta of the cycle (M = HiGH, IO = LOW). M/IO floats to three-state OFF in local bus "hold acknowledge."<br>Write. Indicates that the processor is performing a write memory or write I/O cycle, depending on the                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|          |                                            |                                                                                                                                                                                       | state of M/IO signal. WR is active for T <sub>2</sub> , T <sub>3</sub> , and T <sub>W</sub> of any write cycle. It is active LOW and floats to three-state OFF in local bus "hold acknowledge."                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 24       |                                            | 0                                                                                                                                                                                     | INTA. Is used as a read strobe for interrupt acknowledge cycles. It is active LOW during $T_2$ , $T_3$ , and $T_W$ of each interrupt acknowledge cycle.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 25       | ALE                                        | 0                                                                                                                                                                                     | Address Latch Enable. Provided by the processor to latch the address into 8282/8283 address latch. It is a HIGH pulse active during $T_1$ of any bus cycle. Note that ALE is never floated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 27       | DT/R                                       | 0                                                                                                                                                                                     | Data Transmit/Receive. Needed in minimum system that desires to use an 8286/8287 data bus transceive<br>or it is used to control the direction of data flow through the transceiver. Logically DT/ $\overline{R}$ is equivalent to<br>$\overline{S}_1$ in the maximum mode, and its timing is the same as for M/ $\overline{IO}$ . (T = HIGH, R = LOW.) This signal<br>floats to three-state OFF in local bus "hold acknowledge."                                                                                                                                                                                                                                       |
| 26       | DEN                                        | 0                                                                                                                                                                                     | Data Enable. Provided as an output enable for the 8286/8287 in a minimum system which uses the<br>transceiver. DEN is active LOW during each memory and I/O access and for INTA cycles. For a read or<br>INTA cycle, it is active from the middle of T2 until the middle of T4, while for a write cycle, it is active<br>from the beginning of T2 until the middle of T4. DEN floats to three-state OFF in local bus "hold<br>acknowledg                                                                                                                                                                                                                                |

|          | PIN DESCRIPTION (continued) |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|----------|-----------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Pin No.* | Name                        | 1/0 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| 31, 30   | HOLD,<br>HLDA               | 1/0 | HOLD. Indicates that another master is requesting a local bus "hold." To be acknowledged, HOLD must<br>be active HIGH. The processor receiving the "hold" request will issue HLDA (HIGH) as an acknowledge-<br>ment in the middle of a T <sub>4</sub> or T <sub>1</sub> clock cycle. Simultaneous with the issuance of HLDA, the processor will<br>float the local bus and control lines. After HOLD is detected as being LOW, the processor will LOWer<br>HLDA, and when the processor needs to run another cycle, it will again drive the local bus and control<br>lines. |  |  |  |  |
|          |                             |     | The same rules as for $\overline{RG}/\overline{GT}$ apply, regarding when the local bus will be released.<br>HOLD is not asynchroneous input. External synchronization should be provided if the system cannot otherwise guarantee the set-up time.                                                                                                                                                                                                                                                                                                                         |  |  |  |  |

\*Pin numbers correspond to DIPs only.

#### DETAILED DESCRIPTION

The 8086 CPU is internally organized into two processing units. These two units are the Bus Interface Unit (BIU) and the Execution Unit (EU). A block diagram of this organization is shown on page 1.

The BIU performs instruction fetch and queuing, operand fetch and store, address relocation, and basic bus control. The EU receives operands and instructions from the BIU and processes them on a 16-bit ALU. The EU accesses memory and peripheral devices through requests to the BIU. The BIU generates physical addresses in memory using the 4 segment registers and offset values.

The BIU and EU usually operate asynchronously. This permits the 8086 to overlap execution fetch and execution. Up to 6 instruction bytes can be queued. The instruction queue acts as a FIFO buffer for instructions, from which the EU extracts instruction bytes as required.

#### **Memory Organization**

The 8086 addresses up to 1 megabyte of memory. The address space is organized as a linear array, from 00000 to FFFFF in hexadecimal. Memory is subdivided into segments of 64K bytes each. There are 4 segments: code, stack, data, and extra (usually employed as an extra data segment). Each segment thus contains information of a similar type. Selection of a destination segment is automatically performed using the rules in the table below. This segmentation makes memory more easily relocatable and supports a more structured programming style.

Physical addresses in memory are generated by selecting the appropriate segment, obtaining the segment "base" address from the segment register, shifting the base address 4 digits to the left, and then adding this base to the "offset" address. For programming code, the offset address is obtained from the instruction pointer. For operands, the offset address is calculated in several ways, depending upon information contained in the addressing mode. Memory organization and address generation are shown in Figure 1a.

Certain memory locations are reserved for specific CPU operations. These are shown in Figure 1b. Addresses FFFFOH through FFFFFH are reserved for operations which include a jump to the initial program loading routine. After RESET, the CPU will always begin execution at location FFFFOH, where the jump must be located.

Addresses 00000H through 003FFH are reserved for interrupt operations. The service routine of each of the 256 possible interrupt types is signaled by a 4-byte pointer. The pointer elements must be stored in reserved memory addresses before the interrupts are invoked.



| Memory<br>Reference Need | Segment Register<br>Used | Segment Selection Rule                                                                                              |  |
|--------------------------|--------------------------|---------------------------------------------------------------------------------------------------------------------|--|
| Instructions             | CODE (CS)                | Automatic for all prefetching of instructions.                                                                      |  |
| Stack                    | STACK (SS)               | All stack pushes and pops, and all memory references relative to BP base register<br>except data references.        |  |
| Local Data               | DATA (DS)                | Data references which are relative to the stack, the destination of a string operation, or<br>explicitly overriden. |  |
| External (Global) Data   | EXTRA (ES)               | Destination of string operations, when they are explicitly selected using a segment override.                       |  |

#### **Minimum and Maximum Modes**

The 8086 has two system configurations, minimum and maximum mode. The CPU has a strap pin, MN/MX, which defines the system configuration. The status of this strap pin defines the function of pin numbers 24 through 31.

When MN/MX is strapped to GND, the 8086 operates in maximum mode. The operations of pins 24 through 31 are redefined. In maximum mode, several bus timing and control functions are "off-loaded" to the 8288 bus controller, thus

freeing up the CPU. The CPU communicates status information to the 8288 through pins  $S_0$ ,  $S_1$ , and  $S_2$ . In maximum mode, the 8086 can operate in a multiprocessor system, using the LOCK signal within a Multibus format.

When MN/MX is strapped to V<sub>CC</sub>, the 8086 operates in minimum mode. The CPU sends bus control signals itself through pins 24 through 31. This is shown in the Connection Diagrams (in parentheses). Examples of minimum and maximum mode systems are shown in Figure 2.





#### **Bus Operation**

The 8086 has a combined address and data bus, commonly referred to as "a time multiplexed bus." This technique provides the most efficient use of pins on the processor while permitting the use of a standard 40-lead package. This bus can be used throughout the system with address latching provided on memory and I/O modules. The bus can also be demultiplexed at the processor with a single set of address latches if a standard non-multiplexed bus is desired for the system.

Each bus cycle consists of at least four CLK cycles. These are referred to as T<sub>1</sub>, T<sub>2</sub>, T<sub>3</sub> and T<sub>4</sub> (see Figure 5). The address is sent from the processor during T<sub>1</sub>. Data transfer occurs on the bus during T<sub>3</sub> and T<sub>4</sub>. T<sub>2</sub> is used for changing the direction of the bus during read operations. In the event that a "NOT READY" indication is given by the addressed device, "Wait" states (T<sub>W</sub>) are inserted between T<sub>3</sub> and T<sub>4</sub>. Each inserted "Wait" states (T<sub>1</sub>) or inactive CLK cycles can occur between 8086 bus cycles. The processor uses these cycles for internal housekeeping.

During T<sub>1</sub> of any bus cycle, the ALE (Address Latch Enable) signal is emitted (by either the processor or the 8288 bus controller, depending on the MN/MX strap). At the trailing edge of this pulse, a valid address and certain status information for the cycle may be latched.

Status bits  $\overline{S_0}$ ,  $\overline{S_1}$ , and  $\overline{S_2}$  are used, in maximum mode, by the bus controller to identify the type of bus transaction according to the following table:

| ₹<br>S2 | Ī51 | ₹0 | Characteristics        |  |
|---------|-----|----|------------------------|--|
| 0(LOW)  | 0   | 0  | Interrupt Acknowledge  |  |
| 0       | 0   | 1  | Read I/O               |  |
| 0       | 1   | 0  | Write I/O              |  |
| 0       | 1   | 1  | Halt                   |  |
| 1(HIGH) | 0   | 0  | Instruction Fetch      |  |
| 1       | 0   | 1  | Read Data from Memory  |  |
| 1       | 1   | 0  | Write Data to Memory   |  |
| 1       | 1   | 1  | Passive (no bus cycle) |  |

Status bits S<sub>3</sub> through S<sub>7</sub> are multiplexed with high-order address bits and the BHE signal, and are therefore valid during T<sub>2</sub> through T<sub>4</sub>. S<sub>3</sub> and S<sub>4</sub> indicate which segment register (see Instruction Set description) was used for this bus cycle in forming the address, according to the following table:

| S4      | S <sub>3</sub> | Characteristics                |  |
|---------|----------------|--------------------------------|--|
| 0(LOW)  | 0              | Alternate Data (extra segment) |  |
| 0       | 1              | Stack                          |  |
| 1(HIGH) | 0              | Code or None                   |  |
| 1       | 1              | Data                           |  |

 $S_5$  is a reflection of the PSW interrupt enable bit.  $S_6$  = 0 and  $S_7$  is a spare status bit.

#### I/O Addressing

8086 I/O operations can address up to a maximum of 64K I/O byte registers or 32K I/O word registers. The I/O address appears in the same format as the memory address on bus lines  $A_{15}$ - $A_0$ . The address lines  $A_{19}$ - $A_{16}$  are zero in I/O operations. I/O instructions which use register DX as a pointer have full address capability. Direct I/O instructions directly address one or two of the 256 I/O byte locations in page 0 of the I/O address space. I/O ports are addressed in the same manner as memory locations.



#### EXTERNAL INTERFACE

#### **Processor Reset and Initialization**

Processor initialization or start up is accomplished with activation (HIGH) of the RESET pin. The 8086 RESET is required to be HIGH for greater than 4 CLK cycles. The 8086 will terminate operations on the high-going edge of RESET and will remain dormant as long as RESET is HIGH. The low-going transition of RESET triggers an internal reset sequence for approximately 10 CLK cycles. After this interval the 8086 operates normally beginning with the instruction in absolute location FFFF0H (see Figure 1b). The details of this operation are explained in the Instruction Set description of the MCS-86 Family User's Manual. The RESET input is internally synchronized to the processor clock. At initialization the HIGH-to-LOW transition of RESET must occur no sooner than 50µs after power-up, to allow complete initialization of the 8086.

NMI may not be asserted prior to the 2nd CLK cycle following the end of RESET.

#### **Interrupt Operations**

Interrupt operations fall into two classes: software or hardware initiated. The software initiated interrupts and software aspects of hardware interrupts are described in the Instruction Set description. Hardware interrupts are either non-maskable or maskable.

Interrupts transfer control to a new program location. A 256element table containing address pointers to the interrupt service program locations resides in absolute locations 0 through 3FFH (see Figure 1b), which are reserved for this purpose. Each element in the table is 4 bytes in size and corresponds to an interrupt "type." An interrupting device supplies an 8-bit type number during the interrupt acknowledge sequence, which is used to "vector" through the appropriate element to the new interrupt service program location.

#### Non-Maskable Interrupt (NMI)

The processor provides a single non-maskable interrupt pin (NMI) which has higher priority than the maskable interrupt request pin (INTR). A typical use would be to activate a power

failure routine. The NMI is edge-triggered on a LOW-to-HIGH transition. The activation of this pin causes a type 2 interrupt. (See Instruction Set description.)

NMI is required to have a duration in the HIGH state of greater than two CLK cycles, but is not required to be synchronized to the clock. Any high-going transition of NMI is latched on-chip and will be serviced at the end of the current instruction or between whole moves of a block-type instruction. Worst case response to NMI would be to multiply, divide, and variable shift instructions. There is no specification on the occurrence of the low-going edge; it may occur before, during, or after the servicing of NMI. Another high-going edge triggers another response if it occurs after the start of the NMI procedure. The signal must be free of logical spikes in general and be free of bounces on the low-going edge to avoid triggering extraneous responses.

#### Maskable interrupt (INTR)

The 86/10 provides a single interrupt request input (INTR) which can be masked internally by software with the resetting of the interrupt enable FLAG status bit. The interrupt request signal is level-triggered. It is internally synchronized during each clock cycle on the high-going edge of CLK. To be responded to, INTR must be present (HIGH) during the clock period preceding the end of the current instruction or the end of a whole move for a block-type instruction. During the interrupt response sequence, further interrupts are disabled. The enable bit is reset as part of the response to any interrupt (INTR, NMI, software interrupt, or single-step), although the FLAGS register, which is automatically pushed onto the stack, reflects the state of the processor prior to the Interrupt. Until the old FLAGS register is restored, the enable bit will be zero unless specifically set by an instruction.

During the response sequence (Figure 4), the processor executes two successive (back-to-back) interrupt acknowl-edge cycles. The 8086 emits the LOCK signal from T<sub>2</sub> of the first bus cycle until T<sub>2</sub> of the second. A local bus "hold" request will not be honored until the end of the second bus cycle. In the second bus cycle, a byte is fetched from the external interrupt system (e.g., 8259A PIC) which identifies the source (type) of the interrupt. This byte is multiplied by four and used as a pointer into the interrupt vector lookup table. An INTR signal left HIGH will be continually responded to within the limitations of the enable bit and sample period. The INTERRUPT RETURN instruction includes a FLAGS pop, which returns the status of the original interrupt enable bit when it restores the FLAGS.

#### HALT

When a software "HALT" instruction is executed, the processor indicates that it is entering the "HALT" state in one of two ways depending upon which mode is strapped. In minimum mode, the processor issues one ALE with no qualifying bus control signals. In Maximum Mode, the processor issues appropiate HALT status on  $S_2S_1S_0$ , and the 8288 bus controller issues one ALE. The 8086 will not leave the "HALT" state when a local bus "hold" is entered while in "HALT." In this case, the processor reissues the HALT indicator. An interrupt request or RESET will force the 8086 out of the "HALT" state.

## Read/Modify/Write (Semaphore) Operation Via Lock

The LOCK status information is provided by the processor when directly consecutive bus cycles are required during the execution of an instruction. This provides the processor with the capability of performing read/modify/write operations on memory (via the Exchange Register With Memory Instruction, for example) without the possibility of another system bus master receiving intervening memory cycles. This is useful in multiprocessor system configurations to accomplish "test and set lock" operations. The LOCK signal is activated (forced LOW) in the clock cycle following the one in which the software "LOCK" prefix instruction is decoded by the EU. It is deactivated at the end of the last bus cycle of the instruction following the "LOCK" prefix instruction. While LOCK is active, a request on a RQ/GT pin will be recorded and then honored at the end of the LOCK.

#### **External Synchronization Via Test**

As an alternative to the interrupts and general I/O capabilities, the 8086 provides a single software-testable input known as the TEST signal. At any time, the program may execute a WAIT instruction. If at that time the TEST signal is inactive (HIGH), program execution becomes suspended while the processor waits for TEST to become active. It must remain active for at least 5 CLK cycles. The WAIT instruction is re-executed repeatedly until that time. This activity does not consume bus cycles. The processor remains in an idle state while waiting. All 8086 drivers go to three-state OFF if bus "HOLD" is entered. If interrupts are enabled, they may occur while the processor is waiting. When this occurs, the processor for factors the WAIT instruction one extra time, processes the interrupt, and then re-fetches and re-executes the WAIT instruction upon returning from the interrupt.

#### **Basic System Timing**

Typical system configurations for the processor operating in minimum mode and in maximum mode are shown in Figures 2a and 2b, respectively. In minimum mode, the processor emits bus control signals in a manner similar to the 8085. In maximum mode, the processor emits coded status information which the 8288 bus control ler uses to generate MULTIBUS compatible bus control signals. Figure 3 illustrates the signal timing relationships.

#### System Timing - Minimum System

The read cycle begins in T1 with the assertion of the Address Latch Enable (ALE) signal. The trailing (low-going) edge of this signal is used to latch the address information, which is valid on the local bus at this time, into the 8282/8283 latch. The BHE and A<sub>0</sub> signals address the low, high, or both bytes. From  $T_1$  to  $T_4$ , the M/ $\overline{10}$  signal indicates a memory or I/O operation. At T<sub>2</sub> the address is removed from the local bus and the bus goes to a high impedance state. The read control signal is also asserted at T2. The read (RD) signal causes the addressed device to enable its data bus drivers to the local bus. Some time later valid data will be available on the bus and the addressed device will drive the READY line HIGH. When the processor returns the read signal to a HIGH level, the addressed device will again 3-state its bus drivers. If a transceiver (8286/8287) is required to buffer the 8086 local bus, signals  $DT/\overline{R}$  and  $\overline{DEN}$  are provided by the 8086.

A write cycle also begins with the assertion of ALE and the emission of the address. The M/ $\overline{O}$  signal is again asserted to indicate a memory or I/O write operation. In the T<sub>2</sub> immediately following the address emission, the processor emits the data to be written into the addressed location. This data remains valid until the middle of T<sub>4</sub>. During T<sub>2</sub>, T<sub>3</sub>, and T<sub>W</sub>, the processor asserts the write control signal. The write ( $\overline{WR}$ ) signal becomes active at the beginning of T<sub>2</sub> as opposed to the read which is delayed somewhat into T<sub>2</sub> to provide time for the bus to float.

The  $\overline{BHE}$  and  $A_0$  signals are used to select the proper byte(s) of the memory/IO word to be read or written according to the following table.

| BHE | A <sub>0</sub> | Characteristics                 |
|-----|----------------|---------------------------------|
| 0   | 0              | Whole word                      |
| 0   | 1              | Upper byte from/to odd address  |
| 1   | 0              | Lower byte from/to even address |
| 1   | 1              | None                            |

I/O ports are addressed in the same manner as memory location. Even addressed bytes are transferred on the  $D_7$ - $D_0$  bus lines and odd addressed bytes on  $D_{15}$ - $D_8$ .

The basic difference between the interrupt acknowledge cycle and a read cycle is that the interrupt acknowledge signal (INTA) is asserted in place of the read (RD) signal and the address bus is floated. (See Figure 6.) In the second of two successive INTA cycles, a byte of information is read from bus lines D<sub>7</sub>-D<sub>0</sub> as supplied by the interrupt system logic (i.e., 8259A Priority Interrupt Controller). This byte identifies the source (type) of the interrupt. It is multiplied by four and used as a pointer into a interrupt vector lookup table, as described earlier.

#### **Bus Timing — Medium Size Systems**

For medium size systems, the MN/ $\overline{\text{MX}}$  pin is connected to V<sub>ss</sub>, and the 8288 Bus Controller is added to the system as well as

an 8282/8283 latch for latching the system address and a 8286/8287 transceiver to allow for bus loading greater than the 8086 is capable of handling. Signals ALE, DEN, and DT/R are generated by the 8288 instead of the processor in this configuration, although their timing remains relatively the same. The 8086 status ( $\overline{S}_2$ ,  $\overline{S}_1$ , and  $\overline{S}_0$ ) provide type-of-cycle information and become 8288 inputs. This bus cycle information specifies read (code, data, or I/O), write (data or I/O), interrupt acknowledge, or software halt. The 8288 thus issues control signals specifying memory read or write, I/O read or write, or interrupt acknowledge. The 8288 provides two types of write strobes, normal and advanced, to be applied as required. The normal write strobes have data valid at the leading edge of write. The advanced write strobes have the same timing as read strobes, and hence, data isn't valid at the leading edge of write. The 8286/8287 transceiver receives the usual T and OE inputs from the 8288's DT/R and DEN.

The pointer into the interrupt vector table, which is passed during the second INTA cycle, can derive from an 8259A located on either the local bus or the system bus. If the master 8259A Priority Interrupt Controller is positioned on the local bus, a TTL gate is required to disable the 8286/8287 transceiver when reading from the master 8259A during the interrupt acknowledge sequence and software "poll."



#### ABSOLUTE MAXIMUM RATINGS

| Storage Temperature65 to +150°C         |
|-----------------------------------------|
| Ambient Temperature Under Bias0 to 70°C |
| Voltage on any Pin                      |
| with Respect to Ground1 to +7.0 V       |
| Power Dissipitation                     |

Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability.

| Commercial (C) Devices<br>Temperature (T <sub>A</sub> )0 to +70°C<br>Supply Voltage (V <sub>CC</sub> ) |
|--------------------------------------------------------------------------------------------------------|
| 8086 5 V ± 10%                                                                                         |
| 8086-1, 8086-25 V ± 5%                                                                                 |
| Industrial (I) Devices                                                                                 |
| Temperature (T <sub>A</sub> )40 to +85°C                                                               |
| Supply Voltage (V <sub>CC</sub> )                                                                      |
| 8086 5 V ± 10%                                                                                         |
| 8086-1, 8086-25 V ± 5%                                                                                 |

**OPERATING RANGES** 

Operating ranges define those limits between which the functionality of the device is guaranteed.

#### DC CHARACTERISTICS over COMMERCIAL operating range

| Parameters | Description                                                    | Test Conditions                            | Min   | Max                   | Units |
|------------|----------------------------------------------------------------|--------------------------------------------|-------|-----------------------|-------|
| VIL        | Input Low Voltage                                              |                                            | - 0.5 | + 0.8                 | v     |
| VIH        | Input High Voltage                                             |                                            | 2.0   | V <sub>CC</sub> + 0.5 | v     |
| VOL        | Output Low Voltage                                             | l <sub>OL</sub> = 2.5 mA                   |       | 0.45                  | v     |
| VOH        | Output High Voltage                                            | l <sub>OH</sub> = -400 μA                  | 2.4   |                       | v     |
| lcc        | Power Supply Current                                           | All Speeds                                 |       | 340                   | mA    |
| lu         | Input Leakage Current                                          | 0V ≤ V <sub>IN</sub> ≤ V <sub>CC</sub>     |       | ±10                   | μA    |
| ILO        | Output Leakage Current                                         | 0.45V ≤ V <sub>OUT</sub> ≤ V <sub>CC</sub> |       | ±10                   | μA    |
| VCL        | Clock Input Low Voltage                                        |                                            | - 0.5 | + 0.6                 | v     |
| VCH        | Clock Input High Voltage                                       |                                            | 3.9   | V <sub>CC</sub> + 1.0 | v     |
| CIN        | Capacitance of Input Buffer (All input except AD0-AD15, RQ/GT) | fc = 1 MHz                                 |       | 15                    | pF    |
| CIO        | Capacitance of I/O Buffer (AD0-AD15, RQ/GT)                    | fc = 1 MHz                                 |       | 15                    | pF    |

#### SWITCHING CHARACTERISTICS over COMMERCIAL operating range MINIMUM COMPLEXITY SYSTEM TIMING REQUIREMENTS

| <b>.</b> . | <b>-</b>                                       | Test              | 808 | 5   | 8086 | 2   | 8086- | -1  |       |
|------------|------------------------------------------------|-------------------|-----|-----|------|-----|-------|-----|-------|
| Parameters | Description                                    | Conditions        | Min | Max | Min  | Max | Min   | Max | Units |
| TCLCL      | CLK Cycle Period                               |                   | 200 | 500 | 125  | 500 | 100   | 500 | ns    |
| TCLCH      | CLK Low Time                                   |                   | 118 |     | 68   |     | 53    |     | ns    |
| TCHCL      | CLK High Time                                  |                   | 69  |     | 44   |     | 39    |     | ns    |
| TCH1CH2    | CLK Rise Time                                  | From 1.0 to 3.5V  |     | 10  |      | 10  |       | 10  | ns    |
| TCL2CL1    | CLK Fall Time                                  | From 3.5 to 1.0V  |     | 10  |      | 10  |       | 10  | ns    |
| TDVCL      | Data in Set-up Time                            |                   | 30  |     | 20   |     | 5     |     | ns    |
| TCLDX      | Data in Hold Time                              |                   | 10  |     | 10   |     | 10    | 1   | ns    |
| TR1VCL     | RDY Set-up Time into 8284A<br>(See Notes 1, 2) |                   | 35  |     | 35   |     | 35    |     | ns    |
| TCLR1X     | RDY Hold Time into 8284A<br>(See Notes 1, 2)   |                   | 0   |     | 0    |     | 0     |     | ns    |
| TRYHCH     | READY Set-up Time into 8086                    |                   | 118 |     | 68   |     | 53    |     | ns    |
| TCHRYX     | READY Hold Time into 8086                      |                   | 30  |     | 20   |     | 20    |     | ns    |
| TRYLCL     | READY Inactive to CLK<br>(See Note 3)          |                   | -8  |     | -8   |     | - 10  |     | ns    |
| THVCH      | HOLD Set-up Time                               |                   | 35  |     | 20   |     | 20    |     | ns    |
| TINVCH     | INTR, NMI, TEST Set-up<br>Time (See Note 2)    |                   | 30  |     | 15   |     | 15    |     | ns    |
| TILIH      | Input Rise Time<br>(Except CLK)                | From 0.8 to 2.0 V |     | 20  |      | 20  |       | 20  | ns    |
| TIHIL      | Input Fall Time (Except CLK)                   | From 2.0 to 0.8 V |     | 12  |      | 12  |       | 12  | ns    |

lotes: 1. Signal at 8284A shown for reference only.

2. Set-up requirement for asynchronous signal only to guarantee recognition at next CLK.

3. Applies only to T2 state (8ns into T3).

|            |                                       | Test                                                   | 8086      |     | 8086-2    |     | 8086-1     | l   |       |
|------------|---------------------------------------|--------------------------------------------------------|-----------|-----|-----------|-----|------------|-----|-------|
| Parameters | Description                           | Conditions                                             | Min       | Max | Min       | Max | Min        | Max | Units |
| TCLAV      | Address Valid Delay                   |                                                        | 10        | 110 | 10        | 60  | 10         | 50  | ns    |
| TCLAX      | Address Hold Time                     | 1                                                      | 10        |     | 10        |     | 10         |     | ns    |
| TCLAZ      | Address Float Delay                   | 1                                                      | TCLAX     | 80  | TCLAX     | 50  | 10         | 40  | ns    |
| TLHLL      | ALE Width                             | 1                                                      | TCLCH-20  |     | TCLCH-10  |     | TCLCH-10   |     | ns    |
| TCLLH      | ALE Active Delay                      | 1                                                      |           | 80  |           | 50  |            | 40  | ns    |
| TCHLL      | ALE Inactive Delay                    | 1                                                      |           | 85  |           | 55  |            | 45  | ns    |
| TLLAX      | Address Hold Time to<br>ALE Inactive  |                                                        | TCHCL-10  |     | TCHCL-10  |     | TCHCL-10   |     | ns    |
| TCLDV      | Data Valid Delay                      | 1                                                      | 10        | 110 | 10        | 60  | 10         | 50  | ns    |
| TCHDX      | Data Hold Time                        | 1                                                      | 10        |     | 10        |     | 10         |     | ns    |
| TWHDX      | Data Hold Time After WR               | 1                                                      | TCLCH-30  |     | TCLCH-30  |     | TCLCH-25   |     | ns    |
| TCVCTV     | Control Active Delay 1                | 1                                                      | 10        | 110 | 10        | 70  | 10         | 50  | ns    |
| TCHCTV     | Control Active Delay 2                | *CL = 20-100 pF                                        | 10        | 110 | 10        | 60  | 10         | 45  | ns    |
| TCVCTX     | Control Inactive Delay                | for all 8086<br>Outputs (in addition                   | 10        | 110 | 10        | 70  | 10         | 50  | ns    |
| TAZRL      | Address Float to<br>READ active       | to 8086 self-load).<br>Typical $C_L = 100 \text{ pF}.$ | 0         |     | 0         |     | 0          |     | ns    |
| TCLRL      | RD Active Delay                       | 1                                                      | 10        | 165 | 10        | 100 | 10         | 70  | ns    |
| TCLRH      | RD Inactive Delay                     | 7                                                      | 10        | 150 | 10        | 80  | 10         | 60  | ns    |
| TRHAV      | RD Inactive to Next<br>Address Active |                                                        | TCLCL-45  |     | TCLCL-40  |     | TCLCL - 35 |     | ns    |
| TCLHAV     | HLDA Valid Delay                      | 1                                                      | 10        | 160 | 10        | 100 | 10         | 60  | ns    |
| TRLRH      | RD Width                              | 1                                                      | 2TCLCL-75 |     | 2TCLCL-50 |     | 2TCLCL-40  |     | ns    |
| TWLWH      | WR Width                              | 1                                                      | 2TCLCL-60 |     | 2TCLCL-40 |     | 2TCLCL-35  |     | ns    |
| TAVAL      | Address Valid to ALE Low              | ]                                                      | TCLCH-60  |     | TCLCH-40  |     | TCLCH-35   |     | ns    |
| TOLOH      | Output Rise Time                      | From 0.8 to 2.0 V                                      |           | 20  |           | 20  |            | 20  | ns    |
| TOHOL      | Output Fall Time                      | From 2.0 to 0.8 V                                      |           | 12  |           | 12  |            | 12  | ns    |

## SWITCHING CHARACTERISTICS over COMMERCIAL operating range (continued)

SWITCHING TEST INPUT/OUTPUT WAVEFORM







AC Testing inputs are driven at 2.4 V for a logic ''1'' and 0.45 V for a logic ''0.'' Timing measurements are made at 1.5 V for both a logic ''1'' and ''0.''

CL includes jig capacitance

# SWITCHING CHARACTERISTICS over COMMERCIAL operating range (continued) MAX MODE SYSTEM (USING 8288 BUS CONTROLLER) TIMING REQUIREMENTS

| <b>-</b> . |                                                                 | Test              | 8086 |     | 8086- | 2   | 8086-1 |     |       |
|------------|-----------------------------------------------------------------|-------------------|------|-----|-------|-----|--------|-----|-------|
| Parameters | Description                                                     | Conditions        | Min  | Max | Min   | Max | Min    | Max | Unite |
| TCLCL      | CLK Cycle Period                                                |                   | 200  | 500 | 125   | 500 | 100    | 500 | ns    |
| TCLCH      | CLK Low Time                                                    |                   | 118  |     | 68    |     | 53     |     | ns    |
| TCHCL      | CLK High Time                                                   |                   | 69   |     | 44    |     | 39     |     | ns    |
| TCH1CH2    | CLK Rise Time                                                   | From 1.0 to 3.5 V |      | 10  |       | 10  |        | 10  | ns    |
| TCL2CL1    | CLK Fall Time                                                   | From 3.5 to 1.0 V |      | 10  |       | 10  |        | 10  | ns    |
| TDVCL      | Data in Set-up Time                                             |                   | 30   |     | 20    |     | 5      |     | ns    |
| TCLDX      | Data in Hold Time                                               |                   | 10   |     | 10    |     | 10     |     | ns    |
| TR1VCL     | RDY Set-up Time into 8284A<br>(See Notes 1, 2)                  |                   | 35   |     | 35    |     | 35     |     | ns    |
| TCLR1X     | RDY Hold Time into 8284A<br>(See Notes 1, 2)                    |                   | 0    |     | 0     |     | 0      |     | ns    |
| TRYHCH     | READY Set-up Time into 8086                                     |                   | 118  |     | 68    |     | 53     |     | ns    |
| TCHRYX     | READY Hold Time into 8086                                       |                   | 30   |     | 20    |     | 20     |     | ns    |
| TRYLCL     | READY Inactive to CLK<br>(See Note 4)                           |                   | -8   |     | -8    |     | - 10   |     | ns    |
| TINVCH     | Set-up Time for Recognition<br>(INTR, NMI, TEST<br>(See Note 2) |                   | 30   |     | 15    |     | 15     |     | ns    |
| TGVCH      | RQ/GT Set-up Time                                               |                   | 30   |     | 15    |     | 12     |     | ns    |
| TCHGX      | RQ Hold Time into 8066                                          |                   | 40   |     | 30    |     | 20     |     | ns    |
| TILIH      | Input Rise Time<br>(Except CLK)                                 | From 0.8 to 2.0 V |      | 20  |       | 20  |        | 20  | ns    |
| TIHIL      | Input Fall Time<br>(Except CLK)                                 | From 2.0 to 0.8 V |      | 12  |       | 12  |        | 12  | ns    |

Notes: 1. Signal at 8284A or 8288 shown for reference only.

2. Set-up requirement for asynchronous signal only to guarantee recognition at next CLK.

3. Applies only to T3 and wait states.

4. Applies only to T2 state (8ns into T3).

|            | <b>_</b>                                         | Test                                       | 8086      | 8086 |           | 8086-2 |           | 8086-1 |       |
|------------|--------------------------------------------------|--------------------------------------------|-----------|------|-----------|--------|-----------|--------|-------|
| Parameters | Description                                      | Conditions                                 | Min       | Max  | Min       | Max    | Min       | Max    | Units |
| TCLML      | Command Active Delay<br>(See Note 1)             |                                            | 10        | 35   | 10        | 35     | 10        | 35     | ns    |
| TCLMH      | Command Inactive Delay<br>(See Note 1)           |                                            | 10        | 35   | 10        | 35     | 10        | 35     | ns    |
| TRYHSH     | READY Active to Status<br>Passive (See Note 3)   |                                            |           | 110  |           | 65     |           | 45     | ns    |
| TCHSV      | Status Active Delay                              |                                            | 10        | 110  | 10        | 60     | 10        | 45     | ns    |
| TCLSH      | Status Inactive Delay                            | 1                                          | 10        | 130  | 10        | 70     | 10        | 55     | ns    |
| TCLAV      | Address Valid Delay                              |                                            | 10        | 110  | 10        | 60     | 10        | 50     | ns    |
| TCLAX      | Address Hold Time                                |                                            | 10        |      | 10        |        | 10        |        | ns    |
| TCLAZ      | Address Float Delay                              |                                            | TCLAX     | 80   | TCLAX     | 50     | 10        | 40     | ns    |
| TSVLH      | Status Valid to ALE High<br>(See Note 1)         |                                            |           | 15   |           | 15     |           | 15     | ns    |
| TSVMCH     | Status Valid to MCE High<br>(See Note 1)         |                                            |           | 15   |           | 15     |           | 15     | ns    |
| TCLLH      | CLK Low to ALE Valid<br>(See Note 1)             |                                            |           | 15   |           | 15     |           | 15     | ns    |
| TCLMCH     | CLK Low to MCE High<br>(See Note 1)              |                                            |           | 15   |           | 15     |           | 15     | ns    |
| TCHLL      | ALE Inactive Delay<br>(See Note 1)               | C <sub>L</sub> = 20-100 pF<br>for all 8086 |           | 15   |           | 15     |           | 15     | ns    |
| TCLMCL     | MCE Inactive Delay<br>(See Note 1)               | Outputs (In addition<br>to 8086 self-load) |           | 15   |           | 15     |           | 15     | ns    |
| TCLDV      | Data Valid Delay                                 |                                            | 10        | 110  | 10        | 60     | 10        | 50     | ns    |
| TCHDX      | Data Hold Time                                   |                                            | 10        |      | 10        |        | 10        |        | ns    |
| TCVNV      | Control Active Delay<br>(See Note 1)             |                                            | 5         | 45   | 5         | 45     | 5         | 45     | ns    |
| TCVNX      | Control Inactive Delay<br>(See Note 1)           |                                            | 10        | 45   | 10        | 45     | 10        | 45     | ns    |
| TAZRL      | Address Float to<br>Read Active                  |                                            | 0         |      | 0         |        | 0         |        | ns    |
| TCLRL      | RD Active Delay                                  | 7                                          | 10        | 165  | 10        | 100    | 10        | 70     | ns    |
| TCLRH      | RD Inactive Delay                                |                                            | 10        | 150  | 10        | 80     | 10        | 60     | ns    |
| TRHAV      | RD Inactive to Next<br>Address Active            |                                            | TCLCL-45  |      | TCLCL-40  |        | TCLCL-35  |        | ns    |
| TCHDTL     | Direction Control Active<br>Delay (See Note 1)   |                                            |           | 50   |           | 50     |           | 50     | ns    |
| тснотн     | Direction Control Inactive<br>Delay (See Note 1) |                                            |           | 30   |           | 30     |           | 30     | ns    |
| TCLGL      | GT Active Delay                                  |                                            | 0         | 85   | 0         | 50     | 0         | 38     | ns    |
| TCLGH      | GT Inactive Delay                                |                                            | 0         | 85   | 0         | 50     | 0         | 45     | ns    |
| TRLRH      | RD Width                                         |                                            | 2TCLCL-75 |      | 2TCLCL-50 |        | 2TCLCL-40 |        | ns    |
| TOLOH      | Output Rise Time                                 | From 0.8 to 2.0 V                          |           | 20   |           | 20     |           | 20     | ns    |
| TOHOL      | Output Fall Time                                 | From 2.0 to 0.8 V                          | 1         | 12   |           | 12     |           | 12     | n     |

Notes: 1. Signal at 8284A or 8288 shown for reference only.

Set-up requirement for asynchronous signal only to guarantee recognition at next CLK.
 Applies only to T3 and wait states.
 Applies only to T2 state (8ns into T3).

#### ABSOLUTE MAXIMUM RATINGS

| Storage Temperature65          | to +150°C  |
|--------------------------------|------------|
| Ambient Temperature Under Bias | 0 to 70°C  |
| Voltage on any Pin             |            |
| with Respect to Ground1        | to + 7.0 V |
| Power Dissipitation            | 2.5 W      |

Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability.

#### **OPERATING RANGES**

Military (M) Devices

Temperature (T<sub>C</sub>)..... -55 to +125°C 

Operating ranges define those limits between which the functionality of the device is guaranteed.

DC CHARACTERISTICS over MILITARY operating range (for APL Products, Group A, Subgroups 1, 2, 3 are tested unless otherwise noted)

| Parameter<br>Symbol | Parameter<br>Description                                          | Test Conditions                                              | Min.  | Max.                   | Unit |
|---------------------|-------------------------------------------------------------------|--------------------------------------------------------------|-------|------------------------|------|
| VIL †               | Input LOW Voltage                                                 | V <sub>CC</sub> = Min. & Max.                                | -0.5* | + 0.8                  | v    |
| VIH †               | Input HIGH Voltage                                                | V <sub>CC</sub> = Min. & Max.                                | 2.0   | V <sub>CC</sub> + 0.5* | v    |
| V <sub>OL</sub>     | Output LOW Voltage                                                | I <sub>OL</sub> = 2.0 mA,<br>V <sub>CC</sub> = Min.          |       | 0.45                   | v    |
| V <sub>OH</sub>     | Output HIGH Voltage                                               | $I_{OH} = -400 \ \mu A,$<br>$V_{CC} = Min.$                  | 2.4   |                        | v    |
| lcc                 | Power Supply Current (Note 1)                                     | $T_C = 25^{\circ}C, V_{CC} = Max.$                           |       | 340                    | mA   |
| łu                  | Input Leakage Current                                             | V <sub>CC</sub> = Max.,<br>V <sub>IN</sub> = 5.5 V & 0 V     | - 10  | 10                     | μA   |
| 1LO ††              | Output Leakage Current                                            | V <sub>CC</sub> = Max.,<br>V <sub>OUT</sub> = 5.5 V & 0.45 V | - 10  | 10                     | μA   |
| VCL †               | Clock Input LOW Voltage                                           | V <sub>CC</sub> = Min. & Max.                                | -0.5* | + 0.6                  | v    |
| V <sub>CH</sub> †   | Clock Input HIGH Voltage                                          | V <sub>CC</sub> = Min. & Max.                                | 3.9   | V <sub>CC</sub> + 1.0* | v    |
| C <sub>IN</sub> ††† | Capacitance of Input Buffer (All Input Except<br>AD0-AD15, RQ/GT) | fc = 1 MHz                                                   |       | 20*                    | pF   |
| CIO ttt             | Capacitance of I/O Buffer (AD0-AD15, RQ/GT)                       | fc = 1 MHz                                                   |       | 20*                    | pF   |

Guaranteed by design; not tested.
 † Group A, Subgroups 7 and 8 only are tested.
 †† Group A, Subgroups 1 and 2 only are tested.
 †† Not included in Group A tests.

Notes: 1. I<sub>CC</sub> is measured while running a functional pattern with spec value I<sub>OL</sub>/I<sub>OH</sub> loads applied.

SWITCHING CHARACTERISTICS over MILITARY operating range (for APL Products, Group A, Subgroups 9, 10, 11 are tested unless otherwise noted)

#### MINIMUM COMPLEXITY SYSTEM TIMING REQUIREMENTS

| Parameter | Parameter                               | Test<br>Conditions | 80   | )86  | 808  | 36-2 |      |
|-----------|-----------------------------------------|--------------------|------|------|------|------|------|
| Symbol    | Description                             | (Note 6)           | Min. | Max. | Min. | Max. | Unit |
| TCLCL     | CLK Cycle Period (Note 11)              |                    | 200  | 500  | 125  | 500  | ns   |
| TCLCH     | CLK LOW Time                            |                    | 118  |      | 68   |      | ns   |
| TCHCL     | CLK HIGH Time                           |                    | 69   |      | 44   |      | ns   |
| TCH1CH2   | CLK Rise Time (Note 5)                  | From 1.0 to 3.5 V  |      | 10   |      | 10   | ns   |
| TCL2CL1   | CLK Fall Time (Note 5)                  | From 3.5 to 1.0 V  |      | 10   |      | 10   | ns   |
| TDVCL     | Data in Setup Time                      |                    | 30   |      | 20   |      | ns   |
| TCLDX     | Data in Hold Time                       |                    | 10   |      | 10   |      | ns   |
| TR1VCL    | RDY Setup Time into 8284A (Notes 1 & 2) |                    | 35   |      | 35   |      | ns   |
| TCLR1X    | RDY Hold Time into 8284A (Notes 1 & 2)  |                    | 0    |      | 0    |      | ns   |
| TRYHCH    | READY Setup Time into 8086              |                    | 118  |      | 68   |      | ns   |
| TCHRYX    | READY Hold Time into 8086               |                    | 30   |      | 20   |      | ns   |
| TRYLCL    | READY Inactive to CLK (Note 4)          |                    | -8   | 1    | -8   |      | ns   |
| THVCH     | HOLD Setup Time                         |                    | 35   |      | 20   |      | ns   |
| TINVCH    | INTR, NMI, TEST Setup Time (Note 2)     |                    | 30   |      | 15   |      | ns   |
| TILIH     | Input Rise Time (Except CLK) (Note 5)   | From 0.8 to 2.0 V  | 1    | 20   |      | 20   | ns   |
| TIHIL     | Input Fall Time (Except CLK) (Note 5)   | From 2.0 to 0.8 V  |      | 12   |      | 12   | ns   |

Notes: 1. Signal at 8284A and 8288 shown for reference only. 2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK. 3. Applies only to T3 and wait states. 4. Applies only to T2 state (8 ns into T3). 5. Not tested; these specs are controlled by the Teradyne J941 tester. 6.  $V_{CC} = 4.5 V$ , 5.5 V V<sub>IH</sub> = 2.4 V V<sub>IL</sub> = .45 V V<sub>IH</sub> = 4.3 V V<sub>IL</sub> = .45 V V<sub>IH</sub> = 4.3 V V<sub>IC</sub> = .14 V 7. Minimum spec tested at V<sub>CC</sub> Max. (5.5 V) only. 8. Maximum spec tested at V<sub>CC</sub> Max. (4.5 V) only. 9. Tested at V<sub>CC</sub> Min. (4.5 V) only. 10. Tested at V<sub>CC</sub> Min. (4.5 V) only. 11. Test conditions for TCLCL Max. are: V<sub>CC</sub> = 1.4 V

| Vcc  | = | 4.5 V |  | VOL  | = | 1 | ۷ |
|------|---|-------|--|------|---|---|---|
| VIL  | = | 0 V   |  | VIH  | - | 4 | ۷ |
| VILC | = | 0 V   |  | VIHC | = | 5 | ۷ |
|      |   |       |  |      |   |   |   |

## SWITCHING CHARACTERISTICS over MILITARY operating range (continued)

### TIMING RESPONSES

| D                   | Parameter                                    | Test<br>Conditions                   | 80   | 86   | 808  | 86-2 |     |
|---------------------|----------------------------------------------|--------------------------------------|------|------|------|------|-----|
| Parameter<br>Symbol | Description                                  | (Note 6)                             | Min. | Max. | Min. | Max. | Uni |
| TCLAV               | Address Valid Delay                          |                                      | 10   | 110  | 10   | 60   | ns  |
| TCLAX               | Address Hold Time (Notes 7 & 8)              |                                      | 10   |      | 10   | 1    | ns  |
| TCLAZ               | Address Float Delay (Note 8)                 |                                      | 10   | 80   | 10   | 50   | ns  |
| TLHLL               | ALE Width (Note 10)                          |                                      | 98   |      | 58   |      | ns  |
| TCLLH               | ALE Active Delay (Note 8)                    |                                      |      | 80   |      | 50   | ns  |
| TCHLL               | ALE Inactive Delay (Note 8)                  |                                      |      | 85   |      | 55   | ns  |
| TLLAX               | Address Hold Time to ALE Inactive (Note 7)   |                                      | 59   | Î    | 34   |      | ns  |
| TCLDV               | Data Valid Delay (Note 8)                    |                                      | 10   | 110  | 10   | 60   | ns  |
| TCHDX               | Data Hold Time (Note 10)                     |                                      | 10   |      | 10   |      | ns  |
| TWHDX               | Data Hold Time After WR (Note 9)             |                                      | 88   |      | 38   |      | ns  |
| TCVCTV              | Control Active Delay 1 (Note 8)              |                                      | 10   | 110  | 10   | 70   | ns  |
| TCHCTV              | Control Active Delay 2 (Note 8)              | C <sub>L</sub> = 100 pF              | 10   | 110  | 10   | 60   | ns  |
| TCVCTX              | Control Inactive Delay (Note 8)              | for all 8086<br>Outputs (in addition | 10   | 110  | 10   | 70   | ns  |
| TAZRL               |                                              |                                      | 0    |      | 0    |      | ns  |
| TCLRL               | RD Active Delay (Note 8)                     |                                      | 10   | 165  | 10   | 100  | ns  |
| TCLRH               | RD Inactive Delay (Note 8)                   |                                      | 10   | 150  | 10   | 80   | ns  |
| TRHAV               | RD Inactive to Next Address Active (Note 10) |                                      | 155  |      | 85   |      | ns  |
| TCLHAV              | HLDA Valid Delay (Note 8)                    |                                      | 10   | 160  | 10   | 100  | ns  |
| TRLRH               | RD Width (Note 10)                           |                                      | 325  |      | 200  |      | ns  |
| TWLWH               | WR Width (Note 10)                           |                                      | 340  |      | 210  | 1    | ns  |
| TAVAL               | Address Valid to ALE LOW (Note 9)            |                                      | 58   |      | 28   |      | ns  |
| TOLOH               | Output Rise Time (Note 9)                    | From 0.8 to 2.0 V                    |      | 20   |      | 20   | ns  |
| TOHOL               | Output Fall Time (Note 9) From 2.0 to 0.8 V  |                                      |      | 12   |      | 12   | ns  |

$$= 4.5 \text{ V}, 5.5 \text{ V}$$
  $\text{V}_{\text{H}} = 2.4 \text{ V}$ 

$$ILC = .25 V$$

 $\begin{array}{c} \text{VOL} = 1.4 \text{ V} \\ \text{VOL} = 1.4 \text{ V} \\ \text{Nimimum spec tested at } \text{V}_{CC} \text{ Max}. (5.5 \text{ V}) \text{ only.} \\ \text{8. Maximum spec tested at } \text{V}_{CC} \text{ Min.} (4.5 \text{ V}) \text{ only.} \\ \text{9. Tested at } \text{V}_{CC} \text{ Min.} (4.5 \text{ V}) \text{ only.} \\ \text{10. Tested at } \text{V}_{CC} \text{ Min.} (4.5 \text{ V}) \text{ only.} \\ \text{11. Test conditions for TCLCL Max. are:} \\ \text{V}_{CC} = 4.5 \text{ V} \\ \text{V}_{CL} = 1 \text{ V} \\ \end{array}$ 

| VCC  | - | 4.5 V | VOL  | - | 1 | v |  |
|------|---|-------|------|---|---|---|--|
| VIL  | = | 0 V   | VIH  | = | 4 | ۷ |  |
| VILC | - | 0 V   | VIHC | = | 5 | ۷ |  |

### SWITCHING CHARACTERISTICS over MILITARY operating range (continued)

#### MAX MODE SYSTEM (USING 8288 BUS CONTROLLER) TIMING REQUIREMENTS

| Composition     Compositi |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| n<br>n<br>n<br>n<br>n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| n<br>n<br>n<br>n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| n<br>n<br>n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| n<br>n<br>n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 20                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| 11. | Test | conditions | for | TCLCL | Max. | į |
|-----|------|------------|-----|-------|------|---|
|     | Vaa  | - 45 V     |     |       | Voi  |   |

|    | 00   |     | 4.0 4 | * UL |   |   | • |
|----|------|-----|-------|------|---|---|---|
| ۱. | /11_ | -   | 0 V   | VIH  | = | 4 | ۷ |
| '  | /ILC | 222 | 0 V   | VIHC | - | 5 | v |
|    |      |     |       |      |   |   |   |

#### SWITCHING CHARACTERISTICS over MILITARY operating range (continued) TIMING RESPONSES

| Parameter<br>Symbol | Parameter<br>Description                  | Test                                            | 80   | 86   | 8086-2 |      |      |
|---------------------|-------------------------------------------|-------------------------------------------------|------|------|--------|------|------|
|                     |                                           | Conditions<br>(Note 6)                          | Min. | Max. | Min.   | Max. | Unit |
| TCLML               | Command Active Delay (Note 1)             |                                                 | 10   | 35   | 10     | 35   | ns   |
| TCLMH               | Command Inactive Delay (Note 1)           |                                                 | 10   | 35   | 10     | 35   | ns   |
| TRYHSH              | READY Active to Status Passive (Note 3)   |                                                 |      | 110  |        | 65   | ns   |
| TCHSV               | Status Active Delay (Notes 7 & 8)         |                                                 | 10   | 110  | 10     | 60   | ns   |
| TCLSH               | Status Inactive Delay                     | ]                                               | 10   | 130  | 10     | 70   | ns   |
| TCLAV               | Address Valid Delay                       | ]                                               | 10   | 110  | 10     | 60   | ns   |
| TCLAX               | Address Hold Time                         |                                                 | 10   | 1    | 10     | 1    | ns   |
| TCLAZ               | Address Float Delay                       |                                                 | 10   | 80   | 10     | 50   | ns   |
| TSVLH               | Status Valid to ALE HIGH (Note 1)         |                                                 |      | 15   |        | 15   | ns   |
| TSVMCH              | Status Valid to MCE HIGH (Note 1)         |                                                 |      | 15   |        | 15   | ns   |
| TCLLH               | CLK LOW to ALE Valid (Note 1)             |                                                 |      | 15   |        | 15   | ns   |
| TCLMCH              | CLK LOW to MCE HIGH (Note 1)              |                                                 |      | 15   |        | 15   | ns   |
| TCHLL               | ALE Inactive Delay (Note 1)               | C <sub>L</sub> = 100 pF<br>for all 8086         |      | 15   |        | 15   | ns   |
| TCLMCL              | MCE Inactive Delay (Note 1)               | Outputs (In addition<br>to 8086 internal loads) |      | 15   |        | 15   | ne   |
| TCLDV               | Data Valid Delay                          |                                                 | 10   | 110  | 10     | 60   | ne   |
| TCHDX               | Data Hold Time                            | 1                                               | 10   |      | 10     | 1    | ns   |
| TCVNV               | Control Active Delay (Note 1)             | 1                                               | 5    | 45   | 5      | 45   | ns   |
| TCVNX               | Control Inactive Delay (Note 1)           | 1                                               | 10   | 45   | 10     | 45   | ns   |
| TAZRL               | Address Float to Read Active              |                                                 | 0    |      | 0      | 1    | ns   |
| TCLRL               | RD Active Delay                           |                                                 | 10   | 165  | 10     | 100  | ns   |
| TCLRH               | RD Inactive Delay                         | 1                                               | 10   | 150  | 10     | 80   | ns   |
| TRHAV               | RD Inactive to Next Address Active        | 1                                               | 155  |      | 85     |      | ns   |
| TCHDTL              | Direction Control Active Delay (Note 1)   |                                                 |      | 50   |        | 50   | ns   |
| TCHDTH              | Direction Control Inactive Delay (Note 1) | 1                                               |      | 30   |        | 30   | ns   |
| TCLGL               | GT Active Delay (Note 8)                  | 1                                               | 0    | 85   | 0      | 50   | ns   |
| TCLGH               | GT Inactive Delay (Note 8)                | 1                                               | 0    | 85   | 0      | 50   | ns   |
| TRLRH               | RD Width                                  | 1                                               | 325  |      | 200    |      | ns   |
| TOLOH               | Output Rise Time                          | From 0.8 to 2.0 V                               |      | 20   |        | 20   | ns   |
| TOHOL               | Output Fall Time                          | From 2.0 to 0.8 V                               |      | 12   |        | 12   | ns   |

Notes: 1. Signal at 8284A and 8288 shown for reference only. 2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK. 3. Applies only to T3 and wait states. 4. Applies only to T2 state (8 ns into T3). 5. Not tested; these specs are controlled by the Teradyne J941 tester. 6.  $V_{CC} = 4.5 V$ , 5.5 V  $V_{H} = 2.4 V$   $V_{IL} = .45 V$   $V_{HC} = 4.3 V$   $V_{IL} = .25 V$   $V_{OH} = 1.6 V$   $V_{CT} = 1.4 V$ 

$$V_{01} = 1.4 V$$

 $v_{OL} = 1.4 v$ 7. Minimum spec tested at  $V_{CC}$  Max. (5.5 V) only. 8. Maximum spec tested at  $V_{CC}$  Min. (4.5 V) only. 9. Tested at  $V_{CC}$  Max. (5.5 V) only.

11. Test conditions for TCLCL Max. are:

$$\begin{array}{ccccc} V_{CC} &= 4.5 \ V & V_{OL} &= 1 \ V \\ V_{IL} &= 0 \ V & V_{IH} &= 4 \ V \\ V_{ILC} &= 0 \ V & V_{IHC} &= 5 \ V \end{array}$$











## 8086/8088 INSTRUCTION SET SUMMARY

| DATA TRANSFER                       |                 |               |               |               |
|-------------------------------------|-----------------|---------------|---------------|---------------|
| MOV = Move                          | 76543210        | 76543210      | 76543210      | 76543210      |
| Register/memory to /from register   | 100010dw        | mod reg r/m   |               |               |
| Immediate to register/memory        | 1100011w        | mod 0 0 0 r/m | data          | data if w = 1 |
| Immediate to register               | 1011w reg       | data          | data if w = 1 |               |
| Memory to accumulator               | 101000w         | addr-low      | addr-high     |               |
| Accumulator to memory               | 101001w         | addr-low      | addr-high     |               |
| Register/memory to segment register | 10001110        | mod 0 reg r/m |               |               |
| Segment register to register/memory | 10001100        | mod 0 reg r/m |               |               |
| PUSH = Push:                        |                 |               |               |               |
| Register/memory                     | 11111111        | mod 1 1 0 r/m |               |               |
| Register                            | 0 1 0 1 0 reg   |               |               |               |
| Segment register                    | 0 0 0 reg 1 1 0 |               |               |               |
|                                     | L               | 1             |               |               |
| POP = Pop:                          |                 |               |               |               |
| Register/memory                     | 10001111        | mod 0 0 0 r/m |               |               |
| Register                            | 0 1 0 1 1 reg   |               |               |               |
| Segment register                    | 000 reg 1 1 1   |               |               |               |
| XCHG = Exchange:                    |                 |               |               |               |
| Register/memory with register       | 1000011w        | mod reg r/m   |               |               |
| Register with accumulator           | 10010 reg       |               |               |               |
|                                     |                 |               |               |               |
| IN = Input from:                    |                 |               |               |               |
| Fixed port                          | 1110010w        | port          |               |               |
| Variable port                       | 1110110w        |               |               |               |
| OUT = Ouput to:                     |                 |               |               |               |
| Fixed port                          | 1110011w        | port          |               |               |
| Variable port                       | 1110111w        |               |               |               |
| XLAT = Transtate byte to AL         | 11010111        |               |               |               |
| LEA = Load EA to register           | 10001101        | mod reg r/m   |               |               |
| LDS - Load pointer to DS            | 11000101        | mod reg r/m   |               |               |
| LES - Load pointer to ES            | 11000100        | mod reg r/m   |               |               |
| LANF - Load AH with flags           | 10011111        |               |               |               |
| SANF = Store AH into flags          | 10011110        |               |               |               |
| PUSHF = Push flags                  | 10011100        |               |               |               |
| POPF = Pop flags                    | 10011101        |               |               |               |

## **INSTRUCTION SET SUMMARY** (continued)

## ARITHMETIC

## ADD = Add

Reg/memory with register to either

Immediate to register / memory

# Immediate to accumulator

Reg/memory with register to either Immediate to register/memory Immediate to accumulator

INC = Increment:

Register/memory

Register

AAA = ASCII adjust for add

DAA = Decimal adjust for add

#### SUB = Subtract:

| Reg/memory and register to either |
|-----------------------------------|
| Immediate from register/memory    |
| Immediate from accumulator        |

#### SBB = Subtract with borrow:

| Reg/memory and register to either |  |
|-----------------------------------|--|
| Immediate from register/memory    |  |
| Immediate from accumulator        |  |

#### DEC = Decrement:

Register/memory Register

NEG Change sign

#### CMP = Compare:

| Register/memory with register   |
|---------------------------------|
| Register with register/memory   |
| Immediate with register/memory  |
| Immediate with accumulator      |
| AAS ASCII adjust for subtract   |
| DAS Decimal adjust for subtract |
| MUL Mulitiply (unsigned)        |
| IMUL Integer multiply (signed): |
| AAM ASCII adjust for multiply   |
| DIV Divide (unsigned):          |
| IDIV Integer divide (signed)    |
| AAD ASCH adjust for divide      |
| CBW Convert byte to word        |
| CWD Convert word to double word |

## 76543210 76543210 76543210 76543210

| 0 0 0 0 0 d w | mod reg r/m   |               |                  |
|---------------|---------------|---------------|------------------|
| 100000sw      | mod 0 0 0 r/m | data          | data if s:w = 01 |
| 0000010w      | data          | data if w = 1 | 7                |

| 000100dw | mod reg r/m   |               |                  |
|----------|---------------|---------------|------------------|
| 10000sw  | mod 0 1 0 r/m | data          | data if s:w = 01 |
| 0001010w | data          | data if w = 1 | ]                |

| 1111111w  | mod 0 0 0 r/m |
|-----------|---------------|
| 01000 reg |               |
| 00110111  |               |
| 00100111  |               |

| 001010dw | mod reg r/m   |               |                  |
|----------|---------------|---------------|------------------|
| 10000sw  | mod 1 0 1 r/m | data          | data if s:w = 01 |
| 0010110w | data          | data if w = 1 |                  |

| 000110dw | mod reg r/m   | )             |                  |
|----------|---------------|---------------|------------------|
| 10000sw  | mod 0 1 1 r/m | data          | data if s:w = 01 |
| 0001110w | data          | data if w = 1 |                  |

| 1111111w  | mod 0 0 1 r/m |
|-----------|---------------|
| 01001 reg |               |
| 1111011w  | mod 0 1 1 r/m |

| 0011101w | mod reg r/m   |               |                  |
|----------|---------------|---------------|------------------|
| 0011100w | mod reg r/m   |               |                  |
| 10000sw  | mod 1 1 1 r/m | data          | data if s:w = 01 |
| 0011110w | data          | data if w = 1 |                  |
| 00111111 |               |               |                  |
| 00101111 |               |               |                  |
| 1111011w | mod 1 0 0 r/m |               |                  |
| 1111011w | mod 1 0 1 r/m |               |                  |
| 11010100 | 00001010      |               |                  |
| 1111011w | mod 1 1 0 r/m |               |                  |
| 1111011w | mod 1 1 1 r/m |               |                  |
| 11010101 | 00001010      |               |                  |
| 10011000 |               |               |                  |
| 10011001 |               |               |                  |

#### **INSTRUCTION SET SUMMARY** (continued) LOGIC 76543210 76543210 76543210 76543210 NOT Invert 1111011w mod 0 1 0 r/m SHL/SAL Shift logical/arithmetic left 110100vw mod 1 0 0 r/m SHR Shift logical right 110100vw mod 1 0 1 r/m 110100vw SAR Shift arithmetic right mod 1 1 1 r/m **ROL** Rotate left 110100vw mod 0 0 0 r/m ROR Rotate right 110100vw mod 0 0 1 r/m RCL Rotate through carry flag left 110100vw mod 0 1 0 r/m RCR Rotate through carry right 110100vw mod 0 1 1 r/m AND = And: Reg/memory and register to either 001000dw mod reg r/m Immediate to register/memory 100000w mod 1 0 0 r/m data data if w = 1 Immediate to accumulator 0010010w data data if w = 1 TEST = And function to flags, no result: 1000010w Register/memory and register mod reg r/m Immediate data and register/memory 1111011w mod 0 0 0 r/m data data if w = 1 Immediate data and accumulator 1010100w data data if w = 1 OR = Or: Reg/memory and register to either 000010dw mod reg r/m Immediate to register/memory 100000w mod 0 0 1 r/m data data if w = 1 Immediate to accumulator 0000110w data data if w = 1 XOR = Exclusive or: 001100dw Reg/memory and register to either mod reg r/m 100000w mod 1 1 0 r/m data if w = 1 Immediate to register/mømory data Immediate to accumulator 0011010w data data if w = 1 STRING MANIPULATION: REP - Repeat 1111001z MOVS = Move byte/word 1010010w CMPS - Compare byte/word 1010011w SCAS = Scan byte/word 1010111w LODS = Load byte/wd to AL/AX 1010110w STOS = Stor byte/wd from AL/A 1010101w

|                                                      | CTION SET SUN |                  |             |          |
|------------------------------------------------------|---------------|------------------|-------------|----------|
| CONTROL TRANSFER<br>CALL = Call                      | 76543210      | 76543210         | 76543210    | 76543210 |
| Direct within segment                                | 11101000      | disp-low         | disp-high   | ]        |
| indirect within segment                              | 1111111       | mod 0 1 0 r/m    | ]           | 1        |
| Direct intersegment                                  | 10011010      | offset-low       | offset-high | ו        |
|                                                      |               | seg-low          | seg-high    | ]        |
| Indirect intersegment                                | 11111111      | mod 0 1 1 r/m    | ]           | 1        |
| JMP = Unconditional jump:                            |               |                  |             |          |
| • •                                                  | 11101001      | dian law         | disp-high   | 1        |
| Direct within segment<br>Direct within segment-short |               | disp-low<br>disp | ) asp-nign  | 1        |
| ndirect within segment                               |               | mod 1 0 0 r/m    |             |          |
| ·                                                    |               |                  | ]           | ı        |
| Direct intersegment                                  | 11101010      | offset-low       | offset-high | l<br>r   |
|                                                      |               | seg-low          | seg-high    | 1        |
| ndirect intersegment                                 | 11111111      | mod 1 0 1 r/m    | 1           |          |
| RET = Return from CALL:                              |               |                  |             |          |
| Within segment                                       | 11000011      |                  |             |          |
| Within seg adding immed to SP                        | 1100010       | data-low         | data-high   | ]        |
| ntersegment                                          | 11001011      |                  |             |          |
| ntersegment adding immediate to SP                   | 11001010      | data-low         | data-high   | ]        |
| IE/JZ = Jump on equal/zero                           | 01110100      | disp             | ]           | _        |
| IL/JNGE = Jump on less/not greater or equal          | 01111100      | disp             | ]           |          |
| JLE/JNG = Jump on less or equal/not greater          | 0111110       | disp             | ]           |          |
| JB/JNAE = Jump on below/not above or equal           | 01110010      | disp             | ]           |          |
| JBE/JNA = Jump on below or equal/not above           | 01110110      | disp             | ]           |          |
| JP/JPE = Jump on parity/parity even                  | 01111010      | disp             | ]           |          |
| JO = Jump on overflow                                | 01110000      | disp             | ]           |          |
| <b>JS</b> = Jump on sign                             | 01111000      | disp             | ]           |          |
| JNE/JNZ = Jump on not equal/not zero                 | 01110101      | disp             | ]           |          |
| JNL/JGE = Jump on not less/greater or equal          | 01111101      | disp             | ]           |          |
| JNLE/JG = Jump on not less or equal/greater          | 01111111      | disp             | ]           |          |
| JNB/JAE = Jump on not below/above or equal           | 01110011      | disp             | ]           |          |
| JNBE/JA = Jump on not below or equal/above           | 01110111      | disp             | ]           |          |
| JNP/JPO = Jump on not par/par odd                    | 01111011      | disp             | ]           |          |
| JNO = Jump on not overflow                           | 01110001      | disp             | ]           |          |
| <b>JNS</b> = Jump on not sign                        | 01111001      | disp             | ]           |          |
| LOOP = Loop CX times                                 | 11100010      | disp             | ]           |          |
| LOCPZ/LOOPE = Loop while zero/equal                  | 11100001      | disp             | ]           |          |
| LOOPNZ/LOOPNE = Loop while not zero/equal            | 11100000      | disp             | ]           |          |
| JCXZ = Jump on CX zero                               | 11100011      | disp             | 1           |          |

| INSTRUCTION SET SUMMARY (continued) |                 |               |          |          |  |  |  |
|-------------------------------------|-----------------|---------------|----------|----------|--|--|--|
| CONTROL TRANSFER (Cont'd.)          |                 |               |          |          |  |  |  |
| INT = Interrupt                     | 76543210        | 76543210      | 76543210 | 76543210 |  |  |  |
| Type specified                      | 11001101        | type          | ]        |          |  |  |  |
| Туре 3                              | 11001100        | ]             |          |          |  |  |  |
| INTO = Interrupt on overflow        | 11001110        | ]             |          |          |  |  |  |
| IRET = Interrupt return             | 11001111        | ]             |          |          |  |  |  |
| PROCESSOR CONTROL                   |                 |               |          |          |  |  |  |
|                                     |                 | •             |          |          |  |  |  |
| CLC = Clear carry                   | 11111000        | ]             |          |          |  |  |  |
| CMC = Complement carry              | 11110101        | ]             |          |          |  |  |  |
| STC = Set carry                     | 11111001        | ]             |          |          |  |  |  |
| CLD = Clear direction               | 11111100        | ]             |          |          |  |  |  |
| STD = Set direction                 | 1111101         | ]             |          |          |  |  |  |
| CLI = Clear interrupt               | 11111010        | ]             |          |          |  |  |  |
| STI = Set interrupt                 | 11111011        | ]             |          |          |  |  |  |
| HLT = Halt                          | 11110100        | ]             |          |          |  |  |  |
| WAIT = Wait                         | 10011011        | ]             |          |          |  |  |  |
| ESC = Processor Extension Escape    | 1 1 0 1 1 x x x | mod x x x r/m | ]        |          |  |  |  |
| LOCK = Bus lock prefix              | 11110000        | ]             |          |          |  |  |  |

#### Footnotes:

AL = 8-bit accumulator AX = 16-bit accumulator CX = Count register DS = Data segment ES = Extra segment Above/below refers to unsigned value. Above reference is to unsigned value. Greater = more positive (more negative) signed values if d = 1 then 'to'' reg if d = 0 then 'trom'' reg w = 1 then word instruction; if w = 0 then byte instruction if mod = 11 then r/m is treated as a REG field if mod = 00 then DISP = 0 , disp-low and disp-high are absent if mod = 01 then DISP = disp-low sign-extended to 16-bits, disp-high is absent if mod = 10 then DISP = disp-high: disp-low

If inde = 10 then DISP = disp-inght disp-to if r/m = 000 then EA = (BX) + (SI) + DISP if r/m = 001 then EA = (BX) + (DI) + DISP if r/m = 010 then EA = (BP) + (DI) + DISP if r/m = 101 then EA = (BP) + (DI) + DISP if r/m = 101 then EA = (DI) + DISP if r/m = 101 then EA = (BP) + DISP\* if r/m = 111 then EA = (BX) + DISP\*

DISP follows 2nd byte of instruction (before data if required)

\*except if mod = 00 and r/m = 110 then EA = disp-high: disp-low.

if s:w = 01 then 16 bits of immediate data form the operand. if s:w = 11 then an immediate data byte is sign extended to form the 16-bit operand.

if v = 0 then "count" = 1; if v = 1 then "count" in (CL) x = don't carez is used for string primitives for comparison with ZF Flag.

SEGMENT OVERRIDE PREFIX

| 0 | 0 | 1 | rea | 1 | 1 | 0 |
|---|---|---|-----|---|---|---|

REG is assigned according to the following table:

| 16-Bit (w = 1) | 8-Bit (w = 0) | Segment |
|----------------|---------------|---------|
| 000 AX         | 000 AL        | 00 ES   |
| 001 CX         | 001 CL        | 01 CS   |
| 010 DX         | 010 DL        | 10 SS   |
| 011 BX         | 011 BL        | 11 DS   |
| 100 SP         | 100 AH        |         |
| 101 BP         | 101 CH        |         |
| 110 SI         | 110 DH        |         |
| 111 DI         | 111 BH        |         |

Instructions which reference the flag register files as a 16-bit object use the symbol FLAGS to represent the file:

FLAGS = X:X:X:X:(OF):(DF):(TF):(SF):(ZF):X:(AF):X:(PF):X:(CF)

## 8088

8-Bit Microprocessor CPU

iAPX86 Family

FINAL

## DISTINCTIVE CHARACTERISTICS

- 8-bit data bus, 16-bit internal architecture
- · Directly addresses 1 Mbyte of memory
- Software compatible with 8086 CPU
- Byte, word, and block operations

AMD

24 operand addressing modes

- Powerful instruction set
- Efficient high level language implementation • •
  - Three speed options: 5MHz 8088
    - 8MHz 8088-2 10MHz 8088-1

## **GENERAL DESCRIPTION**

The 8088 CPU is an 8-bit processor designed around the 8086 internal structure. Most functions of the 8088 are identical to the equivalent 8086 functions. The pinout is slightly different. The 8088 handles the external bus the same way the 8086 does, but it handles only 8 bits at a time. Sixteen-bit words are fetched or written in two consecutive bus cycles. Both processors will appear identical to the software engineer, with the exception of execution time

The 8088 is made with N-channel silicon gate technology and is packaged in a 40-pin Plastic dip, CERDIP or Plastic Leaded Chip Carrier.

Issue Date: August 1989











| Valid Combinations |       |  |  |  |  |  |
|--------------------|-------|--|--|--|--|--|
| 8088               | /BQA  |  |  |  |  |  |
| 8088-2             | / DUA |  |  |  |  |  |

Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations or to check for newly released valid combinations.

#### **Group A Tests**

Group A tests consist of Subgroups 1, 2, 3, 7, 8, 9, 10, 11.

## PIN DESCRIPTION

| Pin No.* | Name                                    | 1/0 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|----------|-----------------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 9-16     | AD <sub>7</sub> -AD <sub>0</sub>        | 1/0 | Address Data Bus. These lines constitute the time multiplexed memory/IO address ( $T_1$ ) and data ( $T_2$ , $T_3$ , $T_W$ and $T_4$ ) bus. These lines are active HIGH and float to three-state OFF during interrupt acknowledge and local bus "hold acknowledge."                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| 39, 2-8  | A <sub>15</sub> -A <sub>8</sub>         | 0   | Address Bus. These lines provide address bits 8 through 15 for the entire bus cycle ( $T_1-T_4$ ). These lines do not have to be latched by ALE to remain valid. A <sub>15</sub> -A <sub>6</sub> are active HIGH and float to 3-state OFF during interrupt acknowledge. <sup>1</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| 35-38    | A19/S6,<br>A18/S5,<br>A17/S4,<br>A16/S3 | 0   | Address/Status. During T <sub>1</sub> , these are the four most significant address lines for memory operations. During I/C<br>operations, these lines are LOW. During memory and I/O operations, status information is available on these line<br>during T <sub>2</sub> , T <sub>3</sub> , T <sub>4</sub> and T <sub>4</sub> . S <sub>6</sub> is always LOW. The status of the interrupt enable flat bit (S <sub>5</sub> ) is updated at th<br>beginning of each clock cycle. S <sub>4</sub> and S <sub>3</sub> are encoded as shown.<br>This information indicates which segment register is presently being used for data accessing.<br>These lines float to three-state OFF during local bus "hold acknowledge." |  |  |  |  |  |  |
|          |                                         |     | S <sub>4</sub> S <sub>3</sub> Characteristics                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
|          |                                         |     | 0 (LOW) 0 Alternate Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
|          |                                         |     | 0 1 Stack                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|          |                                         |     | 1 (HIGH) 0 Code or None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
|          | 1                                       |     | 1 1 Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
|          |                                         |     | S <sub>6</sub> is 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
|          | RD                                      |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
| 32       |                                         | 0   | Read. Read strobe indicates that the processor is performing a memory or I/O read cycle, depending on the stat<br>of the IO/M pin or S2. This signal is used to read devices which reside on the 8088 local bus. RD is active LOV<br>during T2, T3 and Tw of any read cycle and is guaranteed to remain HIGH in T2 until the 8088 local bus ha<br>floated.<br>This signal floats to 3-state OFF in "hold acknowledge."                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
| 22       | READY                                   | 1   | READY. The acknowledgment from the addressed memory or I/O device that it will complete the data transfe<br>The RDY signal from memory or I/O is synchronized by the 8284 clock generator to form READY. This signal<br>active HIGH. The 8088 READY input is not synchronized. Correct operation is not guaranteed if the set-up an<br>hold times are not met.                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| 18       | INTR                                    | 1   | Interrupt Request. A level-triggered input which is sampled during the last clock cycle of each instruction to<br>determine if the processor should enter into an interrupt acknowledge operation. A subroutine is vectored to via an<br>interrupt vector lookup table located in system memory. It can be internally masked by software resetting the<br>interrupt enable bit. INTR is internally synchronized. This signal is active HIGH.                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
| 23       | TEST                                    | 1   | TEST. Input is examined by the "wait for test" instruction. If the TEST input is LOW, execution continue:<br>otherwise, the processor waits in an "Idle" state. This input is synchronized internally during each clock cycle o<br>the leading edge of CLK.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| 17       | NMI                                     | 1   | Non-Maskable Interrupt. An edge-triggered input which causes a type 2 interrupt. A subroutine is vectored to via a<br>interrupt vector lookup table located in system memory. NMI is not maskable internally by software. A transiti<br>from a LOW to HIGH initiates the interrupt at the end of the current instruction. This input is interrally synchronized                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
| 21       | RESET                                   | I   | RESET. Causes the processor to immediately terminate its present activity. The signal must be active HIGH for<br>least four clock cycles. It restarts execution, as described in the instruction set description, when RESET return<br>LOW. RESET is internally synchronized.                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
| 19       | CLK                                     | 1   | Clock. Provides the basic timing for the processor and bus controller. It is asymmetric with a 33% duty cycle<br>provide optimized internal timing.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| 40       | Vcc                                     |     | V <sub>CC</sub> . The +5 V ±10% power supply pin.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| 1, 20    | GND                                     |     | GND. The ground pins.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
| 33       | MIN/MX                                  |     | Minimum/Maximum. Indicates what mode the processor is to operate in. The two modes are discussed in the following sections.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| 28       | 10/ <b>M</b>                            | 0   | Status Line. An inverted maximum mode $S_2$ . It is used to distinguish a memory access from an I/O access. IO/ becomes valid in the Ta preceding a bus cycle and remains valid until the final Ta of the cycle (I/O = HIGI $M = LOW$ ). Io/M floats to three-state OFF in local bus "hold acknowledge."                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| 29       | WR                                      | 0   | Write. Strobe indicates that the processor is performing a write memory or write I/O cycle, depending on the stat<br>of the IO/M signal. WR is active for T2, T3 and Tw of any write cycle. It is active LOW and floats to 3-state OFF<br>local bus "hold acknowledge."                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
| 24       | INTA                                    | 0   | INTA. Used as a read strobe for interrupt acknowledge cycles. It is active LOW during T2, T3 and TW of eac interrupt acknowledge cycle.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
| 25       | ALE                                     | 0   | Address Latch Enable. Provided by the processor to latch the address into 8282/8283 address latch. It is a HIG<br>pulse active during clock low of T1 of any bus cycle. Note that ALE is never floated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
| 27       | DT/R                                    | 0   | Data Transmit/Receive. Needed in a minimum system that desires to use an 8286/8287 data bus transceiver. It used to control the direction of data flow through the transceiver. Logically DT/R is equivalent to $S_1$ in the maximum mode, and its timing is the same as for IO/M (T = HIGH, R = LOW.) This signal floats to three-state OF in local bus "hold acknowledge."                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
| 26       | DEN                                     | 0   | Data Enable. Provided as an output enable for the 8286/8287 in a minimum system that uses the transceiver. DE<br>is active LOW during each memory and I/O access and for INTA cycles. For a read or INTA cycle, it is active fro<br>the middle of T <sub>2</sub> until the middle of T <sub>4</sub> while for a write cycle, it is active from the beginning of T <sub>2</sub> until the middle                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |

| Pin No.* | Name                                             | 1/0 | Description                                                                          |                                                |                                             |                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                           |
|----------|--------------------------------------------------|-----|--------------------------------------------------------------------------------------|------------------------------------------------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31, 30   | HOLD,<br>HLDA                                    | 1/0 | HIGH. The proces<br>a T <sub>4</sub> or T <sub>1</sub> clock of<br>lines. After HOLD | ssor rec<br>cycle. Si<br>is dete               | eiving ti<br>multane<br>cted as             | ne "hold" request will is<br>sous with the issuance                                                                                                                               | al bus "hold." To be acknowledged, HOLD must be activ<br>ssue HLDA (HIGH) as an acknowledgment in the middle<br>of HLDA, the processor will float the local bus and contr<br>ssor lowers HLDA, and when the processor needs to ru<br>ontrol lines.                                                                        |
|          |                                                  |     | HOLD is not an a guarantee the se                                                    |                                                |                                             | put. External synchron                                                                                                                                                            | ization should be provided if the system cannot otherwis                                                                                                                                                                                                                                                                  |
| 34       | SSO                                              | 0   |                                                                                      |                                                |                                             | to SO in the maximum r<br>he current bus cycle                                                                                                                                    | node. The combination of $\overline{SSO}$ , IO/ $\overline{M}$ and DT/ $\overline{R}$ allows th status.                                                                                                                                                                                                                   |
|          |                                                  |     | IO/M                                                                                 | DT/R                                           | -                                           | Characteristics                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                           |
|          |                                                  |     | 1 (HIGH)                                                                             | 0                                              | 0                                           | Interrupt<br>Acknowledge                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                           |
|          |                                                  |     | 1                                                                                    | 0                                              | 1                                           | Read I/O port                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                           |
|          |                                                  |     | 1                                                                                    | 1                                              | 0                                           | Write I/O port                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                           |
|          |                                                  |     | 1                                                                                    | 1                                              | 1                                           | Halt                                                                                                                                                                              | 4                                                                                                                                                                                                                                                                                                                         |
|          |                                                  |     | 0 (LOW)                                                                              | 0                                              | 0                                           | Code Access                                                                                                                                                                       | -                                                                                                                                                                                                                                                                                                                         |
|          |                                                  |     | 0                                                                                    | 1                                              | 0                                           | Read memory<br>Write memory                                                                                                                                                       | -                                                                                                                                                                                                                                                                                                                         |
|          |                                                  |     |                                                                                      | 1                                              | 1                                           | Passive                                                                                                                                                                           | -                                                                                                                                                                                                                                                                                                                         |
| 28-26    | S <sub>2</sub> , S <sub>1</sub> , S <sub>0</sub> | 0   | Tw when READY<br>control signals. A<br>return to the pas<br>These signals flo        | is HIGH<br>ny char<br>sive stated<br>at to the | H. This<br>ige by a<br>ate in T<br>aree-sta | status is used by the 8 ${}^{5}_{2}$ , $\overline{S}_{1}$ or $\overline{S}_{0}$ during T <sub>4</sub><br>T <sub>3</sub> or T <sub>W</sub> is used to in<br>te OFF during ''hold a | returned to the passive state $(1, 1, 1)$ during $T_3$ or during 286 bus controller to generate all memory and I/O access is used to indicate the beginning of a bus cycle, and indicate the end of a bus cycle.<br>acknowledge." During the first clock cycle after RES this first clock, they float to three-state OFF. |
|          |                                                  |     | S2                                                                                   | S1                                             |                                             | Characteristics                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                           |
|          |                                                  |     | 0 (LOW)                                                                              | 0                                              | 0                                           | Interrupt                                                                                                                                                                         | -                                                                                                                                                                                                                                                                                                                         |
|          |                                                  |     |                                                                                      |                                                |                                             | Acknowledge                                                                                                                                                                       | _                                                                                                                                                                                                                                                                                                                         |
|          |                                                  |     | 0                                                                                    | 0                                              | 1                                           | Read I/O Port                                                                                                                                                                     | 4                                                                                                                                                                                                                                                                                                                         |
|          |                                                  |     | 0                                                                                    |                                                | 0                                           | Write I/O Port<br>Halt                                                                                                                                                            | -1                                                                                                                                                                                                                                                                                                                        |
|          |                                                  |     | 1 (HIGH)                                                                             | 0                                              | 0                                           | Code Access                                                                                                                                                                       | -                                                                                                                                                                                                                                                                                                                         |
|          |                                                  |     | 1                                                                                    | 0                                              | 1                                           | Read Memory                                                                                                                                                                       | -                                                                                                                                                                                                                                                                                                                         |
|          |                                                  |     | 1                                                                                    | 1                                              | 0                                           | Write Memory                                                                                                                                                                      | -                                                                                                                                                                                                                                                                                                                         |
|          |                                                  |     | 1                                                                                    | 1                                              | 1                                           | Passive                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                           |
| 31, 30   | RO/GT <sub>0</sub> .<br>RO/GT <sub>1</sub>       | 1/0 | of the processor's<br>RQ/GT has an in<br>1. A pulse of one<br>(pulse 1).             | s currer<br>ternal p<br>CLK w                  | it bus c<br>iull-up r<br>ide froi           | ycle. Each pin is bidire<br>esistor, so may be left<br>m another local bus m                                                                                                      | s to force the processor to release the local bus at the ectional with $\overline{RO/GT}_0$ having higher priority than $\overline{RO/GT}$ unconnected. The request/grant sequence is as follow aster indicates a local bus request ("hold") to the 80                                                                    |
|          |                                                  |     | that the 8088 h<br>CLK. The CPU'<br>same rules as                                    | as allow<br>s bus in<br>for HC                 | ved the<br>terface<br>LD/HL                 | local bus to float and i<br>unit is disconnected lo<br>DA apply as for when                                                                                                       | from the 8088 to the requesting master (pulse 2), indicat<br>that it will enter the "hold acknowledge" state at the ne<br>gically from the local bus during "hold acknowledge." T<br>the bus is released.<br>ndicates to the 8088 (pulse 3) that the "hold" request                                                       |
|          |                                                  |     | about to end a                                                                       | and tha                                        | t the 8                                     | 088 can reclaim the l                                                                                                                                                             | bocal bus at the next CLK. The CPU then enters T <sub>4</sub> .<br>uence of three pulses. There must be one idle CLK cyc                                                                                                                                                                                                  |
|          |                                                  |     | If the request is n                                                                  | nade wł                                        | nile the                                    |                                                                                                                                                                                   | nemory cycle, it will release the local bus during $T_4$ of t                                                                                                                                                                                                                                                             |
|          |                                                  |     |                                                                                      | s on o<br>is not t<br>is not t                 | r before<br>he low<br>he first              | ∋T <sub>2</sub> .<br>bit of a word.                                                                                                                                               | nterrupt acknowledge sequence.                                                                                                                                                                                                                                                                                            |
|          |                                                  |     | 1                                                                                    |                                                |                                             |                                                                                                                                                                                   | vo possible events will follow:                                                                                                                                                                                                                                                                                           |
|          |                                                  |     | 1. Local bus will                                                                    | be rele<br>e will si                           | ased clart with                             | luring the next clock.<br>hin 3 clocks. Now the                                                                                                                                   | four rules for a currently active memory cycle apply wi                                                                                                                                                                                                                                                                   |
|          | LOCK                                             | 0   |                                                                                      |                                                |                                             | · · · · · · · · · · · · · · · · · · ·                                                                                                                                             | t to gain control of the system bus while LOCK is acti                                                                                                                                                                                                                                                                    |

| Pin No.* | Name     | 1/0 | Description                         |                                                           |                                 |  |
|----------|----------|-----|-------------------------------------|-----------------------------------------------------------|---------------------------------|--|
| 24, 25   | QS1, QS0 | 0   | Queue Status. F<br>valid during the | nal 8088 instruction queue. The queue status is erformed. |                                 |  |
|          |          |     | QS1                                 | QS <sub>0</sub>                                           | Characteristics                 |  |
|          |          |     | 0 (LOW)                             | 0                                                         | No Operation                    |  |
|          |          |     | 0                                   | 1                                                         | First Byte of Opcode from Queue |  |
|          |          |     | 1 (HIGH)                            | 0                                                         | Empty the Queue                 |  |
|          |          |     |                                     | v                                                         | Linkly the Guede                |  |

\*Pin numbers correspond to DIPs only.

#### DETAILED DESCRIPTION

#### The 8088 Compared to the 8086

- The queue length is 4 bytes in the 8088; whereas, the 8086 queue contains 6 bytes, or three words. The queue was shortened to prevent overuse of the bus by the BIU when prefetching instructions. This was required because of the additional time necessary to fetch instructions 8 bits at a time.
- To further optimize the queue, the prefetching algorithm was changed. The 8088 BIU will fetch a new instruction to load into the queue each time there is a 1 byte hole (space available) in the queue. The 8086 waits until a 2-byte space is available.
- The internal execution time of the instruction set is affected by the 8-bit interface. All 16-bit fetches and writes from/to memory take an additional four clock cycles. The CPU is also limited by the speed of instruction fetches. This latter problem only occurs when a series of simple operations occurs. When the more sophisticated instructions of the 8088 are being used, the queue has time to fill and the execution proceeds as fast as the execution unit will allow.

The 8088 and 8086 are completely software compatible by virtue of their identical execution units. Software that is system dependent may not be completely transferable, but software that is not system dependent will operate equally as well on an 8088 or an 8086.

The hardware interface of the 8088 contains the major differences between the two CPUs. The pin assignments are nearly identical, however, with the following functional changes:

- A<sub>8</sub>-A<sub>15</sub> These pins are only address outputs on the 8088. These address lines are latched internally and remain valid throughout a bus cycle in a manner similar to the 8085 upper address lines.
- BHE has no meaning on the 8088 and has been eliminated.
- SSO provides the SO status information in the minimum mode. This output occurs on pin 34 in minimum mode only. DT/R, IO/M, and SSO provide the complete bus status in minimum mode.
- IO/M has been inverted to be compatible with the MCS-85 bus structure.
- ALE is delayed by one clock cycle in the minimum mode when entering HALT, to allow the status to be latched with ALE.

#### I/O Addressing

In the 8088, I/O operations can address up to a maximum of 64K I/O registers. The I/O address appears in the same format as the memory address on bus lines  $A_{15} - A_0$ . The

address lines  $A_{19} - A_{16}$  are zero in I/O operations. The variable I/O instructions, which use register DX as a pointer, have full address capability, while the direct I/O instructions directly address one or two of the 256 I/O byte locations in page 0 of the I/O address space. I/O ports are addressed in the same manner as memory locations.

Designers familiar with the 8085 or upgrading an 8085 design should note that the 8085 addresses I/O with an 8-bit address on both halves of the 16-bit address bus. The 8088 uses a full 16-bit address of its lower 16 address lines.

#### **Bus Operation**

The 8088 address/data bus is broken into three parts — the lower eight address/data bus is broken into three parts — the down eight address/data bits ( $A_D_0 - A_D_7$ ), the middle eight address bits ( $A_B - A_{15}$ ) and the upper four address bits ( $A_{16} - A_{19}$ ). The address/data bits and the highest four address bits are time multiplexed. This technique provides the most efficient use of pins on the processor, permitting the use of a standard 40 lead package. The middle eight address bits are not multiplexed; i.e., they remain valid throughout each bus cycle. In addition, the bus can be demultiplexed at the processor with a single address latch if a standard, non-multiplexed bus is desired for the system.

Each processor bus cycle consists of at least four CLK cycles. These are referred to as T1, T2, T3 and T4. The address is emitted from the processor during T1 and data transfer occurs on the bus during T3 and T4. T2 is used primarily for changing the direction of the bus during read operations. In the event that a ''NOT READY'' indication is given by the addressed device, ''wait'' states (Tw) are inserted between T3 and T4. Each inserted ''wait'' state is of the same duration as a CLK cycle. Periods can occur between 8088 driven bus cycles. These are referred to as ''idle'' states (Ti) or inactive CLK cycles. The processor uses these cycles for internal housekeeping.

During T1 of any bus cycle, the ALE (address latch enable), signal is emitted (by either the processor or the 8288 bus controller, depending on the MN/MX strap). At the trailing edge of this pulse, a valid address and certain status information for the cycle may be latched.

Status bits  $\overline{S0}$ ,  $\overline{S1}$ , and  $\overline{S2}$  are used by the bus controller, in maximum mode, to identify the type of bus transaction according to the following table:

| ₹s2      | ₹ī | ₹0 | Characteristics        |
|----------|----|----|------------------------|
| 0 (LOW)  | 0  | 0  | Interrupt Acknowledge  |
| 0        | 0  | 1  | Read I/O               |
| 0        | 1  | 0  | Write I/O              |
| 0        | 1  | 1  | Halt                   |
| 1 (HIGH) | 0  | 0  | Instruction Fetch      |
| 1        | 0  | 1  | Read Data from Memory  |
| 1        | 1  | 0  | Write Data to Memory   |
| 1        | 1  | 1  | Passive (no bus cycle) |

Status bits S3 through S6 are multiplexed with high order address bits and are therefore valid during T2 through T4. S3 and S4 indicate which segment register was used for this bus cycle in forming the address according to the following table:

| S4       | S <sub>3</sub> | Characteristics                |
|----------|----------------|--------------------------------|
| 0 (LOW)  | 0              | Alternate Data (extra segment) |
| 0        | 1              | Stack                          |
| 1 (HIGH) | 0              | Code or None                   |
| 1        | 1              | Data                           |

S5 is a reflection of the PSW interrupt enable bit. S6 is always equal to 0.

## **External Interface**

#### **Processor Reset and Initialization**

Processor initialization or start up is accomplished with activation (HIGH) of the RESET pin. The 8088 RESET is required to be HIGH for greater than four clock cycles. The 8088 will terminate operations on the high-going edge of RESET and will remain dormant as long as RESET is HIGH. The low-going transition of RESET triggers an internal reset sequence for approximately 7 clock cycles. After this interval the 8088 operates normally, beginning with the instruction in absolute location FFFF0H (see Figure 3). The RESET input is internally synchronized to the processor clock. At initialization, the HIGH to LOW transition of RESET must occur no sooner than 50 µs after power up, to allow complete initialization of the 8088.

If INTR is asserted sconer than nine clock cycles after the end of RESET, the processor may execute one instruction before responding to the interrupt.

All three-state outputs float to three-state OFF during RESET. Status is active in the idle state for the first clock after RESET becomes active and then floats to three-state OFF.

#### **Interrupt Operations**

Interrupt operations fall into two classes: software or hardware initiated. The software initiated interrupts and software aspects of hardware interrupts are specified in the instruction set description in the iAPX 88 book or the iAPX 86, 88 User's Manual. Hardware interrupts can be classified as nonmaskable or maskable.

Interrupts result in a transfer of control to a new program location. A 256 element table containing address pointers to the interrupt service program locations resides in absolute locations of through 3FFH (see Figure 3), which are reserved for this purpose. Each element in the table is 4 bytes in size and corresponds to an interrupt "type." An interrupting device supplies an 8-bit type number, during the interrupt acknowl-edge sequence, which is used to vector through the appropriate element to the new interrupt service program location.

#### Non-Maskable Interrupt (NMI)

The processor provides a single non-maskable interrupt (NMI) pin which has higher priority than the maskable interrupt request (INTR) pin. A typical use would be to activate a power failure routine. The NMI is edge-triggered on a LOW to HIGH transition. The activation of this pin causes a type 2 interrupt.

NMI is required to have a duration in the HIGH state of greater than two clock cycles but is not required to be synchronized to the clock. Any higher going transition of NMI is latched on-chip and will be serviced at the end of the current instruction or between whole moves (2 bytes in the case of word moves) of a block type instruction. Worst case response to NMI would be for multiply, divide and variable shift instructions. There is no specification on the occurrence of the low-going edge; it may occur before, during or after the servicing of NMI. Another high-going edge triggers another response if it occurs after the start of the NMI procedure. The signal must be free of logical spikes in general and be free of bounces on the low-going edge to avoid triggering extraneous responses.

#### Maskable Interrupt (INTR)

The 8088 provides a single interrupt request input (INTR) which can be masked internally by software with the resetting of the interrupt enable (IF) flag bit. The interrupt request signal is level triggered. It is internally synchronized during each clock cycle on the high-going edge of CLK. To be responded to, INTR must be present (HIGH) during the clock period preceding the end of the current instruction. During interrupt response sequence, further interrupts are disabled. The enable bit is reset as part of the response to any interrupt (INTR, NMI, software interrupt, or single step), although the FLAGS register which is automatically pushed onto the stack reflects the state of the processor prior to the interrupt. Until the old FLAGS register is restored, the enable bit will be zero unless specifically set by an instruction.

During the response sequence (see Figure 1), the processor executes two successive (back to back) interrupt acknowledge cycles. The 8088 emits the LOCK signal (maximu mode only) from T2 of the first bus cycle until T2 of the second. A local bus "hold" request will not be honored until the end of the second bus cycle. In the second bus cycle, a byte is fetched from the external interrupt system (e.g., 8259A PIC) which identifies the source (type) of the interrupt. This byte is multiplied by four and used as a pointer into the interrupt vector lookup table. An INTR signal left HIGH will be continually responded to within the limitations of the enable bit and sample period. The interrupt return instruction includes a flags pop which returns the status of the original interrupt enable bit when it restores the flags.

## HALT

When a software HALT instruction is executed, the processor indicates that it is entering the HALT state in one of two ways, depending upon which mode is strapped. In minimum mode, the processor issues ALE, delayed by one clock cycle, to allow the system to latch the halt status. Halt status is available on IO/M, DT/R and SSO. In maximum mode, the processor issues appropriate HALT status on S2, S1 and S0, and the 8288 bus controller issues one ALE. The 8088 will not leave the HALT state when a local bus hold is entered while in HALT. In this case, the processor reissues the HALT indicator at the end of the local bus hold. An interrupt request or RESET will force the 8088 out of the HALT state.

## Read/Modify/Write (Semaphore) Operations via LOCK

The LOCK status information is provided by the processor when consecutive bus cycles are required during the execution of an instruction. This allows the processor to perform read/modify/write operations on memory (via the "exchange register with memory" instruction), without another system bus master receiving intervening memory cycles. This is useful in multiprocessor system configurations to accomplish "test and set lock" operations. The LOCK signal is activated (LOW) in the clock cycle following decoding of the LOCK prefix instruction. It is deactivated at the end of the last bus cycle of the instruction of allowing the LOCK prefix. While LOCK is active, a request on a RO/GT pin will be recorded, and then honored at the end of the LOCK.



#### External Synchronization via TEST

As an alternative to interrupts, the 8088 provides a single software-testable input pin (TEST). This input is utilized by executing a WAIT instruction. The single WAIT instruction is repeatedly executed until the TEST input goes active (LOW). The execution of WAIT does not consume bus cycles once the queue is full.

If a local bus request occurs during WAIT execution, the 8088 three-states all output drivers. If interrupts are enabled, the 8088 will recognize interrupts and process them. The WAIT instruction is then refetched, and reexecuted.

#### **Basic System Timing**

In minimum mode, the MN/ $\overline{\text{MX}}$  pin is strapped to V<sub>CC</sub> and the processor emits bus control signals compatible with the 8085 bus structure. In maximum mode, the MN/ $\overline{\text{MX}}$  pin is strapped to GND, and the processor emits coded status information, which the 8288 bus controller uses to generate MULTIBUS compatible bus control signals.

#### System Timing - Minimum System

The read cycle begins in T1 with the assertion of the address latch enable (ALE) signal. The trailing (low going) edge of this signal is used to latch the address information, which is valid on the address/data bus (AD0 - AD7) at this time, into the 8282/8283 latch. Address lines A8 through A15 do not need to be latched because they remain valid throughout the bus cycle. From T1 to T4 the IO/M signal indicates a memory or I/O operation. At T2 the address is removed from the address/data bus, and the bus goes to a high impedance state. The read control signal is also asserted at T2. The read (RD) signal causes the addressed device to enable its data bus drivers to the local bus. Some time later, valid data will be available on the bus and the addressed device will drive the READY line HIGH. When the processor returns the read signal to a HIGH level, the addressed device will again three-state its bus drivers. If a transceiver (8286/8287) is required to buffer the 8088 local bus, signals DT/R and DEN are provided by the 8088.

A write cycle also begins with the assertion of ALE and the emission of the address. The IO/ $\overline{M}$  signal is again asserted to indicate a memory or I/O write operation. In T2, immediately following the address emission, the processor emits the data to be written into the addressed location. This data remains valid until at least the middle of T4. During T2, T3 and T<sub>W</sub>, the processor asserts the write control signal. The write ( $\overline{WR}$ ) signal becomes active at the beginning of T2, as opposed to the read, which is delayed somewhat into T2 to provide time for the bus to float.

The basic difference between the interrupt acknowledge cycle and a read cycle is that the interrupt acknowledge ( $\overline{INTA}$ ) signal is asserted in place of the read ( $\overline{RD}$ ) signal and the address bus is floated (see Figure 1). In the second of two successive  $\overline{INTA}$  cycles, a byte of information is read from the data bus, as supplied by the interrupt system logic (i.e., 8259A priority interrupt controller). This byte identifies the source (type) of the interrupt. It is multiplied by four and used as a pointer into the interrupt vector lookup table, as described earlier.

#### **Bus Timing — Medium Complexity Systems**

For medium complexity systems, the MN/MX pin is connected to GND and the 8288 bus controller is added to the system, as well as an 8282/8283 latch for latching the system address, and an 8286/8287 transceiver to allow for bus loading greater than the 8088 is capable of handling. Signals ALE, DEN and DT/R are generated by the 8288 instead of the processor in this configuration, although their timing remains relatively the same. The 8088 status outputs (S2, S1 and S0) provide type of cycle information and become 8288 inputs. This bus cycle information specifies read (code, data or I/O), write (data or I/O), interrupt acknowledge, or software halt. The 8288 thus issues control signals specifying memory read or write, I/O read or write or interrupt acknowledge. The 8288 provides two types of write strobes, normal and advanced, to be applied as required. The normal write strobes have data valid at the leading edge of write. The advanced write strobes have the same timing as read strobes, and hence, data is not valid at the leading edge of write. The 8286/8287 transceiver receives the usual T and  $\overline{OE}$  inputs from the 8288's DT/ $\overline{R}$  and  $\overline{DEN}$  outputs.

The pointer into the interrupt vector table, which is passed during the second  $\overline{INTA}$  cycle, can derive from an 8259A located on either the local bus or the system bus. If the master 8269A priority interrupt controller is positioned on the local bus, a TTL gate is required to disable the 8266/8287 transceiver when reading from the master 8259A during the interrupt acknowledge sequence and software "poll."

#### Memory Organization

The processor provides a 20-bit address to memory which locates the byte being referenced. The memory is organized as a linear array of up to 1 million bytes, addressed as 00000(H) to FFFF(H). The memory is logically divided into code, data, extra data and stack segments of up to 64K bytes each, with each segment falling on 16-byte boundaries (see Figure 2).

All memory references are made relative to base addresses contained in high speed segment registers. The segment types were chosen based on the addressing needs of programs. The segment register to be selected is automatically chosen according to the rules of the following table. All information in one segment type share the same logical attributes (e.g., code or data). By structuring memory into relocatable areas of similar characteristics and by automatically selecting segment registers, programs are shorter, faster and more structured.



Figure 2. Memory Organization

Word (16-bit) operands can be located on even or odd address boundaries. For address and data operands, the least significant byte of the word is stored in the lower valued address location and the most significant byte in the next higher address location. The BIU will automatically execute two fetch or write cycles for 16-bit operands.

Certain locations in memory are reserved for specific CPU operations (see Figure 3). Locations from addresses FFFFOH through FFFFFH are reserved for operations including a jump to the initial system initialization routine. Following RESET, the CPU will always begin execution at location FFFFOH where the jump must be located. Locations 00000H through 003FFH are reserved for interrupt operations. Four-byte pointers consisting of a 16-bit segment address and a 16-bit offset address direct program flow to one of the 256 possible interrupt service routines. The pointer elements are assumed to have been stored at their respective places in reserved memory prior to the occurrence of interrupts.

#### Minimum and Maximum Modes

The requirements for supporting minimum and maximum 8088 systems are sufficiently different that they cannot be done efficiently with 40 uniquely defined pins. Consequently, the 8088 is equipped with a strap pin (MN/ $\overline{MX}$ ) which defines the system configuration. The definition of a certain subset of the pins changes, dependent on the condition of the strap pin. When the MN/ $\overline{MX}$  pin is strapped to GND, the 8088 defines pins 24 through 31 and 34 in maximum mode. When the MN/ $\overline{MX}$  pin is 24 through 31 and 34 and 34.



Figure 3. Reserved Memory Locations

| Memory<br>Reference Need  | Segment Register<br>Used | Segment Selection Rule                                                                                 |
|---------------------------|--------------------------|--------------------------------------------------------------------------------------------------------|
| Instructions              | CODE (CS)                | Automatic with all instruction prefetch.                                                               |
| Stack                     | STACK (SS)               | All stack pushes and pops. Memory references relative to BP base reg-<br>ister except data references. |
| Local Data                | DATA (DS)                | Data references when: relative to stack, destination of string operation, or explicitly overridden.    |
| External (Global)<br>Data | EXTRA (ES)               | Destination of string operations: Explicitly selected using a segment override.                        |

The minimum mode 8088 can be used with either a multiplexed or demultiplexed bus. The multiplexed bus configuration is compatible with the MCS-85<sup>TM</sup> multiplexed bus peripherals (8155, 8156, 8355, 8755A, and 8185). This configuration (see Figure 4) provides the user with a minimum chip count system. This architecture provides the 8088 processing power in a highly integrated form.

The demultiplexed mode requires one latch (for 64K addressability) or two latches (for a full megabyte of addressing). A third latch can be used for buffering if the address bus loading requires it. An 8286 or 8287 transceiver can also be used if data bus buffering is required (see Figure 5). The 8088 provides DEN and DT/R to control the transceiver, and ALE to latch the addresses. This configuration of the minimum mode provides the standard demultiplexed bus structure with heavy bus buffering and relaxed bus timing requirements.

The maximum mode employs the 8288 bus controller (see Figure 6). The 8288 decodes status lines  $\overline{S0}$ ,  $\overline{S1}$  and  $\overline{S2}$  and provides the system with all bus control signals. Moving the bus control to the 8288 provides better source and sink current capability to the control lines and frees the 8088 pins for extended large system features. Hardware lock, queue status and two request/grant interfaces are provided by the 8088 in maximum mode. These features allow co-processors in local bus and remote bus configurations.









## ABSOLUTE MAXIMUM RATINGS

| Storage Temperature65 to +150°C |
|---------------------------------|
| Voltage on any Pin              |
| with Respect to Ground          |
| Power Dissipation               |

Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability.

| Commercial (C) Devices<br>Temperature (T <sub>A</sub> )0 to +70°C<br>Supply Voltage (V <sub>CC</sub> )  |  |
|---------------------------------------------------------------------------------------------------------|--|
| 8088 5 V ± 10%                                                                                          |  |
| 8088-1, 8088-25 V ± 5%                                                                                  |  |
| Industrial (I) Devices<br>Temperature (T <sub>A</sub> )40 to +85°C<br>Supply Voltage (V <sub>CC</sub> ) |  |
| 8088 5 V ± 10%                                                                                          |  |
| 8088-1, 8088-25 V ± 5%                                                                                  |  |
|                                                                                                         |  |
| Operating ranges define those limits between which the                                                  |  |

**OPERATING RANGES** 

functionality of the device is guaranteed.

| DC CHARACTERISTICS over        | operating | range ( | for APL, | Products, | Group A, | Subgroups | 1, 2, 3 are |  |
|--------------------------------|-----------|---------|----------|-----------|----------|-----------|-------------|--|
| tested unless otherwise noted) |           |         |          |           |          |           |             |  |

| Parameter<br>Symbol | Parameter Description                                         | Test Condi                                                   | tions                                  | Min      | Max                    | Units |
|---------------------|---------------------------------------------------------------|--------------------------------------------------------------|----------------------------------------|----------|------------------------|-------|
| V. 4                |                                                               | COML: see N                                                  | lote 1                                 | -0.5*    | + 0.8                  | v     |
| VILT                | Input Low Voltage                                             | MIL: V <sub>CC</sub> = M                                     | in. & Max.                             | -0.5     | + 0.8                  | v     |
| ViHt                | Input High Voltage                                            | COML: see N                                                  | otes 1 & 2                             | 2.0      | V <sub>CC</sub> + 0.5* | v     |
| VIH I               |                                                               | MIL: V <sub>CC</sub> = M                                     | in. & Max.                             | 2.0      | VCC + 0.5              | ľ     |
|                     |                                                               | COML: IOL =                                                  | 2.0 mA                                 |          |                        |       |
| VOL                 | Output Low Voltage                                            | MIL: I <sub>OL</sub> = 2.0<br>V <sub>CC</sub> = M            |                                        |          | 0.45                   | v     |
|                     |                                                               | COML: IOH =                                                  | -400 μA                                |          |                        |       |
| VOH                 | Output High Voltage                                           | MIL: IOH = -4<br>VCC = M                                     |                                        | 2.4      |                        | v     |
| Icc                 | Power Supply Current (Note 6)                                 | MIL: T <sub>C</sub> = 25°                                    | C, V <sub>CC</sub> = Max.              |          | 340                    | mA    |
|                     |                                                               | COML: 0 $V \leq V_{IN} \leq V_{CC}$                          |                                        |          | ±10                    |       |
| lu -                | Input Leakage Current                                         | MIL: V <sub>CC</sub> = Max.<br>V <sub>IN</sub> = 5.5 V & 0 V |                                        | -10      | 10                     | μA    |
|                     |                                                               | COML: 0.45                                                   | / ≤ V <sub>OUT</sub> ≤ V <sub>CC</sub> |          | COML ±10               |       |
| ILOTT               | Output Leakage Current                                        | MIL: V <sub>CC</sub> = M<br>V <sub>OUT</sub> = 5             | ax.<br>5.5 V & 0.45 V                  | MIL - 10 | MIL 10                 | μA    |
| V <sub>CL</sub>     | Clock Input Low Voltage                                       |                                                              |                                        | -0.5     | + 0.6                  | v     |
| V <sub>CH</sub>     | Clock Input High Voltage                                      |                                                              |                                        | 3.9      | V <sub>CC</sub> + 1.0  | V     |
| C <sub>IN</sub>     | Capacitance of Input Buffer (All input except AD0-AD7, RQ/GT) | fc = 1 MHz                                                   |                                        |          | 15                     | pF    |
| CIO                 | Capacitance of I/O Buffer (AD0-AD7, RQ/GT)                    | fc = 1 MHz                                                   |                                        |          | 15                     | pF    |
|                     |                                                               |                                                              | 8088                                   |          | 340                    |       |
| lcc                 | Power Supply Current                                          | T <sub>A</sub> = 25°C                                        | 8088-1, -2                             |          | 350                    | mA    |
|                     |                                                               |                                                              | P8088                                  |          | 250                    | ]     |

Notes: 1. V<sub>IL</sub> tested with MN/ $\overline{MX}$  pin = 0 V; V<sub>IH</sub> tested with MN/ $\overline{MX}$  pin = 5 V; MN/ $\overline{MX}$  is a strap pin.

2. Not applicable to RQ/GT0 and RQ/GT1 pins (pins 30 and 31).

3. Signal at 8284 or 8288 shown for reference only.

4. Setup requirement for asynchronous signal only to guarantee recognition at next CLK.

5. Applies only to T<sub>3</sub> and Wait states.

6. I<sub>CC</sub> is measured while running a functional pattern with spec value  $I_{OL}/I_{OH}$  loads applied.

Guaranteed by design; not tested.

† Group A, Subgroups 7 and 8 only are tested.

tt Group A, Subgroups 1 and 2 only are tested.

## SWITCHING CHARACTERISTICS over COMMERCIAL operating range MINIMUM COMPLEXITY SYSTEM TIMING REQUIREMENTS

| Devenator           | Parameter                                     | Taat               | 80  | 88  | 80  | 88-2 | 808  | 38-1 |       |
|---------------------|-----------------------------------------------|--------------------|-----|-----|-----|------|------|------|-------|
| Parameter<br>Symbol | Description                                   | Test<br>Conditions | Min | Max | Min | Max  | Min  | Max  | Units |
| TCLCL               | CLK Cycle Period                              |                    | 200 | 500 | 125 | 500  | 100  | 500  | ns    |
| TCLCH               | CLK Low Time                                  |                    | 118 |     | 68  |      | 53   |      | ns    |
| TCHCL               | CLK High Time                                 |                    | 69  |     | 44  |      | 39   |      | ns    |
| TCH1CH2             | CLK Rise Time                                 | From 1.0 to 3.5 V  |     | 10  | 1   | 10   | 1    | 10   | ns    |
| TCL2CL1             | CLK Fall Time                                 | From 3.5 to 1.0 V  |     | 10  |     | 10   | I    | 10   | ns    |
| TDVCL               | Data in Set-up Time                           |                    | 30  |     | 20  |      | 5    |      | ns    |
| TCLDX               | Data in Hold Time                             |                    | 10  |     | 10  |      | 10   |      | ns    |
| TR1VCL              | RDY Set-up Time into 8284<br>(See Notes 3, 4) |                    | 35  |     | 35  |      | 35   |      | ns    |
| TCLR1X              | RDY Hold Time into 8284<br>(See Notes 3, 4)   |                    | 0   |     | 0   |      | 0    |      | ns    |
| TRYHCH              | READY Set-up Time into 8088                   |                    | 118 |     | 68  |      | 53   |      | ns    |
| TCHRYX              | READY Hold Time into 8088                     |                    | 30  |     | 20  |      | 20   |      | ns    |
| TRYLCL              | READY Inactive to CLK<br>(See Note 5)         |                    | -8  |     | -8  |      | - 10 |      | ns    |
| THVCH               | HOLD Set-up Time                              |                    | 35  |     | 20  |      | 20   |      | ns    |
| TINVCH              | INTR, NMI, TEST Set-up Time<br>(See Note 4)   |                    | 30  |     | 15  |      | 15   |      | ns    |
| TILIH               | Input Rise Time (Except CLK)                  | From 0.8 to 2.0 V  |     | 20  |     | 20   |      | 20   | ns    |
| TIHIL               | Input Fall Time (Except CLK)                  | From 2.0 to 0.8 V  |     | 12  |     | 12   |      | 12   | ns    |

## SWITCHING CHARACTERISTICS over COMMERCIAL operating range (continued) TIMING RESPONSES

|                     |                                       |                                      | 8088        | 3   | 8088-       | 2   | 8088-       | 1   |       |
|---------------------|---------------------------------------|--------------------------------------|-------------|-----|-------------|-----|-------------|-----|-------|
| Parameter<br>Symbol | Parameter<br>Description              | Test<br>Conditions                   | Min         | Max | Min         | Max | Min         | Max | Units |
| TCLAV               | Address Valid Delay                   |                                      | 10          | 110 | 10          | 60  | 10          | 50  | ns    |
| TCLAX               | Address Hold Time                     | ]                                    | 10          |     | 10          |     | 10          |     | ns    |
| TCLAZ               | Address Float Delay                   | 1                                    | TCLAX       | 80  | TCLAX       | 50  | 10          | 40  | ns    |
| TLHLL               | ALE Width                             |                                      | TCLCH - 20  |     | TCLCH - 10  |     | TCLCH - 10  |     | ns    |
| TCLLH               | ALE Active Delay                      |                                      |             | 80  |             | 50  |             | 40  | ns    |
| TCHLL               | ALE Inactive Delay                    | 1                                    |             | 85  |             | 55  |             | 45  | ns    |
| TLLAX               | Address Hold Time to<br>ALE Inactive  |                                      | TCHCL - 10  |     | TCHCL - 10  |     | TCHCL - 10  |     | ns    |
| TCLDV               | Data Valid Delay                      |                                      | 10          | 110 | 10          | 60  | 10          | 50  | ns    |
| TCHDX               | Data Hold Time                        | ]                                    | 10          |     | 10          |     | 10          |     | ns    |
| TWHDX               | Data Hold Time After<br>WR            |                                      | TCLCH - 30  |     | TCLCH - 30  |     | TCLCH -25   |     | ns    |
| TCVCTV              | Control Active Delay 1                | 1                                    | 10          | 110 | 10          | 70  | 10          | 50  | ns    |
| TCHCTV              | Control Active Delay 2                | C <sub>L</sub> = 20-100 pF           | 10          | 110 | 10          | 60  | 10          | 45  | ns    |
| TCVCTX              | Control Inactive Delay                | for all 8088<br>Outputs (in addition | 10          | 110 | 10          | 70  | 10          | 50  | ns    |
| TAZRL               | Address Float to<br>READ Active       | to internal loads)                   | 0           |     | 0           |     | 0           |     | ns    |
| TCLRL               | RD Active Delay                       |                                      | 10          | 165 | 10          | 100 | 10          | 70  | ns    |
| TCLRH               | RD Inactive Delay                     |                                      | 10          | 150 | 10          | 80  | 10          | 60  | ns    |
| TRHAV               | RD Inactive to Next<br>Address Active | ]                                    | TCLCL -45   |     | TCLCL -40   |     | TCLCL - 35  |     | ns    |
| TCLHAV              | HLDA Valid Delay                      | 1                                    | 10          | 160 | 10          | 100 | 10          | 60  | ns    |
| TRLRH               | RD Width                              | 1                                    | 2TCLCL - 75 |     | 2TCLCL - 50 |     | 2TCLCL -40  |     | ns    |
| TWLWH               | WR Width                              | 1                                    | 2TCLCL -60  |     | 2TCLCL - 40 |     | 2TCLCL - 35 |     | ns    |
| TAVAL               | Address Valid to ALE<br>Low           | ]                                    | TCLCH -60   |     | TCLCH -40   |     | TCLCH -35   |     | ns    |
| TOLOH               | Output Rise Time                      | From 0.8 to 2.0 V                    |             | 20  |             | 20  |             | 20  | ns    |
| TOHOL               | Output Fall Time                      | From 2.0 to 0.8 V                    |             | 12  |             | 12  |             | 12  | ns    |



| Parameter | Deverter                                                         | Test              | 80  | 88  | 80  | 38-2 | 80  | 88-1 |       |
|-----------|------------------------------------------------------------------|-------------------|-----|-----|-----|------|-----|------|-------|
| Symbol    | Parameter<br>Description                                         | Conditions        | Min | Max | Min | Max  | Min | Max  | Units |
| TCLCL     | CLK Cycle Period                                                 |                   | 200 | 500 | 125 | 500  | 100 | 500  | ns    |
| TCLCH     | CLK Low Time                                                     |                   | 118 |     | 68  |      | 53  |      | ns    |
| TCHCL     | CLK High Time                                                    |                   | 69  |     | 44  |      | 39  |      | ns    |
| TCH1CH2   | CLK Rise Time                                                    | From 1.0 to 3.5 V |     | 10  |     | 10   |     | 10   | ns    |
| TCL2CL1   | CLK Fall Time                                                    | From 3.5 to 1.0 V |     | 10  |     | 10   |     | 10   | ns    |
| TDVCL     | Data in Set-up Time                                              |                   | 30  |     | 20  |      | 5   |      | ns    |
| TCLDX     | Data in Hold Time                                                |                   | 10  |     | 10  |      | 10  |      | ns    |
| TRIVCL    | RDY Set-up Time into 8284<br>(See Notes 1, 2)                    |                   | 35  |     | 35  |      | 35  |      | ns    |
| TCLR1X    | RDY Hold Time into 8284<br>(See Notes 1,2)                       |                   | 0   |     | 0   |      | 0   |      | ns    |
| TRYHCH    | READY Set-up Time into 8088                                      |                   | 118 |     | 68  |      | 53  |      | ns    |
| TCHRYX    | READY Hold Time into 8088                                        |                   | 30  |     | 20  |      | 20  |      | ns    |
| TRYLCL    | READY Inactive to CLK<br>(See Note 3)                            |                   | -8  |     | -8  |      | -10 |      | ns    |
| TINVCH    | Set-up Time for Recognition<br>(INTR, NMI, TEST)<br>(See Note 2) |                   | 30  |     | 15  |      | 15  |      | ns    |
| TGVCH     | RQ/GT Set-up Time                                                |                   | 30  |     | 15  |      | 12  |      | ns    |
| TCHGX     | RQ Hold Time into 8086                                           |                   | 40  |     | 30  |      | 20  |      | ns    |
| TILIH     | Input Rise Time<br>(Except CLK)                                  | From 0.8 to 2.0 V |     | 20  |     | 20   |     | 20   | ns    |
| TIHIL     | Input Fall Time<br>(Except CLK)                                  | From 2.0 to 0.8 V |     | 12  |     | 12   |     | 12   | ns    |

Notes: 1. Signal at 8284 or 8288 shown for reference only.

2. Set-up requirement for asynchronous signal only to guarantee recognition at next CLK.

3. Applies only to T3 and Wait states.

| Parameter<br>Symbol<br>TCLML | Parameter<br>Description                         |                                            |                | 38  |               | 8-2 | 808            |     | 1     |
|------------------------------|--------------------------------------------------|--------------------------------------------|----------------|-----|---------------|-----|----------------|-----|-------|
|                              |                                                  | Test<br>Conditions                         | Min            | Max | Min           | Max | Min            | Max | Units |
|                              | Command Active Delay<br>(See Note 1)             |                                            | 10             | 35  | 10            | 35  | 10             | 35  | ns    |
| TCLMH                        | Command Inactive Delay<br>(See Note 1)           |                                            | 10             | 35  | 10            | 35  | 10             | 35  | ns    |
| TRYHSH                       | READY Active to Status<br>Passive (See Note 3)   |                                            |                | 110 |               | 65  |                | 45  | ns    |
| TCHSV                        | Status Active Delay                              | ]                                          | 10             | 110 | 10            | 60  | 10             | 45  | ns    |
| TCLSH                        | Status Inactive Delay                            | 1                                          | 10             | 130 | 10            | 70  | 10             | 55  | ns    |
| TCLAV                        | Address Valid Delay                              | 1                                          | 10             | 110 | 10            | 60  | 10             | 50  | ns    |
| TCLAX                        | Address Hold Time                                |                                            | 10             |     | 10            |     | 10             |     | ns    |
| TCLAZ                        | Address Float Delay                              | 1                                          | TCLAX          | 80  | TCLAX         | 50  | 10             | 40  | ns    |
| TSVLH                        | Status Valid to ALE High<br>(See Note 1)         | ]                                          |                | 15  |               | 15  |                | 15  | ns    |
| TSVMCH                       | Status Valid to MCE High<br>(See Note 1)         |                                            |                | 15  |               | 15  |                | 15  | ns    |
| TCLLH                        | CLK Low to ALE Valid<br>(See Note 1)             |                                            |                | 15  |               | 15  |                | 15  | ns    |
| TCLMCH                       | CLK Low to MCE High<br>(See Note 1)              |                                            |                | 15  |               | 15  |                | 15  | ns    |
| TCHLL                        | ALE Inactive Delay<br>(See Note 1)               | C <sub>L</sub> = 20-100 pF<br>for all 8088 |                | 15  |               | 15  |                | 15  | ns    |
| TCLMCL                       | MCE Inactive Delay<br>(See Note 1)               | outputs (in addition<br>to internal loads) |                | 15  |               | 15  |                | 15  | ns    |
| TCLDV                        | Data Valid Delay                                 |                                            | 10             | 110 | 10            | 60  | 10             | 50  | ns    |
| TCHDX                        | Data Hold Time                                   | 1                                          | 10             |     | 10            |     | 10             |     | ns    |
| TCVNV                        | Control Active Delay<br>(See Note 1)             | ]                                          | 5              | 45  | 5             | 45  | 5              | 45  | ns    |
| TCVNX                        | Control Inactive Delay<br>(See Note 1)           |                                            | 10             | 45  | 10            | 45  | 10             | 45  | ns    |
| TAZRL                        | Address Float to<br>Read Active                  |                                            | 0              |     | 0             |     | 0              |     | ns    |
| TCLRL                        | RD Active Delay                                  |                                            | 10             | 165 | 10            | 100 | 10             | 70  | ns    |
| TCLRH                        | RD Inactive Delay                                |                                            | 10             | 150 | 10            | 80  | 10             | 60  | ns    |
| TRHAV                        | RD Inactive to Next<br>Address Active            |                                            | TCLCL<br>-45   |     | TCLCL<br>-40  |     | TCLCL<br>-35   |     | ns    |
| TCHDTL                       | Direction Control Active<br>Delay (See Note 1)   |                                            |                | 50  |               | 50  |                | 50  | ns    |
| тснотн                       | Direction Control Inactive<br>Delay (See Note 1) |                                            |                | 30  |               | 30  |                | 30  | ns    |
| TCLGL                        | GT Active Delay                                  | 1                                          |                | 85  |               | 50  | 0              | 45  | ns    |
| TCLGH                        | GT Inactive Delay                                |                                            |                | 85  |               | 50  | 0              | 45  | ns    |
| TRLRH                        | RD Width                                         |                                            | 2TCLCL<br>- 75 |     | 2TCLCL<br>-50 |     | 2TCLCL<br>- 40 |     | ns    |
| TOLOH                        | Output Rise Time                                 | From 0.8 to 2.0 V                          |                | 20  |               | 20  |                | 20  | ns    |

Notes: 1. Signal at 8284 or 8288 shown for reference only. 2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK. 3. Applies only to T<sub>2</sub> state (8 ns into T<sub>3</sub> state).

|                                                                | B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Tool Openitations           | 80   | 88   | 808  | 88-2 |      |
|----------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|------|------|------|------|------|
| Parameter<br>Symbol                                            | Parameter<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Test Conditions<br>(Note 6) | Min. | Max. | Min. | Max. | Unit |
| TCLCL                                                          | CLK Cycle Period (Note 11)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                             | 200  | 500  | 125  | 500  | ns   |
| TCLCH                                                          | CLK LOW Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                             | 118  |      | 68   |      | ns   |
| TCHCL                                                          | CLK HIGH Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                             | 69   |      | 44   |      | ns   |
| TCH1CH2                                                        | CLK Rise Time (Note 5)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | From 1.0 to 3.5 V           |      | 10   |      | 10   | ns   |
| TCL2CL1                                                        | CLK Fall Time (Note 5)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | From 3.5 to 1.0 V           |      | 10   |      | 10   | ns   |
| TDVCL                                                          | Data in Setup Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                             | 30   |      | 20   |      | ns   |
| TCLDX                                                          | Data in Hold Time<br>RDY Setup Time into 8284A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                             | 10   |      | 10   |      | ns   |
| TR1VCL                                                         | (Notes 1 & 2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                             | 35   |      | 35   |      | ns   |
| TCLR1X                                                         | RDY Hold Time into 8284A<br>(Notes 1 & 2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                             | 0    |      | 0    |      | ns   |
| TRYHCH                                                         | READY Setup Time into 8088                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                             | 118  |      | 68   |      | ns   |
| TCHRYX                                                         | READY Hold Time into 8088                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                             | 30   |      | 20   |      | ns   |
| TRYLCL                                                         | READY Inactive to CLK<br>(Note 3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                             | -8   |      | -8   |      | ns   |
| THVCH                                                          | HOLD Setup Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                             | 35   |      | 20   |      | ns   |
| TINVCH                                                         | INTR, NMI, TEST Setup<br>Time (Note 2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                             | 30   |      | 15   |      | ns   |
| TILIH                                                          | Input Rise Time<br>(Except CLK) (Note 5)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | From 0.8 to 2.0 V           |      | 20   |      | 20   | ns   |
| TIHIL                                                          | Input Fall Time (Except CLK) (Note 5)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | From 2.0 to 0.8 V           |      | 12   |      | 12   | ns   |
| 7. Min<br>8. May<br>9. Tes<br>10. Tes<br>11. Tes<br>VCC<br>VIL | $\begin{array}{cccc} -45 & V & V_{IHC} & -4.3 & V \\ -45 & V & V_{IHC} & -4.3 & V \\ -1.4 & V & V_{OH} & -1.6 & V \\ \hline \text{imum spec tested at V_{CC} Max. (5.5 & V) or \\ \text{imum spec tested at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted at V_{CC} Min. (4.5 & V) only. \\ \ \text{ted out (4.5 & V) only. } \ \ \text{ted out (4.5 & V) only. } \ \ \text{ted out (4.5 & V) only. } \ \ \text{ted out (4.5 & V) only. } \ \ \text{ted out (4.5 & V) only. } \ \ \text{ted out (4.5 & V) only. } \ \ \text{ted out (4.5 & V) only. } \ \ \text{ted out (4.5 & V) only. } \ \ \text{ted out (4.5 & V) only. } \ \ \text{ted out (4.5 & V) only. } \ \ \text{ted out (4.5 & V) only. } \ \ \text{ted out (4.5 & V) only. } \ \ \text{ted out (4.5 & V) only. } \ \ \text{ted out (4.5 & V) only. } \ \ \ \text{ted out (4.5 & V) only. } \ \ \ \text{ted out (4.5 & V) only. } \ \ \ \ \text{ted out (4.5 & V) only. } \ \ \ \ \ \ \ \ \ \$ | niy.<br>Niy.                |      |      |      |      |      |
|                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                             |      |      |      |      |      |

| )                                                                                                    | Beremeter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Test Canditions (blats                                                   | 80          | 88   | 808  | 38-2 |      |
|------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|-------------|------|------|------|------|
| Parameter<br>Symbol                                                                                  | Parameter<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Test Conditions (Note<br>6)                                              | Min.        | Max. | Min. | Max. | Unit |
| TCLAV                                                                                                | Address Valid Delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                          | 10          | 110  | 10   | 60   | ns   |
| TCLAX                                                                                                | Address Hold Time (Notes 7 & 8)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1 [                                                                      | 10          |      | 10   |      | ns   |
| TCLAZ                                                                                                | Address Float Delay (Note 8)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1 6                                                                      | 10          | 80   | 10   | 50   | ns   |
| TLHLL                                                                                                | ALE Width (Note 10)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 1                                                                        | 98          |      | 58   |      | ns   |
| TCLLH                                                                                                | ALE Active Delay (Note 8)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1 6                                                                      |             | 80   |      | 50   | ns   |
| TCHLL                                                                                                | ALE Inactive Delay (Note 8)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1 [                                                                      |             | 85   |      | 55   | ns   |
| TLLAX                                                                                                | Address Hold Time to<br>ALE Inactive (Note 7)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                          | 59          |      | 34   |      | ns   |
| TCLDV                                                                                                | Data Valid Delay (Note 8)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1 [                                                                      | 10          | 110  | 10   | 60   | ns   |
| TCHDX                                                                                                | Data Hold Time (Note 10)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ] [                                                                      | 10          |      | 10   |      | ns   |
| TWHDX                                                                                                | Data Hold Time After WR (Note 9)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ] [                                                                      | 88          |      | 38   |      | ns   |
| TCVCTV                                                                                               | Control Active Delay 1 (Note 8)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1 1                                                                      | 10          | 110  | 10   | 70   | ns   |
| TCHCTV                                                                                               | Control Active Delay 2 (Note 8)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | C <sub>L</sub> = 100 pF                                                  | 10          | 110  | 10   | 60   | ns   |
| TCVCTX                                                                                               | Control Inactive Delay (Note 8)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | for all 8088<br>Outputs (in addition                                     | 10          | 110  | 10   | 70   | ns   |
| TAZRL                                                                                                | Address Float to<br>READ Active (Note 9)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | to internal loads).                                                      | 0           |      | 0    |      | ns   |
| TCLRL                                                                                                | RD Active Delay (Note 8)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ] [                                                                      | 10          | 165  | 10   | 100  | ns   |
| TCLRH                                                                                                | RD Inactive Delay (Note 8)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ] [                                                                      | 10          | 150  | 10   | 80   | ns   |
| TRHAV                                                                                                | RD Inactive to Next<br>Address Active (Note 10)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ]                                                                        | 155         |      | 85   |      | ns   |
| TCLHAV                                                                                               | HLDA Valid Delay (Note 8)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ] [                                                                      | 10          | 160  | 10   | 100  | ns   |
| TRLRH                                                                                                | RD Width (Note 10)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ] [                                                                      | 325         |      | 200  |      | ns   |
| TWLWH                                                                                                | WR Width (Note 10)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                          | 340         |      | 210  |      | ns   |
| TAVAL                                                                                                | Address Valid to ALE Low<br>(Note 9)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                          | 58          |      | 28   |      | ns   |
| TOLOH                                                                                                | Output Rise Time (Note 9)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | From 0.8 to 2.0 V                                                        |             | 20   |      | 20   | ns   |
| TOHOL                                                                                                | Output Fall Time (Note 9)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | From 2.0 to 0.8 V                                                        |             | 12   |      | 12   | ns   |
| Notes: 1. S<br>2. S<br>3. A<br>4. A<br>5. N<br>6. V<br>V<br>V<br>V<br>V<br>V<br>V<br>V<br>0. V<br>1. | ignal at 8284A and 8288 shown for refere<br>stup requirement for asynchronous signal of<br>pplies only to T3 and wait states.<br>pplies only to T2 state (8 ns into T3).<br>ot tested; these specs are controlled by tt<br>CC = 4.5 V, 5.5 V<br>LC = 4.5 V, 5.5 V<br>LC = 2.5 V<br>LC = 2.5 V<br>LC = 2.5 V<br>LC = 2.5 V<br>VHC = 1.6 V<br>OL = 1.4 V<br>DL = 1.4 V<br>DL = 1.4 V<br>CC Max. (5.5 V) only.<br>seted at V <sub>CC</sub> Min. (4.5 V) only.<br>seted at V <sub>CC</sub> Min. (4.5 V) only.<br>seted at V <sub>CC</sub> Min. (4.5 V) only.<br>set conditions for TCLCL Max. are:<br>$C_{C} = 4.5 V$<br>Vol = 1 V | nce only.<br>nnly to guarantee recognition a<br>ne Teradyne J941 tester. | at next CLI | 12   |      |      |      |
| v                                                                                                    | L = 0 V VIH = 4 V<br>LC = 0 V VIHC = 5 V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                          |             |      |      |      |      |

## 8088

|                                                                                                 |                                                            |                             | 80   | 88   | 808  | 38-2 |      |
|-------------------------------------------------------------------------------------------------|------------------------------------------------------------|-----------------------------|------|------|------|------|------|
| Parameter<br>Symbol                                                                             | Parameter<br>Description                                   | Test Conditions<br>(Note 6) | Min. | Max. | Min. | Max. | Unit |
| TCLCL                                                                                           | CLK Cycle Period (Note 11)                                 |                             | 200  | 500  | 125  | 500  | ns   |
| TCLCH                                                                                           | CLK LOW Time                                               |                             | 118  | 1    | 68   |      | ns   |
| TCHCL                                                                                           | CLK HIGH Time                                              |                             | 69   |      | 44   |      | ns   |
| TCH1CH2                                                                                         | CLK Rise Time (Note 5)                                     | From 1.0 to 3.5 V           |      | 10   |      | 10   | ns   |
| TCL2CL1                                                                                         | CLK Fall Time (Note 5)                                     | From 3.5 to 1.0 V           |      | 10   |      | 10   | ns   |
| TDVCL                                                                                           | Data in Setup Time                                         |                             | 30   |      | 20   |      | ns   |
| TCLDX                                                                                           | Data in Hold Time                                          |                             | 10   |      | 10   |      | ns   |
| TRIVCL                                                                                          | RDY Setup Time into 8284A<br>(Notes 1 & 2)                 |                             | 35   |      | 35   |      | ns   |
| TCLR1X                                                                                          | RDY Hold Time into 8284A<br>(Notes 1 & 2)                  |                             | 0    |      | 0    |      | ns   |
| TRYHCH                                                                                          | READY Setup Time into 8088                                 |                             | 118  |      | 68   |      | ns   |
| TCHRYX                                                                                          | READY Hold Time into 8088                                  |                             | 30   |      | 20   |      | ns   |
| TRYLCL                                                                                          | READY Inactive to CLK<br>(Note 3)                          |                             | -8   |      | -8   |      | ns   |
| TINVCH                                                                                          | Setup Time for Recognition<br>(INTR, NMI, TEST<br>(Note 2) |                             | 30   |      | 15   |      | ns   |
| TGVCH                                                                                           | RQ/GT Setup Time                                           |                             | 30   |      | 15   |      | ns   |
| TCHGX                                                                                           | RQ Hold Time into 8086                                     |                             | 40   |      | 30   |      | ns   |
| TILIH                                                                                           | Input Rise Time<br>(Except CLK) (Note 5)                   | From 0.8 to 2.0 V           |      | 20   |      | 20   | ns   |
| TIHIL                                                                                           | Input Fall Time<br>(Except CLK) (Note 5)                   | From 2.0 to 0.8 V           |      | 12   |      | 12   | ns   |
| 5. Not<br>6. VCC<br>VIL<br>VUL<br>7. Minir<br>8. Maxi<br>9. Test<br>10. Test<br>11. Test<br>VCC | $\begin{array}{llllllllllllllllllllllllllllllllllll$       | ly.                         |      |      |      |      |      |

# SWITCHING CHARACTERISTICS over MILITARY operating range (continued) TIMING RESPONSES

| Parameter<br>Description                                                                                                                                                                                                                                                                                                                                                                  | Test Conditions<br>(Note 6)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                           | (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Min.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Max.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Min.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Max.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Unit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Command Active Delay<br>(Note 1)                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 35                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 35                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Command Inactive Delay<br>(Note 1)                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 35                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 35                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| READY Active to Status<br>Passive (Note 4)                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 65                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Status Active Delay (Notes 7 & 8)                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 60                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Status Inactive Delay                                                                                                                                                                                                                                                                                                                                                                     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 130                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 70                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Address Valid Delay                                                                                                                                                                                                                                                                                                                                                                       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 60                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Address Hold Time                                                                                                                                                                                                                                                                                                                                                                         | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Address Float Delay                                                                                                                                                                                                                                                                                                                                                                       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 80                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 50                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Status Valid to ALE HIGH<br>(Note 1)                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Status Valid to MCE HIGH<br>(Note 1)                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| CLK LOW to ALE Valid<br>(Note 1)                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| CLK LOW to MCE HIGH<br>(Note 1)                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| ALE Inactive Delay<br>(Note 1)                                                                                                                                                                                                                                                                                                                                                            | C <sub>L</sub> = 100 pF<br>for all 8088                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| MCE Inactive Delay<br>(Note 1)                                                                                                                                                                                                                                                                                                                                                            | to internal loads)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Data Valid Delay                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 60                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Data Hold Time                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Control Active Delay<br>(Note 1)                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 45                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 45                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Control Inactive Delay<br>(Note 1)                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 45                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 45                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Read Active                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 165                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 150                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 80                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Address Active                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 155                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 85                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Delay (Note 1)                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 50                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 50                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Delay (Note 1)                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 50                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| GT Inactive Delay (Note 8)                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 85                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 50                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 325                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 200                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| b requirement for asynchronous signal c<br>so only to T3 and wait states.<br>se only to T2 state (8 ns into T3).<br>ested; these specs are controlled by th<br>= 4.5 V, $5.5 V$ V <sub>IH</sub> $= 2.4 V= .45 V$ V <sub>IH</sub> $= 2.4 V= .25 V$ V <sub>IH</sub> $= 1.6 V= 1.6 Vrun spec tested at VCC Max. (5.5 V) conum spec tested at VCC Min. (4.5 V) cod at VCC Max. (5.5 V) only.$ | nly to guarantee recognition a<br>le Teradyne J941 tester.<br>nly.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | at next CLK.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                                                                                                           | (Note 1)         READY Active to Status         Passive (Note 4)         Status Active Delay (Notes 7 & 6)         Status Inactive Delay         Address Valid Delay         Address Float Delay         Address Float Delay         Status Valid to ALE HIGH<br>(Note 1)         Status Valid to ALE HIGH<br>(Note 1)         CLK LOW to ALE Valid<br>(Note 1)         CLK LOW to MCE HIGH<br>(Note 1)         ALE Inactive Delay<br>(Note 1)         MCE Inactive Delay<br>(Note 1)         Data Valid Delay         Data Valid Delay         (Note 1)         Control Active Delay<br>(Note 1)         Address Float to Belay<br>(Note 1)         Address Float to Belay         RD Inactive Delay<br>(Note 1)         Address Float to<br>Read Active         Diraction Control Active Delay<br>(Note 1)         Diractive Delay<br>(Note 1)         Diractive Delay (Note 8)         GT Inactive Delay (Note 8) | (Note 1)         READY Active to Status         Passive (Note 4)         Status Active Delay (Notes 7 & 8)         Status Inactive Delay         Address Valid Delay         Address Valid Delay         Address Float Delay         Address Float Delay         Status Valid to ALE HIGH<br>(Note 1)         CLK LOW to ALE Valid<br>(Note 1)         CLK LOW to MCE HIGH<br>(Note 1)         CLK LOW to MCE HIGH<br>(Note 1)         ALE Inactive Delay<br>(Note 1)         Data Valid Delay         Data Hold Time         Control Active Delay<br>(Note 1)         Data Hold Time         Control Active Delay<br>(Note 1)         Address Float to<br>Read Active         RD Inactive to Next<br>Address Float to<br>Read Active         RD Inactive to Next<br>Address Active         Diractive Delay (Note 1)         Diractive Delay (Note 8)         GT Inactive to Next<br>Address Active         Direction Control Inactive<br>Delay (Note 1)         Direction Control Inactive<br>Delay (Note 1)         Direction Control Inactive<br>Delay (Note 1)         Output Rise Time       From 0.8 to 2.0 V         Output Rise Time       From 2.0 to 0.8 V         I at 828A and 8288 shown for reference only.         orequirement for asynchronous signal only to guara | (Note 1)       10         READY Active to Status<br>Passive (Note 4)       10         Status Active Delay (Notes 7 & 8)       10         Address Vaid Delay       10         Address Vaid to ALE HIGH<br>(Note 1)       10         CLK LOW to ALE Vaid<br>(Note 1)       10         CLK LOW to MCE HIGH<br>(Note 1)       10         ALE inactive Delay<br>(Note 1)       0         Data Vaid Delay       10         Data Hold Time       10         Control Inactive Delay<br>(Note 1)       10         Data Hold Time       10         Control Inactive Delay<br>(Note 1)       10         Address Float to<br>Read Active       0         RD Inactive Delay<br>(Note 1)       10         Direction Control Inactive<br>Delay (Note 1)       10         Direction Control Inactive<br>Delay (Note 1)       10         Output File Time       From 0.8 to 2.0 V         Output File Time       From 2.0 to 0.8 V         I at 8284A and 8288 shown for reference only.       12         requirement for asynchronous signal only to guarantee recognition at next CLK. <t< td=""><td>(Note 1)         10         33           READY Active to Status         110         33           Pessive (Note 4)         110         10         110           Status active Delay         Address Valid Delay         10         110         130           Address Valid Delay         10         10         130         130           Address Valid Delay         10         10         10         10         10           Address Valid to ALE HIGH<br/>(Note 1)         10         10         80         15         15           Status Valid to ALE HIGH<br/>(Note 1)         110         15         15         15         15         15         15         15         15         15         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10</td><td>(Note 1)         10         33         10           READY Active to Status         Passive (Note 4)         110         10           Status Inactive Delay         10         130         10           Address Valid Delay         10         130         10           Address Folat Delay         10         130         10           Address Valid to ALE HIGH<br/>(Note 1)         10         10         10         10           Status Valid to ALE HIGH<br/>(Note 1)         15         15         15           CLK LOW to MCE HIGH<br/>(Note 1)         15         15         15           CLK LOW to MCE HIGH<br/>(Note 1)         10         10         10         10           Data Valid Delay         0         15         15         15           Data Valid Delay         0         10         10         10         10           Data Valid Delay         0         0         0         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10</td></t<> <td>(Note 1)         10         33         10         33           PREADY Active to Status<br/>Passive (Note 4)         110         65           Status factive Delay (Notes 7 &amp; 8)         10         10         10         65           Status factive Delay (Notes 7 &amp; 8)         10         10         10         66           Address Vaid Delay         Address Vaid Delay         10         10         10         60           Address Vaid Delay         Address Vaid Delay         10         10         10         60           Address Vaid Delay         Address Vaid Delay         10         10         10         60           Address Vaid Delay         Address Vaid Delay         15         15         15         15           CLL DW to ALE Valid (Note 1)         Ci = 100 pF         10         10         10         10         10         10         10         15         15         15         15         15         15         15         15         15         15         15         15         15         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         <td< td=""></td<></td> | (Note 1)         10         33           READY Active to Status         110         33           Pessive (Note 4)         110         10         110           Status active Delay         Address Valid Delay         10         110         130           Address Valid Delay         10         10         130         130           Address Valid Delay         10         10         10         10         10           Address Valid to ALE HIGH<br>(Note 1)         10         10         80         15         15           Status Valid to ALE HIGH<br>(Note 1)         110         15         15         15         15         15         15         15         15         15         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10 | (Note 1)         10         33         10           READY Active to Status         Passive (Note 4)         110         10           Status Inactive Delay         10         130         10           Address Valid Delay         10         130         10           Address Folat Delay         10         130         10           Address Valid to ALE HIGH<br>(Note 1)         10         10         10         10           Status Valid to ALE HIGH<br>(Note 1)         15         15         15           CLK LOW to MCE HIGH<br>(Note 1)         15         15         15           CLK LOW to MCE HIGH<br>(Note 1)         10         10         10         10           Data Valid Delay         0         15         15         15           Data Valid Delay         0         10         10         10         10           Data Valid Delay         0         0         0         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10 | (Note 1)         10         33         10         33           PREADY Active to Status<br>Passive (Note 4)         110         65           Status factive Delay (Notes 7 & 8)         10         10         10         65           Status factive Delay (Notes 7 & 8)         10         10         10         66           Address Vaid Delay         Address Vaid Delay         10         10         10         60           Address Vaid Delay         Address Vaid Delay         10         10         10         60           Address Vaid Delay         Address Vaid Delay         10         10         10         60           Address Vaid Delay         Address Vaid Delay         15         15         15         15           CLL DW to ALE Valid (Note 1)         Ci = 100 pF         10         10         10         10         10         10         10         15         15         15         15         15         15         15         15         15         15         15         15         15         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10         10 <td< td=""></td<> |







1-58



- 7. All timing measurements are made at 1.5 V unless otherwise noted.
- 8. Status inactive in state just prior to T<sub>4</sub>.



## 8086/8088 INSTRUCTION SET SUMMARY

| MOV = Move                          | 76543210        | 76543210      | 76543210      | 765432      |
|-------------------------------------|-----------------|---------------|---------------|-------------|
| Register/memory to/from register    | 100010dw        | mod reg r/m   |               |             |
| Immediate to register/memory        | 1100011w        | mod 0 0 0 r/m | data          | data if w = |
| Immediate to register               | 1011w reg       | data          | data if w = 1 | ]           |
| Memory to accumulator               | 101000w         | addr-low      | addr-high     | j           |
| Accumulator to memory               | 1010001w        | addr-low      | addr-high     | ]           |
| Register/memory to segment register | 10001110        | mod 0 reg r/m |               | -           |
| Segment register to register/memory | 10001100        | mod 0 reg r/m |               |             |
|                                     | <b></b>         |               |               |             |
| PUSH = Push:                        | <u> </u>        |               | 1             |             |
| Register/memory                     | 1111111         | mod 1 1 0 r/m |               |             |
| Register                            | 0 1 0 1 0 reg   |               |               |             |
| Segment register                    | 0 0 0 reg 1 1 0 | ]             |               |             |
| POP = Pop:                          |                 |               |               |             |
| Register/memory                     | 10001111        | mod 0 0 0 r/m |               |             |
| Register                            | 0 1 0 1 1 reg   | ]             |               |             |
| Segment register                    | 0 0 0 reg 1 1 1 |               |               |             |
|                                     |                 | -             |               |             |
| XCHG = Exchange:                    |                 |               | 1             |             |
| Register/memory with register       | 1000011w        | mod reg r/m   |               |             |
| Register with accumulator           | 10010 reg       | 1             |               |             |
| IN = Input from:                    |                 |               |               |             |
| Fixed port                          | 1110010w        | port          |               |             |
| Variable port                       | 1110110w        |               |               |             |
|                                     |                 |               |               |             |
| OUT = Output to:<br>Fixed port      | 1110011w        | port          | l             |             |
| Variable port                       | 1110111w        |               | I             |             |
| XLAT - Transtate byte to AL         | 11010111        | ]             |               |             |
|                                     |                 | mod reg r/m   | I             |             |
| LEA = Load EA to register           |                 |               |               |             |
| LDS = Load pointer to DS            | 11000101        | mod reg r/m   |               |             |
| LES = Load pointer to ES            | 11000100        | mod reg r/m   | l             |             |
| LANF = Load AH with flags           | 10011111        | 1             |               |             |
| SANF = Store AH into flags          | 10011110        | 1             |               |             |
| PUSHF = Push flags                  |                 |               |               |             |

#### **INSTRUCTION SET SUMMARY** (continued)

| 0         0         0         0         w         mod reg r/m           1         0         0         0         sw         mod         0         0         r/m         data         data if s:w = 01           0         0         0         0         1         0         w         data         data if w = 1           0         0         0         0         w         mod reg r/m         data         data         data if s:w = 01           1         0         0         0         sw         mod 0         1         r/m         data         data if s:w = 01           0         0         1         0         0         0         sw = 01         data         data if s:w = 01 | 76543210                              | 76543210      | 76543210      | 76543210         |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|---------------|---------------|------------------|
| 0 0 0 0 0 1 0 w data data if w = 1<br>0 0 0 1 0 0 d w mod reg r/m<br>1 0 0 0 0 0 s w mod 0 1 0 r/m data data if s:w = 01                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | w b 0 0 0 0 0 0                       | mod reg r/m   |               |                  |
| 0 0 0 1 0 0 d w mod reg r/m<br>1 0 0 0 0 0 s w mod 0 1 0 r/m data data if s:w=01                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 100000sw                              | mod 0 0 0 r/m | data          | data if s:w = 01 |
| 1 0 0 0 0 0 s w mod 0 1 0 r/m data data if s:w=01                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0000010w                              | data          | data if w = 1 | ]                |
| 1 0 0 0 0 0 s w mod 0 1 0 r/m data data if s:w=01                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                       |               |               |                  |
| 1 0 0 0 0 0 s w mod 0 1 0 r/m data data if s:w=01                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | · · · · · · · · · · · · · · · · · · · |               |               |                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 000100dw                              | mod reg r/m   |               |                  |
| 0 0 0 1 0 1 0 w data data if w = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 100000sw                              | mod 0 1 0 r/m | data          | data if s:w = 01 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0001010w                              | data          | data if w = 1 |                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                       |               |               |                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                       |               |               |                  |
| 1 1 1 1 1 1 w mod 0 0 0 r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1111111w                              | mod 0 0 0 r/m |               |                  |
| 1 1 1 1 1 1 1 w mod 0 0 0 r/m<br>0 1 0 0 0 reg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                       | mod 0 0 0 r/m |               |                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 01000 reg                             | mod 0 0 0 r/m |               |                  |

| 001010dw | mod reg r/m   |               |                  |
|----------|---------------|---------------|------------------|
| 100000sw | mod 1 0 1 r/m | data          | data if s:w = 01 |
| 0010110w | data          | data if w = 1 | ]                |

| 000110dw | mod reg r/m   |               |                  |
|----------|---------------|---------------|------------------|
| 100000sw | mod 0 1 1 r/m | data          | data if s:w = 01 |
| 0001110w | data          | data if w = 1 |                  |

| 1111111w  | mod 0 0 1 r/m |
|-----------|---------------|
| 01001 reg |               |
| 1111011w  | mod 0 1 1 r/m |

| 0011101w | mod reg r/m   |               |                  |
|----------|---------------|---------------|------------------|
| 0011100w | mod reg r/m   |               |                  |
| 100000sw | mod 1 1 1 r/m | data          | data if s:w = 01 |
| 0011110w | data          | data if w = 1 |                  |
| 00111111 |               |               |                  |
| 00101111 |               |               |                  |
| 1111011w | mod 1 0 0 r/m |               |                  |
| 1111011w | mod 1 0 1 r/m |               |                  |
| 11010100 | 00001010      |               |                  |
| 1111011w | mod 1 1 0 r/m |               |                  |
| 1111011w | mod 1 1 1 r/m |               |                  |
| 11010101 | 00001010      |               |                  |
| 10011000 |               |               |                  |
| 10011001 |               |               |                  |

## ADD = Add Reg/memory with register to either Immediate to register / memory

ARITHMETIC

Immediate to accumulator

#### ADC = Add with carry:

Reg/memory with register to either Immediate to register/memory

Immediate to accumulator

INC = Increment:

Register/memory

Register

AAA = ASCII adjust for add

DAA = Decimal adjust for add

#### SUB = Subtract:

| Reg/memory and register to either | Ľ | 0 | 0 | 1 | 0 | 1 | C |   | d | w | mod reg   |
|-----------------------------------|---|---|---|---|---|---|---|---|---|---|-----------|
| Immediate from register/memory    | [ | 1 | 0 | 0 | 0 | 0 | 0 | 1 | s | w | mod 1 0 1 |
| Immediate from accumulator        | Ľ | 0 | 0 | 1 | 0 | 1 | 1 | ( | 0 | w | data      |

### SBB = Subtract with borrow:

| Reg/memory and register to either |                 |  |  |  |  |  |
|-----------------------------------|-----------------|--|--|--|--|--|
| Immediate from                    | register/memory |  |  |  |  |  |
| Immediate from                    | accumulator     |  |  |  |  |  |

#### DEC = Decrement:

Register/memory

Register

NEG Change sign

#### CMP = Compare:

| Register/memory with register   |
|---------------------------------|
| Register with register/memory   |
| Immediate with register/memory  |
| Immediate with accumulator      |
| AAS ASCII adjust for subtract   |
| DAS Decimal adjust for subtract |
| MUL Mulitiply (unsigned)        |
| IMUL Integer multiply (signed): |
| AAM ASCII adjust for multiply   |
| DIV Divide (unsigned):          |
| IDIV Integer divide (signed)    |
| AAD ASCH adjust for divide      |
| CBW Convert byte to word        |
| CWD Convert word to double word |

## **INSTRUCTION SET SUMMARY** (continued)

## LOGIC

NOT Invert

SHR Shift logical right SAR Shift arithmetic right ROL Rotate left ROR Rotate right

#### 76543210 76543210 76543210 76543210 1111011w mod 010r/m

| 1 1 1 0 |       | mod o i o min |
|---------|-------|---------------|
| 11010   | 0 v w | mod 1 0 0 r/m |
| 11010   | 0 v w | mod 1 0 1 r/m |
| 11010   | 0 v w | mod 1 1 1 r/m |
| 11010   | 0 v w | mod 0 0 0 r/m |
| 11010   | 0 v w | mod 0 0 1 r/m |
| 11010   | 0 v w | mod 0 1 0 r/m |
| 11010   | 0 v w | mod 0 1 1 r/m |
|         |       |               |

| AND = And: |     |          |    |        |
|------------|-----|----------|----|--------|
| Reg/memory | and | register | to | either |

RCL Rotate through carry flag left RCR Rotate through carry right

SHL/SAL Shift logical/arithmetic left

| Immediate | to | register/memory |
|-----------|----|-----------------|
| Immediate | to | accumulator     |

#### TEST = And function to flags, no result:

| Register/memory and register |      |     |                 |  |  |
|------------------------------|------|-----|-----------------|--|--|
| Immediate                    | data | and | register/memory |  |  |
| Immediate                    | data | and | accumulator     |  |  |

## OR = Or:

| Reg/memory and register to either |  |
|-----------------------------------|--|
| Immediate to register/memory      |  |
| Immediate to accumulator          |  |

#### XOR = Exclusive or:

| Reg/memory and register to either |
|-----------------------------------|
| Immediate to register/memory      |
| Immediate to accumulator          |

### STRING MANIPULATION:

| REP = Repeat                   | 1111001z |
|--------------------------------|----------|
| MOVS = Move byte/word          | 1010010w |
| CMPS = Compare byte/word       | 1010011w |
| SCAS = Scan byte/word          | 1010111w |
| LODS = Load byte/wd to AL/AX   | 1010110w |
| STOS = Store byte/wd from AL/A | 1010101w |

| 0 0 |   |   |   | - | _ | _ | data          | data if w = 1 | /             |
|-----|---|---|---|---|---|---|---------------|---------------|---------------|
| 10  | 0 | 0 | 0 | 0 | 0 | w | mod 1 0 0 r/m | data          | data if w = 1 |
| 00  | 1 | 0 | 0 | 0 | d | w | mod reg r/m   |               |               |
|     |   |   |   |   |   |   |               |               |               |
|     |   |   |   |   |   |   |               |               |               |
| 11  | υ | 1 | 0 | υ | v | w | mod 0 1 1 r/m |               |               |

| 1000010w | mod reg r/m   |               |               |
|----------|---------------|---------------|---------------|
| 1111011w | mod 0 0 0 r/m | data          | data if w = 1 |
| 1010100w | data          | data if w = 1 | ]             |

| 000010dw | mod reg r/m   |               |               |
|----------|---------------|---------------|---------------|
| 100000w  | mod 0 0 1 r/m | data          | data if w = 1 |
| 0000110w | data          | data if w = 1 |               |

| 001100dw | mod reg r/m   |               |               |
|----------|---------------|---------------|---------------|
| 100000w  | mod 1 1 0 r/m | data          | data if w = 1 |
| 0011010w | data          | data if w = 1 | ]             |

| INSTRU                                                                                     | CTION SET SUM | MARY (contin  | lued)       |          |
|--------------------------------------------------------------------------------------------|---------------|---------------|-------------|----------|
| CONTROL TRANSFER                                                                           |               |               |             |          |
| CALL = Call                                                                                | 76543210      | 76543210      | 76543210    | 76543210 |
| Direct within segment                                                                      | 11101000      | disp-low      | disp-high   |          |
| indirect within segment                                                                    | 11111111      | mod 0 1 0 r/m |             |          |
| Direct intersegment                                                                        | 10011010      | offset-low    | offset-high |          |
|                                                                                            |               | seg-low       | seg-high    |          |
| Indirect intersegment                                                                      | 11111111      | mod 0 1 1 r/m |             |          |
| JMP = Unconditional jump:                                                                  |               |               |             |          |
| Direct within segment                                                                      | 11101001      | disp-low      | disp-high   | ]        |
| Direct within segment-short                                                                | 11101011      | disp          |             |          |
| Indirect within segment                                                                    | 11111111      | mod 1 0 0 r/m |             |          |
| Direct intersegment                                                                        | 11101010      | offset-low    | offset-high | ]        |
|                                                                                            |               | seg-low       | seg-high    |          |
| Indirect intersegment                                                                      | 11111111      | mod 1 0 1 r/m |             |          |
|                                                                                            |               |               |             |          |
| RET = Return from CALL:                                                                    |               | n             |             |          |
| Within segment                                                                             | 11000011      | ]<br>         | Jack Brak   | ı        |
| Within segment adding immediate to SP                                                      | 11000010      | data-low      | data-high   | I        |
| Intersegment                                                                               | 11001011      | data-low      | data biab   | ı        |
| Intersegment adding immediate to SP                                                        | 11001010      |               | data-high   | J        |
| JE/JZ = Jump on equal/zero                                                                 | 01110100      | disp          | ]           |          |
| JL/JNGE = Jump on less/not greater or equal                                                | 01111100      | disp          | ]           |          |
| JLE/JNG = Jump on less or equal/not greater                                                | 01110010      | disp          |             |          |
| JB/JNAE = Jump on below/not above or equal                                                 |               |               | ]           |          |
| JBE/JNA = Jump on below or equal/not above                                                 | 01110110      | disp          | ]           |          |
| JP/JPE = Jump on parity/parity even                                                        | 01111010      | disp          |             |          |
| JO = Jump on overflow                                                                      | 01110000      | L             | ]           |          |
| JS = Jump on sign                                                                          | 01111000      | disp          | ]           |          |
| JNE/JNZ = Jump on not equal/not zero                                                       | 01110101      | disp          | l<br>I      |          |
| JNL/JGE = Jump on not less/greater or equal<br>JNLE/JG = Jump on not less or equal/greater | 01111101      | disp          | ]           |          |
| JNB/JAE = Jump on not below/above or equal                                                 | 01110011      | disp          | J           |          |
| JNB/JAE = Jump on not below above or equal<br>JNBE/JA = Jump on not below or equal/above   | 01110111      | disp          | l<br>I      |          |
| JNP/JPO = Jump on not par/par odd                                                          | 0111011       | d isp         | l           |          |
| JNO = Jump on not overflow                                                                 | 0111001       | disp          | l<br>I      |          |
| JNC = Jump on not overnow                                                                  | 01110001      | disp          | 1           |          |
| LOOP = Loop CX times                                                                       |               | disp          | J           |          |
| LOOPZ/LOOPE = Loop while zero/equal                                                        | 11100010      | disp          | J           |          |
|                                                                                            |               | disp          | J           |          |
| LOOPNZ/LOOPNE = Loop while not zero/equal<br>JCXZ = Jump on CX zero                        | 11100000      | disp          | J<br>r      |          |

| <b>INSTRUCTION SET SUMMARY</b> (continued) |                 |               |          |          |  |
|--------------------------------------------|-----------------|---------------|----------|----------|--|
| CONTROL TRANSFER (continued)               |                 |               |          |          |  |
| INT = Interrupt                            | 76543210        | 76543210      | 76543210 | 76543210 |  |
| Type specified                             | 11001101        | type          |          |          |  |
| Туре 3                                     | 11001100        |               |          |          |  |
| INTO = Interrupt on overflow               | 11001110        |               |          |          |  |
| IRET = Interrupt return                    | 1 1 0 0 1 1 1 1 |               |          |          |  |
| PROCESSOR CONTROL                          |                 |               |          |          |  |
| CLC = Clear carry                          | 11111000        |               |          |          |  |
| CMC = Complement carry                     | 11110101        |               |          |          |  |
| STC = Set carry                            | 11111001        |               |          |          |  |
| CLD = Clear direction                      | 1111100         |               |          |          |  |
| STD = Set direction                        | 1111101         |               |          |          |  |
| CLI = Clear interrupt                      | 11111010        |               |          |          |  |
| STI = Set interrupt                        | 1111011         |               |          |          |  |
| HLT = Halt                                 | 11110100        |               |          |          |  |
| WAIT = Wait                                | 10011011        |               |          |          |  |
| ESC = Processor Extension Escape           | 1 1 0 1 1 x x x | mod x x x r/m |          |          |  |
| LOCK = Bus lock prefix                     | 11110000        |               |          |          |  |

#### Footnotes:

AL = 8-bit accumulator AX = 16-bit accumulator AX = 16-bit accumulator CX = Count register DS = Data segment ES = Extra segment Above/below refers to unsigned value. Greater = more positive. Less = less positive (more negative) signed values Less = less positive (more negative) signed values Less = less positive (more negative) signed values if d = 1 then 'to' reg; if d = 0 then 'trom'' reg w = 1 then word instruction; if w = 0 then byte instruction if mod = 11 then r/m is treated as a REG field if mod = 00 then DISP = 0, disp-low and disp-high are absent if mod = 00 then DISP = 0 disp-low sign-extended to 16-bits, disp-high is absent if mod = 10 then DISP = disp-high: disp-low if r/m = 000 then EA = (BX) + (SI) + DISP if r/m = 010 then EA = (BX) + (SI) + DISP if r/m = 010 then EA = (BP) + (DI) + DISP if r/m = 101 then EA = (BP) + (DI) + DISP if r/m = 101 then EA = (BP) + DISP if r/m = 110 then EA = (BP) + DISP if r/m = 110 then EA = (BP) + DISP DISP follows 2nd byte of instruction (before data if required)

\*except if mod = 00 and r/m = 110 then EA = disp-high: disp-low.

if s:w = 01 then 16 bits of immediate data form the operand. if s:w = 11 then an immediate data byte is sign extended to form the 16-bit operand.

if v = 0 then "count" = 1; if v = 1 then "count" in (CL)

x = don't care z is used for string primitives for comparison with Z.F Flag.

SEGMENT OVERRIDE PREFIX

| ^ | ^ | 4 | -0-0 | - | - |
|---|---|---|------|---|---|

REG is assigned according to the following table:

| 16-Bit (w = 1) | 8-Bit (w = 0) | Segment |
|----------------|---------------|---------|
| 000 AX         | 000 AL        | 00 ES   |
| 001 CX         | 001 CL        | 01 CS   |
| 010 DX         | 010 DL        | 10 SS   |
| 011 BX         | 011 BL        | 11 DS   |
| 100 SP         | 100 AH        |         |
| 101 BP         | 101 CH        |         |
| 110 SI         | 110 DH        |         |
| 111 DI         | 111 BH        |         |

Instructions which reference the flag register files as a 16-bit object use the symbol FLAGS to represent the file:

 $\mathsf{FLAGS} = \mathsf{X}: \mathsf{X}: \mathsf{X}: \mathsf{X}: (\mathsf{OF}): (\mathsf{DF}): (\mathsf{TF}): (\mathsf{SF}): (\mathsf{ZF}): \mathsf{X}: (\mathsf{AF}): \mathsf{X}: (\mathsf{PF}): \mathsf{X}: (\mathsf{CF})$ 

# **80286** High-Performance Microprocessor with Memory Management and Protection

### **DISTINCTIVE CHARACTERISTICS**

- High-performance processor (up to 13.3 times iAPX 86 when using the 16-MHz 80286)
- Large address space -16 Mb physical
  - -1 Gb virtual memory per task
- Integrated memory management, four-level memory protection and support for virtual memory and operating systems
- Two iAPX 86 upward-compatible operating modes

# **GENERAL DESCRIPTION**

The 80286 is an advanced, high-performance microprocessor with specially optimized capabilities for multiple user and multitasking systems. The 80286 has built-in memory protection that supports operating system and task isolation as well as program and data privacy within tasks. A 16-MHz 80286 provides up to 13.3 times greater throughput than the standard 5-MHz 8086. The 80286 includes memory management capabilities -iAPX 86 real address mode -Protected virtual address mode

- High bandwidth bus interface (16 Mb/s)
- Range of clock rates
  - 8 MHz 80286-8
  - -10 MHz 80286-10
  - -12 MHz 80286-12 -16 MHz 80286-16
  - -16 MHZ 60286-16

that map up to 2<sup>30</sup> bytes (one gigabyte) of virtual address space per task into 2<sup>24</sup> bytes (16 Mb) of physical memory.

The 80286 is upward-compatible with iAPX 86 and 88 software. Using iAPX 86 real address mode, the 80286 is object-code compatible with existing iAPX 86, 88 software.



# **BLOCK DIAGRAM**

# **GENERAL DESCRIPTION (continued)**

In protected virtual address mode, the 80286 is sourcecode compatible with iAPX 86, 88 software and may require upgrading to use virtual addresses supported by the 80286's integrated memory management and protection mechanism. Both modes operate at full 80286 performance and execute a superset of the iAPX 86 and 88 instructions. The 80286 provides special operations to support the efficient implementation and execution of operating systems. For example, one instruction can end execution of one task, save its state, switch to a new task, load its state, and start execution of the new task. The 80286 also supports virtual memory systems by providing a segment-not-present exception and restartable instructions.

# **Related AMD Products**

| Part No. | Description                 |
|----------|-----------------------------|
| 82284    | Clock Driver                |
| 82C54    | Programmable Interval Timer |
| Am9517A  | DMA Controller              |

# CONNECTION DIAGRAMS

Component Pad Views—As viewed from underside of component on the PC Board





There are no electrical connections on the <sup>03552–3</sup> bottom of this package

# PIN DESIGNATIONS (Sorted by pin number)

| Pin<br>No. | Pin<br>Name                   | Pin<br>No. | Pin<br>Name    | Pin<br>No. | Pin<br>Name  |
|------------|-------------------------------|------------|----------------|------------|--------------|
| 1          | BHE                           | 24         | A7             | 47         | D13          |
| 2<br>3     | NC<br>NC<br>S1<br>S0<br>PEACK | 25         | A6             | 48         | D6           |
| 3          | NC                            | 26         | A5             | 49         | D14          |
| 4          | S1                            | 27         | A4             | 50         | D7           |
| 5          | SO                            | 28         | A3             | 51         | D15          |
| 6          | PEACK                         | 29         | RESET          | 52         | CAP          |
| 7          | A23                           | 30         | Vcc            | 53         | ERROR        |
| 8          | A22                           | 31         | CLK            | 54         | BUSY         |
| 9          | Vss                           | 32         | A <sub>2</sub> | 55         | NC           |
| 10         | A21                           | 33         | A1             | 56         | NČ           |
| 11         | A20                           | 34         | Ao             | 57         | INTR         |
| 12         | A 19                          | 35         | Vss            | 58         | NC           |
| 13         | A18                           | 36<br>37   | Do             | 59         | NMI          |
| 14         | A17                           | 37         | Da             | 60         | Vss          |
| 15         | A16                           | 38         | Dı             | 61         | PEREQ        |
| 16         | A15                           | 39         | D9             | 62         | Vcc          |
| 17         | A14                           | 40         | D2             | 63         | Vcc<br>READY |
| 18         | A13                           | 41         | D10            | 64         | HOLD         |
| 19         | A12                           | 42         | Dз             | 65         | HLDA         |
| 20         | A11                           | 43         | D11            | 66         | COD/INTA     |
| 21         | A10                           | 44         | D4             | 67         | M/IO         |
| 22         | Aa                            | 45         | D12            | 68         | LOCK         |
| 23         | A <sub>8</sub>                | 46         | D5             |            |              |

#### LCC PC Board Views—As viewed from the component side of the PC Board



# **ORDERING INFORMATION**

#### Standard Products

AMD standard products are available in several packages and operating ranges. The order number (Valid Combination) is formed by a combination of the elements below.



Blank = Commercial (Tc =  $0^{\circ}C$  to +85°C)

| Valid C | ombinations |
|---------|-------------|
| R       | 802868      |
|         | 80286-10    |
|         | 80286-12    |
|         | 80286-16    |

#### Valid Combinations

Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations, to check on newly released combinations, and to obtain additional data on AMD's standard military grade products.

# **PIN DESCRIPTION**

# CLK

#### System Clock (Input; Active High)

System Clock provides the fundamental timing for 80286 systems. It is divided by two inside the 80286 to generate the processor clock. The internal divide-bytwo circuitry can be synchronized to an external clock generator by Low-to-High transition on the RESET input.

# D<sub>0</sub>-D<sub>15</sub>

#### Data Bus (Input/Output; Active High)

Data Bus inputs data during memory, I/O, and interrupt acknowledge read cycles; outputs data during memory and I/O write cycles. The data bus is active High and floats to three-state OFF during bus hold acknowledge.

# A23-A0

#### Address Bus (Output; Active High)

Address Bus outputs physical memory and I/O port addresses.  $A_o$  is Low when data is to be transferred on pins  $D_7$ – $D_o$ .  $A_{2a}$ – $A_{1e}$  are Low during I/O transfers. The address bus is active High and floats to three-state OFF during bus hold acknowledge.

# BHE

#### Bus High Enable (Output; Active Low)

Bus High Enable indicates transfer of data on the upper byte of the data bus  $D_{1s}-D_{a}$ . Eight-bit oriented devices assigned to the upper byte of the data bus would normally use BHE to condition chip select functions. BHE is active Low and floats to three-state OFF during bus hold acknowledge.

|              | BHE and A <sub>0</sub> Encodings |                                                                                                             |  |  |  |  |  |
|--------------|----------------------------------|-------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| BHE<br>Value | A,<br>Value                      | Function                                                                                                    |  |  |  |  |  |
| 0            | 0                                | Word transfer                                                                                               |  |  |  |  |  |
| 0            | 1                                | Byte transfer on upper half of data bus (D,,,)                                                              |  |  |  |  |  |
| 1            | 0                                | Byte transfer on upper half of data bus $(D_{15-6})$<br>Byte transfer on lower half of data bus $(D_{7-6})$ |  |  |  |  |  |
| 1            | 1                                | Reserved                                                                                                    |  |  |  |  |  |

# <u>51, 50</u>

#### Bus Cycle Status (Output; Active Low)

Bus Cycle Status indicates initiation of a bus cycle and, along with M/IO and COD/INTA, defines the type of bus cycle. The bus is in a Ts state whenever one or both are Low. S1 and S0 are active Low and float to three-state OFF during bus hold acknowledge.

#### 80286 Bus Cycle Status Definition

| COD/<br>INTA | M∕ĪŌ | <u>51</u> | <u>50</u> | Bus Cycle Status Definition           |
|--------------|------|-----------|-----------|---------------------------------------|
| 0 (Low)      | 0    | 0         | 0         | Interrupt acknowledge                 |
| 0            | 0    | 0         | 1         | Reserved                              |
| 0            | 0    | 1         | 0         | Reserved                              |
| 0            | 0    | 1         | 1         | None; not a status cycle              |
| 0            | 1    | 0         | 0         | If $A_1 = 1$ then halt; else shutdown |
| 0            | 1    | 0         | 1         | Memory data read                      |
| 0            | 1    | 1         | 0         | Memory data write                     |
| 0            | 1    | 1         | 1         | None; not a status cycle              |
| 1 (High)     | ) 0  | 0         | 0         | Reserved                              |
| 1            | 0    | 0         | 1         | I/O Read                              |
| 1            | 0    | 1         | 0         | I/O Write                             |
| 1            | 0    | 1         | 1         | None; not a status cycle              |
| 1            | 1    | 0         | 0         | Reserved                              |
| 1            | 1    | 0         | 1         | Memory instruction read               |
| 1            | 1    | 1         | 0         | Reserved                              |
| 1            | 1    | 1         | 1         | None; not a status cycle              |

# M/ĪŌ

# Memory/IO Select (Output)

Memory/ $\overline{IO}$  Select distinguishes memory access from I/O access. If High during Ts, a memory cycle or a halt/ shutdown cycle is in progress. If Low, an I/O cycle or an interrupt acknowledge cycle is in progress. M/ $\overline{IO}$  floats to three-state OFF during bus hold acknowledge.

# COD/INTA

### Code/Interrupt Acknowledge (Output)

Code/Interrupt Acknowledge distinguishes instruction fetch cycles from memory data read cycles. Also distinguishes interrupt acknowledge cycles from I/O cycles. COD/INTA floats to three-state OFF during bus hold acknowledge.

# LOCK

### Bus Lock (Output; Active Low)

Bus Lock indicates that other system bus masters are not to gain control of the system bus following the current bus cycle. The LOCK signal may be activated explicitly by the LOCK instruction prefix or automatically by 80286 hardware during memory XCHG instructions, interrupt acknowledge, or descriptor table access. LOCK is active Low and floats to three-state OFF during hold acknowledge.

# **PIN DESCRIPTION (continued)**

# READY

#### Bus Ready (Input; Active Low)

Bus Ready terminates a bus cycle. Bus cycles are extended without limit until terminated by READY Low. READY is an active Low synchronous input requiring set-up and hold times relative to the system clock be met for correct operation. READY is ignored during bus hold acknowledge.

#### HOLD, HLDA Bus Hold Request and Hold Acknowledge (Input/Output; Active High)

Bus Hold Request and Hold Acknowledge control ownership of the 80286 local bus. The HOLD input allows another local bus master to request control of the local bus. When control is granted, the 80286 will float its bus drivers to three-state OFF and then active HLDA, thus entering the bus hold acknowledge condition. The local bus will remain granted to the requesting master until HOLD becomes inactive which results in the 80286 deactivating HLDA and regaining control of the local bus. This terminates the bus hold acknowledge condition. HOLD may be asynchronous to the system clock. These signals are active High.

### INTR

#### Interrupt Request (Input; Active High)

Interrupt Request requests the 80286 to suspend its current program execution and service a pending external request. Interrupt requests are masked whenever the interrupt enable bit in the flag word is cleared. When the 80286 responds to an interrupt request, it performs two interrupt acknowledge bus cycles to read an 8-bit interrupt vector that identifies the source of the interrupt. To assure program interruption, INTR must remain active until the first interrupt acknowledge cycle is completed. INTR is sampled at the beginning of each processor cycles before the current instruction ends in order to interrupt before the next instruction. INTR is level sensitive, active High, and may be asynchronous to the system clock.

#### NMI

# Non-Maskable Interrupt Request (Input; Active High)

Non-maskable Interrupt Request interrupts the 80286 with an internally supplied vector value of 2. No interrupt acknowledge cycles are performed. The interrupt enable bit in the 80286 flag word does not affect this input. The NMI input is active High, may be asynchronous to the system clock, and is edge triggered after internal synchronization. For proper recognition, the input must have been previously Low for at least four system clock cycles.

# PEREQ, PEACK

# Processor Extension Operand Request and Acknowledge (Input/Output)

Processor Extension Operand Request and Acknowledge extended the memory management and protection capabilities of the 80286 to processor extensions. The PEREQ input requests the 80286 to perform a data operand transfer for a processor extension. The PEACK output signals the processor extension when the requested operand is being transferred. PEREQ is active High and may be asynchronous to the system clock. PEACK is active Low.

# BUSY, ERROR

# Processor Extension Busy and Error (Input/Input, Active Low)

Processor Extension Busy and Error indicate the operating condition of a processor extension to the 80286. An active BUSY input stops 80286 program execution on WAIT and some ESC instructions until BUSY becomes inactive (High). The 80286 may be interrupted while waiting for BUSY to become inactive. An active ERROR input causes the 80286 to perform a processor extension interrupt when executing WAIT or some ESC instructions. These inputs are active Low and may be asynchronous to the system clock.

# RESET

#### System Reset (Input; Active High)

System Reset clears the internal logic of the 80286 and is active High. The 80286 may be reinitialized at any time with a Low-to-High transition on RESET which remains active for more than 16 system clock cycles. During RESET active, the output pins of the 80286 enter the state shown below.

| Pin Value           | Pin Names                                                |
|---------------------|----------------------------------------------------------|
| 1 (High)<br>0 (Low) | SO, ST, PEACK, A23-A0, BHE, LOCK<br>M/IO, COD/INTA, HLDA |
| Three-state OFF     | D <sub>15</sub> –D <sub>0</sub>                          |

Operation of the 80286 begins after a High-to-Low transition on RESET. The High-to-Low transition of RESET must be synchronous to the system clock. Approximately 50 system clock cycles are required by the 80286 for internal initializations before the first bus cycle to fetch code from the power-on execution address is performed.

# **PIN DESCRIPTION (continued)**

A Low-to-High transition of RESET synchronous to the system clock will begin a new processor cycle at the next High-to-Low transition of the system clock. The Low-to-High transition of RESET may be asynchronous to the system clock; however, in this case it cannot be predetermined which phase of the processor clock will occur during the next system period. Synchronous Low-to-High transitions of RESET are only required for systems where the processor clock must be phase synchronous to another clock.

#### Vss

System Ground (Input)

System Ground: 0 V.

#### Vcc

System Power (Input)

System Power: +5 V power supply.

### CAP

#### Substrate Filter Capacitor (Input; Active High)

A 0.047  $\mu F$  ±20% 12 V capacitor must be connected between this pin and ground. This capacitor filters the output of the internal substrate bias generator. A maximum DC leakage current of 1  $\mu A$  is allowed through the capacitor.

For correct operation of the 80286, the substrate bias generator must charge this capacitor to its operating voltage. The capacitor charge-up time is 5 ms (Max) after Vcc and CLK reach their specified AC and DC parameters. RESET may be applied to prevent spurious activity by the CPU during this time. After this time, the 80286 processor clock can be phase synchronized to another clock by pulsing RESET Low synchronous to the system clock.

# **FUNCTIONAL DESCRIPTION**

#### Introduction

The 80286 is an advanced, high-performance microprocessor with specially optimized capabilities for multiple user and multi-tasking systems. Depending on the application, the 80286's performance is up to 13.3 times faster than the standard 5-MHz 8086's, while providing complete upward software compatibility with AMD's iAPX 86, 88, and 186 family of CPUs.

The 80286 operates in two modes: iAPX 86 real address mode and protected virtual address mode. Both modes execute a superset of the iAPX 86 and 88 instruction set.

In iAPX 86 real address mode programs use real addresses with up to one megabyte of address space. Programs use virtual addresses in protected virtual address mode, also called protected mode. In protected mode, the 80286 CPU automatically maps 1 gigabyte of virtual addresses per task into a 16-megabyte real address space. This mode also provides memory protection to isolate the operating system and ensure privacy of each task's programs and data. Both modes provide the same base instruction set, registers, and addressing modes.

The following pages describe first, the base 80286 architecture common to both modes; second, iAPX 86 real address mode; and third, protected mode.

#### 80286 Base Architecture

The iAPX 86, 88, 186, and 286 CPU family all contain the same basic set of registers, instructions, and addressing modes. The 80286 processor is upward-compatible with the 8086, 8088, and 80186 CPUs.

### **Register Set**

The 80286 base architecture has fifteen registers as shown in Figure 1. These registers are grouped into the following four categories:

General Registers: Eight 16-bit general purpose registers used to contain arithmetic and logical operands. Four of these (AX, BX, CX, and DX) can be used either in their entirety as 16-bit words or split into pairs of separate 8-bit registers.

Segment Registers: Four 16-bit special purpose registers select, at any given time, the segments of memory that are immediately addressable for code, stack, and data. (For usage, refer to Memory Organization.)

Base and Index Registers: Four of the general purpose registers may also be used to determine offset addresses of operands in memory. These registers may contain base addresses or indexes to particular locations within a segment. The addressing mode determines the specific registers used for operand address calculations.

Status and Control Registers: Three 16-bit special purpose registers record or control certain aspects of the 80286 processor state. These include the Instruction Pointer, which contains the offset address of the next sequential instruction to be executed.



Figure 1. Register Set

03552-7



03552-8

Figure 2. Status and Control Register Bit Functions

# Flags Word Description

The Flags Word (Flags) records specific characteristics of the result of logical and arithmetic instructions (bits 0, 2, 4, 6, 7, and 11) and controls the operation of the 80286 within a given operating mode (bits 8 and 9). Flags is a 16-bit register. The function of the flag bits is given in Table 1.

#### **Table 1. Flags Word Bit Functions**

| Bit<br>Position | Name | Function                                                                                                                                                                   |
|-----------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0               | CF   | Carry Flag—Set on high-order bit carry or borrow; cleared otherwise                                                                                                        |
| 2               | PF   | Parity Flag—Set if low-order 8 bits of re-<br>sult contain an even number of 1 bits;<br>cleared otherwise                                                                  |
| 4               | AF   | Set on carry-from or borrow-to the low-or-<br>der four bits of AL; cleared otherwise                                                                                       |
| 6               | ZF   | Zero Flag—Set if result is zero; cleared otherwise                                                                                                                         |
| 7               | SF   | Sign Flag—Set equal to high-order bit of result (0 if positive, 1 if negative)                                                                                             |
| 11              | OF   | Overflow Flag—Set if result is a too-large<br>positive number or a too-small negative<br>number (excluding sign-bit) to fit in desti-<br>nation operand; cleared otherwise |
| 8               | TF   | Single Step Flag—Once set, a single<br>step interrupt occurs after the next in-<br>struction executes. TF is cleared by the<br>single step interrupt                       |
| 9               | IF   | Interrupt-Enable Flag—When set, mask-<br>able interrupts will cause the CPU to<br>transfer control to an interrupt vector<br>specified location                            |
| 10              | DF   | Direction Flag—Causes string instruc-<br>tions to auto-decrement the appropriate<br>index registers when set. Clearing DF<br>causes auto increment.                        |

### **Instruction Set**

The instruction set is divided into seven categories: data transfer, arithmetic, shift/rotate/logical, string manipulation, program transfer, high-level instructions, and processor control. These categories are summarized in Figures 3–9.

An 80286 instruction can reference zero, one, or two operands where an operand resides in a register, in the instruction itself, or in memory. Zero-operand instructions (e.g., NOP and HLT) are usually one byte long. One-operand instructions (e.g., INC and DEC) are usually two bytes long, but some are encoded in only one byte. One-operand instructions may reference a register or memory location. Two-operand instructions permit the following six types of instruction operations.

> Register to Register Memory to Register Immediate to Register Memory to Memory Register to Memory Immediate to Memory

Two-operand instructions (e.g., MOV and ADD) are usually three to six bytes long. Memory to memory operations are provided by a special class of string instructions requiring one to three bytes. For detailed instruction formats and encodings, refer to the instruction set summary at the end of this document.

|       | General Purpose              |
|-------|------------------------------|
| MOV   | Move byte or word            |
| PUSH  | Push word onto stack         |
| POP   | Pop word off stack           |
| PUSHA | Push all registers on stack  |
| POPA  | Pop all registers from stack |
| XCHG  | Exchange byte or word        |
| XLAT  | Translate byte               |
|       | Input/Output                 |
| IN    | Input byte or word           |
| OUT   | Output byte or word          |
|       | Address Object               |
| LEA   | Load effective address       |
| LDS   | Load pointer using DS        |
| LES   | Load pointer using ES        |
|       | Flag Transfer                |
| LAHF  | Load AH register from flags  |
| SAHF  | Store AH register in flags   |
| PUSHF | Push flags onto stack        |
| POPF  | Pop flags off stack          |

#### Figure 3. Data Transfer Instructions

|      | Addition                          | MOVS<br>- INS     |
|------|-----------------------------------|-------------------|
| ADD  | Add byte or word                  | OUTS<br>- CMPS    |
| ADC  | Add byte or word with carry       | SCAS              |
| INC  | Increment byte or word by 1       | LODS              |
| AAA  | ASCII adjust for addition         | STOS              |
| DAA  | Decimal adjust for addition       | REP               |
|      | Subtraction                       | - REPE/F<br>REPNE |
| SUB  | Subtract byte or word             | -                 |
| SBB  | Subtract byte or word with borrow |                   |
| DEC  | Decrement byte or word by 1       |                   |
| NEG  | Negate byte or word               |                   |
| CMP  | Compare byte or word              | NOT               |
| AAS  | ASCII adjust for subtraction      | AND               |
| DAS  | Decimal adjust for subtraction    | OR                |
|      | Multiplication                    | - XOR<br>TEST     |
| MUL  | Multiply byte or word unsigned    |                   |
| IMUL | Integer multiply byte or word     |                   |
| AAM  | ASCII adjust for multiply         |                   |
|      |                                   | _ SHL/SA          |
|      | Division                          | SHR<br>SAR        |
| DIV  | Divide byte or word unsigned      |                   |
| IDIV | Integer divide byte or word       |                   |
| AAD  | ASCII adjust for division         |                   |
| CBW  | Convert byte to word              | ROL               |
| CWD  | Convert word to double word       | ROR               |
| F    | igure 4. Arithmetic Instructions  | RCL<br>RCR        |
| •    |                                   | nun               |
|      |                                   |                   |

| MOVS        | Move byte or word string        |
|-------------|---------------------------------|
| INS         | Input bytes or word string      |
| OUTS        | Output bytes or word string     |
| CMPS        | Compare byte or word string     |
| SCAS        | Scan byte or word string        |
| LODS        | Load byte or word string        |
| STOS        | Store byte or word string       |
| REP         | Repeat                          |
| REPE/REPZ   | Repeat while equal/zero         |
| REPNE/REPNZ | Repeat while not equal/not zero |
| Figu        | ure 5. String Instructions      |
|             |                                 |
|             | Logicals                        |
| NOT         | "Not" byte or word              |

| NOT     | "Not" byte or word                         |
|---------|--------------------------------------------|
| AND     | "And" byte or word                         |
| OR      | "Inclusive or" byte or word                |
| XOR     | "Exclusive or" byte or word                |
| TEST    | "Test" byte or word                        |
|         | Shifts                                     |
| SHL/SAL | Shift logical/arithmetic left byte or word |
| SHR     | Shift logical right byte or word           |
| SAR     | Shift arithmetic right byte or word        |
|         | Rotates                                    |
| ROL     | Rotate left byte or word                   |
| ROR     | Rotate right byte or word                  |
| RCL     | Rotate through carry left byte or word     |
| RCR     | Rotate through carry right byte or word    |

# Figure 6. Shift/Rotate/Logical

|                                                          | Conditional Transfers                                                                                                                                                                         | Uncondition                                  | al Transfers                                                                      |
|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|-----------------------------------------------------------------------------------|
| JA/JNBE<br>JAE/JNB<br>JB/JNAE<br>JBE/JNA                 | Jump if above/not below nor equal<br>Jump if above or equal/not below<br>Jump if below/not above nor equal<br>Jump if below or equal/not above                                                | CALL<br>RET<br>JMP                           | Call procedure<br>Return from procedure<br>Jump                                   |
| JC                                                       | Jump if carry                                                                                                                                                                                 | Iteration                                    | Controls                                                                          |
| JE/JZ<br>JG/JNLE<br>JGE/JNL<br>JL/JNGE<br>JLE/JNG<br>JNC | Jump if equal/zero<br>Jump if greater/not less nor equal<br>Jump if greater or equal/not less<br>Jump if less/not greater nor equal<br>Jump if less or equal/not greater<br>Jump if not carry | LOOP<br>LOOPE/LOOPZ<br>LOOPNE/LOOPNZ<br>JCXZ | Loop<br>Loop if equal/zero<br>Loop if not equal/not zero<br>Jump if register CX=0 |
| JNE/JNZ                                                  | Jump if not equal/not zero                                                                                                                                                                    | Inter                                        | rupts                                                                             |
| JNO<br>JNP/JPO<br>JNS<br>JO<br>JP/JPE<br>JS              | Jump if not overflow<br>Jump if not parity/parity odd<br>Jump if not sign<br>Jump if overflow<br>Jump if parity/parity even<br>Jump if sign                                                   | INT<br>INTO<br>IRET                          | Interrupt<br>Interrupt if overflow<br>Interrupt return                            |

# Figure 7. Program Transfer Instructions

#### Flag Operations

|                                          | Flag Operations                  |  |
|------------------------------------------|----------------------------------|--|
| STC                                      | Set carry flag                   |  |
| CLC                                      | Clear carry flag                 |  |
| CMC                                      | Complement carry flag            |  |
| STD                                      | Set direction flag               |  |
| CLD                                      | Clear direction flag             |  |
| STI                                      | Set interrupt enable flag        |  |
| CLI                                      | Clear interrupt enable flag      |  |
|                                          | External Synchronization         |  |
| HLT                                      | Halt until interrupt or reset    |  |
| WAIT                                     | Wait for BUSY not active         |  |
| ESC                                      | Escape to extension processor    |  |
| LOCK                                     | Lock bus during next instruction |  |
|                                          | No Operation                     |  |
| NOP                                      | No operation                     |  |
| Execution Environment Control            |                                  |  |
| LMSW                                     | Load machine status word         |  |
| SMSW                                     | Store machine status word        |  |
| Figure 8. Processor Control Instructions |                                  |  |

| ENTER | Format stack for procedure entry        |
|-------|-----------------------------------------|
| LEAVE | Restore stack for procedure exit        |
| BOUND | Detects values outside prescribed range |

**Figure 9. High-Level Instructions** 

#### **Memory Organization**

Memory is organized as sets of variable length segments. Each segment is a linear contiguous sequence of up to  $64K(2^{16})$  8-bit bytes. Memory is addressed using a two-component address (a pointer) that consists of a 16-bit segment selector and a 16-bit offset. The segment selector indicates the desired segment in memory. The offset component indicates the desired byte address within the segment.

Most instructions need not explicitly specify which segment register is used. The correct segment register is automatically chosen according to the rules of Table 2. These rules follow the way programs are written (see Figure 11) as independent modules that require areas for code and data, a stack, and access to external data areas. All instructions that address operands in memory must specify the segment and the offset. For speed and compact instruction encoding, segment selectors are usually stored in the high speed segment registers. An instruction need specify only the desired segment register and an offset to address a memory operand.



03552-9

Figure 10. Two-Component Address

#### Table 2. Segment Register Selection Rules

| Memory<br>Reference<br>Needed | Segment<br>Register<br>Used | Implicit Segment<br>Selection Rule                                                      |
|-------------------------------|-----------------------------|-----------------------------------------------------------------------------------------|
| Instructions                  | Code (CS)                   | Automatic with instruction prefetch                                                     |
| Stack                         | Stack (SS)                  | All stack pushes and pops.<br>Any memory reference which<br>uses BP as a base register. |
| Local Data                    | Data (DS)                   | All data references except<br>when relative to stack or<br>string destination.          |
| External<br>(Global) Data     | Extra (ES)                  | Alternate data segment and destination of string operation.                             |

Special segment override instruction prefixes allow the implicit segment register selection rules to be overridden for special cases. The stack, data, and extra segments may coincide for simple programs. To access operands that do not reside in one of the four immediately available segments, either a full 32-bit pointer can be used or a new segment selector must be loaded.





Figure 11. Segmented Memory Helps Structure Software

### Addressing Modes

The 80286 provides a total of eight addressing modes for instructions to specify operands. Two addressing modes are provided for instructions that operate on register or immediate operands:

**Register Operand Mode:** The operand is located in one of the 8- or 16-bit general registers.

**Immediate Operand Mode:** The operand is included in the instruction.

Six modes are provided to specify the location of an operand in a memory segment. A memory operand address consists of two 16-bit components: segment selector and offset. The segment selector is supplied by a segment register either implicitly chosen by the addressing mode or explicitly chosen by a segment override prefix. The offset is calculated by summing any combination of the following three address elements:

the displacement (an 8- or 16-bit immediate value contained in the instruction)

the base (contents of either the BX or BP base registers)

the index (contents of either the SI or DI index registers)

Any carry out from the 16-bit addition is ignored. Eightbit displacements are sign extended to 16-bit values. Combinations of these three address elements define the six memory addressing modes here described:

**Direct Mode:** The operand's offset is contained in the instruction as an 8- or 16-bit displacement element.

**Register Indirect Mode:** The operand's offset is in one of the registers SI, DI, BX, or BP.

**Based Mode:** The operand's offset is the sum of an 8- or 16-bit displacement and the contents of a base register (BX or BP).

Indexed Mode: The operand's offset is the sum of an 8or 16-bit displacement and the contents of an index register (SI or DI).

**Based Indexed Mode:** The operand's offset is the sum of the contents of a base register and an index register.

**Based Indexed Mode with Displacement:** The operand's offset is the sum of a base register's contents, an index register's contents, and an 8- or 16-bit displacement.

# **Data Types**

The 80286 directly supports the following data types:

| Integer:        | A signed binary numeric value con-<br>tained in an 8-bit byte or a 16-bit word.<br>All operations assume a two's comple-<br>ment representation. Signed 32- and<br>64-bit integers are supported using the<br>80287 Numeric Data Processor. |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Ordinal:        | An unsigned binary numeric value con-<br>tained in an 8-bit byte or 16-bit word.                                                                                                                                                            |
| Pointer:        | A 32-bit quantity, composed of a seg-<br>ment selector component and an offset<br>component. Each component is a<br>16-bit word.                                                                                                            |
| String:         | A contiguous sequence of bytes or<br>words. A string may contain from 1 byte<br>to 64K bytes.                                                                                                                                               |
| ASCII:          | A byte representation of alphanumeric<br>and control characters using the ASCII<br>standard of character representation.                                                                                                                    |
| BCD:            | A byte (unpacked) representation of the decimal digits 0–9.                                                                                                                                                                                 |
| Packed BCD:     | A byte (packed) representation of two decimal digits 0–9 storing one digit in each nibble of the byte.                                                                                                                                      |
| Floating Point: | A signed 32-, 64-, or 80-bit real number<br>representation. (Floating point oper-<br>ands are supported using the iAPX 287<br>Numeric Processor configuration.)                                                                             |
| Figure 12 grap  | hically represents the data types sup-                                                                                                                                                                                                      |

Figure 12 graphically represents the data types supported by the 80286.





\*Supported by iAPX 286/287 Numeric Data Processor Configuration

03552-11

# I/O Space

The I/O space consists of 64K 8-bit or 32K 16-bit ports. I/O instructions address the I/O space with either an 8-bit port address, specified in the instruction, or a 16-bit port address in the DX register. Eight-bit port addresses are zero extended such that  $A_{15}$ - $A_8$  are Low. I/O port addresses 00F8(H) through 00FF(H) are reserved.

# Interrupts

An interrupt transfers execution to a new program location. The old program address (CS:IP) and machine state (Flags) are saved on the stack to allow resumption of the interrupted program. Interrupts fall into three classes: hardware initiated, INT instructions, and instruction exceptions. Hardware initiated interrupts occur in response to an external input and are classified as non-maskable or maskable. Programs may cause an interrupt with an INT instruction. Instruction exceptions occur when an unusual condition, which prevents further instruction processing, is detected while attempting to execute an instruction. The return address from an exception will always point at the instruction causing the exception and include any leading instruction prefixes.

A table containing up to 256 pointers defines the proper interrupt service routine for each interrupt. Interrupts 0–31, some of which are used for instruction exceptions, are reserved. For each interrupt, an 8-bit vector must be supplied to the 80286 which identifies the appropriate table entry. Exceptions supply the interrupt vector internally. INT instructions contain or imply the vector and allow access to all 256 interrupts. Maskable hardwareinitiated interrupts supply the 8-bit vector to the CPU during an interrupt acknowledge bus sequence. Nonmaskable hardware interrupts use a predefined internally supplied vector.

# Maskable Interrupt (INTR)

The 80286 provides a maskable hardware interrupt request pin, INTR. Software enables this input by setting the interrupt flag bit (IF) in the flag word. All 224

user-defined interrupt sources can share this input, yet they can retain separate interrupt handlers. An 8-bit vector read by the CPU during the interrupt acknowledge sequence (discussed in the System Interface section) identifies the source of the interrupt.

Further maskable interrupts are disabled while servicing an interrupt by resetting the IF but as part of the response to an interrupt or exception. The saved flag word will reflect the enable status of the processor prior to the interrupt. Until the flag word is restored to the flag register, the interrupt flag will be zero unless specifically set. The interrupt return instruction includes restoring the flag word, thereby restoring the original status of IF.

# Non-Maskable Interrupt Request (NMI)

A non-maskable interrupt input (NMI) is also provided. NMI has higher priority than INTR. A typical use of NMI would be to activate a power failure routine. The activation of this input causes an interrupt with an internally supplied vector value of 2. No external interrupt acknowledge sequence is performed.

While executing the NMI servicing procedure, the 80286 will not service further NMI requests, INTR requests, or the processor extension segment overrun interrupt until an interrupt return (IRET) instruction is executed or the CPU is reset. If NMI occurs while currently servicing an NMI, its presence will be saved for servicing after executing the first IRET instruction. IF is cleared at the beginning of an NMI interrupt to inhibit INTR interrupts.

# Single Step Interrupt

The 80286 has an internal interrupt that allows programs to execute one instruction at a time. It is called the single step interrupt and is controlled by the single step flag bit (TF) in the flag word. Once this bit is set, an internal single step interrupt will occur after the next instruction has been executed. The interrupt clears the TF bit and uses an internally supplied vector of 1. The IRET instruction is used to set the TF bit and transfer control to the next instruction to be single stepped.

| Function                                    | Interrupt<br>Number | Related<br>Instructions                | Return Address<br>Before Instruction<br>Causing Exception? |
|---------------------------------------------|---------------------|----------------------------------------|------------------------------------------------------------|
| Divide error exception                      | 0                   | DIV, IDIV                              | Yes                                                        |
| Single step interrupt                       | 1                   | All                                    |                                                            |
| NMI interrupt                               | 2                   | All                                    |                                                            |
| Breakpoint interrupt                        | 3                   | INT                                    |                                                            |
| INTO detected overflow exception            | 4                   | INTO                                   | No                                                         |
| BOUND range exceeded exception              | 5                   | BOUND                                  | Yes                                                        |
| Invalid opcode exception                    | 6                   | Any undefined op-code                  | Yes                                                        |
| Processor extension not available exception | 7                   | ESC or WAIT                            | Yes                                                        |
| Reserved                                    | 8–15                | ····                                   |                                                            |
| Processor extension error input             | 16                  | ESC or WAIT                            |                                                            |
| Reserved                                    | 17–31               |                                        |                                                            |
| User-defined                                | 32-255              | ······································ |                                                            |

#### **Table 3. Interrupt Vector Assignments**

# Interrupt Priorities

When simultaneous interrupt requests occur, they are processed in a fixed order as shown in Table 4. Interrupt processing involves saving the flags, return address, and setting CS:IP to point at the first instruction of the interrupt handler. If other interrupts remain enabled, they are processed before the first instruction of the current interrupt handler is executed. The last interrupt processed is therefore the first one serviced.

| Table 4. Interrupt Processing Orde | Table 4. | Interrupt | Processing | Order |
|------------------------------------|----------|-----------|------------|-------|
|------------------------------------|----------|-----------|------------|-------|

| Order | Interrupt                           |
|-------|-------------------------------------|
| 1     | INT instruction or exception        |
| 2     | Single step                         |
| 3     | NMI                                 |
| 4     | Processor extension segment overrun |
| 5     | INTR                                |

# Initialization and Processor Reset

Processor initialization or start up is accomplished by driving the RESET input pin High. RESET forces the 80286 to terminate all execution and local bus activity. No instruction or bus activity will occur as long as RE-SET is active. After RESET becomes inactive and an internal processing interval elapses, the 80286 begins execution in real address mode with the instruction at physical location FFFFF0(H). RESET also sets some registers to predefined values as shown in Table 5.

#### Table 5. 80286 Initial Register State after RESET

| 0002(H) |
|---------|
| FFF0(H) |
| FFF0(H) |
| F000(H) |
| 0000(H) |
| 0000(H) |
| 0000(H) |
|         |

# Machine Status Word Description

The machine status word (MSW) records when a task switch takes place and controls the operating mode of the 80286. It is a 16-bit register of which the lower four bits are used. One bit places the CPU into protected mode, while the other three bits, as shown in Table 6, control the processor extension interface. After RESET, this register contains FFF0(H) which places the 80286 in iAPX 86 real address mode.

The LMSW and SMSW instructions can load and store the MSW in real address mode. The recommended use of TS, EM, and MP is shown in Table 7.

| Bit<br>Position | Name | Function                                                                                                                                                                                                               |
|-----------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0               | PE   | Protected mode Enable places the<br>80286 into protected mode and<br>cannot be cleared except by RESET.                                                                                                                |
| 1               | MP   | Monitor Processor extension allows<br>WAIT instructions to cause a<br>processor extension not present<br>exception (number 7).                                                                                         |
| 2               | EM   | Emulate processor extension causes<br>a processor extension not present<br>exception (number 7) on ESC<br>instructions to allow emulating a<br>processor extension.                                                    |
| 3               | TS   | Task Switched indicates the next<br>instruction using a processor<br>extension will cause exception 7,<br>allowing software to test whether the<br>current processor extension context<br>belongs to the current task. |

Table 6. MSW Bit Functions



| тѕ | МР | ЕМ | Recommended Use                                                                                                                                                                                                           | Instructions<br>Causing<br>Exception |
|----|----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|
| 0  | 0  | 0  | iAPX 86 real address mode only. Initial encoding after RESET. 80286 operation is identical to iAPX 86, 88.                                                                                                                | None                                 |
| 0  | 0  | 1  | No processor extension is available. Software will emulate its function.                                                                                                                                                  | ESC                                  |
| 1  | 0  | 1  | No processor extension is available. Software will emulate its function. The current processor extension context may belong to another task.                                                                              | ESC                                  |
| 0  | 1  | 0  | A processor extension exists.                                                                                                                                                                                             | None                                 |
| 1  | 1  | 0  | A processor extension exists. The current processor extension context may belong to<br>another task. The exception on WAIT allows software to test for an error<br>pending from a previous processor extension operation. | ESC or WAIT                          |

#### Table 7. Recommended MSW Encodings For Processor Extension Control

### Halt

The HLT instruction stops program execution and prevents the CPU from using the local bus until restarted. Either NMI, INTR with IF = 1, or RESET will force the 80286 out of halt. If interrupted, the saved CS:IP will point to the next instruction after the HLT.

### iAPX 286 Real Address Mode

The 80286 executes a fully upward-compatible superset of the 8086 instruction set in real address mode. In real address mode the 80286 is object code compatible with 8086 and 8088 software. The real address mode architecture (registers and addressing modes) is exactly as described in the 80286 Base Architecture section.

### **Memory Size**

Physical memory is a contiguous array of up to 1,048,576 bytes (one megabyte) addressed by pins  $A_0$  through  $A_{19}$  and BHE. A<sub>20</sub> through  $A_{23}$  are ignored.

### **Memory Addressing**

In real address mode the processor generates 20-bit physical addresses directly from a 20-bit segment base address and a 16-bit offset.

The selector portion of a pointer is interpreted as the upper 16 bits of a 20-bit segment address. The lower four bits of the 20-bit segment address are always zero. Segment addresses, therefore, begin on multiples of 16 bytes. See Figure 13 for a graphic representation of address formation.

All segments in real address mode are 64 kbytes in size and may be read, written, or executed. An exception or interrupt can occur if data operands or instructions attempt to wrap around the end of a segment (e.g., a word with its low order byte at offset FFFF(H) and its high order byte at offset 0000(H)). If, in real address mode, the information contained in a segment does not use the full 64 kbytes, the unused end of the segment may be overlaid by another segment to reduce physical memory requirements.

# **Reserved Memory Locations**

The 80286 reserves two fixed areas of memory in real address mode (see Figure 1): system initialization area and interrupt table area. Locations from addresses FFFF0(H) through FFFFF(H) are reserved for system initialization. Initial execution begins at location FFFF0 (H). Locations 00000(H) through 003FF(H) are reserved for interrupt vectors.



03552-12

#### Figure 13. iAPX 86 Real Address Mode Address Calculation



#### Figure 14. iAPX 86 Real Address Mode Initially Reserved Memory Locations

| Table 8. Real A                               | al Address Mode Addressing Interrupts |                                                                                                      |                                       |
|-----------------------------------------------|---------------------------------------|------------------------------------------------------------------------------------------------------|---------------------------------------|
| Function                                      | Interrupt<br>Number                   | Related<br>Instructions                                                                              | Return Address<br>Before Instruction? |
| Interrupt table limit too small exception     | 8                                     | INT vector is not within table limit                                                                 | Yes                                   |
| Processor extension segment overrun interrupt | 9                                     | ESC with memory operand extending<br>beyond offset FFFF(H)                                           | No No                                 |
| Segment overrun exception                     | 13                                    | Word memory reference with<br>offset = FFFF(H) or an attempt to<br>execute past the end of a segment | Yes                                   |

# Interrupts

Table 8 shows the interrupt vectors reserved for exceptions and interrupts which indicate an addressing error. The exceptions leave the CPU in the state existing before attempting to execute the failing instruction (except for PUSH, POP, PUSHA, or POPA). Refer to the next section on protected mode initialization for a discussion on exception 8.

# **Protected Mode Initialization**

To prepare the 80286 for protected mode, the LIDT instruction is used to load the 24-bit interrupt table base and 16-bit limit for the protected mode interrupt table. This instruction can also set a base and limit for the interrupt vector table in real address mode. After reset, the interrupt table base is initialized to 000000(H) and its size set to 03FF(H). These values are compatible with iAPX 86, 88 software. LIDT should only be executed in preparation for the protected mode.

### Shutdown

Shutdown occurs when a severe error is detected that prevents further instruction processing by the CPU. Shutdown and halt are externally signaled via a halt bus operation. They can be distinguished by A<sub>1</sub> High for halt and A<sub>1</sub> Low for shutdown. In real address mode, shutdown can occur under two conditions:

- Exceptions 8 or 13 happen and the IDT limit does not include the interrupt vector.
- A CALL, INT, or POP instruction attempts to wrap around the stack segment when SP is not even.

An NMI input can bring the CPU out of shutdown if the IDT limit is at least 000F(H) and SP is greater than 0005(H); otherwise, shutdown can only be exited via the RESET input.

# **Protected Virtual Address Mode**

The 80286 executes a fully upward-compatible superset of the 8086 instruction set in protected virtual address mode (protected mode). Protected mode also provides memory management and protection mechanisms and associated instructions.

The 80286 enters protected virtual address mode from real address mode by setting the PE (Protection Enable) bit of the machine status word with the Load Machine Status Word (LMSW) instruction. Protected mode offers

extended physical and virtual memory address space, memory protection mechanisms, and new operations to support operating systems and virtual memory.

All registers, instructions, and addressing modes described in the 80286 Base Architecture section remain the same. Programs for the iAPX 86, 88, 186, and real address mode 80286 can be run in protected mode; however, embedded constants for segment selectors are different.

# **Memory Size**

The protected mode 80286 provides a 1 gigabyte virtual address space per task mapped into a 16-megabyte physical address space defined by the address pin A<sub>23</sub>-A<sub>0</sub> and  $\overrightarrow{BHE}$ . The virtual address space may be larger than the physical address space since any use of an address that does not map to a physical memory location will cause a restartable exception.

# **Memory Addressing**

As in real address mode, protected mode uses 32-bit pointers, consisting of 16-bit selector and offset components. The selector, however, specifies an index into a memory resident table rather than the upper 16 bits of a real memory address.

The 24-bit base address of the desired segment is obtained from the tables in memory. The 16-bit offset is added to the segment base address to form the physical address as shown in Figure 15. The tables are automatically referenced by the CPU whenever a segment register is loaded with a selector. All 80286 instructions which load a segment register will reference the memorybased tables without additional software. The memorybased tables contain 8-byte values called descriptors.



Figure 15. Protected Mode Memory Addressing

# Descriptors

Descriptors define the use of memory. Special types of descriptors also define new functions for transfer of control and task switching. The 80286 has segment descriptors for code, stack and data segments, and system control descriptors for special system data segments and control transfer operations. Descriptor accesses are performed as locked bus operations to assure descriptor integrity in multi-processor systems.

# **Code and Data Segment Descriptors**

### (S = 1)

Besides segment base addresses, code and data descriptors contain other segment attributes, including segment size (1 to 64 kbytes), access rights (read-only, read/write, execute-only, and execute/read), and presence in memory (for virtual memory systems) (see Figure 16). Any segment usage violating a segment attribute indicate by the segment descriptor will prevent the memory cycle and cause an exception or interrupt.



<sup>\*</sup>Must be set to 0 for compatibility with iAPX 386.

Code and data are stored in two types of segments: code segments and data segments. Both types are identified and defined by segment descriptors. Code segments are identified by the executable (E) bit set to 1 in the descriptor access rights byte. The access rights byte of both code and data segment descriptor types have three fields in common: present (P) bit, Descriptor Privilege Level (DPL), and accessed (A) bit. If P = 0, any attempted use of this segment will cause a not-present exception. DPL specifies the privilege level of the segment descriptor. DPL controls when the descriptor may be used by a task (refer to privilege discussion). The A bit shows whether the segment has been previously accessed for usage profiling, a necessity for virtual memory systems. The CPU will always set this bit when accessing the descriptor.

Data segments (S = 1, E = 0) may be either read-only or read-write as controlled by the W bit of the access rights byte. Read-only (W = 0) data segments may not be written into. Data segments may grow in two directions, as determined by the Expansion Direction (ED) bit: upwards (ED = 0) for data segments, and downwards (ED = 1) for a segment containing a stack. The limit field for a data segment descriptor is interpreted differently depending on the ED bit (see Figure 16).

A code segment (S = 1, E = 1) may be execute-only or execute/read as determined by the Readable (R) bit. Code segments may never be written into and executeonly code segments (R = 0) may not be read. A code segment may also have an attribute called Conforming (C). A conforming code segment may be shared by programs that execute at different privilege levels. The DPL of a conforming code segment defines the range of privilege levels at which the segment may be executed (refer to privilege discussion).

# System Segment Descriptors (S = 0, Type 1–3)

In addition to code and data segment descriptors, the protected mode 80286 defines system segment descriptors. These descriptors define special system data

# Access Rights Byte Definition

segments which contain a table of descriptors (Local Descriptor Table Descriptor) or segments which contain the execution state of a task (Task State Segment Descriptor).

Figure 17 gives the formats for the special system data segment descriptors. The descriptors contain a 24-bit base address of the segment and a 16-bit limit. The access byte defines the type of descriptor, its state and privilege level. The descriptor contents are valid and the segment is in physical memory if P = 1. If P = 0, the segment is not valid. The DPL field is only used in Task State Segment descriptor may be used (see Privilege). Since the Local Descriptor Table descriptor may only be used by a special privilege instruction, the DPL field is not used. Bit 4 of the access byte is 0 to indicate that it is a system control descriptor. The Type field specifies the descriptor type as indicated in Figure 17.

|                     | Bit<br>Position | Name                                | Functio        | n                                                                                                                                                                     |
|---------------------|-----------------|-------------------------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | 7               | Present (P)                         | P = 1<br>P = 0 | Segment is mapped into physical memory.<br>No mapping to physical memory exists; base and limit are<br>not used. Segment privilege attribute used in privilege tests. |
|                     | 6–5             | Descriptor Privilege<br>Level (DPL) |                |                                                                                                                                                                       |
|                     | 4               | Segment Descriptor (S)              | S=1<br>S=0     | Code or Data segment descriptor<br>Non-segment descriptor                                                                                                             |
|                     | 3<br>2          | Executable (E)                      | E=0            | Data segment descriptor type is:                                                                                                                                      |
|                     | 2               | Expansion Direction                 |                | Grow up segment, offsets must be ≤ limit.                                                                                                                             |
|                     | 1               | (ED)<br>Writable (W)                |                | Grow down segment, offsets must be > limit.<br>Data segment may not be written into.<br>Data segment may be written into.                                             |
| Туре                | 3               | Executable (E)                      | E=1            | Code Segment Descriptor type is:                                                                                                                                      |
| Field<br>Definition | 2               | Conforming (C)                      | C=1            | Code segment may only be executed when<br>CPL≥DPL. Code                                                                                                               |
|                     | 1               | Readable (R)                        | R=0<br>R=1     | Code segment may not be read. Segment<br>Code segment may be read.                                                                                                    |
|                     | 0               | Accessed (A)                        | A = 0<br>A = 1 | Segment has not been accessed.<br>Segment selector has been loaded into segment register<br>or used by selector test instructions.                                    |

Figure 16. Code and Data Segment Descriptors

System Segment Descriptor



\*Must be set to 0 for compatibility with iAPX 386.

03552-16

#### System Segment Descriptor Fields

| Name  | Value                               | Description                                                                                                                                                                |
|-------|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Туре  | 0<br>1<br>2<br>3<br>4–7<br>8<br>9–F | Invalid Descriptor<br>Available Task State Segment<br>Local Descriptor Table Descriptor<br>Busy Task State Segment<br>Control Descriptor<br>Invalid Descriptor<br>Reserved |
| P     | 0<br>1                              | Descriptor contents are not valid<br>Descriptor contents are valid                                                                                                         |
| DPL   | 0–3                                 | Descriptor Privilege Level                                                                                                                                                 |
| Base  | 24-bit<br>number                    | Base Address of special system data segment in real memory                                                                                                                 |
| Limit | 16-bit<br>number                    | Offset of last byte in segment                                                                                                                                             |

#### Figure 17. System Segment Format

# Gate Descriptors (S = 0, Type = 4–7)

Gates are used to control access to entry points within the target code segment. The gate descriptors are call gates, task gates, interrupt gates and trap gates. Gates provide a level of indirection between the source and destination of the control transfer. This indirection allows the CPU to automatically perform protection checks and control the entry point of the destination. Call gates are used to change privilege levels (see Privilege); task gates are used to perform a task switch; and interrupt and trap gates are used to specify interrupt service routines. The interrupt gate disables interrupts (resets IF) while the trap gates does not.

Figure 18 shows the format of the gate descriptors. The descriptor contains a destination pointer that points to the descriptor of the target segment and the entry point offset. The destination selector in an interrupt gate, trap

gate, and call gate must refer to a code segment descriptor. These gate descriptors contain the entry point to prevent a program from constructing and using an illegal entry point. Task gates may only refer to a task state segment. Since task gates invoke a task switch, the destination offset is not used in the task gate.

Exception 13 is generated when the gate is used if a destination selector does not refer to the correct descriptor type. The Word Count field is used in the call gate descriptor to indicate the number of parameters (0–31 words) to be automatically copied from the caller's stack to the stack of the called routine when a control transfer changes privilege levels. The Word Count field is not used by any other gate descriptor.



\*Must be set to 0 for compatibility with iAPX 386.

#### **Gate Descriptor Fields**

| Name                  | Value            | Description                                                                                            |
|-----------------------|------------------|--------------------------------------------------------------------------------------------------------|
| Туре                  | 4<br>5<br>6<br>7 | Call Gate<br>Task Gate<br>Interrupt Gate<br>Trap Gate                                                  |
| Ρ                     | 0<br>1           | Descriptor Contents are not valid<br>Descriptor Contents are valid                                     |
| DPL                   | 0–3              | Descriptor Privilege Level                                                                             |
| Word<br>Count         | 0–31             | Number of words to copy from<br>callers stack to called procedures<br>stack. Only used with call gate. |
| Destination segment   | 16-bit           | Selector to the target code                                                                            |
| Selector              | selector         | (Call, Interrupt or Trap Gate)<br>Selector to the target task state<br>segment (Task Gate)             |
| Destination<br>Offset | 16-bit<br>offset | Entry point within the target code segment                                                             |

#### Figure 18. Gate Descriptor Format

The access byte format is the same for all gate descriptors. P = 1 indicates that the gate contents are valid. P = 0 indicates the contents are not valid and causes exception 11 if referenced. DPL is the Descriptor Privilege Level and specifies when this descriptor may be used by a task (refer to privilege discussion). Bit 4 must equal 0 to indicate a system control descriptor. The Type field specifies the descriptor type as indicated in Figure 18.

# **Segment Descriptor Cache Registers**

A segment descriptor cache register is assigned to each of the four segment registers (CS, SS, DS, ES). Segment descriptors are automatically loaded (cached) into a segment descriptor cache register (Figure 20) whenever the associated segment register is loaded with a selector. Only segment descriptors may be loaded into segment descriptor cache registers. Once loaded, all references to that segment of memory use the cached descriptor information instead of reaccessing memory. The descriptor cache registers are not visible to programs. No instructions exist to store their contents. They only change when a segment register is loaded.

# Selector Fields

A protected mode selector has three fields: descriptor entry index, local or global descriptor table indicator (TI), and selector privilege (RPL), as shown in Figure 19. These fields select one of two memory-based tables of descriptors, select the appropriate table entry, and allow high-speed testing of the selector's privilege attribute (refer to privilege discussion).







Figure 20. Descriptor Cache Registers

### Local and Global Descriptor Tables

Two tables of descriptors, called descriptor tables, contain all descriptors accessible by a task at any given time. A descriptor table is a linear array of up to 8192 descriptors. The upper 13 bits of the selector value are an index into a descriptor table. Each table has a 24-bit base register to locate the descriptor table in physical memory and a 16-bit limit register that confines descriptor access to the defined limits of the table as shown in Figure 21. A restartable exception (13) will occur if an attempt is made to reference a descriptor outside the table limits.

One table, called the Global Descriptor Table (GDT), contains descriptors available to all tasks. The other table, called the Local Descriptor Table (LDT), contains descriptors that can be private to a task. Each task may have its own private LDT. The GDT may contain all descriptor types except interrupt and trap descriptors. The LDT may contain only segment, task gate, and call gate descriptors. A segment cannot be accessed by a task if its segment descriptor does not exist in either descriptor table at the time of access.

The LGDT and LLDT instructions load the base and limit of the global and local descriptor tables. LGDT and

LLDT are protected. They may only be executed by trusted programs operating at level 0. The LGDT instruction loads a six-byte field containing the 16-bit table limit and 24-bit base address of the Global Descriptor Table as shown in Figure 22. The LLDT instruction loads a selector which refers to a descriptor in the Local Descriptor Table. This descriptor contains the base address and limit for an LDT, as shown in Figure 21.

# Interrupt Descriptor Table

The protected mode 80286 has a third descriptor table, called the Interrupt Descriptor Table (IDT) (see Figure 23), used to define up to 256 interrupts. It may contain only task gates, interrupt gates and trap gates. The IDT (Interrupt Descriptor Table) has a 24-bit base and 16-bit limit register in the CPU. The protected LIDT instruction loads these registers with a six-byte value of identical form to that of the LGDT instruction (see Figure 22 and Protected Mode Initialization).

References to IDT entries are made via INT instructions, external interrupt vectors, or exceptions. The IDT must be at least 256 bytes in size to allocate space for all reserved interrupts.



03552-19

Figure 21. Local and Global Descriptor Table Definitions



\*Must be set to 0 for compatibility with iAPX 386.

Figure 22. Global Descriptor Table and Interrupt Descriptor Data Types



Figure 23. Interrupt Descriptor Table Definition

# Privilege

The 80286 has a four-level hierarchical privilege system which controls the use of privileged instructions and access to descriptors (and their associated segments) within a task. Four-level privilege, as shown in Figure 24, is an extension of the user/supervisor mode commonly found in minicomputers. The privilege levels are numbered 0 through 3. Level 0 is the most privileged level. Privilege levels provide protection *within* a task. (Tasks are isolated by providing private LDT's for each task.) Operating system routines, interrupt handlers, and other system software can be included and protected within the virtual address space of each task using the four levels of privilege. Tasks may also have a separate stack for each privilege level.

Tasks, descriptors, and selectors have a privilege level attribute that determines whether the descriptor may be used. Task privilege effects the use of instructions and descriptors. Descriptor and selector privilege only effect access to the descriptor.

#### **Task Privilege**

The task always executes at one of the four privilege levels. A task privilege level at any specific instant is called the Current Privilege Level (CPL) and is defined by the lower two bits of the CS register. CPL cannot change during execution in a single code segment. A task's CPL may only be changed by control transfers through gate descriptors to a new code segment (See Control Transfer). Tasks begin executing at the CPL value specified by the code segment when the task is initiated via a task switch operation. A task executing at Level 0 can access all data segments defined in the GDT and the task's LDT and is considered the most trusted level. A task executed at Level 3 has the most trusted level.

#### **Descriptor Privilege**

Descriptor privilege is specified by the Descriptor Privilege Level (DPL) field of the descriptor access byte. DPL specifies the least trusted privilege level (CPL) at which a task may access the descriptor. Descriptors with DPL = 0 are the most protected. Only tasks executing at privilege level 0 (CPL = 0) may access them. Descriptors with DPL = 3 are the least protected (i.e., have the least restricted access) since tasks can access them when CPL = 0, 1, 2, or 3. This rule applies to all descriptors, except LDT descriptors.

#### Selector Privilege

Selector privilege is specified by the Requested Privilege Level (RPL) field in the least significant two bits of a selector. Selector RPL may establish a less trusted privilege level than the current privilege level for the use of a selector. This level is called the task's effective privilege level (EPL). RPL can only reduce the scope of a task's access to data with this selector. A task's effective privilege is the numeric maximum of RPL and CPL. A selector with RPL = 0 imposes no additional restriction on its use while a selector with RPL = 3 can only refer to segments at privilege Level 3 regardless of the task's



Figure 24. Hierarchical Privilege Levels

CPL. RPL is generally used to verify that pointer parameters passed to a more trusted procedure are not allowed to use data at a more privileged level than the caller (refer to pointer testing instructions).

# Descriptor Access and Privilege Validation

Determining the ability of a task to access a segment involves the type of segment to be accessed, the instruction used, the type of descriptor used and CPL, RPL, and DPL. The two basic types of segment accesses are control transfer (selectors loaded into CS) and data (selectors loaded into DS, ES, or SS).

#### **Data Segment Access**

Instructions that load selectors into DS and ES must refer to a data segment descriptor or readable code segment descriptor. The CPL of the task and the RPL of the selector must be the same as or more privileged (numerically equal to or lower than) than the descriptor DPL. In general, a task can only access data segments at the same or less privileged levels than the CPL or RPL (whichever is numerically higher) to prevent a program from accessing data it cannot be trusted to use.

An exception to the rule is a readable conforming code segment. This type of code segment can be read from any privilege level.

If the privilege checks fail (e.g., DPL is numerically less than the maximum of CPL and RPL) or an incorrect type of descriptor is referenced (e.g., gate descriptor or execute only code segment), exception 13 occurs. If the segment is not present, exception 11 is generated.

Instructions that load selectors into SS must refer to data segment descriptors for writable data segments. The descriptor privilege (DPL) and RPL must equal CPL.

All other descriptor types or privilege level violation will cause exception 13. A not-present fault causes exception 12.

#### **Control Transfer**

Four types of control transfer can occur when a selector is loaded into CS by a control transfer operation (see Table 9). Each transfer type can only occur if the operation which loaded the selector references the correct descriptor type. Any violation of these descriptor usage rules (e.g., JMP through a call gate or RET to a Task State Segment) will cause exception 13.

The ability to reference a descriptor for control transfer is also subject to rules of privilege. A CALL or JUMP instruction may only reference a code segment descriptor with DPL equal to the task CPL or a conforming segment with DPL of equal or greater privilege than CPL. The RPL of the selector used to reference the code descriptor must have as much privilege as CPL.

RET and IRET instructions may only reference code segment descriptors with descriptor privilege equal to or less privileged than the task CPL. The selector loaded into CS is the return address from the stack. After the return, the selector RPL is the task's new CPL. If CPL changes, the old stack pointer is popped after the return address.

When a JMP or CALL references a Task State Segment descriptor, the descriptor DPL must be the same or less privileged than the task's CPL. Reference to a valid Task State Segment descriptor causes a task switch (see Task Switch Operation). Reference to a Task State Segment descriptor at a more privileged level than the task's CPL generates exception 13.

When an instruction or interrupt references a gate descriptor, the gate DPL must have the same or less privilege than the task CPL. If DPL is at a more privileged level than CPL, exception 13 occurs. If the destination

| Control Transfer Types                                     | Operation Types                                                      | Descriptor<br>Referenced  | Descriptor<br>Table |
|------------------------------------------------------------|----------------------------------------------------------------------|---------------------------|---------------------|
| Intersegment within the same privilege level               | JMP, CALL, RET, IRET*                                                | Code Segment              | GDT/LDT             |
| Intersegment to the same or higher privilege level         | CALL                                                                 | Call Gate                 | GDT/LDT             |
| Interrupt within task may change CPL                       | Interrupt Instruction,<br>Exception, External<br>Interrupt           | Trap or Interrupt<br>Gate | IDT                 |
| Intersegment to a lower privilege level (changes task CPL) | RET, IRET*                                                           | Code Segment              | GDT/LD1             |
| Task Switch                                                | CALL, JMP                                                            | Task State Segment        | GDT                 |
|                                                            | CALL, JMP                                                            | Task Gate                 | GDT/LDT             |
|                                                            | IRET**<br>Interrupt Instruction,<br>Exception, External<br>Interrupt | Task Gate                 | IDT                 |

Table 9. Descriptor Types Used for Control Transfer

\* NT (Nested Task bit of flag word) = 0

\*\* NT (Nested Task bit of flag word) = 1

# 

selector contained in the gate references a code segment descriptor, the code segment descriptor DPL must be the same or more privileged than the task CPL. If not, Exception 13 is issued. After the control transfer, the code segment descriptor DPL is the task's new CPL. If the destination selector in the gate references a task state segment, a task switch is automatically performed (see Task Switch Operation).

The privilege rules on control transfer require:

- JMP or CALL direct to a code segment (code segment descriptor) can only be to a conforming segment with DPL of equal or greater privilege than CPL or a non-conforming segment at the same privilege level.
- interrupts within the task or calls that may change privilege levels can only transfer control through a gate at the same or a less privileged level than CPL to a code segment at the same or more privileged level than CPL.
- return instructions that don't switch tasks can only return control to a code segment at the same or less privileged level.
- task switch can be performed by a call, a jump or an interrupt which references either a task gate or task state segment at the same or less privileged level.

# **Privilege Level Changes**

Any control transfer that changes CPL within the task causes a change of stacks as part of the operation. Initial values of SS:SP for privilege levels 0, 1, and 2 are kept in the task state segment (refer to Task Switch Operation). During a JMP or CALL control transfer, the new stack pointer is loaded into the SS and SP registers and the previous stack pointer is pushed onto the new stack.

When returning to the original privilege level, its stack is restored as part of the RET or IRET instruction operation. For subroutine calls that pass parameters on the stack and cross privilege levels, a fixed number of words, as specified in the gate, are copied from the previous stack to the current stack. The intersegment RET instruction with a stack adjustment value will correctly restore the previous stack pointer upon return.

# Protection

The 80286 includes mechanisms to protect critical instructions that affect the CPU execution state (e.g., HLT) and code or data segments from improper usage. These mechanisms are grouped under the term "protection" and have three forms:

 Restricted usage of segments (e.g., no write allowed to read-only data segments). The only segments available for use are defined by descriptors in the Local Descriptor Table (LDT) and Global Descriptor Table (GDT).

- Restricted access to segments via the rules of privilege and descriptor usage.
- Privileged instructions or operations that may only be executed at certain privilege levels as determined by the CPL and I/O Privilege Level (IOPL). The IOPL is defined by bits 14 and 13 of the flag word.

These checks are performed for all instructions and can be split into three categories: segment load checks (Table 10), operand reference checks (Table 11), and privileged instruction checks (Table 12). Any violation of the rules shown will result in an exception. A not-present exception related to the stack segment causes exception 12.

The IRET and POPF instructions do not perform some of their defined functions if CPL is not of sufficient privilege (numerically small enough). Precisely, these are:

- The IF bit is not changed if CPL > IOPL.
- The IOPL field of the flag word is not changed if CPL > 0.

No exceptions or other indication are given when these conditions occur.

| Error Description                                                                                                                                                                                                                                                                                                            | Exception<br>Number |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| Descriptor table limit exceeded                                                                                                                                                                                                                                                                                              | 13                  |
| Segment descriptor not present                                                                                                                                                                                                                                                                                               | 11 or 12            |
| Privilege rules violated                                                                                                                                                                                                                                                                                                     | 13                  |
| <ul> <li>Invalid descriptor/segment type segment<br/>register load:</li> <li>Read only data segment load to SS</li> <li>Special control descriptor load to DS,<br/>ES, SS</li> <li>Execute only segment load to DS, ES,<br/>SS</li> <li>Data segment load to CS</li> <li>Read/Execute code segment load<br/>to SS</li> </ul> | 13                  |

#### Table 11. Operand Reference Checks

| Error Description                   | Exception<br>Number |
|-------------------------------------|---------------------|
| Write into code segment             | 13                  |
| Read from execute-only code segment | 13                  |
| Write to read-only data segment     | 13                  |
| Segment limit exceeded              | 12 or 13            |

Note: Carry out in offset calculations is ignored.

| Table 12. Privileged Instruction Checks                                                         |                     |
|-------------------------------------------------------------------------------------------------|---------------------|
| Error Description                                                                               | Exception<br>Number |
| CPL≠0 when executing the following<br>instructions:<br>LIDT, LLDT, LGDT, LTR, LMSW,<br>CTS, HLT | 13                  |
| CPL > IOPL when executing the following<br>instructions:<br>INS, IN, OUTS, OUT, STI, CLI, LOCK  | 13                  |

# Exceptions

The 80286 detects several types of exceptions and interrupts in protected mode (see Table 13). Most are restartable after the exceptional condition is removed. Interrupt handlers for most exceptions receive an error code, pushed on the stack after the return address, that identifies the selector involved (0 if none). The return address normally points to the failing instruction, including all leading prefixes. For a processor extension segment overrun exception, the return address will not point at the ESC instruction that caused the exception; however, the processor extension registers may contain the address of the failing instruction.

# **Special Operations**

#### **Task Switch Operation**

The 80286 provides a built-in task switch operation which saves the entire 80286 execution state (registers, address space, and a link to the previous task), loads a new execution state, and commences execution in the new task. Like gates, the task switch operation is invoked by executing an inter-segment JMP or CALL instruction which refers to a Task State Segment (TSS) or task gate descriptor in the GDT or LDT. An INT n instruction, exception, or external interrupt may also invoke the task switch operation by selecting a task gate descriptor in the associated IDT descriptor entry.

The TSS descriptor points at a segment (see Figure 25) containing the entire 80286 execution state while a task gate descriptor contains a TSS selector. The limit field must be > 002B(H).

Each task must have a TSS associated with it. The current TSS is identified by a special register in the 80286 called the Task Register (TR). This register contains a selector referring to the task state segment descriptor that defines the current TSS. A hidden base and limit register associated with TR are loaded whenever TR is loaded with a new selector.

The IRET instruction is used to return control to the task that called the current task or was interrupted. Bit 14 in the flag register is called the Nested Task(NT) bit. It controls the function of the IRET instruction. If NT=0, the IRET instruction performs the regular current task return; when NT = 1, IRET performs a task switch operation back to the previous task.

When a CALL or INT instruction initiates a task switch, the old and new TSS will be marked busy and the back link field of the new TSS set to the old TSS selector. The NT bit of the new task is set by CALL or INT initiated task switches. An interrupt that does not cause a task switch will clear NT. NT may also be set or cleared by POPF or IRET instructions.

The task state segment is marked busy by changing the descriptor type field from Type 1 to Type 3. Use of a selector that references a busy task state segment causes Exception 13.

| Interrupt<br>Vector | Function                                     | Return Address<br>At Failing<br>Instruction? | Always<br>Restartable? | Error<br>Code<br>on Stack? |
|---------------------|----------------------------------------------|----------------------------------------------|------------------------|----------------------------|
| 8                   | Double exception detected                    | Yes                                          | No <sup>2</sup>        | Yes                        |
| 9                   | Processor extension segment overrun          | No                                           | No²                    | No                         |
| 10                  | Invalid task state segment                   | Yes                                          | Yes                    | Yes                        |
| 11                  | Segment not present                          | Yes                                          | Yes                    | Yes                        |
| 12                  | Stack segment overrun or segment not present | Yes                                          | Yes <sup>1</sup>       | Yes                        |
| 13                  | General protection                           | Yes                                          | No <sup>2</sup>        | Yes                        |

#### Table 13. Protected Mode Exceptions

#### Notes:

- 1. When a PUSHA or POPA instruction attempts to wrap around the stack segment, the machine state after the exception will not be restartable because stack segment wraparound is not permitted. This condition is identified by the value of the saved SP being either 0000(H), 0001(H), FFFE(H), or FFFF(H).
- These exceptions indicate a violation to privilege rules or usage rules has occurred. Restart is generally not attempted under those conditions.
- 3. All these checks are performed for all instructions and can be split into three categories: Segment Load Checks (Table 10), Operand Reference Checks (Table 11), and Privileged Instruction Checks (Table 12). Any violation of the rules shown will result in an exception. A not-present exception causes exception 11 or 12 and is restartable.



00002 2

Figure 25. Task State Segment and TSS Registers

# **Processor Extension Context Switching**

The context of a processor extension is not changed by the task switch operation. A processor extension context need only be changed when a different task attempts to use the processor extension (which still contains the context of a previous task). The 80286 detects the first use of a processor extension after a task switch by causing the processor extension not present exception (7). The interrupt handler may then decide whether a context change is necessary.

Whenever the 80286 switches tasks, it sets the Task Switched (TS) bit of the MSW. TS indicates that a processor extension context may belong to a different task than the current one. The processor extension not present exception (7) will occur when attempting to execute an ESC or WAIT instruction if TS = 1 and a processor extension is present (MP = 1 in MSW).

# **Pointer Testing Instructions**

The 80286 provides several instructions to speed pointer testing and consistency checks for maintaining system integrity (see Table 14). These instructions use the memory management hardware to verify that a selector value refers to an appropriate segment without risking an exception. A condition flag indicates whether use of the selector or segment will cause an exception.

| Instruction | Operands              | Function                                                                                                                                                                                           |
|-------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ARPL        | Selector,<br>Register | Adjust Requested Privilege<br>Level: adjusts the RPL of the<br>selector to the numeric maxi-<br>mum of current selector RPL<br>value and the RPL value in the<br>register. Set zero flag if selec- |
|             | Selector              | tor RPL was changed.                                                                                                                                                                               |
| VERR        | Selector              | VERify for Read: sets the zero<br>flag is the segment referred to<br>by the selector can be read.                                                                                                  |
| VERW        | Register,<br>Selector | VERify for Write: sets the zero<br>flag if the segment referred to<br>by the selector can be written.                                                                                              |
| LSL         |                       | Load Segment Limit: reads<br>the segment limit into the reg-<br>ister if privilege rules and de-<br>scriptor type allow. Set zero<br>flag if successful.                                           |
| LAR         | Register,<br>Selector | Load Access Rights: reads<br>the descriptor access rights<br>byte into the register if privi-<br>lege rules allow. Set zero<br>flag if successful.                                                 |

#### **Table 14. Pointer Test Instructions**

# **Double Fault and Shutdown**

If two separate exceptions are detected during a single instruction execution, the 80286 performs the double fault exception (8). If an exception occurs during processing of the double fault exception, the 80286 will enter shutdown. During shutdown no further instructions or exceptions are processed. Either NMI (CPU remains in protected mode) or RESET (CPU exits protected mode) can force the 80286 out of shutdown. Shutdown is externally signaled via a HALT bus operation with A<sub>1</sub> High.

# **Protected Mode Initialization**

The 80286 initially executes in real address mode after RESET. To allow initialization code to be placed at the top of physical memory, A<sub>23-20</sub> will be High when the 80286 performs memory references relative to the CS register, until CS is changed. A<sub>23-20</sub> will be zero for references to the DS, ES, or SS segments. Changing CS in real address mode will force A<sub>23-20</sub> Low whenever using CS thereafter. The initial CS:IP value of FFOO:FFFO provides 64K bytes of code space for initialization code without changing CS.

Before placing the 80286 into protected mode, several registers must be initialized. The GDT and IDT base registers must refer to a valid GDT and IDT. After executing the LMSW instruction to set PE, the 80286 must immediately execute an intrasegment JMP instruction to clear the instruction queue of instructions decoded in real address mode.

To force the 80286 CPU registers to match the initial protected mode state assumed by software, execute a JMP instruction with a selector referring to the initial TSS used in the system. This will load the task register, local descriptor table register, segment registers and initial general register state. The TR should point at a valid TSS since a task switch operation involves saving the current

# System Interface

The 80286 system interface appears in two forms: a local bus and a system bus. The local bus consists of address, data, status, and control signals at the pins of the CPU. A system bus is any buffered version of the local bus. A system bus may also differ from the local bus in terms of coding of status and control lines and/or timing and loading of signals. The 80286 family includes several devices to generate standard system buses such as the IEEE 796 Standard MULTIBUS.

# **Bus Interface Signals and Timing**

The 80286 microsystem local bus interfaces the 80286 to local memory and I/O components. The interface has 24 address lines, 16 data lines, and 8 status and control signals.

The 80286 CPU, 82284 clock generator, 82C288 bus controller, 82289 bus arbiter, 8286/7 transceivers, and 8282/3 latches provide a buffered and decoded system bus interface. The 82284 generates the system clock and synchronizes READY and RESET. The 82C288 converts bus operation status encoded by the 80286 into command and bus control signals. These components can provide the timing and electrical power drive levels required for most system bus interfaces including the MULTIBUS.

# Physical Memory and I/O Interface

A maximum of 16 megabytes of physical memory can be addressed in protected mode. One megabyte can be addressed in real address mode. Memory is accessible as bytes or words. Words consist of any two consecutive bytes addressed with the least significant byte stored in the lowest address.

Byte transfers occur on either half of the 16-bit local data bus. Even bytes are accessed over  $D_{7-0}$  while odd bytes are transferred over  $D_{15-0}$ . Even-addressed words are transferred over  $D_{15-0}$  in one bus cycle, while odd-addressed words require *two* bus operations. The first transfers data on  $D_{15-0}$ , and the second transfers data on  $D_{7-0}$ . Both byte data transfers occur automatically, transparent to software.

Two bus signals,  $A_0$  and  $\overline{BHE}$ , control transfers over the lower and upper halves of the data bus. Even address byte transfers are indicated by  $A_0$  Low and  $\overline{BHE}$  High. Odd address byte transfers are indicated by  $A_0$  High and  $\overline{BHE}$  Low. Both  $A_0$  and  $\overline{BHE}$  are Low for even address word transfers.

The I/O address space contains 64K addresses in both modes. The I/O space is accessible as either bytes or words, as is memory. Byte-wide peripheral devices may be attached to either the upper or lower byte of the data bus. Byte-wide I/O devices attached to the upper data byte ( $D_{15-8}$ ) are accessed with odd I/O addresses. Devices on the lower data byte are accessed with even I/O addresses. An interrupt controller such as the 8259A must be connected to the lower data byte ( $D_{7-0}$ ) for proper return of the interrupt vector.

# **Bus Operation**

The 80286 uses a double-frequency system clock (CLK input) to control bus timing. All signals on the local bus are measured relative to the system CLK input. The CPU divides the system clock by 2 to produce the internal processor clock, which determines bus state. Each processor clock is composed of two system clock cycles named phase 1 and phase 2. The 82284 clock generator output (PCLK) identifies the next phase of the processor clock. (See Figure 26.)

Six types of bus operations are supported: memory read, memory write, I/O read, I/O write, interrupt acknowledge, and halt/shutdown. Data can be transferred at a maximum rate of one word per two processor clock cycles.

The 80286 bus has three basic states: idle (Ti), send status (Ts), and perform command (Tc). The 80286 CPU also has a fourth local bus state called hold (Th). Th indicates that the 80286 has surrendered control of the local bus to another bus master in response to a HOLD request.

Each bus state is one processor clock long. Figure 27 shows the four 80286 local bus states and allowed transitions.

### **Bus States**

The idle (Ti) state indicates that no data transfers are in progress or requested. The first active state, Ts, is signaled by either status line  $\overline{S1}$  or  $\overline{S0}$  going Low also identifying phase 1 of the processor clock. During Ts, the command encoding, the address, and data (for a write operation) are available on the 80286 output pins. The 82C288 bus controller decodes the status signals and generates MULTIBUS-compatible read/write command and local transceiver control signals.

After Ts, the perform command (Tc) state is entered. Memory or I/O devices respond to the bus operation during Tc, either transferring read data to the CPU or accepting write data. Tc states may be repeated as often as necessary to assure sufficient time for the memory or I/O device to respond. The READY signal determines whether Tc is repeated. A repeated Tc state is called a wait state.

During hold (Th), the 80286 will float all address, data, and status output pins, enabling another bus master to use the local bus. The 80286 HOLD input signal is used to place the 80286 into the Th state. The 80286 HLDA output signal indicates that the CPU has entered Th.

# **Pipelined Addressing**

The 80286 uses a local bus interface with pipelined timing to allow as much time as possible for data access.



03552-24

Figure 26. System and Processor Clock Relationships



Figure 27. 80286 Bus States

Pipelined timing allows bus operations to be performed in two processor cycles, while allowing each individual bus operation to last for three processor cycles.

The timing of the address outputs is pipelined such that the address of the next bus operation becomes available during the current bus operation. Or in other words, the first clock of the next bus operation is overlapped with the last clock of the current bus operation. Therefore, address decode and routing logic can operate in advance of the next bus operation. External address latches may hold the address stable for the entire bus operation and provide additional AC and DC buffering.

The 80286 does not maintain the address of the current bus operation during all Tc states. Instead, the address for the next bus operation may be emitted during phase 2 of any Tc. The address remains valid during phase 1 of the first Tc to guarantee hold time, relative to ALE, for the address latch inputs.



Pipelining: valid address (N+1) available in last phase of bus cycle (N).

03552-26



# **Bus Control Signals**

The 82C288 bus controller provides control signals: address latch enable (ALE), Read/Write commands, data transmit/receive ( $DT/\overline{R}$ ), and data enable (DEN) that control the address latches, data transceivers, write enable, and output enable for memory and I/O systems.

The Address Latch Enable (ALE) output determines when the address may be latched. ALE provides at least one system CLK period of address hold time from the end of the previous bus operation until the address for the next bus operation appears at the latch outputs. This address hold time is required to support MULTIBUS and common memory systems.

The data bus transceivers are controlled by 82C288 outputs Data Enable (DEN) and Data Transmit/Receive (DT/ $\overline{R}$ ). DEN enables the data transceivers while DT/ $\overline{\overline{R}}$  controls transceiver direction. DEN and DT/ $\overline{\overline{R}}$  are timed to prevent bus contention between the bus master, data bus transceivers, and system data bus transceivers.

### **Command Timing Controls**

Two system timing customization options, command extension and command delay, are provided on the 80286 local bus.

Command extension allows additional time for external devices to respond to a command and is analogous to inserting wait states on the 80286. External logic can control the duration of any bus operation such that the operation is only as long as necessary. The READY input signal can extend any bus operation for as long as necessary.

Command delay allows an increase of address or write data set-up time to system bus command active for any bus operation by delaying when the system bus command becomes active. Command delay is controlled by the 82C288 CMDLY input. After Ts, the bus controller samples CMDLY at each failing edge of CLK. If CMDLY is High, the 82C288 will not activate the command signal. When CMDLY is Low, the 82C288 will activate the command signal. After the command becomes active, the CMDLY input is not sampled.

When a command is delayed, the available response time from command active to return read data or accept write data is less. To customize system bus timing, an address decoder can determine which bus operations require delaying the command. The CMDLY input does not affect the timing of ALE, DEN, or  $DT/\overline{R}$ .

Figure 29 illustrates four uses of CMDLY. Example 1 shows delaying the read command two system CLKs for cycle N-1 and no delay for cycle N, and example 2 shows delaying the read command one system CLK for cycle N-1 and one system CLK delay for cycle N.

# **Bus Cycle Termination**

At maximum transfer rates, the 80286 bus alternates between the status and command states. The bus status signals become inactive after Ts so that they may correctly signal the start of the next bus operation after the completion of the current cycle. No external indication of Tc exists on the 80286 local bus. The bus master and bus controller enter Tc directly after Ts and continue executing Tc cycles until terminated by READY.



03552-27

Figure 29. CMDLY Controls and Leading Edge of the Command

# **READY** Operation

The current bus master and 82C288 bus controller terminate each bus operation simultaneously to achieve maximum bus bandwidth. Both are informed in advance by  $\overline{\text{READY}}$  active which identifies the last Tc cycle of the current bus operation. The bus master and bus controller must see the same sense of the  $\overline{\text{READY}}$  signal, thereby requiring  $\overline{\text{READY}}$  be synchronous to the system clock.

# Synchronous Ready

The 82284 clock generator provides  $\overline{READY}$  synchronization from both synchronous and asynchronous sources (see Figure 30). The synchronous ready input (SRDY) of the clock generator is sampled with the falling edge of CLK at the end of phase 1 of each Tc. The state of SRDY is then broadcast to the bus master and bus controller via the READY output line.

# Asynchronous Ready

Many systems have devices or subsystems that are asynchronous to the system clock. As a result, their ready outputs cannot be guaranteed to meet the 82284 SRDY set-up and hold time requirements. The 82284 asynchronous ready input ( $\overline{\text{ARDY}}$ ) is designed to accept such signals. The  $\overline{\text{ARDY}}$  input is sampled at the beginning of each Tc cycle by 82284 synchronization logic. This provides a system CLK cycle time to resolve its value before broadcasting it to the bus master and bus controller.

ARDY or ARDYEN must be High at the end of Ts. ARDY cannot be used to terminate bus cycle with no wait status.

Each ready input of the 82284 has an enable pin (SRDYEN and ARDYEN) to select whether the current bus operation will be terminated by the synchronous or asynchronous ready. Either of the ready inputs may terminate a bus operation. These enable inputs are active low and have the same timing as their respective ready inputs. Address decode logic usually selects whether the current bus operation should be terminated by ARDY or SRDY.

# **Data Bus Control**

Figures 31, 32, and 33 show how the  $DT/\overline{R}$ , DEN, data bus, and address signals operate for different combinations of read, write, and idle bus operations.  $DT/\overline{R}$  goes



- 2. If SRDYEN is High, the state of SRDY will not affect READY.
- 3. ARDYEN is active Low.

### Figure 30. Synchronous and Asynchronous Ready

active (Low) for a read operation. DT/R remains High before, during, and between write operations.

The data bus is driven with write data during the second phase of Ts. The delay in write data timing allows the read data drivers, from a previous read cycle, sufficient time to enter three-state OFF before the 80286 CPU begins driving the local data bus for write operations. Write data will always remain valid for one system clock past the last Tc to provide sufficient hold time for MULTI-BUS or other similar memory or I/O systems. During write-read or write-idle sequences, the data bus enters three-state OFF during the second phase of the processor cycle after the last Tc. In a write-write sequence the data bus does not enter three-state OFF between Tc and Ts.

# **Bus Usage**

The 80286 local bus may be used for several functions: instruction data transfers, data transfers by other bus masters, instruction fetching, processor extension data transfers, interrupt acknowledge, and halt/shutdown. This section describes local bus activities which have special signals or requirements.

# HOLD and HLDA

HOLD and HLDA allow another bus master to gain control of the local bus by placing the 80286 bus into the  $T_h$  state. The sequence of events required to pass control

between the 80286 and another local bus master are shown in Figure 34.

In this example, the 80286 is initially in the T<sub>h</sub>, state as signaled by HLDA being active. Upon leaving T<sub>h</sub>, as signaled by HLDA going inactive, a write operation is started. During the write operation another local bus master requests the local bus from the 80286 as shown by the HOLD signal. After completing the write operation, the 80286 performs one T<sub>i</sub> bus cycle, to guarantee write data hold time, then enters T<sub>h</sub> as signaled by HLDA going active.

The CMDLY signal and ARDY ready are used to start and stop the write bus command, respectively. Note that SRDY must be inactive or disabled by SRDYEN to guarantee ARDY will terminate the cycle.

HOLD must not be active during the time from the leading edge of RESET until 34 CLKs following the trailing edge of RESET unless the 80286 is in the Halt condition. To ensure that the 80286 remains in the Halt condition until the processor Reset operation is complete, no interrupts should occur after the execution of HLT until 34 CLKs after the trailing edge of the RESET pulse.

### Lock

The CPU asserts an active lock signal during Interrupt-Acknowledge cycles, the XCHG instruction, and during some descriptor accesses. Lock is also asserted when



Figure 31. Back-to-Back Read-Write Cycles

the LOCK prefix is used. The LOCK prefix may be used with the following ASM-286 assembly instructions; MOVS, INS, and OUTS. For bus cycles other than Interrupt-Acknowledge cycles, Lock will be active for the first and subsequent cycles of a series of cycles to be locked. Lock will not be shown active during the last cycle to be locked. For the next-to-last cycle, Lock will become inactive at the end of the first Tc regardless of the number of wait-states inserted. For Interrupt-Acknowledge cycles, Lock will be active for each cycle, and will become inactive at the end of the first Tc for each cycle regardless of the number of wait-states inserted.

# Instruction Fetching

The 80286 Bus Unit (BU) will fetch instructions ahead of the current instruction being executed. This activity is called prefetching. It occurs when the local bus would otherwise be idle and obeys the following rules:

A prefetch bus operation starts when at least two bytes of the 6-byte prefetch queue are empty.

The prefetcher normally performs word prefetches independent of the byte alignment of the code segment base in physical memory. The prefetcher will perform only a byte code fetch operation for control transfers to an instruction beginning on a numerically odd physical address.

Prefetching stops whenever a control transfer or HLT instruction is decoded by the IU and placed into the instruction queue.

In real address mode, the prefetcher may fetch up to 5 bytes beyond the last control transfer or HLT instruction in a code segment.

In protected mode, the prefetcher will never cause a segment overrun exception. The prefetcher stops at the last physical memory word of the code segment. Exception 13 will occur if the program attempts to execute beyond the last full instruction in the code segment.

If the last byte of a code segment appears on an even physical memory address, the prefetcher will read the next physical byte of memory (perform a word code fetch). The value of this byte is ignored and any attempt to execute it causes exception 13. 

Figure 33. Back-to-Back Write-Write Cycles

03552-31

DT/Ã



- Notes: 1. Status lines are not driven by 80286, yet remain high due to pull-up resistors in 82C288 and 82289 during HOLD state.
  - 2. Address, M/IO and COD/INTA may start may start floating during any TC, depending on when internal 80286 bus arbiter decides to release bus to external HOLD. The float starts in  $\phi$ 2 of TC.
  - 3. BHE and LOCK may start floating after the end of any TC, depending on when internal 80286 bus arbiter decides to release bus to external HOLD.
  - 4. The minimum HOLD  $\downarrow$  to HLDA  $\downarrow$  time is shown. Maximum is one T\_{\_{\rm H}} longer.
  - 5. The earliest HOLD 1 time is shown which will always allow a subsequent memory cycle if pending.
  - 6. The minimum HOLD  $\uparrow$  to HLDA  $\uparrow$  time is shown. Maximum is a function of the instruction, type of bus cycle and other machine status (i.e., Interrupts, Waits, Lock, etc.).
  - 7. Asynchronous ready allows termination of the cycle. Synchronous ready does not signal ready in this example. Synchronous ready state is ignored after ready is signaled via the asynchronous input.

#### Figure 34. MULTIBUS Write Terminated by Asynchronous Ready with Bus Hold

# **Processor Extension Transfers**

The processor extension interface uses I/O port addresses 00F8(H), and 00FA(H), and 00FC(H) which are part of the I/O port address range and is a reserved area. An ESC instruction with EM = 0 and TS = 0 will perform I/O bus operations to one or more of these I/O port addresses independent of the value of IOPL and CPL.

ESC instructions with memory references enable the CPU to accept PEREQ inputs for processor extension operand transfers. The CPU will determine the operand starting address and read/write status of the instruction. For each operand transfer, two or three bus operations, one word transfer with I/O port address 00FA(H), and one or two bus operations with memory are performed. Three bus operations are required for each word operand aligned on an odd byte address.

# Interrupt Acknowledge Sequence

Figure 35 illustrates an interrupt acknowledge sequence performed by the 80286 in response to an INTR input. An interrupt acknowledge sequence consists of two INTA bus operations. The first allows a master 8259A Programmable Interrupt Controller (PIC) to determine which, if any, of its slaves should return the interrupt vector. An eight-bit vector is read by the 80286 during the second INTA bus operation to select an interrupt handler routine from the interrupt table.

The Master Cascade Enable (MCE) signal of the 82C288 is used to enable the cascade address drivers, during INTA bus operations (see Figure 35), onto the local address bus for distribution to slave interrupt controllers via the system address bus. The 80286 emits the LOCK signal (active Low) during Ts of the first INTA bus operation. A local bus "hold" request will not be honored until the end of the second INTA bus operation.

Three idle processor clocks are provided by the 80286 between INTA bus operations to allow for the minimum INTA to INTA time and CAS (cascade address) out delay of the 8259A. The second INTA bus operation must always have at least one extra Tc state added via logic controlling READY. A23-A0 are in three-state OFF until after the first Tc state of the second INTA bus operation. This prevents bus contention between the cascade address drivers and CPU address drivers. The extra Tc state allows time for the 80286 to resume driving the address lines for subsequent bus operations.

# Local Bus Usage Priorities

The 80286 local bus is shared among several internal units and external HOLD requests. In case of simultaneous requests, their relative priorities are:

(Highest) Any transfers which assert LOCK either explicitly (via the LOCK instruction prefix) or implicitly (i.e., segment descriptor access, interrupt acknowledge sequence, or an XCHG with memory).

The second of the two-byte bus operations required for an odd aligned word operand.

Local bus request via HOLD input.

Processor extension data operand transfer via PEREQ input.

Data transfer performed by EU as part of an instruction.

(Lowest) An instruction prefetch request from BU. The EU will inhibit prefetching two processor clocks in advance of any data transfers to minimize waiting by EU for a prefetch to finish.

# Halt or Shutdown Cycles

The 80286 externally indicates halt or shutdown conditions as a bus operation. These conditions occur due to a HLT instruction or multiple protection exceptions while attempting to execute one instruction. A halt or shutdown bus operation is signalled when  $\overline{S1}$ ,  $\overline{S0}$  and COD/  $\overline{INTA}$  are Low and  $M/\overline{IO}$  is High. A<sub>1</sub> High indicates halt, and A<sub>1</sub> Low indicates shutdown. The 82C288 bus controller does not issue ALE, nor is  $\overline{READY}$  required to terminate a halt or shutdown bus operation.

During halt or shutdown, the 80286 may service PEREQ or HOLD requests. A processor extension segment overrun exception during shutdown will inhibit further service of PEREQ. Either NMI or RESET will force the 80286 out of either halt or shutdown. An INTR, if interrupts are enabled, or a processor extension segment overrun exception will also force the 80286 out of halt.

# System Configurations

The versatile bus structure of the 80286 microsystem, with a full complement of support chips, allows flexible configuration of a wide range of systems. The basic configuration, shown in Figure 36, is similar to an iAPX 86 maximum mode system. It includes the CPU plus an 8259A interrupt controller, 82284 clock generator, and the 82C288 Bus Controller. The iAPX 86 latches (29843 and 29845) and transceivers (29833 and 29863) may be used in an 80286 microsystem.



03552-33

Notes: 1. Data is ignored.

- 2. First INTA cycle should have at least one wait state inserted to meet 8259A minimum INTA pulse width.
- Second INTA cycle must have at least one wait state inserted since the CPU will not drive A<sub>23</sub>-A<sub>0</sub>, BHE, and LOCK until after the first T<sub>c</sub> state.

The CPU imposed one/clock delay prevents bus contention between cascade address buffer being disabled by MCE  $\downarrow$  and address outputs.

Without the wait state, the 80286 address will not be valid for a memory cycle started immediately after the second INTA cycle. The 8259A also requires one wait state for minimum INTA pulse width.

- 4. LOCK is active for the first INTA cycle to prevent the 82289 from releasing the bus between INTA cycles in a multi-master system.
- 5.  $A_{23}$ - $A_0$  exits three-state OFF during  $\phi$ 2 of the second T<sub>c</sub> in the INTA cycle.

#### Figure 35. Interrupt Acknowledge Sequence



Figure 36. Basic 80286 System Configuration

As indicated by the dashed lines in Figure 36, the ability to add processor extensions is an integral feature of 80286 microsystems. The processor extension interface allows external hardware to perform special functions and transfer data concurrent with CPU execution of other instructions. Full system integrity is maintained because the 80286 supervises all data transfers and instruction execution for the processor extension.

The 80286 with the 80287 numeric processor extension (NPX) uses this interface. The iAPX 286/287 has all the instructions and data types of an iAPX 86/87 or iAPX 88/87. The 80287 NPX can perform numeric calculations and data transfers concurrently with CPU program execution. Numerics code and data have the same integrity as all other information protected by the 80286 protection mechanism.

The 80286 can overlap chip select decoding and address propagation during the data transfer for the previous bus operation. This information is latched into the 29843/45's by ALE during the middle of a Ts cycle. The latched chip select and address information remains stable during the bus operation while the next cycle's address is being decoded and propagated into the system. Decode logic can be implemented with a highspeed bipolar PROM. The optional decode logic shown in Figure 36 takes advantage of the overlap between address and data of the 80286 bus cycle to generate advanced memory and I/O-select signals. This minimizes system performance degradation caused by address propagation and decode delays. In addition to selecting memory and I/O, the advanced selects may be used with configurations supporting local and system buses to enable the appropriate bus interface for each bus cycle. The COD/INTA and M/IO signals are applied to the decode logic to distinguish between interrupt, I/O, code and data bus cycles.

By adding the 82289 bus arbiter chip, the 80286 provides a MULTIBUS system bus interface as shown in Figure 37. The ALE output of the 82C288 for the MULTI-BUS bus is connected to its CMDLY input to delay the start of commands one system CLK as required to meet MULTIBUS address and write data set-up times. This arrangement will add at least one extra Tc state to each bus operation which uses the MULTIBUS.

A second 82C288 bus controller and additional latches and transceivers could be added to the local bus of Figure 37. This configuration allows the 80286 to



03552-35

AMD

Figure 37. MULTIBUS System Bus Interface

support an on-board bus for local memory and peripherals and the MULTIBUS for system bus interfacing.

Figure 38 shows the interface of the 80286 with the Am2968 Dynamic Memory Controller. The interface is a timing controller which consists of some control logic and a delay line. The timing controller runs asynchronously to the CPU. It arbitrates between memory requests and refresh requests by generating the proper signals to the dynamic memory controller and

memory. The design described is a simple, costeffective solution to interfacing the 80286 with the Am2968. A further description about DRAM selection based on processor speed may be found in the Am2968 Application Note.

Two-operand instructions (e.g., MOV and ADD) are usually three to six bytes long. Memory-to-memory operations are provided by a special class of string instructions requiring one to three bytes.



03552-36

#### Figure 38. 80286 Interface with the Am2968 Dynamic Memory Controller

#### Table 15. 80286 Systems Recommended Pull-up Resistor Values

| 80286 Pin and Name | Pull-up Value | Purpose                                                                                     |
|--------------------|---------------|---------------------------------------------------------------------------------------------|
| 4- <u>S1</u>       |               |                                                                                             |
| 5– <del>3</del> 0  | 20KΩ±10%      | Pull SO, S1, and PEACK inactive during 80286 hold periods.                                  |
| 6-PEACK            |               |                                                                                             |
| 53-ERROR           | 20KΩ±10%      | Pull ERROR and BUSY inactive when 80287<br>not present (or temporarily removed from         |
| 54–BUSY            | 20132 1076    | socket).                                                                                    |
| 63-READY           | 910Ω±5%       | Pull READY inactive within required minimum time (C <sub>L</sub> = 150 pF, $I_R \le 7mA$ ). |



#### A. Short Opcode Format Example



#### B. Long Opcode Format Example

03552-38

#### Figure 39. 80286 Instruction Format Examples

# 80286 INSTRUCTION SET SUMMARY Instruction Timing Notes

The instruction clock counts listed below establish the maximum execution rate of the 80286. With no delays in bus cycles, the actual clock count of an 80286 program will average 5% more than the calculated clock count, due to instruction sequences which execute faster than they can be fetched from memory.

To calculate elapsed times for instruction sequences, multiply the sum of all instruction clock counts, as listed in the table below, by the processor clock period. An 8-MHz processor clock has a clock period of 125 nanoseconds and requires an 80286 system clock (CLK input) of 16 MHz.

### Instruction Clock Count Assumptions

- 1. The instruction has been prefetched, decoded, and is ready for execution. Control transfer instruction clock counts include all time required to fetch, decode, and prepare the next instruction for execution.
- 2. Bus cycles do not require wait states.
- There are no processor extension data transfer or local bus HOLD requests.

4. No exceptions occur during instruction execution.

### Instruction Set Summary Notes

Addressing displacements selected by the MOD field are not shown. If necessary they appear after the instruction fields shown.

Above/below refers to unsigned value

Greater refers to positive signed value

Less refers to less positive (more negative) signed values

- if d = 1 then to register; if d = 0 then from register
- if w = 1 then word instruction; if w = 0 then byte instruction
- if s = 0 then 16-bit immediate data to form the operand
- if s = 0 then an immediate data byte is signextended to form the 16-bit operand
- x = don't care
- z = used for string primitives for comparison with ZF FLAG

If two clock counts are given, the smaller refers to a register operand and the larger refers to a memory operand.

- \* = add one clock if offset calculation requires summing 3 elements
- n = number of times repeated
- m = number of bytes of code in next instruction

Level (L)-Lexical nesting level of the procedure

The following comments describe possible exceptions, side effects, and allowed usage for instructions in both operating modes of the 80286.

#### **Real Address Mode Only**

1. This is a protected mode instruction. Attempted execution in real address mode will result in an undefined op-code exception (6).

- A segment overrun exception (13) will occur if a word operand reference at offset FFFF(H) is attempted.
- 3. This instruction may be executed in real address mode to initialize the CPU for protected mode.
- 4. The IOPL and NT fields will remain 0.
- Processor extension segment overrun interrupt (9) will occur if the operand exceeds the segment limit.

#### Either Mode

- 6. An exception may occur, depending on the value of the operand.
- LOCK is automatically asserted regardless of the presence or absence of the LOCK instruction prefix.
- LOCK does not remain active between all operand transfers.

#### Protected Virtual Address Mode Only

- A general protection exception (13) will occur if the memory operand cannot be used due to either a segment limit or access rights violation. If a stack segment limit is violated, a stack segment overrun exception (12) occurs.
- 10. For segment load operations, the CPL, RPL, and DPL must agree with privilege rules to avoid an exception. The segment must be present to avoid a not-present exception (11). If the SS register is the destination, and a segment-not-present violation occurs, a stack exception (12) occurs.
- 11. All segment descriptor accesses in the GDT or LDT made by this instruction will automatically assert LOCK to maintain descriptor integrity in multiprocessor systems.
- JMP, CALL, INT, RET, IRET instructions referring to another code segment will cause a general protection exception (13) if any privilege rule is violated.
- A general protection exception (13) occurs if CPL≠0.
- 14. A general protection exception (13) occurs if CPL > IOPL.
- The IF field of the flag word is not updated if CPL>IOPL. The IOPL field is updated only if CPL=0.
- 16. Any violation of privilege rules as applied to the selector operand do not cause a protection exception; rather, the instruction does not return a result and the zero flag is cleared.
- 17. If the starting address of the memory operand violates a segment limit, or an invalid access is attempted, a general protection exception (13) will occur before the ESC instruction is executed. A stack segment overrun exception (12) will occur if the stack limit is violated by the operand's starting address. If a segment limit is violated during an attempted data transfer, then a processor extension segment overrun exception (9) occurs.
- The destination of an INT, JMP, CALL, RET, or IRET instruction must be in the defined limit of a code segment or a general protection exception (13) will occur.

# ABSOLUTE MAXIMUM RATINGS

| Storage Temperature     | –65 to + 150° C   |
|-------------------------|-------------------|
| Voltage on Any Pin with |                   |
| Respect to Ground       | . −1.0 to + 7.0 V |
| Power Dissipation       | 3.15 W            |

Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability.

# DC CHARACTERISTICS

 $(V_{CC} = 5 V \pm 5\%, T_{CASE} = 0 \text{ to } + 85^{\circ} \text{ C})$ 

# **OPERATING RANGES**

| Commercial (C) Devices |             |
|------------------------|-------------|
| Temperature (Tc)       | 0 to +85° C |
| Supply Voltage (Vcc)   | 5 V±5%      |

Operating ranges define those limits between which the functionality of the device is guaranteed.

| Parameter | Description                                     | Test Conditions               | Min | Max       | Unit |
|-----------|-------------------------------------------------|-------------------------------|-----|-----------|------|
| VIL       | Input Low Voltage                               |                               | 5   | 8         | V    |
| VIH       | Input High Voltage                              |                               | 2.0 | Vcc +0 .5 | V    |
| VILC      | CLK Input Low Voltage                           |                               | 5   | .6        | V    |
| Vінс      | CLK Input High Voltage                          |                               | 3.8 | Vcc + 0.5 | V    |
| Vol       | Output Low Voltage                              | loL=2.0 mA                    |     | 0.45      | V    |
| Vон       | Output High Voltage                             | Іон =400 µА                   | 2.4 |           | V    |
| lu -      | Input Leakage Current                           | $0 V \leq V_{IN} \leq V_{CC}$ |     | ±10       | μΑ   |
| llo       | Output Leakage Current                          | 0.45 V ≤ Vout ≤ Vcc           |     | ±10       | μA   |
| lcc       | Supply Current (turn on, 0°C)                   | Note 1                        |     | 600       | mA   |
| Ссік      | CLK Input Capacitance                           | Fc=1 MHz                      |     | 20        | pF   |
| Cin       | Other Input Capacitance                         | Fc=1 MHz                      |     | 10        | pF   |
| Co        | Input /Output Capacitance                       | Fc=1 MHz                      |     | 20        | pF   |
| llo       | Output Leakage Current                          | 0 V ≤ Vout ≤ 0.45 V           |     | ±1        | mA   |
| lı.       | Input Sustaining Current On BUSY and ERROR pins | $V_{IN} = 0 V$                | 30  | 500       | μΑ   |
| ILCR      | Input CLK Leakage Current                       | 0.45 ≤ ViN ≤ Vcc              |     | ±10       | μΑ   |
| ILCR      | Input CLK Leakage Current                       | $0 V \leq V_{IN} \leq 0.45 V$ |     | +1        | mA   |

Note: Low temperature is worst case.

# SWITCHING CHARACTERISTICS

 $V_{CC} = +5 V \pm 5\%$ ,  $T_{CASE} = 0^{\circ}$  to  $+85^{\circ} C$ 

AC Timings are referenced to 0.8 V and 2.0 V points of signals as illustrated in data sheet waveforms, unless otherwise noted.

|            |                                 |                 | 81   | MHz  | 10 1 | AHz  |      |
|------------|---------------------------------|-----------------|------|------|------|------|------|
| Parameters | Description                     | Test Conditions | Min. | Max. | Min. | Max. | Unit |
| 1          | System Clock (CLK) Period       |                 | 62   | 125  | 50   | 125  | ns   |
| 2          | System Clock (CLK) Low Time     | at 1.0 V        | 15   | 100  | 12   | 109  | ns   |
| 3          | System Clock (CLK) High Time    | at 3.6 V        | 25   | 110  | 16   | 113  | ns   |
| 17         | System Clock (CLK) Rise Time    | 1.0 V to 3.6 V  |      | 10   |      | 8    | ns   |
| 18         | System Clock (CLK) Fall Time    | 3.6 V to 1.0 V  |      | 10   |      | 8    | ns   |
| 4          | Asynchronous Inputs Setup Time  | Note 1          | 20   |      | 20   |      | ns   |
| 5          | Asynchronous Inputs Hold Time   | Note 1          | 20   |      | 20   |      | ns   |
| 6          | RESET Setup Time                |                 | 28   |      | 23   |      | ns   |
| 7          | RESET Hold Time                 |                 | 5    |      | 5    |      | ns   |
| 8          | Read Data Setup Time            |                 | 10   |      | 8    |      | ns   |
| 9          | Read Data Hold Time             |                 | 8    |      | 8    |      | ns   |
| 10         | READY Setup Time                |                 | 38   |      | 26   |      | ns   |
| 11         | READY Hold Time                 |                 | 25   |      | 25   |      | ns   |
| 12         | Status/PEACK Valid Delay        | Note 2, Note 3  | 1    | 40   | -    | -    | ns   |
| 12a        | Status/PEACK Active Delay       | Note 2, Note 3  | -    | -    | 1    | 22   | ns   |
| 12b        | Status/PEACK Inactive Delay     | Note 2, Note 3  | -    | -    | 1    | 30   | ns   |
| 13         | Address Valid Delay             | Note 2, Note 3  | 1    | 60   | 1    | 35   | ns   |
| 14         | Write Data Valid Delay          | Note 2, Note 3  | 0    | 50   | 0    | 30   | ns   |
| 15         | Address/Status/Data Float Delay | Note 2, Note 4  | 0    | 50   | 0    | 47   | ns   |
| 16         | HLDA Valid Delay                | Note 2, Note 3  | 0    | 50   | 0    | 47   | ns   |
| 19         | Address Valid to Status         | Note 3, Note 5, | 38   |      | 27   |      | ns   |
|            | Valid Setup Time                | Note 6          |      |      |      |      |      |

Notes: 1. Asynchronous inputs are INTR, NMI, HOLD PEREQ, ERROR, and BUSY. This specification is given only for testing purposes, to assure recognition at a specific CLK edge.

- 2. Delay from 1.0 V on the CLK to 0.8 V or 2.0 V or float on the output as appropriate for valid or floating condition.
- 3. Output load:  $C_L = 100 \text{ pF}$ .
- 4. Float condition occurs when output current is less than  $I_{Lo}$  in magnitude.
- 5. Delay measured from address either reaching 0.8 V or 2.0 V (valid) to status going active reaching 2.0 V or status going inactive reaching 0.8 V.
- 6. For load capacitance of 10 pF on STATUS/PEACK lines, subtract typically 7 ns for 8 MHz spec, and maximum 7 ns for 10 MHz spec.

# SWITCHING CHARACTERISTICS (continued)

 $V_{CC} = +5 V \pm 5\%$ ,  $T_{CASE} = 0^{\circ}$  to  $+85^{\circ} C$ AC Timings are referenced to 0.8 V and 2.0 V points of signals as illustrated in data sheet waveforms, unless otherwise noted.

|            |                                 |                 | 12.5 | MHz  | 16   |      |      |
|------------|---------------------------------|-----------------|------|------|------|------|------|
| Parameters | Description                     | Test Conditions | Min. | Max. | Min. | Max. | Unit |
| 1          | System Clock (CLK) Period       |                 | 40   | 125  | 31   | 125  | ns   |
| 2          | System Clock (CLK) Low Time     | at 1.0 V        | 11   | 112  | 10   | 113  | ns   |
| 3          | System Clock (CLK) High Time    | at 3.6 V        | 13   | 114  | 12   | 115  | ns   |
| 17         | System Clock (CLK) Rise Time    | 1.0 V to 3.6 V  |      | 8    | 8    |      | ns   |
| 18         | System Clock (CLK) Fall Time    | 3.6 V to 1.0 V  |      | 8    | 8    |      | ns   |
| 4          | Asynchronous Inputs Setup Time  | Note 1          | 15   |      | 11   |      | ns   |
| 5          | Asynchronous Inputs Hold Time   | Note 1          | 15   |      | 11   |      | ns   |
| 6          | RESET Setup Time                |                 | 18   |      | 14   |      | ns   |
| 7          | RESET Hold Time                 |                 | 5    |      | 3    |      | ns   |
| 8          | Read Data Setup Time            |                 | 5    |      | 5    |      | ns   |
| 9          | Read Data Hold Time             |                 | 6    |      | 5    |      | ns   |
| 10         | READY Setup Time                |                 | 22   |      | 15   |      | ns   |
| 11         | READY Hold Time                 |                 | 20   |      |      |      | ns   |
| 12         | Status/PEACK Valid Delay        | Note 2, Note 3  | -    | -    | 1    | 18   | ns   |
| 12a        | Status/PEACK Active Delay       | Note 2, Note 3  | 3    | 18   | 1    | 18   | ns   |
| 12b        | Status/PEACK Inactive Delay     | Note 2, Note 3  | 3    | 20   | 1    | 20   | ns   |
| 13         | Address Valid Delay             | Note 2, Note 3  | 1    | 32   | 1    | 29   | ns   |
| 14         | Write Data Valid Delay          | Note 2, Note 3  | 0    | 30   | 0    | 22   | ns   |
| 15         | Address/Status/Data Float Delay | Note 2, Note 4  | 0    | 32   | 0    | 29   | ns   |
| 16         | HLDA Valid Delay                | Note 2, Note 3  | 0    | 25   | 0    | 25   | ns   |
| 19         | Address Valid to Status         | Note 3, Note 5, | 22   |      | 22   |      | ns   |
|            | Valid Setup Time                | Note 6          |      |      |      |      |      |

Notes: 1. Asynchronous inputs are INTR, NMI, HOLD PEREQ, ERROR, and BUSY. This specification is given only for testing purposes, to assure recognition at a specific CLK edge.

2. Delay from 1.0 V on the CLK to 0.8 V or 2.0 V or float on the output as appropriate for valid or floating condition.

3. Output load:  $C_L = 100 \, pF$ .

4. Float condition occurs when output current is less than  ${\rm I}_{\rm LO}$  in magnitude.

5. Delay measured from address either reaching 0.8 V or 2.0 V (valid) to status going active reaching 2.0 V or status going inactive reaching 0.8 V.

6. For load capacitance of 10 pF on STATUS/PEACK lines, subtract typically 7 ns for 8 MHz spec, and maximum 7 ns for 10 MHz spec.

#### AC Test Loading on Outputs



#### AC Drive and Measurement Points-CLK Input



03552-40

#### AC Setup, Hold and Delay Time Measurement—General



# SWITCHING WAVEFORMS Major Cycle Timing





03552-42

# SWITCHING WAVEFORMS (continued)

#### 80286 Asynchronous Input Signai Timing



- Notes: 1. PCLK indicates which processor cycle phase will occur on the next CLK. PCLK may not indicate the correct phase until the first bus cycle is performed.
  - 2. These inputs are asynchronous. The setup and hold times shown assure recognition for testing purposes.

#### 80286 Reset Input Timing and Subsequent Processor Cycle Phase



Note: When RESET meets the set-up time shown, the next CLK will start or repeat \$1 of a processor cycle.



03552-45

- Notes: 1. These signals may not be driven by the 80286 during the time shown. The worst case in terms of latest float time is shown.
  - 2. The data bus will be driven as shown if the last cycle before T<sub>1</sub> in the diagram was a write T<sub>c</sub>.
  - 3. The 80286 floats its status pins during T<sub>µ</sub>. External 20 k $\Omega$  resistors keep these signals high (see Table 15).
  - 4. For HOLD request set-up to HLDA, refer to Figure 34.
  - 5. BHE and LOCK are driven at this time but will not become valid until Ts.
  - 6. The data bus will remain in three-state OFF if a read cycle is performed.

# SWITCHING WAVEFORMS (continued)





Assuming word-aligned memory operand; if odd-aligned, 80286 transfers to/from memory byte-at-a-time with two memory cycles.

- Notes: 1. PEACK always goes active during the first bus operation of a processor extension data operand transfer sequence. The first bus operation will be either a memory read at operand address or I/O read at port address 00FA(H).
  - 2. To prevent a second processor extension data operand transfer, the worst case maximum time (shown above) is: 3x 1-11 max-4 min. The actual, configuration dependent, maximum time is: 3 x 1-11 max-4 min + A x 2 x 1. A is the number of extra T<sub>c</sub> states added to either the first or second bus operation of the processor extension data operand transfer sequence.

#### Initial 80286 Pin State During Reset



- Notes: 1. Set-up time for RESET ↑ may be violated with the consideration that ¢1 of the processor clock may begin one system CLK period later.
  - 2. Set-up and hold times for RESET ↓ must be met for proper operation, but RESET ↓ may occur during ¢1 or ¢2.
  - 3. The data bus is only guaranteed to be in three-state OFF at the time shown.
  - 4. HOLD is acknowledged during RESET, causing HLDA to go active and the appropriate pins to float. If HOLD remains active while RESET goes inactive, the 80286 remains in HOLD state and will not perform any bus accesses until HOLD is deactivated.

# 80286 INSTRUCTION SET SUMMARY

| Function Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Real<br>Address | Protected<br>Virtual | Real            | Protected                  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------------------|-----------------|----------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Mode            | Address<br>Mode      | Address<br>Mode | Virtual<br>Address<br>Mode |
| DATA TRANSFER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                 |                      |                 |                            |
| MOV = Move:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                 |                      |                 |                            |
| Register to Register/Memory 1000100w mod reg r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 2,3*            | 2,3*                 | 2               | 9                          |
| Register/Memory to Register 1000101 w mod reg r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 2,5*            | 2,5*                 | 2               | 9                          |
| Immediate to register/ 1100011w mod0000r/m data data if w=1<br>Memory                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 2,3*            | 2,3*                 | 2               | 9                          |
| Immediate to register 1011wreg data data if w = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 2               | 2                    |                 |                            |
| Memory to accumulator 1010000 w addr-low addr-high                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 5               | 5                    | 2               | 9                          |
| Accumulator to memory 1010001w addr-low addr-high                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 3               | 3                    | 2               | 9                          |
| Register/memory to<br>segment register         10001110         mod 0 reg r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 2,5*            | 17,19*               | 2               | 9,10,11                    |
| Segment register to register/memory 10001100 mod 0 reg r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 2,3*            | 2,3*                 | 2               | 9                          |
| PUSH = Push:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                 |                      |                 |                            |
| Memory 11111111 mod 110 r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 5*              | 5*                   | 2               | 9                          |
| Register 01010reg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 3               | 3                    | 2               | 9                          |
| Segment register 000 reg 110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 3               | 3                    | 2               | 9                          |
| Immediate* 0110100 data data if s = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 3               | 3                    | 2               | 9                          |
| PUSHA = Push All* 01100000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 17              | 17                   | 2               | 9                          |
| POP = Pop                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                 |                      |                 |                            |
| Memory 10001111 mod0000r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 5⁺              | 5⁺                   | 2               | 9                          |
| Register 01011reg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 5               | 5                    | 2               | 9                          |
| Segment register 000 reg 1 1 1 (reg ≠ 01)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 5               | 20                   | 2               | 9,10,11                    |
| POPA = Pop All* 01100001                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 19              | 19                   | 2               | 9                          |
| XCHG = Exchange:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                 |                      |                 |                            |
| Register/memory with 1000011w mod reg r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 3,5*            | 3,5*                 | 2,7             | 7,9                        |
| Register with accumulator 10010 reg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 3               | 3                    |                 |                            |
| IN = Input from:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                 |                      |                 |                            |
| Fixed port 1110010w port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 5               | 5                    |                 | 14                         |
| Variable port 1110110w                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 5               | 5                    |                 | 14                         |
| OUT = Output to:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                 |                      |                 |                            |
| Fixed port 1110011w port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 3               | 3                    |                 | 14                         |
| Variable port 1110111w                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 3               | 3                    |                 | 14                         |
| XLAT = Translate byte to AL 11010111                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 5               | 5                    |                 | 9                          |
| LEA = Load EA to register 10001101 mod reg r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 3⁺              | 3*                   |                 |                            |
| LDS = Load pointer to DS 11000101 mod reg r/m (mod ≠ 11)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 7*              | 21*                  | 2               | 9,10,11                    |
| LES = Load pointer to ES 11000100 mod reg r/m (mod ≠ 11)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 7*              | 21*                  | 2               | 9,10,11                    |
| LAHF = Load AH with flags 10011111                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 2               | 2                    |                 |                            |
| SAHF = Store AH into flags 10011110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 2               | 2                    |                 |                            |
| minimum more description of the second | 3               | 3                    | 2               | 9                          |
| PUSHF = Push flags         10011100           POPF = Pop flags         10011101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 5               | 5                    | 2,4             | 9,15                       |

\*Indicates instructions not available in iAPX 86, 88 microsystems.

See footnotes on page 1-124.

# 80286 INSTRUCTION SET SUMMARY (continued)

|                                    |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |                  | Clock                   | < Count                                 | Com                     | ments                                   |
|------------------------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|------------------|-------------------------|-----------------------------------------|-------------------------|-----------------------------------------|
| Function                           | Format            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |                  | Real<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode |
| ARITHMETIC                         |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |                  |                         |                                         |                         |                                         |
| ADD=Add:                           |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |                  |                         |                                         |                         |                                         |
| Reg/memory with register to either | w b 0 0 0 0 0 0 0 | mod reg r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |               |                  | 2,7*                    | 2,7*                                    | 2                       | 9                                       |
| Immediate to register/memory       | 100000sw          | mod 0 0 r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | data          | data if s:w = 01 | 3, 7*                   | 3,7*                                    | 2                       | 9                                       |
| Immediate to accumulator           | 0000010w          | data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | data if w = 1 |                  | 3                       | 3                                       |                         |                                         |
| ADC = Add with carry:              |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |                  |                         |                                         |                         |                                         |
| Reg/memory with register to either | 000100dw          | mod reg r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |               |                  | 2, 7*                   | 2,7*                                    | 2                       | 9                                       |
| Immediate to register/memory       | 100000sw          | mod 0 1 0 r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | data          | data if s:w = 01 | 3, 7*                   | 3, 7*                                   | 2                       | 9                                       |
| Immediate to accumulator           | 0001010w          | data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | data if w = 1 |                  | 3                       | 3                                       |                         |                                         |
| INC =Increment:                    | Lana              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               | ,                |                         |                                         |                         |                                         |
| Register/memory                    | 1111111w          | mod 0 0 0 r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |               |                  | 2,7*                    | 2,7*                                    | 2                       | 9                                       |
| Register                           | 01000 reg         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |                  | 2                       | 2                                       |                         |                                         |
| SUB =Subtract:                     |                   | l de la constante de |               |                  |                         |                                         |                         |                                         |
| Reg/memory and register to either  | 001010dw          | mod reg r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |               |                  | 2,7*                    | 2,7*                                    | 2                       | 9                                       |
| Immediate from register/memory     | 100000sw          | mod 1 0 1 r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | data          | data if s:w = 1  | 3,7*                    | 3,7*                                    | 2                       | 9                                       |
| Immediate from accumulator         | 0001110w          | data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | data if w = 1 |                  | 3                       | 3                                       | _                       |                                         |
| SBB = Subtract with borrow:        |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               | 1                |                         |                                         |                         |                                         |
| Reg/memory and register to either  | 000110dw          | mod reg r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |               |                  | 2,7*                    | 2,7*                                    | 2                       | 9                                       |
| Immediate from register/memory     | 100000sw          | mod 0 1 1 r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | data          | data if s:w = 01 | 3,7*                    | 3,7*                                    | 2                       | 9                                       |
| Immediate from accumulator         | 0010110w          | data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | data if w = 1 |                  | 3                       | 3                                       |                         | Ū                                       |
| DEC = Decrement:                   |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               | 1                | -                       |                                         |                         |                                         |
| Register/memory                    | 1111111w          | mod 0 0 1 r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |               |                  | 2,7*                    | 2,7*                                    | 2                       | 9                                       |
| Register                           | 01001 reg         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |                  | 2                       | 2                                       |                         | -                                       |
| CMP = Compare:                     |                   | J                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |               |                  |                         |                                         |                         |                                         |
| Register/memory with register      | 0011101w          | mod reg r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |               |                  | 2,6*                    | 2,6*                                    | 2                       | 9                                       |
| Register with register/memory      | 0011100w          | mod reg r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |               |                  | 2,7*                    | 2,7*                                    | 2                       | 9                                       |
| Immediate with register/memory     | 100000sw          | mod 1 1 1 r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | data          | data if s:w = 01 | 3,6*                    | 3,6*                                    | 2                       | 9                                       |
| Immediate with accumulator         | 0011110w          | data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | data if w = 1 |                  | 3                       | 3                                       |                         |                                         |
| NEG = Change sign                  | 1111011w          | mod 0 1 1 r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |               | 1                | 2                       | 7⁺                                      | 2                       | 7                                       |
| AAA = ASCII adjust for add         | 00110111          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |                  | 3                       | 3                                       |                         |                                         |
| DAA = Decimal adjust for add       | 00100111          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |                  | 3                       | 3                                       |                         |                                         |
| AAS = ASCII adjust for subtract    | 00111111          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |                  | 3                       | 3                                       |                         |                                         |
| DAS = Decimal adjust for subtract  | 00101111          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |                  | 3                       | 3                                       |                         |                                         |
| MUL = Multiply (unsigned)          | 1111011w          | mod 1 0 0 r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |               |                  | 10                      |                                         |                         |                                         |
| Register-Byte<br>Register-Word     |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |                  | 13<br>21                | 13<br>21                                |                         |                                         |
| Memory-Byte                        |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |                  | 16*                     | 16*                                     | 2                       | 9                                       |
| Memory-Word                        |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |                  | 24*                     | 24*                                     | 2                       | 9                                       |
| IMUL = Integer multiply (signed)*  | 1111011w          | mod 1 0 1 r/m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |               |                  |                         |                                         |                         |                                         |
| Register-Byte                      |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |                  | 13                      | 13                                      |                         |                                         |
| Register-Word                      |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |                  | 21                      | 21                                      |                         |                                         |
| Memory-Byte<br>Memory-Word         |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |                  | 16*<br>24*              | 16*<br>24*                              | 2                       | 9<br>9                                  |
|                                    |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               |                  |                         |                                         |                         |                                         |
| *Indiantan instructions not quails |                   | 89                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |               |                  | L                       | <u> </u>                                |                         |                                         |

# 80286 INSTRUCTION SET SUMMARY (continued)

|                                                                   |                      |                              |               |               | Clock                   | Count                                   | Col                     | nment                                  |
|-------------------------------------------------------------------|----------------------|------------------------------|---------------|---------------|-------------------------|-----------------------------------------|-------------------------|----------------------------------------|
| Function                                                          | Format               |                              |               |               | Real<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode | Protecta<br>Virtual<br>Address<br>Mode |
| ARITHMETIC (Continued)                                            |                      |                              |               |               |                         |                                         |                         |                                        |
| IMUL = Integer immediate multiply:<br>(signed)*                   | 011010a1             | mod reg r/m                  | data          | data if a = 0 | 21,24*                  | 21, 24*                                 | 2                       | 9                                      |
| DIV = Divide (unsigned):                                          | 1111011w             | mod 1 1 0 r/m                |               |               |                         | 1                                       |                         |                                        |
| Register-Byte                                                     |                      |                              |               |               | 14                      | 14                                      |                         |                                        |
| Register-Word<br>Memory-Byte                                      |                      |                              |               |               | 22<br>17*               | 22<br>17*                               | 2,6                     | 6,9                                    |
| Memory-Word                                                       |                      |                              |               |               | 25*                     | 25*                                     | 2,6                     | 6,9                                    |
| IDIV = Integer divide (signed)                                    | 1111011w             | mod 1 1 1 r/m                | 1             |               |                         |                                         | ļ                       |                                        |
| Register-Byte                                                     |                      |                              |               |               | 17                      | 17                                      |                         |                                        |
| Register-Word                                                     |                      |                              |               |               | 25<br>20*               | 25<br>20*                               |                         | Ι.                                     |
| Memory-Byte<br>Memory-Word                                        |                      |                              | _             |               | 20                      | 20                                      | 2                       |                                        |
| AAM = ASCII adjust for multiply                                   | 11010100             | 00001010                     | ]             |               | 16                      | 16                                      |                         |                                        |
| AAD = ASCII adjust for divide                                     | 11010101             | 00001010                     | ]             |               |                         | 14                                      | 14                      |                                        |
| CBW = Convert byte to word                                        | 10011000             |                              | •             |               |                         | 2                                       | 2                       |                                        |
| CWD = Convert word to double word                                 | 10011001             |                              |               |               |                         | 2                                       | 2                       |                                        |
| LOGIC                                                             |                      | I                            |               |               |                         |                                         |                         |                                        |
| Shift/Rotate Instructions:                                        |                      |                              |               |               |                         |                                         |                         |                                        |
| Register/Memory by 1                                              | 1101000w             | mod TTT r/m                  |               |               | 2, 7*                   | 2,7*                                    | 2                       |                                        |
|                                                                   |                      |                              |               |               | 5+n,                    | 5+n,                                    |                         |                                        |
| Register/Memory by CL                                             | 1101001w             | mod TTT r/m                  |               |               | 8+n*                    | 8+n*                                    | 2                       |                                        |
|                                                                   |                      |                              |               |               | 5+n,                    | 5+n,                                    |                         |                                        |
| Register Memory by Count*                                         | 1100000w             | mod TTT r/m                  |               |               | 8+n*                    | 8+n*                                    | 2                       |                                        |
|                                                                   | TTT<br>0 0 0         | Instruction<br>ROL           |               |               |                         |                                         |                         |                                        |
|                                                                   | 001                  | ROR                          |               |               |                         |                                         |                         |                                        |
|                                                                   | 010                  | RCL                          |               |               | 1                       |                                         |                         |                                        |
|                                                                   | 011<br>100           | RCR<br>SHL/SAL               |               |               |                         |                                         |                         |                                        |
|                                                                   | 101                  | SHR                          |               |               |                         |                                         |                         |                                        |
|                                                                   | 111                  | SAR                          |               |               |                         |                                         |                         |                                        |
| AND = And:                                                        |                      |                              |               |               |                         |                                         |                         |                                        |
| Reg/memory and register to either                                 | 00100dw              | mod reg r/m                  |               |               | 2, 7*                   | 2, 7*                                   | 2                       |                                        |
| Immediate to register/memory                                      | 100000w              | mod 1 0 0 r/m                | data          | data if w = 1 | 3, 7*                   | 3, 7*                                   | 2                       |                                        |
| Immediate to accumulator                                          | 0010010w             | data                         | data if w = 1 |               | 3                       | 3                                       |                         |                                        |
| TEST = And function to flags, no re-                              | sult:                |                              |               |               |                         |                                         |                         |                                        |
| Register/memory and register                                      | 1000010w             | mod reg r/m                  |               |               | 2,6*                    | 2,6*                                    | 2                       | ) (                                    |
| Immediate data and register/memory                                |                      | mod 0 0 0 r/m                | data          | data if w = 1 | 3, 6*                   | 3,6*                                    | 2                       | '                                      |
| Immediate data and accumulator                                    | 1010100w             | data                         | data if w = 1 |               | 3                       | 3                                       |                         |                                        |
| OR = Or:                                                          |                      |                              |               |               |                         |                                         |                         |                                        |
| Reg/memory and register to either                                 | 000010dw             | mod reg r/m                  |               |               | 2, 7*                   | 2, 7*                                   | 2                       | '                                      |
| Immediate to register/memory                                      | 100000w              | mod 0 0 1 r/m                | data          | data if w = 1 | 3, 7*                   | 3, 7*                                   | 2                       | '                                      |
| Immediate to accumulator                                          | 0000110w             | data                         | data if w = 1 |               | 3                       | 3                                       |                         | 1                                      |
| XOR = Exclusive or:                                               | 0.0.1.1.0.0.4        | mod roa s/                   |               |               | <u> </u>                | 0.7*                                    | ļ _                     |                                        |
| Reg/memory and register to either<br>Immediate to register/memory | 001100dw<br>1000000w | mod reg r/m<br>mod 1 1 0 r/m | data          | data if w = 1 | 2, 7*<br>3, 7*          |                                         | 2                       |                                        |
| Immediate to register/memory                                      | 0011010w             | data                         | data if w = 1 |               | 3,7                     | · ·                                     | <sup>2</sup>            |                                        |
| minioulate to accumulator                                         | HOLD ON              | Jaia                         |               |               | I 3                     | 1 3                                     | 1                       | 1                                      |
| NOT = Invert register/memory                                      | 1111011w             | mod 0 1 0 r/m                |               |               | 2, 7*                   | 2,7*                                    | 2                       | 1 9                                    |

# 80286 INSTRUCTION SET SUMMARY (continued)

|                                                                                                                                                                                                |                           | 1997 - Barne April - Spiller - Jones and Sciences and Sciences |              | Clock                                                 | Count                                                      | Cor                                                            | nments                                                                     |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|----------------------------------------------------------------|--------------|-------------------------------------------------------|------------------------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------------------------|--|
| Function                                                                                                                                                                                       | Format                    |                                                                |              | Real<br>Address<br>Mode                               | Protected<br>Virtual<br>Address<br>Mode                    | Real<br>Address<br>Mode                                        | Protected<br>Virtual<br>Address<br>Mode                                    |  |
| STRING MANIPULATION:                                                                                                                                                                           |                           |                                                                |              |                                                       |                                                            | [                                                              |                                                                            |  |
| MOVS = Move byte/word                                                                                                                                                                          | 1010010w                  |                                                                |              | 5                                                     | 5                                                          | 2                                                              | 9                                                                          |  |
| CMPS = Compare byte/word                                                                                                                                                                       | 1010011w                  |                                                                |              | 8                                                     | 8                                                          | 2                                                              | 9                                                                          |  |
| SCAS = Scan byte/word                                                                                                                                                                          | 1010111w                  |                                                                |              | 7                                                     | 7                                                          | 2                                                              | 9                                                                          |  |
| LODS = Load byte/wd to AL/AX                                                                                                                                                                   | 1010110w                  |                                                                |              | 5                                                     | 5                                                          | 2                                                              | 9                                                                          |  |
| STOS = Stor byte/wd from AL/A                                                                                                                                                                  | 1010101w                  |                                                                |              | 3                                                     | 3                                                          | 2                                                              | 9                                                                          |  |
| INS = Input byte/wd from DX port                                                                                                                                                               | 0110110w                  |                                                                |              | 5                                                     | 5                                                          | 2                                                              | 9,14                                                                       |  |
| OUTS = Output byte/wd to DX port                                                                                                                                                               | 0110111w                  |                                                                |              | 5                                                     | 5                                                          | 2                                                              | 9,14                                                                       |  |
| Repeated by count in CX*                                                                                                                                                                       |                           |                                                                |              |                                                       |                                                            |                                                                |                                                                            |  |
| MOVS = Move string                                                                                                                                                                             | 11110010                  | 1010010w                                                       |              | 5+4n                                                  | 5+4n                                                       | 2                                                              | 9                                                                          |  |
| CMPS = Compare string                                                                                                                                                                          | 1111001z                  | 1010011w                                                       |              | 5+9n                                                  | 5+9n                                                       | 2                                                              | 9                                                                          |  |
| SCAS = Scan string                                                                                                                                                                             | 1111001z                  | 1010111w                                                       |              | 5+8n                                                  | 5+8n                                                       | 2                                                              | 9                                                                          |  |
| LODS = Load string                                                                                                                                                                             | 1111010                   | 1010110w                                                       |              | 5+4n                                                  | 5+4n                                                       | 2                                                              | 9                                                                          |  |
| STOS = Store string                                                                                                                                                                            | 11110010                  | 1010101w                                                       |              | 4+3n                                                  | 4+3n                                                       | 2                                                              | 9                                                                          |  |
| INS = Input string*                                                                                                                                                                            | 11110010                  | 0110110w                                                       |              | 5+4n                                                  | 5+4n                                                       | 2                                                              | 9,14                                                                       |  |
| OUTS = Output string*                                                                                                                                                                          | 11110010                  | 0110111w                                                       |              | 5+4n                                                  | 5+4n                                                       | 2                                                              | 9,14                                                                       |  |
| CONTROL TRANSFER                                                                                                                                                                               |                           |                                                                |              |                                                       |                                                            |                                                                |                                                                            |  |
| CALL = Call:                                                                                                                                                                                   |                           |                                                                |              |                                                       |                                                            |                                                                |                                                                            |  |
| Direct within segment                                                                                                                                                                          | 11101000                  | disp-low                                                       | disp-high    | 7+m                                                   | 7+m                                                        | 2                                                              | 8                                                                          |  |
| Register memory indirect                                                                                                                                                                       | 11111111                  | mod 0 1 0 r/m                                                  |              | 7+m.11+m                                              |                                                            | 2                                                              | 8,9                                                                        |  |
| within segment                                                                                                                                                                                 |                           |                                                                | ſ            |                                                       |                                                            | -                                                              | 0,0                                                                        |  |
| Direct intersegment                                                                                                                                                                            | 10011010                  | segmen                                                         | t offset     | 13+m                                                  | 26 + m                                                     | 2                                                              | 8,11,12                                                                    |  |
| -                                                                                                                                                                                              |                           | segment                                                        |              | 1                                                     |                                                            |                                                                |                                                                            |  |
| Protected Mode Only (Direct Inter-<br>Via call gate to same privilege leve<br>Via call gate to different privilege k<br>Via call gate to different privilege k<br>Via TSS<br>Via task gate     | el<br>evel, no parameters | 5                                                              |              | 41 + m<br>82 + m<br>86 + 4x + m<br>177 + m<br>182 + m |                                                            | 8,11,12<br>8,11,12<br>8,11,12<br>8,11,12<br>8,11,12<br>8,11,12 |                                                                            |  |
| Indirect intersegment                                                                                                                                                                          | 11111111                  | mod 0 1 1 r/m                                                  | (mod ≠ 11)   | 16+m                                                  | 29 + m*                                                    | 2                                                              | 8,9,11,12                                                                  |  |
| Protected Mode Only (Indirect Inte<br>Via call gate to same privilege leve<br>Via call gate to different privilege leve<br>Via call gate to different privilege le<br>Via TSS<br>Via task gate | el<br>evel, no parameters | 5                                                              |              |                                                       | 44 + m*<br>83 + m*<br>90 + 4x + m*<br>180 + m*<br>185 + m* |                                                                | 8,9,11,12<br>8,9,11,12<br>8,9,11,12<br>8,9,11,12<br>8,9,11,12<br>8,9,11,12 |  |
| JMP = Unconditional jump                                                                                                                                                                       |                           | T                                                              | 1            |                                                       | _                                                          |                                                                |                                                                            |  |
| Short/long                                                                                                                                                                                     | 11101011                  | disp-low                                                       |              | 7+m                                                   | 7+m                                                        |                                                                | 8                                                                          |  |
| Direct within segment                                                                                                                                                                          | 11101001                  | disp-low                                                       | disp-high    | 7+m                                                   | 7+m                                                        |                                                                | 8                                                                          |  |
| Register/mem indirect within segme                                                                                                                                                             | nt 1 1 1 1 1 1 1 1 1      | mod 1 0 0 r/m                                                  |              | 7+m,11+m*                                             | 7+m,11+m*                                                  | 2                                                              | 8,9                                                                        |  |
| Direct intersegment                                                                                                                                                                            | 11101010                  | segmer                                                         | it offset    | 11+m                                                  | 23 + m                                                     |                                                                | 8,11,12                                                                    |  |
| Protected Mode Only (Indirect Inte<br>Via call gate to same privilege leve<br>Via TSS<br>Via task gate                                                                                         |                           | segment                                                        | selector     |                                                       | 38 + m<br>175 + m<br>180 + m                               |                                                                | 8,11,12<br>8,11,12<br>8,11,12                                              |  |
| Indirect intersegment                                                                                                                                                                          | 11111111                  | mod 1 0 1 r/m                                                  | (mod ≠ 11)   | 15+m*                                                 | 26+m*                                                      | 2                                                              | 8.9.11.12                                                                  |  |
| nunser intersegnient                                                                                                                                                                           | 1                         |                                                                | [ (nou ≠ 11) | 1 10+11                                               | 20+11                                                      | 1 4                                                            | 10,3,11,12                                                                 |  |

# 80286 INSTRUCTION SET SUMMARY (continued)

|                                                                                                                                        |          |          |           | Clock                   | Count                                   | Com                     | ments                                   |
|----------------------------------------------------------------------------------------------------------------------------------------|----------|----------|-----------|-------------------------|-----------------------------------------|-------------------------|-----------------------------------------|
| Function                                                                                                                               | Format   |          |           | Real<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode | Reai<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode |
| CONTROL TRANSFER (Continued):<br>Protected Mode Only (Indirect Inter<br>Via call gate to same privilege le<br>Via TSS<br>Via task gate | segment) |          |           |                         | 41+m*<br>178+m*<br>183+m*               |                         | 8,9,11,12<br>8,9,11,12<br>8,9,11,12     |
| RET = Return from CALL:                                                                                                                |          |          |           |                         |                                         |                         |                                         |
| Within segment                                                                                                                         | 11000011 |          |           | 11+m                    | 11+m                                    | 2                       | 8,9                                     |
| Within seg adding immed to SP                                                                                                          | 11000010 | data-low | data-high | 11+m                    | 11+m                                    | 2                       | 8,9                                     |
| Intersegment                                                                                                                           | 11001011 |          |           | 15+m                    | 25+m                                    |                         | 8,9,11,1                                |
| Intersegment adding immediate to SP<br>Protected Mode Only (RET):                                                                      | 11001010 | data-low | data-high | 15+m                    |                                         | 2                       | 8,9,11,12                               |
| To different privilege level                                                                                                           |          |          |           |                         | 55+m                                    |                         |                                         |
| JE/JZ = Jump on equal zero                                                                                                             | 01110100 | disp     |           | 7+m or 3                | 7+m or 3                                |                         | 8                                       |
| JL/JNGE =<br>Jump on less not greater or equal                                                                                         | 01111100 | disp     |           | 7+m or 3                | 7+m or 3                                |                         |                                         |
| JLE/JNG =<br>Jump on less or equal not greater                                                                                         | 0111110  | disp     |           | 7+m or 3                | 7+m or 3                                |                         |                                         |
| JB/JNAE =<br>Jump on below not above or equal                                                                                          | 01110010 | disp     |           | 7+m or 3                | 7+m or 3                                |                         | 8                                       |
| JBE/JNA =<br>Jump on below or equal not above                                                                                          | 01110110 | disp     |           | 7+m or 3                | 7+m or 3                                |                         |                                         |
| JP/JPE = Jump on parity/parity even                                                                                                    | 01111010 | disp     |           | 7+m or 3                | 7+m or 3                                |                         |                                         |
| JO = Jump on overflow                                                                                                                  | 01110000 | disp     |           | 7+m or 3                | 7+m or 3                                |                         |                                         |
| JS=Jump on sign                                                                                                                        | 01111000 | disp     |           | 7+m or 3                | 7+m or 3                                |                         | .                                       |
| JNE/JNZ =<br>Jump on not equal not zero                                                                                                | 01110101 | disp     |           | 7+m or 3                | 7+m or 3                                |                         |                                         |
| JNL/JGE =<br>Jump on not less greater or equal                                                                                         | 01111101 | disp     |           | 7+m or 3                | 7+m or 3                                |                         |                                         |
| JNLE/JG =<br>Jump on not less or equal greater                                                                                         | 01111111 | disp     |           | 7+m or 3                | 7+m or 3                                |                         |                                         |
| JNB/JAE =<br>Jump on not below above or equal                                                                                          | 01110011 | disp     | ,<br>     | 7+m or 3                | 7+m or 3                                |                         |                                         |
| JNBE/JA =                                                                                                                              |          |          |           |                         |                                         |                         |                                         |
| Jump on not below or equal above                                                                                                       | 01110111 | disp     |           | 7+m or 3                | 7+m or 3                                |                         |                                         |
| JNP/JPO = Jump on not par/par odd                                                                                                      | 01111011 | disp     |           | 7+m or 3                | 7+m or 3                                |                         |                                         |
| JNO = Jump on not overflow                                                                                                             | 01110001 | disp     |           | 7+m or 3                | 7+m or 3                                |                         |                                         |
| JNS = Jump on not sign                                                                                                                 | 01111001 | disp     |           | 7+m or 3                | 7+m or 3                                |                         |                                         |
| LOOP = Loop CX Times                                                                                                                   | 11100010 | disp     |           | 8+m or 4                | 8+m or 4                                |                         |                                         |
| LOOPZ/LOOPE =<br>Loop while zero equal                                                                                                 | 11100001 | disp     | 1         | 8+m or 4                | 8+m or 4                                |                         |                                         |
| LOOPNZ/LOOPNE =                                                                                                                        |          |          |           |                         |                                         |                         |                                         |
| Loop while not zero equal                                                                                                              | 11100000 | disp     |           | 8+m or 4                | 8+m or 4                                |                         | 1                                       |
| JCXZ = Jump on CX zero                                                                                                                 | 11100011 | disp     |           | 8+m or 4                | 8+m or 4                                |                         |                                         |
| ENTER = Enter Procedure*                                                                                                               | 11001000 | data-low | data-high | L                       |                                         |                         |                                         |
| L=0                                                                                                                                    |          |          | ······    | 11                      | 11                                      | 2                       |                                         |
|                                                                                                                                        |          |          |           | 15                      | 15                                      | 2                       |                                         |
| L=1                                                                                                                                    |          |          |           |                         |                                         |                         |                                         |
|                                                                                                                                        | 11001001 |          |           | 16-4(L-1)<br>5          | 16–4(L–1)<br>5                          | 2                       |                                         |

# 80286 INSTRUCTION SET SUMMARY (continued)

|                                                               |                                                                    | Clock                   | Count                                      | Comments                |                                         |  |
|---------------------------------------------------------------|--------------------------------------------------------------------|-------------------------|--------------------------------------------|-------------------------|-----------------------------------------|--|
| Function                                                      | Format                                                             | Real<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode    | Real<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode |  |
| CONTROL TRANSFER (Continued):                                 |                                                                    |                         |                                            |                         |                                         |  |
| INT = Interrupt:                                              |                                                                    |                         |                                            |                         |                                         |  |
| Type specified                                                | 11001101 type                                                      | 23 + m                  |                                            | 2                       |                                         |  |
| Туре 3                                                        | 11001100                                                           | 23 + m                  |                                            | 2                       |                                         |  |
| INTO = Interrupt on overflow                                  | 11001110                                                           | 24 - m or 3             | 24 – or 3                                  | 2                       |                                         |  |
| ·                                                             |                                                                    | (3 if no)               | (3 if no)                                  |                         |                                         |  |
|                                                               |                                                                    | (Interrupt)             | (Interrupt)                                |                         |                                         |  |
| Protected Mode Only:<br>Via interrupt or trap gate to same pr | ivilege level                                                      |                         | 40 + m                                     |                         | 8,11,12                                 |  |
| Via interrupt or trap gate to fit different                   | ent privilege level                                                |                         | 78 + m                                     |                         | 8,11,12                                 |  |
| Via Task Gate                                                 | , <b>,</b>                                                         |                         | 167 + m                                    |                         | 8,11,12                                 |  |
| IRET = Interrupt return                                       | 11001111                                                           | 17+m                    | 31 + m                                     | 2,4                     | 8,9,11                                  |  |
| ·                                                             |                                                                    |                         |                                            |                         | 12,15                                   |  |
| Protected Mode Only:<br>To different privilege level          |                                                                    |                         |                                            | 55+m                    | 8,9,11<br>12,15                         |  |
| To different task (NT = 1)                                    |                                                                    |                         |                                            | 169 + m                 | 8,9,11,1                                |  |
| BOUND = Detect value out of range*                            | 0 1 1 0 0 0 1 0 mod reg r/m                                        | 13                      | 13<br>(Use INT<br>clock count<br>if excep- |                         |                                         |  |
| PROCESSOR CONTROL                                             |                                                                    |                         | tion 6)                                    |                         |                                         |  |
| CLC = Clear carry                                             | 11111000                                                           | 2                       | 2                                          |                         |                                         |  |
| CMC = Complement carry                                        | 11110101                                                           | 2                       | 2                                          |                         |                                         |  |
| STC = Set carry                                               | 11111001                                                           | 2                       | 2                                          |                         |                                         |  |
| CLD = Clear direction                                         | 11111100                                                           | 2                       | 2                                          |                         |                                         |  |
| STD = Set direction                                           | 1111101                                                            | 2                       | 2                                          |                         |                                         |  |
| CLI = Clear interrupt                                         | 11111010                                                           | 3                       | 3                                          |                         | 1.                                      |  |
| STI = Set interrupt                                           | 11111011                                                           | 2                       | 2                                          | l                       | 1.                                      |  |
| HLT = Halt                                                    | 11110100                                                           | 2                       | 2                                          |                         | 1:                                      |  |
| WAIT = Wait                                                   | 10011011                                                           | 3                       | 3                                          |                         |                                         |  |
| LOCK = Bus lock prefix                                        | 11110000                                                           | 0                       | 0                                          |                         | 1.                                      |  |
| CTS = Clear task switched flag                                | 00001111 00000110                                                  | 2                       | 2                                          | 3                       | 1:                                      |  |
| ESC = Processor Extension Escape                              | 10011TTT mod LLL r/m<br>(TTT LL are opcode to processor extension) | 920*                    | 9-20*                                      | 5                       | 1                                       |  |
|                                                               |                                                                    |                         |                                            |                         |                                         |  |
| SEG = Segment override prefix                                 | 0 0 1 reg 1 1 0                                                    | 0                       | 0                                          |                         |                                         |  |

# 80286 INSTRUCTION SET SUMMARY (continued)

|                                                                        |                              | Clock Count             |                                         | Comments                |                                         |
|------------------------------------------------------------------------|------------------------------|-------------------------|-----------------------------------------|-------------------------|-----------------------------------------|
| Function                                                               | Format                       | Real<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode |
| PROTECTION CONTROL:                                                    |                              |                         |                                         |                         |                                         |
| LGDT =<br>Load global descriptor table register*                       | 00001111 0000001 mod 010 r/m | 11*                     | 11*                                     | 2,3                     | 9,13                                    |
| SGDT =<br>Store global descriptor table register*                      | 00001111 0000001 mod 000 r/m | 11*                     | 11*                                     | 2,3                     | 9,13                                    |
| LIDT =<br>Load interrupt descriptor table register*                    | 00001111 0000001 mod 011r/m  | 12*                     | 12*                                     | 2,3                     | 9,13                                    |
| SIDT =<br>Store interrupt descriptor table register*                   | 00001111 0000001 mod 001r/m  | 12*                     | 12*                                     | 2,3                     | 9                                       |
| LLDT =<br>Load local descriptor table register<br>from table memory*   | 00001111 0000000 mod 010 r/m |                         | 17,19*                                  | 1                       | 9,11,13                                 |
| SLDT =<br>Store local descriptor table register<br>to register/memory* | 00001111 0000000 mod 000 r/m |                         | 2,3*                                    | 1                       | 9                                       |
| LTR =<br>Load task register<br>from register/memory*                   | 00001111 000000 mod 011r/m   |                         | 17,19*                                  | 1                       | 9,11,13                                 |
| STR =<br>Store task register to register memory*                       | 00001111 000000 mod 001 r/m  |                         | 2,3*                                    | 1                       | 9,11,13                                 |
| LMSW =<br>Load machine status word from<br>register/memory*            | 00001111 0000001 mod 110 r/m | 3,6*                    | 3,6*                                    | 2,3                     | 9,13                                    |
| SMSW =<br>Store machine status word*                                   | 00001111 0000001 mod 100 r/m | 2,3*                    | 2,3*                                    | 2,3                     | 9                                       |
| LAR =<br>Load access rights from<br>register/memory*                   | 00001111 0000010 mod reg r/m |                         | 14,16*                                  | 1                       | 9,16                                    |
| LSL =<br>Load segment limit from<br>register/memory*                   | 00001111 0000011 mod reg r/m |                         | 14,16*                                  | 1                       | 9,16                                    |
| ARPL =<br>Adjust requested privilege level<br>from register/memory*    | 0 1 1 0 0 0 1 1 mod reg r/m  |                         | 10,11*                                  | 2                       | 9                                       |
| VERR =<br>Verify read access: register/memory*                         | 00001111 0000000 mod 100 r/m |                         | 14,16*                                  | 1                       | 9,16                                    |
| VERR =<br>Verify write access*:                                        | 00001111 000000 mod 101r/m   |                         | 14,16*                                  | 1                       | 9,16                                    |

# 7

# Footnotes

The effective Address (EA) of the memory operand is computed according to the mod and r/m fields:

if mod = 11 then r/m is treated as a REG field

if mod = 00 then  $DISP = 0^*$ , disp-low and disp-high are absent

if mod = 01 then DISP = disp-low sign-extended to 16 bits, disp-high is absent

if mod = 10 then DISP = disp-high: disp-low

if r/m = 000 then EA = (BX) + (SI) + DISP

if r/m = 001 then EA = (BX) + (DI) + DISP

if r/m = 010 then EA = (BP) + (SI) + DISP

if r/m = 011 then EA = (BP) + (DI) + DISP

if r/m = 100 then EA = (SI) + DISP

if r/m = 101 then EA = (DI) + DISP

if r/m = 110 then  $EA = (BP) + DISP^*$ 

if r/m = 111 then EA = (BX) + DISP

DISP follows 2nd byte of instruction (before data if required).

\*Except if mod = 00 and r/m = 110 then EA = disp-high: disp-low.

#### SEGMENT OVERRIDE PREFIX

001 reg 110

REG is assigned according to the following:

| REG | Segment<br>Register |  |
|-----|---------------------|--|
| 00  | ES                  |  |
| 01  | CS                  |  |
| 10  | SS                  |  |
| 11  | CS<br>SS<br>DS      |  |
|     |                     |  |

REG is assigned according to the following table:

| <br>16-Bit | 16-Bit (w = 1) |     | w = 0) |
|------------|----------------|-----|--------|
| 000        | AX             | 000 | AL     |
| 001        | СХ             | 001 | CL     |
| 010        | DX             | 010 | DL     |
| 011        | BX             | 011 | BL     |
| 100        | SP             | 100 | AH     |
| 101        | BP             | 101 | СН     |
| 110        | SI             | 110 | DH     |
| 111        | DI             | 111 | BH     |
|            |                |     |        |

The physical addresses of all operands addressed by the BP register are computed using the SS segment register. The physical addresses of the destination operands of the string primitive operations (those addressed by the DI register) are computed using the ES segment, which may not be overridden.

# 80C286

# High-Speed CMOS 80286 Microprocessor

## DISTINCTIVE CHARACTERISTICS

- Ultra high-performance processor
   —Over 20 times the performance of the 8086
- Wide range of clock rates

  - ----12.5 MHz (80C286-12)
- 100% functionally and pin compatible with NMOS 286

# **GENERAL DESCRIPTION**

The AMD 80C286 is a high-speed implementation of the industry standard 80286 microprocessor. It is 100% functionally compatible with the NMOS version and is a plug compatible replacement. AMD's high-speed CMOS process allows clock speeds much higher than those attainable with NMOS. The 80C286 operates at clock speeds up to 20 MHz.

This CMOS design is a static implementation which allows the processor to be clocked down to DC and still

Static CMOS design for low power operation

Advanced

Micro

Devices

---Standby mode lcc = 5 mA maximum ---Operating mode lcc 220 mA max at 12.5 MHz 260 mA max at 16 MHz 310 mA max at 20 MHz

68-lead PLCC package

retain full register status. This is useful for designs where power consumption is a consideration as the 80C286 uses only 5 mA of supply current when in standby mode. The 80C286 also retains full functionality from its maximum clock frequency through very low frequencies down to DC. Since power consumption is proportional to clock speed, the 80C286 may be clocked at a slower rate to draw less current.





# PIN DESIGNATIONS (sorted by pin number)

| Pin<br>No. | Pin<br>Name     | Pin<br>No. | Pin<br>Name     | Pin<br>No. | Pin<br>Name     |
|------------|-----------------|------------|-----------------|------------|-----------------|
| 1          | BHE             | 24         | A7              | 47         | D13             |
| 2          | NC              | 25         | A6              | 48         | D6              |
| 3          | NC<br>ST<br>SO  | 26         | A5              | 49         | D14             |
| 4          | <u>S1</u>       | 27         | A4              | 50         | D7              |
| 5          | SO              | 28         | A3              | 51         | D15             |
| 6          | PEACK           | 29         | RESET           | 52         | NC              |
| 7          | A23             | 30         | V <sub>cc</sub> | 53         | ERROR           |
| 8          | A22             | 31         | CĽK             | 54         | BUSY            |
| 9          | V <sub>ss</sub> | 32         | A2              | 55         | NC              |
| 10         | A21             | 33         | A1              | 56         | NC              |
| 11         | A20             | 34         | AO              | 57         | INTR            |
| 12         | A19             | 35         | V <sub>ss</sub> | 58         | NC              |
| 13         | A18             | 36         | DO              | 59         | NMI             |
| 14         | A17             | 37         | D8              | 60         | V <sub>ss</sub> |
| 15         | A16             | 38         | D1              | 61         | PEREQ           |
| 16         | A15             | 39         | D9              | 62         | V <sub>cc</sub> |
| 17         | A14             | 40         | D2              | 63         |                 |
| 18         | A13             | 41         | D10             | 64         | HOLD            |
| 19         | A12             | 42         | D3              | 65         | HLDA            |
| 20         | A11             | 43         | D11             | 66         | COD/INTA        |
| 21         | A10             | 44         | D4              | 67         | M/IO            |
| 22         | A9              | 45         | D12             | 68         | LOCK            |
| 23         | A8              | 46         | D5              |            |                 |



# **ORDERING INFORMATION**

#### Standard Products

AMD standard products are available in several packages and operating ranges. The order number (Valid Combination) is formed by a combination of the elements below.



| 30C286-20 |
|-----------|
| 30C286-16 |
| 30C286-12 |
|           |

#### Valid Combinations

Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations, to check on newly released combinations, and to obtain additional data on AMD's standard military grade products.

# PIN DESCRIPTION A23-A0

#### Address Bus (Outputs; Active High)

Address Bus outputs physical memory and I/O port addresses. A0 is Low when data is to be transferred on pins D7–D0. A23–A16 are Low during I/O transfers. The address bus is active High and floats to three-state Off during bus hold acknowledge.

# BHE

#### Bus High Enable (Output; Active Low)

Bus High Enable indicates transfer of data on the upper byte of the data bus D15–D8. Eight-bit oriented devices assigned to the upper byte of the data bus would normally use BHE to condition chip select functions. BHE is active Low and floats to three-state Off during bus hold acknowledge.

#### BHE and A Encodings

| BHE<br>Value | A0<br>Value | Function                                         |
|--------------|-------------|--------------------------------------------------|
| 0            | 0           | Word transfer                                    |
| 0            | 1           | Byte transfer on upper half of data bus (D15–D8) |
| 1            | 0           | Byte transfer on lower half of data bus (D7–D0)  |
| 1            | 1           | Reserved                                         |

# **BUSY, ERROR**

# Processor Extension Busy and Error (Inputs; Active Low)

Processor Extension Busy and Error indicate the operating condition of a processor extension to the 80C286. An active BUSY input stops 80C286 program execution on WAIT and some ESC instructions until BUSY becomes inactive (High). The 80C286 may be interrupted while waiting for BUSY to become inactive. An active ERROR input causes the 80C286 to perform a processor extension interrupt when executing WAIT or some ESC instructions. These inputs are active Low and may be asynchronous to the system clock.

# CLK

#### System Clock (Input; Active High)

System Clock provides the fundamental timing for 80C286 systems. It is divided by two inside the 80C286 to generate the processor clock. The internal divide-bytwo circuitry can be synchronized to an external clock generator by Low-to-High transition on the RESET input.

# COD/INTA

#### Code/Interrupt Acknowledge (Output)

Code/Interrupt Acknowledge distinguishes instruction fetch cycles from memory data read cycles. It also distinguishes interrupt acknowledge cycles from I/O cycles. COD/INTA is pulled up internally during bus hold.

# D15-D0

### Data Bus (Inputs/Outputs; Active High)

Data Bus inputs data during memory, I/O, and interrupt acknowledge read cycles; outputs data during memory and I/O write cycles. The data bus is active High and floats to three-state Off during bus hold acknowledge.

# HOLD, HLDA

#### Bus Hold Request and Hold Acknowledge (Input/Output; Active High)

Bus Hold Request and Hold Acknowledge control ownership of the 80C286 local bus. The HOLD input allows another local bus master to request control of the local bus. When control is granted, the 80C286 will float its bus drivers to three-state Off and then active HLDA, thus entering the bus hold acknowledge condition. The local bus will remain granted to the requesting master until HOLD becomes inactive, which results in the 80C286 deactivating HLDA and regaining control of the local buys. This terminates the bus hold acknowledge condition. HOLD may be asynchronous to the system clock. These signals are active High.

# INTR

### Interrupt Request (Input; Active High)

Interrupt Request requests the 80C286 to suspend its current program execution and service a pending external request. Interrupt requests are masked whenever the interrupt enable bit in the flag word is cleared. When the 80C286 responds to an interrupt request, it performs two interrupt acknowledge bus cycles to read an 8-bit interrupt vector that identifies the source of the interrupt. To assure program interruption, INTR must remain active until the first interrupt acknowledge cycle is completed. INTR is sampled at the beginning of each processor cycles before the current instruction ends in order to interrupt before the next instruction. INTR is level sensitive, active High, and may be asynchronous to the system clock.

# LOCK

# Bus Lock (Output; Active Low)

Bus Lock indicates that other system bus masters are not to gain control of the system bus following the current bus cycle. The LOCK signal may be activated explicitly by the LOCK instruction prefix or automatically by 80C286 hardware during memory XCHG instructions, interrupt acknowledge, or descriptor table access. LOCK is active Low and floats to three-state Off during hold acknowledge.

# M/ĪO

#### Memory/IO Select (Output)

Memory/IO Select distinguishes memory access from I/O access. If High during Ts, a memory cycle or a halt/ shutdown cycle is in progress. If Low, an I/O cycle or an

interrupt acknowledge cycle is in progress. M/IO is pulled up internally during bus hold.

### NC

#### No Connect

No Connect pins should always remain unconnected.

#### NMI

# Non-maskable Interrupt Request (Input; Active High)

Non-maskable Interrupt Request interrupts the 80C286 with an internally supplied vector value of 2. No interrupt acknowledge cycles are performed. The interrupt enable bit in the 80C286 flag word does not affect this input. The NMI input is active High, may be asynchronous to the system clock, and is edge-triggered after internal synchronization. For proper recognition, the input must have been previously Low for at least four system clock cycles.

### PEREQ, PEACK

#### Processor Extension Operand Request (Input; Active High) Processor Extension Acknowledge (Output; Active Low)

Processor Extension Operand Request and Acknowledge extends the memory management and protection capabilities of the 80C286 to processor extensions. The PEREQ input requests the 80C286 to perform a data operand transfer for a processor extension. The PEACK output signals the processor extension when the requested operand is being transferred. PEREQ is active High and may be asynchronous to the system clock. PEACK is active Low.

# READY

#### Bus Ready (Input; Active Low)

Bus Ready terminates a bus cycle. Bus cycles are extended without limit until terminated by READY Low. Bus Ready requires that set-up and hold times relative to the system clock be met for correct operation. READY is ignored during bus hold acknowledge.

#### RESET

#### System Reset (Input; Active High)

System Reset clears the internal logic of the 80C286 and is active High. The 80C286 may be reinitialized at any time with a Low-to-High transition on RESET which remains active for more than 16 system clock cycles. During RESET active, the output pins of the 80C286 enter the state shown below:

80C286 Pin State during Reset

| Pin Value       | Pin Names                        |
|-----------------|----------------------------------|
| 1 (High)        | S0, S1, PEACK, A23-A0, BHE, LOCK |
| 0 (Low)         | M/IO, COD/INTA, HLDA             |
| Three-state Off | D15-D0                           |

Operation of the 80C286 begins after a High-to-Low transition on RESET. The High-to-Low transition of RESET must be synchronous to the system clock. Approximately 50-system clock cycles are required by the 80C286 for internal initializations before the first bus cycle to fetch code from the power-on execution address is performed.

A Low-to-High transition of RESET synchronous to the system clock will begin a new processor cycle at the next High-to-Low transition of the system clock. The Low-to-High transition of RESET may be asynchronous to the system clock; however, in this case it cannot be predetermined which phase of the processor clock will occur during the next system period. Synchronous Low-to-High transitions of RESET are only required for systems where the processor clock must be phase-synchronous to another clock.

#### <u>51, 50</u>

#### Bus Cycle Status (Outputs; Active Low)

Bus Cycle Status indicates initiation of a bus cycle and, along with M/IO and COD/INTA, defines the type of bus cycle. The bus is in a Ts state whenever one or both are Low. S1 and S0 are active Low and are pulled up internally during bus hold.

| COD/<br>INTA | M/IO | <u>51</u> | <u>50</u> | Bus cycle initiated                               |
|--------------|------|-----------|-----------|---------------------------------------------------|
| 0 (Low)      | 0    | 0         | 0         | Interrupt acknowledge                             |
| 0            | 0    | 0         | 1         | Reserved                                          |
| 0            | 0    | 1         | 0         | Reserved                                          |
| 0            | 0    | 1         | 1         | None; not a status cycle                          |
| 0            | 1    | 0         | 0         | If A <sub>1</sub> = 1 then halt; else<br>shutdown |
| 0            | 1    | 0         | 1         | Memory data read                                  |
| 0            | 1    | 1         | 0         | Memory data write                                 |
| 0            | 1    | 1         | 1         | None; not a status cycle                          |
| 1 (High)     | 0    | 0         | 0         | Reserved                                          |
| 1            | 0    | 0         | 1         | I/O Read                                          |
| 1            | 0    | 1         | 0         | I/O Write                                         |
| 1            | 0    | 1         | 1         | None; not a status cycle                          |
| 1            | 1    | 0         | 0         | Reserved                                          |
| 1            | 1    | 0         | 1         | Memory instruction read                           |
| 1            | 1    | 1         | 0         | Reserved                                          |
| 1            | 1    | 1         | 1         | None; not a status cycle                          |

#### Vss

System Ground (Input)

System ground: 0 V.

#### Vcc

System Power (Input)

System power: +5-V power supply.

#### **ABSOLUTE MAXIMUM RATINGS**

| Supply Voltage +8.0 V                   |
|-----------------------------------------|
| Input, Output or I/O                    |
| Voltage Applied GND1.0 V to VDD+1.0 V   |
| Power Dissipation/Speed                 |
| 20 MHz 1.7 W                            |
| 16 MHz 1.4 W                            |
| 12.5 MHz                                |
| Storage Temperature Range65°C to +150°C |
| Junction Temperature                    |
| Lead Temperature                        |
| (Soldering, Ten Seconds)+275°C          |

Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability.

# **OPERATING RANGES**

Range ...... 0 to +100°C case temperature (Meets laptop temperature requirements.)

Operating ranges define those limits between which the functionality of the device is guaranteed.

# DC CHARACTERISTICS over operating range

 $Vcc = +5 V \pm 10\%$  for 80C286-12 and 80C286-16;  $Vcc = +5 V \pm 5\%$  for 80C286-20,  $Tc = 0^{\circ}C$  to  $+100^{\circ}C$ 

| Parameter<br>Symbol | Parameter<br>Description                           | Test Conditions                                      | Min     | Max        | Unit     |
|---------------------|----------------------------------------------------|------------------------------------------------------|---------|------------|----------|
| ViL                 | Input Low Voltage                                  |                                                      | -0.5    | 0.8        | v        |
| ViH                 | Input High Voltage                                 |                                                      | 2.0     | Vcc + 0.5  | V        |
| VILC                | CLK Input Low Voltage                              |                                                      | -0.5    | 1.0        | v        |
| VIHC                | CLK Input High Voltage                             |                                                      | 3.6     | Vcc + 0.5  | V        |
| Vol                 | Output Low Voltage                                 | loL = 2.0 mA                                         | _       | 0.4        | V        |
| Vон                 | Output High Voltage                                | lон =2.0 mA                                          | 3.0     | -          | V        |
|                     |                                                    | lон = −100 mA                                        | Vcc-0.4 |            | V        |
| lı                  | Input Leakage Current                              | V⊪ = GND or Vcc<br>Pins 29, 31, 57, 59,<br>61, 63–64 | -10     | 10         | μΑ       |
| Іѕн                 | Input Sustaining Current on<br>BUSY and ERROR Pins | V <sub>IN</sub> = GND (see Note 5)                   | -30     | -500       | μΑ       |
| Івні                | Input Sustaining Current High                      | VIN = 1.0 V (see Note 1)                             | 38      | 200        | μΑ       |
| Івнн                | Input Sustaining Current High                      | Vin = 3.0 V (see Note 2)                             | -50     | -400       | μΑ       |
| lo                  | Output Leakage Current                             | Vo = GND or Vcc<br>Pins 1, 7–8, 10–28, 32–34         | -10     | 10         | μΑ       |
| ICCOP               | Active Power Supply Current                        | 80C286-12 (see Note 4)<br>80C286-16 (see Note 4)     | -       | 220<br>260 | mA<br>mA |
| Іссяв               | Standby Power Supply Current                       | 80C286-20 (see Note 4)<br>(see Note 3)               | -       | 310<br>5   | mA<br>mA |

Notes: 1. I<sub>BHL</sub> should be measured after lowering V<sub>IN</sub> to GND and then raising to 1.0 V on the following pins: 36–51, 66, 67.

2. I<sub>BHH</sub> should be measured after raising V<sub>IN</sub> to V<sub>cc</sub> and then lowering to 3.0 V on the following pins: 4–6, 36–51, 66–68.

 I<sub>CCSB</sub> tested with the clock stopped in phase two of the processor clock cycle. V<sub>N</sub> = V<sub>cc</sub> or GND, V<sub>cc</sub> = 5.5 V, outputs unloaded.

4.  $I_{cCOP}$  measured at 12.5 MHz for the 80C286-12, 16 MHz for the 80C286-16, and 20 MHz for the 80C286-20.  $V_{IN}$  = 2.4 V or 0.4 V,  $V_{cc}$  = 5.5 V, outputs unloaded.

5.  $I_{SH}$  should be measured after raising  $V_{IN}$  to  $V_{cc}$  and then lowering to GND on pins 53 and 54.

**CAPACITANCE** (T<sub>A</sub> = +25°C; All Measurements Referenced to Device GND)

| Parameter<br>Symbol | Parameter<br>Description | Тур | Unit | Test Conditions |
|---------------------|--------------------------|-----|------|-----------------|
| Ссік                | CLK Input Capacitance    | 10  | pF   | FREQ = 1 MHz    |
| CIN                 | Other Input Capacitance  | 10  | pF   |                 |
| C <sub>I/O</sub>    | I/O Capacitance          | 10  | pF   |                 |

#### SWITCHING CHARACTERISTICS over operating range

 $V_{CC} = +5 V \pm 10\%$  for 80C286-12 and 80C286-16;  $V_{CC} = +5 V \pm 5\%$  for 80C286-20,  $T_{C} = 0^{\circ}C$  to  $+100^{\circ}C$ AC Timings are referenced to 0.8 V and 2.0 V points of the signals as illustrated in datasheet waveforms, for 12.5 and 16 MHz, unless otherwise specified. For 20 MHz, AC timings are referenced to the 1.5 V point of the signals as illustrated in Data Sheet waveforms, unless otherwise specified.

|          | Parameter                       | Test               | 12.5 | MHz | 16 MHz 20 MHz |     |     |     |       |
|----------|---------------------------------|--------------------|------|-----|---------------|-----|-----|-----|-------|
| Symbol   | Description                     | Conditions         | Min  | Max | Min           | Max | Min | Max | Units |
| Timing F | Requirements                    |                    |      |     |               |     |     |     |       |
| 1        | System Clock (CLK) Period       |                    | 40   | -   | 31            | -   | 25  | -   | ns    |
| 2        | System Clock (CLK) Low Time     | @ 1.0 V            | 11   | -   | 7             | -   | 6   |     | ns    |
| 3        | System Clock (CLK) High Time    | @ 3.6 V            | 13   | -   | 11            | -   | 9   | -   | ns    |
| 17       | System Clock (CLK) RISE Time    | 1.0 V to 3.6 V     | -    | 8   | -             | 5   | -   | 4   | ns    |
| 18       | System Clock (CLK) FALL Time    | 3.6 V to 1.0 V     | -    | 8   | -             | 5   | -   | 4   | ns    |
| 4        | Asynchronous Inputs SETUP Time  | (Note 1)           | 15   | -   | 5             | -   | 4   | -   | ns    |
| 5        | Asynchronous Inputs HOLD Time   | (Note 1)           | 15   | -   | 5             | -   | 4   | -   | ns    |
| 6        | RESET SETUP Time                |                    | 10   | -   | 10            | -   | 10  | -   | ns    |
| 7        | RESET HOLD Time                 |                    | 0    | -   | 0             | -   | 0   | -   | ns    |
| 8        | Read Data SETUP Time            |                    | 5    | -   | 5             | -   | 3   | -   | ns    |
| 9        | Read Data HOLD Time             |                    | 4    | -   | 3             | -   | 2   | -   | ns    |
| 10       | READY SETUP Time                |                    | 20   | -   | 12            | -   | 10  | -   | ns    |
| 11       | READY HOLD Time                 |                    | 20   | -   | 5             | -   | 3   | -   | ns    |
| 20       | Input RISE/FALL Times           | 0.8 V to 2.0 V     | -    | 8   | -             | 6   | -   | 6   | ns    |
| Timing I | Responses                       |                    |      |     |               |     |     |     |       |
| 12A      | Status/PEACK Active Delay       | 1, (Notes 3, 6, 7) | 1    | 21  | 1             | 18  | 1   | 15  | ns    |
| 12B      | Status/PEACK Inactive Delay     | 1, (Notes 3, 6)    | 1    | 24  | 1             | 20  | 1   | 16  | ns    |
| 13       | Address Valid Delay             | 1, (Notes 2, 3)    | 1    | 32  | 1             | 27  | 1   | 23  | ns    |
| 14       | Write Data Valid Delay          | 1, (Notes 2, 3)    | 0    | 31  | 0             | 28  | 0   | 27  | ns    |
| 15       | Address/Status/Data Float Delay | 2, (Note 5)        | 0    | 32  | 0             | 29  | 0   | 25  | ns    |
| 16       | HLDA Valid Delay                | 1, (Notes 2, 3, 8) | 0    | 25  | 0             | 25  | 0   | 20  | ns    |
| 19       | Address Valid-Status SETUP Time | 1, (Notes 3, 4)    | 22   | _   | 16            | -   | 9   | -   | ns    |

Notes: 1. Asynchronous inputs are INTR, NMI, HOLD, PEREQ, ERROR, and BUSY. This specification is given only for testing purposes to assure recognition at a specific CLK edge.

2. Delay from 1.0 V on the CLK to 0.8 V or 2.0 V.

3. Output load:  $C_L = 100 \, \text{pF}$ .

4. Delay measured from address either reaching 0.8 V or 2.0 V (valid) to status going active reaching 0.8 V or status going inactive reaching 2.0 V.

5. Delay from 1.0 V on the CLK to Float (no current drive) condition.

6. Delay from 1.0 V on the CLK to 0.8 V for Min (HOLD time) and to 2.0 V for Max (inactive delay).

7. Delay from 1.0 V on the CLK to 2.0 V for Min (HOLD time) and to 0.8 V for Max (active delay).

8. Delay from 1.0 V on the CLK to 2.0 V.

### Switching Test Conditions

| Test Condition | IL (Constant Current Source                                         | CL     |
|----------------|---------------------------------------------------------------------|--------|
| 1              | 2.0 mA                                                              | 100 pF |
| 2              | –6 mA (V <sub>он</sub> to Float)<br>8 mA (V <sub>оL</sub> to Float) | 100 pF |



#### 12.5 MHz and 16 MHz AC Setup, Hold and Delay Time Measurement

09729B-035



09729B-036

20 MHz AC Setup, Hold and Delay Time Measurement



09729B-037

Note: The modified timing is due to the CMDLY signal being active.

# SWITCHING WAVEFORMS (continued) 80C286 Asynchronous Input Signal Timing



Notes: 1. PCLK indicates which processor cycle phase will occur on the next CLK. PCLK may not indicate the correct phase until the first bus cycle is performed.

2. These inputs are asynchronous. The setup and hold times shown assure recognition for testing purposes.

#### 80C286 Reset Input Timing and Subsequent Processor Cycle Phase



Note: When Reset meets the set-up time shown, the next CLK will start or repeat ¢1 of a processor cycle.



09729B-040

Notes: 1. These signals may not be driven by the 80C286 during the time shown. The worst case in terms of latest float time is shown.

- 2. The data bus will be driven as shown if the last cycle before T<sub>1</sub> in the diagram was a write T<sub>c</sub>.
- 3. The 80C286 puts its status pins in a high impedance logic one state during  $T_{H}$ .
- 4. BHE and LOCK are driven at this time but will not become valid until Ts.
- 5. The data bus will remain in three-state Off if a read cycle is performed.



Notes: 1. PEACK always goes active during the first bus operation of a processor extension data operand transfer sequence. The first bus operation will be either a memory read at operand address or I/O read at port address 00FA(H).

2. To prevent a second processor extension data operand transfer, the worst case maximum time (shown above) is: 3×1-12a max-4 min. The actual, configuration dependent, maximum time is: 3×1-12a max-4 min + A×2×1. A is the number of extra T<sub>c</sub> states added to either the first or second bus operation of the processor extension data operand transfer sequence.



Notes: 1. Set-up time for RESET 1 may be violated with the consideration that \$\phi\_1\$ of the processor clock may begin one system CLK period later.

2. Set-up and hold times for RESET ↓ must be met for proper operation, but RESET ↓ may occur during ¢1 or ¢2.

3. The data bus is only guaranteed to be in three-state Off at the time shown.

4. HOLD is acknowledged during RESET, causing HLDA to go active and the appropriate pins to float. If HOLD remains active while RESET goes inactive, the 80C286 remains in HOLD state and will not perform any bus accesses until HOLD is deactivated.

# 80L286

# Low-Power High-Performance Microprocessor with Memory Management and Protection



- High-performance processor (up to 13.3 times IAPX 86 when using the 16-MHz 80L286)
- Identical to the 80286 except consumes less power
- Available in cost-effective Plastic Leaded Chip Carrier (PLCC) package
- Socketed PLCC footprint is compatible with socketed LCC and PGA footprints
- Surface-mountable PLCC for high density board utilization

Advanced

Micro

Devices

- 8-, 10-, and 12.5- and 16-MHz operation
  - Large address space
  - 16-Mb physical
  - 1-Gb virtual memory per task
- Integrated memory management, four-level memory protection and support for virtual memory and operating systems

# **GENERAL DESCRIPTION**

The 80L286 is an advanced, high performance microprocessor, identical to the 80286, except consumes less power. Its reduced power enables the 80L286 to be packaged in low-cost, Plastic Leaded Chip Carrier (PLCC) without a heat sink or heat spreader. Cooler operation also enhances reliability. The PLCC package can be surface-mounted or socketed. The footprint of the socketed PLCC package is identical to the socketed LCC or PGA packages so no board layout change is needed. The 80L286 is available in 8-, 10-, 12-, and 16-MHz speeds and is fully compatible with the 82C288 Bus Controller and the 82284 Clock Driver functions. The 80L286 is upward compatible with iAPX 86 and 88 software. Using iAPX real address mode, the 80L286 is object code compatible with existing iAPX 86, 88 software. In protected virtual address mode, the 80L286 is source code compatible with iAPX 86, 88 software and may require upgrading to use virtual addresses supported by the 80L286's integrated memory management and protection mechanism. Both modes operate at full 80L286 performance and execute a superset of the iAPX 86 and 88 instructions.



# BLOCK DIAGRAM

Publication # 08511 Rev. E Amendment /0 Issue Date: December 1991

# **GENERAL DESCRIPTION (continued)**

The 80L286 provides special operations to support the efficient implementation and execution of operating systems. For example, one instruction can end execution of one task, save its state, switch to a new task,

load its state, and start execution of the new task. The 80L286 also supports virtual memory systems by providing a segment-not-present exception and restartable instructions.

# CONNECTION DIAGRAM Top View



CD010641

As viewed from top of package (PC side of component board)

#### ORDERING INFORMATION Standard Products

AMD standard products are available in several packages and operating ranges. The order number (Valid Combination) is formed by a combination of the elements below.



Blank = Commercial ( $T_{CASE} = 0^{\circ}C$  to +85°C)

| Valid Combinations |                                                 |  |  |  |
|--------------------|-------------------------------------------------|--|--|--|
| N                  | 80L286-16<br>80L286-12<br>80L286-10<br>80L286-8 |  |  |  |

#### Valid Combinations

Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations, to check on newly released combinations, and to obtain additional data on AMD's standard military grade products.

# **PIN DESCRIPTION**

# CLK

# System Clock (Input; Active High)

System Clock provides the fundamental timing for 80L286 systems. It is a 16 MHz signal divided by two inside the 80L286 to generate the 8 MHz processor clock. The internal divide-by-two circuitry can be synchronized to an external clock generator by a Low-to-High transition on the RESET input.

# D0-D15

#### Data Bus (Input/Output; Active High)

Data Bus inputs data during memory, I/O, and interrupt acknowledge read cycles; outputs data during memory and I/O write cycles. The data bus is active High and floats to three-state OFF during bus hold acknowledge.

# A23-A0

#### Address Bus (Output; Active High)

Address Bus outputs physical memory and I/O port addresses. A0 is Low when data is to be transferred on pins D7–D0. A23–A16 are Low during I/O transfers. The address bus is active High and floats to three-state OFF during bus hold acknowledge.

# BHE

#### Bus High Enable (Output; Active Low)

Bus High Enable indicates transfer of data on the upper byte of the data bus D15-D8. Eight-bit oriented devices assigned to the upper byte of the data bus would normally use BHE to condition chip select functions. BHE is active Low and floats to three-state OFF during bus hold acknowledge.

|              | BHE and A <sub>o</sub> Encodings |                                                    |  |  |  |  |  |
|--------------|----------------------------------|----------------------------------------------------|--|--|--|--|--|
| BHE<br>Value | A0<br>Value                      | Function                                           |  |  |  |  |  |
| 0            | 0                                | Word transfer                                      |  |  |  |  |  |
| 0            | 1                                | Byte transfer on upper half of data bus (D15–D8)   |  |  |  |  |  |
| 1            | 0                                | Byte transfer on lower half of data bus<br>(D7–D0) |  |  |  |  |  |
| 1            | 1                                | Reserved                                           |  |  |  |  |  |

# <u>51, 50</u>

# Bus Cycle Status (Output; Active Low)

Bus Cycle Status indicates initiation of a bus cycle and, along with M/IO and COD/INTA, defines the type of bus cycle. The bus is in a Ts state whenever one or both are Low. S1 and S0 are active Low and float to three-state OFF during bus hold acknowledge.

#### 80L286 Bus Cycle Status Definition

| <u>COD/</u><br>INTA | M/ĪŌ | <u>51</u> | <u>50</u> | Bus cycle initiated                |
|---------------------|------|-----------|-----------|------------------------------------|
| 0 (Low)             | 0    | 0         | 0         | Interrupt acknowledge              |
| 0                   | 0    | 0         | 1         | Reserved                           |
| 0                   | 0    | 1         | 0         | Reserved                           |
| 0                   | 0    | 1         | 1         | None; not a status cycle           |
| 0                   | 1    | 0         | 0         | IF A1 = 1 then halt; else shutdown |
| 0                   | 1    | 0         | 1         | Memory data read                   |
| 0                   | 1    | 1         | 0         | Memory data write                  |
| 0                   | 1    | 1         | 1         | None; not a status cycle           |
| 1 (High)            | 0    | 0         | 0         | Reserved                           |
| 1                   | 0    | 0         | 1         | I/O Read                           |
| 1                   | 0    | 1         | 0         | I/O Write                          |
| 1                   | 0    | 1         | 1         | None; not a status cycle           |
| 1                   | 1    | 0         | 0         | Reserved                           |
| 1                   | 1    | 0         | 1         | Memory instruction read            |
| 1                   | 1    | 1         | 0         | Reserved                           |
| 1                   | 1    | 1         | 1         | None; not a status cycle           |

# M/ĪŌ

# Memory/IO Select (Output)

Memory/IO Select distinguishes memory access from I/O access. If High during Ts, a memory cycle or a halt/ shutdown cycle is in progress. If Low, an I/O cycle or an interrupt acknowledge cycle is in progress M/IO floats to three-state OFF during bus hold acknowledge.

# COD/INTA

# Code/Interrupt Acknowledge (Output)

Code/Interrupt Acknowledge distinguishes instruction fetch cycles from memory data read cycles. Also distinguishes interrupt acknowledge cycles from I/O cycles. COD/INTA floats to three-state OFF during bus hold acknowledge.

# LOCK

# Bus Lock (Output; Active Low)

Bus Lock indicates that other system bus masters are not to gain control of the system bus following the current bus cycle. The LOCK signal may be activated explicitly by the "LOCK" instruction prefix or automatically by 80286 hardware during memory XCHG instructions, interrupt acknowledge, or descriptor table access. LOCK is active Low and floats to three-state OFF during hold acknowledge.

# **PIN DESCRIPTION (continued)**

# READY

#### Bus Ready (Input; Active Low)

Bus Ready terminates a bus cycle. Bus cycles are extended without limit until terminated by READY Low. READY is an active Low synchronous input requiring setup and hold times relative to the system clock be met for correct operation. READY is ignored during bus hold acknowledge.

# HOLD, HLDA

# Bus Hold Request and Hold Acknowledge (Input/Output; Active High)

Bus Hold Request and Hold Acknowledge control ownership of the 80L286 local bus. The HOLD input allows another local bus master to request control of the local bus. When control is granted, the 80L286 will float its bus drivers to three-state OFF and then active HLDA, thus entering the bus hold acknowledge condition. The local bus will remain granted to the requesting master until HOLD becomes inactive which results in the 80L286 deactivating HLDA and regaining control of the local buys. This terminates the bus hold acknowledge condition. HOLD may be asynchronous to the system clock. These signals are active HIGH.

# INTR

#### Interrupt Request (Input; Active High)

Interrupt Request requests the 80L286 to suspend its current program execution and service a pending external request. Interrupt requests are masked whenever the interrupt enable bit in the flag word is cleared. When the 80L286 responds to an interrupt request, it performs two interrupt acknowledge bus cycles to read an 8-bit interrupt vector that identifies the source of the interrupt. To assure program interruption, INTR must remain active until the first interrupt acknowledge cycle is completed. INTR is sampled at the beginning of each processor cycles before the current instruction. INTR is level sensitive, active High, and may be asynchronous to the system clock.

# NMI

# Non-maskable Interrupt Request (Input; Active High)

Non-maskable Interrupt Request interrupts the 80L286 with an internally supplied vector value of 2. No interrupt acknowledge cycles are performed. The interrupt enable bit in the 80L286 flag word does not affect this input. The NMI input is active High, may be asynchronous to the system clock, and is edge triggered after internal synchronization. For proper recognition, the input must have been previously Low for at least four system clock cycles and remain High for at least four system clock cycles.

# PEREQ, PEACK

# Processor Extension Operand Request and Acknowledge (Input/Output)

Processor Extension Operand Request and Acknowledge extends the memory management and protection capabilities of the 80L286 to processor extensions. The PEREQ input requests the 80L286 to perform a data operand transfer for a processor extension. The PEACK output signals the processor extension when the requested operand is being transferred. PEREQ is active High and may be asynchronous to the system clock. PEACK is active Low.

# **BUSY**, ERROR

# Processor Extension Busy and Error (Input; Active Low)

Processor Extension Busy and Error indicate the operating condition of a processor extension to the 80L286. An active BUSY input stops 80L286 program execution on WAIT and some ESC instructions until BUSY becomes inactive (High). The 80L286 may be interrupted while waiting for BUSY to become inactive. An active ERROR input causes the 80L286 to perform a processor extension interrupt when executing WAIT or some ESC instructions. These inputs are active Low and may be asynchronous to the system clock.

# RESET

#### System Reset (Input; Active High)

System Reset clears the internal logic of the 80L286 and is active High. The 80L286 may be reinitialized at any time with a Low-to-High transition on RESET which remains active for more than 16 system clock cycles. During RESET active, the output pins of the 80C286 enter the state shown below:

| 80L286 Pin State during Reset          |                                                                    |  |  |
|----------------------------------------|--------------------------------------------------------------------|--|--|
| Pin Value                              | Pin Names                                                          |  |  |
| 1 (High)<br>0 (Low)<br>Three-state OFF | S0, S1, PEACK, A23–A0, BHE, LOCK<br>M/IO, COD/INTA, HLDA<br>D15–D0 |  |  |

Operation of the 80L286 begins after a High-to-Low transition on RESET. The High-to-Low transition of RESET must be synchronous to the system clock. Approximately 50 system clock cycles are required by the 80L286 for internal initializations before the first bus cycle to fetch code from the power-on execution address is performed.

# PIN DESCRIPTION (continued)

A Low-to-High transition of RESET synchronous to the system clock, will begin a new processor cycle at the next High-to-Low transition of the system clock. The Low-to-High transition of RESET may be asynchronous to the system clock; however, in this case it cannot be predetermined which phase of the processor clock will occur during the next system period. Synchronous Low-to-High transitions of RESET are only required for systems where the processor clock must be phase synchronous to another clock.

# Vss

System Ground (Input) System Ground: 0 V.

# Vcc

System Power (Input)

System Power: +5-V power supply.

# CAP

# Substrate Filter Capacitor (Input; Active High)

Substrate Filter Capacitor: a  $0.047 \,\mu\text{F} \pm 20\% \,12$  V capacitor must be connected between this pin and ground. This capacitor filters the output of the internal substrate bias generator. A maximum DC leakage current of 1  $\mu$ A is allowed through the capacitor.

For correct operation of the 80L286, the substrate bias generator must charge this capacitor to its operating voltage. The capacitor charge-up time is 5 ms (max.) after V<sub>CC</sub> and CLK reach their specified AC and DC parameters. RESET may be applied to prevent spurious activity by the CPU during this time. After this time, the 80L286 processor clock can be phase synchronized to another clock by pulsing RESET Low synchronous to the system clock.

# ABSOLUTE MAXIMUM RATINGS

| Storage Temperature     | –65°C to +150°C |
|-------------------------|-----------------|
| Voltage on Any Pin with |                 |
| Respect to Ground       | 1.0 V to 7.0 V  |
| Power Dissipation       | 2.89 Watts      |

Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability.

# **OPERATING RANGES**

Operating Voltage Range  $\dots +4.75$  V to +5.25 V Case Operating Temperature Range  $\dots 0^{\circ}$ C to  $+85^{\circ}$ C

Operating ranges define those limits between which the functionality of the device is guaranteed.

# DC CHARACTERISTICS over operating range

| Parameter<br>Symbol | Parameter<br>Description                        | Test Conditions             | Min. | Max.      | Unit |
|---------------------|-------------------------------------------------|-----------------------------|------|-----------|------|
| VIL                 | Input Low Voltage                               |                             | -0.5 | 0.8       | v    |
| VIH                 | Input High Voltage                              |                             | 2.0  | Vcc + 0.5 | V    |
| Vilc                | CLK Input Low Voltage                           |                             | -0.5 | .6        | V    |
| Vінс                | CLK Input High Voltage                          |                             | 3.8  | Vcc+0.5   | V    |
| Vol                 | Output Low Voltage                              | loL = 2.0 mA                |      | 0.45      | V    |
| Vон                 | Output High Voltage                             | Іон =400 µА                 | 2.4  |           | V    |
| lu                  | Input Leakage Current                           | 0 V ≤ V <sub>IN</sub> ≤ Vcc |      | ±10       | μA   |
| llo                 | Output Leakage Current                          | 0.45 V ≤ Vout ≤ Vcc         |      | ±10       | μΑ   |
| lcc                 | Supply Current                                  | Tc = 0°C                    |      | 550       | mA   |
|                     |                                                 | Tc=85°C                     |      | 475       | mA   |
| CCLK                | CLK Input Capacitance                           | Fc=1 MHz                    |      | 20        | pF   |
| CIN                 | Other Input Capacitance                         | Fc=1 MHz                    |      | 10        | pF   |
| Co                  | Input/Output Capacitance                        | Fc = 1 MHz                  |      | 20        | pF   |
| llo                 | Output Leakage Current                          | 0 V ≤ Vout < 0.45 V         |      | ±1        | mA   |
| lıı.                | Input Sustaining Current on BUSY and ERROR pins | V IN = 0 V                  | 30   | 500       | μА   |
| LCR                 | Input CLK Leakage Current                       | 0.45≤VIN≤Vcc                |      | ± 10      | μΑ   |
|                     | Input CLK Leakage Current                       | $0 V \le V_{IN} \le 0.45 V$ |      | ±1        | mA   |

 $(T_{CASE} = 0^{\circ}C \text{ to } 85^{\circ}C, V_{CC} = 5 V \pm 5\%)$ 

Note: Low temperature is worst case.

# SWITCHING CHARACTERISTICS

 $V_{CC} = +5 V \pm 5\%$ ,  $T_{CASE} = 0^{\circ}C$  to  $+85^{\circ}C$ 

AC timings are referenced to 0.8 V and 2.0 V points of the signals as illustrated in data sheet waveforms, unless otherwise noted.

| Parameter | Parameter                             |                        | 8 N  | IHz  | 10   | MHz  |      |
|-----------|---------------------------------------|------------------------|------|------|------|------|------|
| Symbol    | Description                           | <b>Test Conditions</b> | Min. | Max. | Min. | Max. | Unit |
| 1         | System Clock (CLK) Period             |                        | 62   | 125  | 50   | 125  | ns   |
| 2         | System Clock (CLK) Low Time           | @ 1.0 V                | 15   | 100  | 12   | 109  | ns   |
| 3         | System Clock (CLK) High Time          | @ 3.6 V                | 25   | 110  | 16   | 113  | ns   |
| 17        | System Clock (CLK) RISE Time          | 1.0 V to 3.6 V         |      | 10   |      | 8    | ns   |
| 18        | System Clock (CLK) FALL Time          | 3.6 V to 1.0 V         |      | 10   |      | 8    | ns   |
| 4         | Asynchronous Inputs SETUP Time        | (Note 1)               | 20   |      | 20   |      | ns   |
| 5         | Asynchronous Inputs HOLD Time         | (Note 1)               | 20   |      | 20   |      | ns   |
| 6         | RESET SETUP Time                      |                        | 28   |      | 23   |      | ns   |
| 7         | RESET HOLD Time                       |                        | 5    |      | 5    |      | ns   |
| 8         | Read Data SETUP Time                  |                        | 10   |      | 8    |      | ns   |
| 9         | Read Data HOLD Time                   |                        | 8    |      | 8    |      | ns   |
| 10        | READY SETUP Time                      |                        | 38   |      | 26   |      | ns   |
| 11        | READY HOLD Time                       |                        | 25   |      | 25   |      | ns   |
| 12        | Status/PEACK Valid Delay              | (Notes 2, 3)           | 1    | 40   | -    | -    | ns   |
| 12A       | Status/PEACK Active Delay             | (Notes 2, 3)           | -    | -    | 1    | 22   | ns   |
| 12B       | Status/PEACK Inactive Delay           | (Notes 2, 3)           | -    | -    | 1    | 30   | ns   |
| 13        | Address Valid Delay                   | (Notes 2, 3)           | 1    | 60   | 1    | 35   | ns   |
| 14        | Write Data Valid Delay                | (Notes 2, 3)           | 0    | 50   | 0    | 30   | ns   |
| 15        | Address/Status/Data Float Delay       | (Notes 2, 4)           | 0    | 50   | 0    | 47   | ns   |
| 16        | HLDA Valid Delay                      | (Notes 2, 3)           | 0    | 50   | 0    | 47   | ns   |
| 19        | Address Valid to Status SETUP<br>Time | (Notes 3, 5, 6)        | 38   |      | 27   |      | ns   |

| Parameter   | Parameter                             |                 | 12.5 | MHz  | 16   | MHz  |     |
|-------------|---------------------------------------|-----------------|------|------|------|------|-----|
| Symbol      | Description                           | Test Conditions | Min. | Max. | Min. | Max. | Uni |
| 1           | System Clock (CLK) Period             |                 | 40   | 125  | 31   | 125  | ns  |
| 2           | System Clock (CLK) Low Time           | @ 1.0 V         | 11   | 112  | 10   | 113  | ns  |
| 3           | System Clock (CLK) High Time          | @ 3.6 V         | 13   | 114  | 12   | 115  | ns  |
| 17          | System Clock (CLK) RISE Time          | 1.0 V to 3.6 V  |      | 8    |      | 5    | ns  |
| 18          | System Clock (CLK) FALL Time          | 3.6 V to 1.0 V  |      | 8    |      | 4    | ns  |
| 4           | Asynchronous Inputs SETUP Time        | (Note 1)        | 15   |      | 11   |      | ns  |
| 5           | Asynchronous Inputs HOLD Time         | (Note 1)        | 15   |      | 11   |      | ns  |
| 5<br>6<br>7 | RESET SETUP Time                      |                 | 18   |      | 14   |      | ns  |
| 7           | RESET HOLD Time                       |                 | 5    |      | 3    |      | ns  |
| 8           | Read Data SETUP Time                  |                 | 5    |      | 5    |      | ns  |
| 9           | Read Data HOLD Time                   |                 | 6    |      | 5    |      | ns  |
| 10          | READY SETUP Time                      |                 | 22   |      | 15   |      | ns  |
| 11          | READY HOLD Time                       |                 | 20   |      | 15   |      | ns  |
| 12          | Status/PEACK Valid Delay              | (Notes 2, 3)    | -    | -    | -    | _    | ns  |
| 12A         | Status/PEACK Active Delay             | (Notes 2,3)     | 3    | 18   | 1    | 18   | ns  |
| 12B         | Status/PEACK Inactive Delay           | (Notes 2,3)     | 3    | 20   | 1    | 20   | ns  |
| 13          | Address Valid Delay                   | (Notes 2, 3)    | 1    | 32   | 1    | 29   | ns  |
| 14          | Write Data Valid Delay                | (Notes 2, 3)    | 0    | 30   | 0    | 22   | ns  |
| 15          | Address/Status/Data Float Delay       | (Notes 2, 4)    | 0    | 32   | 0    | 29   | ns  |
| 16          | HLDA Valid Delay                      | (Notes 2, 3)    | 0    | 25   | 0    | 25   | ns  |
| 19          | Address Valid to Status SETUP<br>Time | (Notes 3, 5, 6) | 22   |      | 22   |      | ns  |

# SWITCHING CHARACTERISTICS (continued)

Notes: 1. Asynchronous inputs are INTR, NMI, HOLD, PEREQ, ERROR, and BUSY. This specification is given only for testing purposes, to assure recognition at a specific CLK edge.

2. Delay from 1.0 V on the CLK to 0.8 V or 2.0 V or float on the output as appropriate for valid or floating condition.

3. Output load:  $C_L = 100 \, \text{pF}$ .

4. Float condition occurs when output current is less than  $I_{Lo}$  in magnitude.

- 5. Delay measured from address either reaching 0.8 V or 2.0 V (valid) to status going active reaching 2.0 V or status going inactive reaching 0.8 V.
- For load capacitance of 10 pF on STATUS/PEACK lines, subtract typically 7 ns for 8 MHz spec, and maximum 7 ns for 10 MHz spec.





Major Cycle Timing



WF007983

Note: MWTC is valid at this point only if CMDLY is Low.

# SWITCHING WAVEFORMS (continued)

80L286 Asynchronous Input Signal Timing





times shown assure recognition for testing purposes.



80L286 Reset Input Timing and Subsequent Processor

WF007930 Note: When RESET meets the set-up time shown, the next

CLK will start or repeat of a processor cycle.



WF009942

- Notes: 1. These signals may not be driven by the 80L286 during the time shown. The worst case in terms of latest float time is shown.
  - 2. The data bus will be driven as shown if the last cycle before T<sub>1</sub> in the diagram was a write T<sub>c</sub>.
  - 3. The 80L286 floats its status pins during T\_{\tiny H}. External 20 k $\Omega$  resistors keep these signals High.
  - 4. For HOLD request set-up to HLDA, refer to Figure 34.
  - 5. BHE and LOCK are driven at this time but will not become valid until Ts.
  - 6. The data bus will remain in three-state OFF if a read cycle is performed.

# 80L286 PEREQ/PEACK Timing Required PEREQ Timing for One Transfer Only



- Notes: 1. PEACK always goes active during the first bus operation of a processor extension data operand transfer sequence. The first bus operation will be either a memory read at operand address or I/O read at port address 00FA(H).
  - 2. To prevent a second processor extension data operand transfer, the worst case maximum time (shown above) is: 3x 1–12a max–4 min. The actual, configuration dependent, maximum time is: 3 x 1–12a max–4 min + A x 2 x 1. A is the number of extra T<sub>c</sub> states added to either the first or second bus operation of the processor extension data operand transfer sequence.



Notes: 1. Set-up time for RESET 1 may be violated with the consideration that \$1\$ of the processor clock may begin one system CLK period later.

2. Set-up and hold times for RESET  $\downarrow$  must be met for proper operation, but RESET  $\downarrow$  may occur during  $\phi$ 1 or  $\phi$ 2.

3. The data bus is only guaranteed to be in three-state OFF at the time shown.

4. HOLD is acknowledged during RESET, causing HLDA to go active and the appropriate pins to float. If HOLD remains active while RESET goes inactive, the 80L286 remains in HOLD state and will not perform any bus accesses until HOLD is deactivated.

|            | Am286™ZX/Am286LX<br>Integrated Processors |
|------------|-------------------------------------------|
| AWARD      | <b>Integrated Processors</b>              |
| EXCELLENCE | PC-AT Motherboard-on-a-Chip               |

# **DISTINCTIVE CHARACTERISTICS**

- Integrates entire IBM PC-AT motherboard logic, plus enhancements
  - -80C286 Microprocessor Core
  - -Enhanced Bus Controller
  - -Enhanced Clock Generator
  - -DMA Controllers
  - -Interrupt Controllers
  - -Counter/Timer
  - -Real Time Clock and CMOS Static RAM
- Direct connection to DRAM, AMD 80C287<sup>™</sup> math coprocessor, EPROMs, keyboard controller, and AT-bus slots eliminates the need for buffers and other glue logic
- Full hardware support for EMS 4.0 memory management with 128 EMS registers allows fast switching for multitasking systems
- 100% compatible with the IBM PC-AT standard

- Low-power operation plus power saving features for battery powered notebook/handheld systems (Am286LX processor only)
- Industry standard I/O port 92H fast reset and GATEA20 features for high-speed switching between real and protected mode
- Page mode/interleave DRAM Controller with direct interface to 256-kbit, 1-Mbit, and 4-Mbit DRAMs—supports up to 16 Mb of physical memory
- Complete line of support products available including demo boards, ICE, BIOS, and EMS drivers
- Flexible clock speeds up to 16 MHz
- 28mm x 28mm, 216-Pin EIAJ Plastic Quad Flat Pack (PQFP), with socket available

# **GENERAL DESCRIPTION**

The Am286ZX and Am286LX integrated processors are AMD proprietary PC-AT motherboard-on-a-chip devices for personal computers. They integrate all of the logic functions from the original IBM PC-AT motherboard, plus enhancements, onto one chip. Included are the 80C286 microprocessor, all of the AT standard peripherals, and memory management to provide a high-performance, low-cost, low-power system solution for personal computers. The high level of integration provided by the Am286ZX/LX integrated processor allows designers to reduce the size, power consumption, and cost of a PC-AT compatible system, while increasing functionality and adding features. The Am286ZX/LX integrated processor is ideal for design of desktop, notebook, handheld, embedded, and other industry standard AT personal computers, where performance, size, power consumption, and cost are critical factors. The Am286LX processor version provides additional power saving features including CPU shutdown mode, system shutdown mode, staggered DRAM refresh, and slow-refresh DRAM support.

Figure 1 shows a system block diagram for an AT motherboard, illustrating the high level of integration achieved by the Am286ZX/LX integrated processor.



14753C-001

# Figure 1. PC-AT System Block Diagram Using the Am286ZX/LX Integrated Processor

# SYSTEM ARCHITECTURE

Figure 2 shows the Am286ZX/LX Integrated Processor Bus Interface. The AT System Bus (S Bus), Memory Bus (M Bus), and the I/O Bus (X Bus) directly interface to the rest of the system components. Optional buffers are shown for applications that require extended S-bus drive capability and/or four DRAM banks. The Am286ZX/LX integrated processor is designed to drive two bus slots and two DRAM banks, without requiring buffers.



Figure 2. Am286ZX/LX Integrated Processor Bus Interface



Figure 3. Am286ZX/LX Integrated Processor Internal Block Diagram

# AMD 🗲



Figure 4. Am286ZX/LX Integrated Processor Logic Symbol



Note: Pin 1 is marked for orientation.

14753C--005



| Pin No.  | Pin Name        | Pin No. | Pin Name        | Pin No. | Pin Name        | Pin No. | Pin Name          |
|----------|-----------------|---------|-----------------|---------|-----------------|---------|-------------------|
| 1        | LDATDIR         | 56      | V <sub>cc</sub> | 111     | SA18            | 166     | MDP0              |
| 2        | SBENA           | 57      | V <sub>ss</sub> | 112     | LA18            | 167     | MDP1              |
| 3        | MASTER          | 58      | XA12            | 113     | SA19            | 168     | SD0               |
| 4        | DRQ7            | 59      | XA11            | 114     | LA19            | 169     | SD1               |
| 5        | DACK7           | 60      | XA10            | 115     | LA19<br>LA20    | 170     | SD2               |
| 6        | DRQ6            |         |                 |         |                 | 171     | SD3               |
| 7        | DACK6           | 61      | XA9             | 116     | LA21            | 172     | SD4               |
| 8        | DRQ5            | 62      | XA8             | 117     | LA22            | 173     | SD5               |
| 9        | DACK5           | 63      | XA7             | 118     | LA23            | 174     | SD6               |
| 10       | DRQ0            | 64      | XA6             | 119     | RAS0            | 175     | SD7               |
| 11       | V <sub>cc</sub> | 65      | XA5             | 120     | RAS1            | 176     | V <sub>cc</sub>   |
| 12       |                 | 66      | XA4             | 121     | V <sub>cc</sub> | 177     | V <sub>ss</sub>   |
| 13       | DACK0           | 67      | XA3             | 122     | V <sub>ss</sub> | 178     | SD8               |
| 13       | DACKU           | 68      | XA2             | 123     | RAS2            | 178     | SD9               |
| 14       | MEMR            | 69      | XA1             | 124     | RAS3            |         | SD3               |
| 15       | MEMW            |         |                 | 125     | CASO            | 180     | 1                 |
| 16       | IRQ14           | 70      | XAO             | 126     | CAS1            | 181     | SD11              |
| 10       | 1               | 71      | V <sub>cc</sub> | 127     | V <sub>cc</sub> | 182     | SD12              |
|          | IRQ15           | 72      | V <sub>ss</sub> | 128     | V <sub>ss</sub> | 183     | SD13              |
| 18       | IRQ12           | 73      | MAO             | 129     | CAS2            | 184     | SD14              |
| 19       | IRQ11           | 74      | MA1             | 130     | CAS3            | 185     | SD15              |
| 20       | IRQ10           | 75      | MA2             | 131     | MWENL           | 186     | V <sub>batt</sub> |
| 21       | IOCS16          | 76      | MA3             | 131     | MWENH           | 187     | RTCLKX1           |
| 22       | MEMCS16         | 77      | MA4             |         | 1               | 188     | RTCLKX2           |
| 23       | SBHE            | 78      | V <sub>cc</sub> | 133     | DLYOUT          | 189     | V <sub>cc</sub>   |
| 24       | BALE            | 79      | V <sub>ss</sub> | 134     | DLO             | 190     | V <sub>ss</sub>   |
| 25       | DMATC           | 80      | MA5             | 135     | V <sub>cc</sub> | 191     | LCSROM            |
| 26       | DACK2           | 81      | V <sub>cc</sub> | 136     | V <sub>ss</sub> | 192     | XMEMW             |
|          |                 | 82      | V <sub>ss</sub> | 137     | DL1             | 193     | XMEMR             |
| 27       | V <sub>cc</sub> | 83      | MA6             | 138     | XD0             | 194     | CS8042            |
| 28       | V <sub>ss</sub> | 84      | MAO<br>MA7      | 139     | XD1             | 195     | XIOR              |
| 29       | IRQ3            |         | 1               | 140     | XD2             | 196     | XIOW              |
| 30       | IRQ4            | 85      | MA8<br>MA9      | 141     | XD3             | 197     | RC                |
| 31       | IRQ5            | 86      |                 | 142     | XD4             | 198     | A20G              |
| 32       | IRQ6            | 87      | MA10            | 143     | XD5             | 199     | RESET             |
| 33       | IRQ7            | 88      | V <sub>cc</sub> | 144     | XD6             | 200     | KEYCLK            |
| 34       | REFRESH         | 89      | V <sub>ss</sub> | 145     | XD7             | 201     | KBINT             |
| 35       | DRQ1            | 90      | SA0             | 145     |                 | 202     | PWRGOOD           |
| 36       | SYSCLK          | 91      | SA1             | 140     | V <sub>cc</sub> | 203     | PROCLK            |
| 37       | DACK1           | 92      | SA2             | 1       | V <sub>ss</sub> | 203     | IOCLK             |
| 38       | DRQ3            | 93      | SA3             | 148     | MD0             |         |                   |
| 39       | DACK3           | 94      | SA4             | 149     | MD1             | 205     | F14MHZ            |
| 40       | WOI             | 95      | SA5             | 150     | MD2             | 206     | V <sub>cc</sub>   |
| 41       | IOR             | 96      | SA6             | 151     | MD3             | 207     |                   |
| 42       | SMEMW           |         |                 | 152     | MD4             | 208     | SPKR              |
| 43       | SMEMR           | 97      | SA7             | 153     | MD5             | 209     | P287CLK           |
| 44       | IOCHRDY         | 98      | SA8             | 154     | MD6             | 210     | NPCS              |
| 45       | AEN             | 99      | SA9             | 155     | MD7             | 211     | BUSY              |
| 46       | POWS            | 100     | SA10            | 156     | MD8             | 212     | PEREQ             |
| 47       | DRQ2            | 101     | SA11            | 157     | MD9             | 213     | PEACK             |
| 48       | IRQ9            | 102     | SA12            | 158     | MD10            | 214     | RESET287          |
| 49       | RESETDRV        | 103     | SA13            | 159     | MD11            | 215     | P287ERR           |
| 50       | IOCHK           | 104     | SA14            | 160     | V <sub>cc</sub> | 216     | HDATDIR           |
|          |                 | 105     | SA15            | 161     | V <sub>ss</sub> |         |                   |
| 51<br>52 | XA17            | 106     | SA16            | 162     | MD12            |         |                   |
| 52<br>52 | XA16            | 107     | SA17            | 163     | MD12<br>MD13    |         |                   |
| 53       | XA15            | 1       |                 | 163     | MD13<br>MD14    |         |                   |
| 54       | XA14            | 108     | V <sub>cc</sub> | 164     | MD14<br>MD15    |         |                   |
| 55       | XA13            | 109     | V <sub>ss</sub> | 100     |                 |         |                   |
|          | 1               | 110     | LA17            | 1       | 1               |         | 1                 |

# 

- ononconcert in 12

| PIN DESI     | GNATION TA | BLE (Sorte | d by Pin Nan | ne)               |         |                 |         |
|--------------|------------|------------|--------------|-------------------|---------|-----------------|---------|
| Pin Name     | Pin No.    | Pin Name   | Pin No.      | Pin Name          | Pin No. | Pin Name        | Pin No. |
| A20G         | 198        | LA23       | 118          | RESETDRV          | 49      | V <sub>cc</sub> | 121     |
| AEN          | 45         | LCSROM     | 191          | RTCLKX1           | 187     | V <sub>cc</sub> | 127     |
| BALE         | 24         | LDATDIR    | 1            | RTCLKX2           | 188     | V <sub>cc</sub> | 135     |
| BUSY         | 211        | MAO        | 73           | SA0               | 90      | V <sub>cc</sub> | 146     |
| CASO         | 125        | MA1        | 74           | SA1               | 91      | V <sub>cc</sub> | 160     |
| CAS1         | 126        | MA2        | 75           | SA2               | 92      | V <sub>cc</sub> | 176     |
| CAS2         | 129        | МАЗ        | 76           | SA3               | 93      | V <sub>cc</sub> | 189     |
| <b>CAS</b> 3 | 130        | MA4        | 77           | SA4               | 94      | V <sub>cc</sub> | 206     |
| CS8042       | 194        | MA5        | 80           | SA5               | 95      | V <sub>ss</sub> | 12      |
| DACK0        | 13         | MA6        | 83           | SA6               | 96      | V <sub>ss</sub> | 28      |
| DACK1        | 37         | MA7        | 84           | SA7               | 97      | V <sub>ss</sub> | 57      |
| DACK2        | 26         | MA8        | 85           | SA8               | 98      | Vss<br>Vss      | 72      |
| DACK3        | 39         | MA9        | 86           | SA9               | 99      |                 | 72      |
| DACK5        | 9          | MA10       | 80           | SA10              | 100     | V <sub>ss</sub> | 82      |
| DACK5        | 7          | MATER      | 87<br>3      | SA10<br>SA11      | 100     | V <sub>ss</sub> | 82      |
|              |            |            |              |                   |         | V <sub>ss</sub> | 1       |
| DACK7        | 5          | MD0        | 148          | SA12              | 102     | V <sub>ss</sub> | 109     |
| DL0          | 134        | MD1        | 149          | SA13              | 103     | V <sub>ss</sub> | 122     |
| DL1          | 137        | MD2        | 150          | SA14              | 104     | V <sub>ss</sub> | 128     |
| DLYOUT       | 133        | MD3        | 151          | SA15              | 105     | V <sub>ss</sub> | 136     |
| DMATC        | 25         | MD4        | 152          | SA16              | 106     | V <sub>ss</sub> | 147     |
| DRQ0         | 10         | MD5        | 153          | SA17              | 107     | V <sub>ss</sub> | 161     |
| DRQ1         | 35         | MD6        | 154          | SA18              | 111     | V <sub>ss</sub> | 177     |
| DRQ2         | 47         | MD7        | 155          | SA19              | 113     | V <sub>ss</sub> | 190     |
| DRQ3         | 38         | MD8        | 156          | SBENA             | 2       | V <sub>ss</sub> | 207     |
| DRQ5         | 8          | MD9        | 157          | SBHE              | 23      | XA0             | 70      |
| DRQ6         | 6          | MD10       | 158          | SD0               | 168     | XA1             | 69      |
| DRQ7         | 4          | MD11       | 159          | SD1               | 169     | XA2             | 68      |
| F14MHZ       | 205        | MD12       | 162          | SD2               | 170     | ХАЗ             | 67      |
| HDATDIR      | 216        | MD13       | 163          | SD3               | 171     | XA4             | 66      |
| <b>IOCHK</b> | 50         | MD14       | 164          | SD4               | 172     | XA5             | 65      |
| IOCHRDY      | 44         | MD15       | 165          | SD5               | 173     | XA6             | 64      |
| IOCLK        | 204        | MDP0       | 166          | SD6               | 174     | XA7             | 63      |
| IOCS16       | 21         | MDP1       | 167          | SD7               | 175     | XA8             | 62      |
| IOR          | 41         | MEMCS16    | 22           | SD8               | 178     | XA9             | 61      |
| WOI          | 40         | MEMR       | 14           | SD9               | 179     | XA10            | 60      |
| IRQ3         | 29         | MEMW       | 15           | SD10              | 180     | XA10<br>XA11    | 59      |
| IRQ4         | 30         | MWENH      | 132          | SD11              | 181     | XA12            | 59      |
| IRQ5         | 31         | MWENL      | 131          | SD12              | 182     | XA12<br>XA13    | 1       |
| IRQ6         | 32         | NPCS       | 210          | SD12<br>SD13      | 183     |                 | 55      |
|              |            |            |              |                   |         | XA14            | 54      |
| IRQ7         | 33         | POWS       | 46           | SD14              | 184     | XA15            | 53      |
| IRQ9         | 48         | P287CLK    | 209          | SD15              | 185     | XA16            | 52      |
| IRQ10        | 20         | P287ERR    | 215          | SMEMR             | 43      | XA17            | 51      |
| IRQ11        | 19         | PEACK      | 213          | SMEMW             | 42      | XD0             | 138     |
| IRQ12        | 18         | PEREQ      | 212          | SPKR              | 208     | XD1             | 139     |
| IRQ14        | 16         | PROCLK     | 203          | SYSCLK            | 36      | XD2             | 140     |
| IRQ15        | 17         | PWRGOOD    | 202          | V <sub>batt</sub> | 186     | XD3             | 141     |
| KBINT        | 201        | RAS0       | 119          | V <sub>cc</sub>   | 11      | XD4             | 142     |
| KEYCLK       | 200        | RAS1       | 120          | V <sub>cc</sub>   | 27      | XD5             | 143     |
| LA17         | 110        | RAS2       | 123          | V <sub>cc</sub>   | 56      | XD6             | 144     |
| LA18         | 112        | RAS3       | 124          | V <sub>cc</sub>   | 71      | XD7             | 145     |
| LA19         | 114        | RC         | 197          | V <sub>cc</sub>   | 78      | XIOR            | 195     |
| LA20         | 115        | REFRESH    | 34           | V <sub>cc</sub>   | 81      | XIOW            | 196     |
| LA21         | 116        | RESET      | 199          | V <sub>cc</sub>   | 88      | XMEMR           | 193     |
| LA22         | 117        | RESET287   | 214          | V <sub>cc</sub>   | 108     | XMEMW           | 193     |
|              |            | 1.2021207  | 517          | • 66              |         |                 | 1.52    |



# ORDERING INFORMATION Standard Products

AMD standard products are available in several packages and operating ranges. The order number (Valid Combination) is formed by a combination of the items below:



| Valid Combinations |            |  |  |  |
|--------------------|------------|--|--|--|
| NG286LX            | -12, -12/S |  |  |  |
| NG280LX            | -16, -16/S |  |  |  |
| NG286ZX            | -12, -12/S |  |  |  |
| NG280ZA            | -16, -16/S |  |  |  |

#### Valid Combinations

Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations, and to check on newly released valid combinations.

\*Note: Order Trimmed and Formed PQFP in multiples of 24 units/tray, 4 trays/dry pack.

# PIN DESCRIPTION Clocks

# PROCLK Processor Clock (Input)

Processor clock supplies a clock to the clock divider and multiplexer logic.

# IOCLK

# I/O Clock (Input)

I/O clock supplies a clock to the clock divider and multiplexer logic.

# F14MHZ 14.318-MHz Frequency (Input)

14.318-MHz Frequency input to a divider that generates the clock for the internal 82C54 counter/timer.

# RTCLKX1

# **RTC X1 Crystal Connection (Input)**

Input to the crystal oscillator that supplies the internal real-time clock's 32-kHz frequency.

# RTCLKX2

# **RTC X2 Crystal Connection (Output)**

Output of the crystal oscillator that supplies the internal real-time clock's 32-kHz frequency.

# AT System Bus (S Bus) Interface

# SYSCLK

# System Clock (Output)

System Clock is the S-bus synchronous clock. It is always half the frequency of the AT state machine clock.

#### LA23–LA17 Extended Address (Inputs/Outputs)

# Extended Address lines are used to address up to 16 Mb of memory on the S Bus. These signals are not latched internally with BALE and are valid earlier in the cycle than the SA lines. These pins can be driven by the internal CPU or DMA controller or by an external bus master.

# SA19-SA0

# S-Bus Address (Inputs/Outputs)

S-Bus Address lines are used to address memory and I/O devices on the S Bus and are valid for the entire bus cycle. These pins can be driven by the internal CPU or DMA controller or by an external bus master.

# SBHE

# S-Bus Byte High Enable (Input/Output; Active Low)

S-Bus Byte High Enable signal indicates a transfer of data on the upper byte of the data bus, SD15–SD8, to a 16-bit, S-bus peripheral. This signal can be driven by the internal CPU or DMA controller or by an external bus master.

# SD15–SD0 S-Bus Data (Inputs/Outputs)

S-Bus Data lines are used to transfer data on the S Bus. All 8-bit devices use SD7–SD0. All 16-bit devices use SD15–SD0. Transfers may be initiated by the internal CPU or DMA controller or by an external bus master.

# BALE

# Buffered Address Latch Enable (Output; Active High)

Buffered Address Latch Enable is an active High output used to latch valid addresses and memory decodes during CPU transfer cycles. BALE is forced High during DMA and external bus master cycles.

# IOW

# I/O Write (Input/Output; Active Low)

I/O Write is an active Low control signal for I/O write cycles on the S Bus. This signal can be driven by the internal CPU or DMA controller or by an external bus master.

# IOR

# I/O Read (Input/Output; Active Low)

I/O Read is an active Low control signal for I/O read cycles on the S Bus. This signal can be driven by the internal CPU or DMA controller or by an external bus master.

# MEMW

# Memory Write (Input/Output; Active Low)

Memory Write is an active Low control signal for all memory write cycles on the S Bus. This signal can be driven by the internal CPU or DMA controller or by an external bus master.

# MEMR

# Memory Read (Input/Output; Active Low)

Memory Read is an active Low control signal for all memory read cycles on the S Bus. This signal can be driven by the internal CPU or DMA controller or by an external bus master.

# **SMEMW**

# S-Memory Write (Output; Active Low)

S-Memory Write is an active Low control signal for write cycles to S-bus memory with addresses less than 1Mb.

# SMEMR

# S-Memory Read (Output; Active Low)

S-Memory Read is an active Low control signal for read cycles to S-bus memory with addresses less than 1Mb.



#### MEMCS16

#### Memory 16-Bit Chip Select (Input; Active Low)

Memory 16-Bit Chip Select is an active Low input signal indicating that the present S-bus transfer cycle is a 16-bit memory cycle. This pin should be driven by open collector or three-state buffers. There is an internal pull-up on the pin which can be disabled.

#### IOCS16

#### I/O 16-Bit Chip Select (Input; Active Low)

I/O 16-Bit Chip Select is an active Low input signal indicating that the present S-bus transfer cycle is a 16-bit I/O cycle. This pin is also sampled at reset time to determine ROM size. This pin should be driven by open collector or three-state buffers. There is an internal pull-up on the pin which can be disabled.

#### POWS

#### Zero Wait State (Input; Active Low)

Zero Wait State is an active Low input signal indicating to the bus controller that it can complete the present bus cycle without inserting any additional wait states. This pin should be driven by open collector or three-state buffers. There is an internal pull-up on the pin which can be disabled.

#### IOCHK

#### I/O Channel Check (Input; Active Low)

I/O Channel Check is an active Low input from the S Bus which can cause a NMI to be generated to the internal CPU, indicating a I/O error condition on the S Bus. This pin should be driven by open collector or three-state buffers. There is an internal pull-up on the pin which can be disabled.

# IOCHRDY

#### I/O Channel Ready (Input; Active High)

I/O Channel Ready is an active High signal from the S Bus. When Low it indicates a "not ready" condition and inserts wait states in AT I/O or memory cycles. When High, it allows the current S-bus cycle to complete. This pin should be driven by open collector or three-state buffers. There is an internal pull-up on the pin which can be disabled.

# AEN

#### Address Enable (Output; Active High)

Address Enable is an active High output signal used to indicate to S-bus I/O device address decoders that a DMA cycle is in progress. When active, the internal DMA controller has control of the S-bus address, data, and control pins.

# MASTER

#### Master (Input/Output; Active Low)

MASTER is usually an active Low input signal asserted by an external device on the S Bus to allow S-bus peripherals to access system resources as a bus master. In Bus Master Mode, this pin is an output asserted when a mastering cycle is in progress. This pin should be driven by open collector or three-state buffers. There is an internal pull-up on the pin which can be disabled.

#### DRQ7–DRQ5, DRQ2–DRQ0 DMA Request (Inputs; Active High)

DMA Request signals 7–5 and 2–0 are asynchronous DMA channel request inputs used by peripheral devices to gain access to a DMA service. These pins can also be used by bus masters to gain S-bus control. DRQ2–DRQ0 perform 8-bit DMA transfers and DRQ7–DRQ5 perform 16-bit DMA transfers. There are weak pull-downs on these pins.

# DRQ3

#### DMA Request (Input/Output)

DMA Request 3 is usually defined the same as the other DRQ inputs. In Bus Master Mode, this pin is an output asserted to request bus access on a host system's bus. There is a weak pull-down on this pin.

# DACK7–DACK5, DACK2–DACK0 DMA Acknowledge (Outputs; Active Low)

DMA Acknowledge signals 7–5 and 2–0 are active Low output pins which acknowledge their corresponding DMA requests.

#### DACK3

#### DMA Acknowledge 3 (Input/Output; Active Low)

DMA Acknowledge 3 is usually defined the same as the other  $\overrightarrow{DACK}$  outputs. In Bus Master Mode, this pin is an input which senses the status of a bus request to the host system.

#### DMATC

# DMA Terminal Count (Output; Active High)

DMA Terminal Count is an active High output signal indicating that terminal count for a DMA channel has been reached.

# REFRESH

### Refresh (Input/Output; Active Low)

REFRESH is an active Low signal to indicate a memory refresh cycle. This signal can be driven by an external bus master. There is an internal pull-up on the pin which can be disabled.

# IRQ15–IRQ14, IRQ12–IRQ9, IRQ7–IRQ3 Interrupt Request (Inputs; Active Low)

Interrupt Request input pins signal the internal 82C59 interrupt controllers that an I/O device needs attention. There are weak pull-ups on these pins.

# RESETDRV

# Reset Drive (Output; Active High)

Reset Drive is an active High signal used to reset or initialize system logic at power-up time. It is synchronous to SYSCLK.

# SBENA

# S-Bus Buffer Enable (Output; Active Low)

S-Bus Buffer Enable is an active Low enable for the S-bus address and data expansion buffers.

# HDATDIR

# High Data Direction (Output; Active High)

High Data Direction is an active High direction control pin for the high byte of the S-bus data buffer. A logic High on this pin indicates a drive direction out from the chip.

# LDATDIR

# Low Data Direction (Output; Active High)

Low Data Direction is an active High direction control pin for the low byte of the S-bus data buffer. A logic High on this pin indicates a drive direction out from the chip.

# **DRAM Interface**

# RAS3-RAS0

# Row Address Strobe (Outputs; Active Low)

Row Address Strobes are active Low outputs used by the DRAMs as RAS signals to clock in row addresses for each of the 4 possible DRAM banks.

# CAS3-CAS0

# Column Address Strobe (Outputs; Active Low)

Column Address Strobes are active Low outputs used by the DRAMs as CAS signals to clock in column addresses for each of the 4 possible DRAM banks.

# MA10–MA0 Memory Address (Outputs)

Memory Address lines are multiplexed outputs and convey the following information: row addresses during RAS signals, column addresses during CAS signals, and refresh addresses during refresh cycles. 256-kbit DRAMs use MA8–MA0; 1-Mbit DRAMs use MA9–MA0; and, 4-Mbit DRAMs use MA10–MA0.

# MD15-MD0 Memory Data (Inputs/Outputs)

Memory Data bus transfers data to/from the DRAMs and the AMD 80C287 math coprocessor. The high byte of the bus, MD15–MD8, is also used for transfers involving 16-bit ROM and 16-bit X-bus I/O devices.

#### MDP1-MDP0

#### Memory Data Parity (Inputs/Outputs)

Memory Data Parity bits 1 and 0 transfer parity bit information to/from the optional parity DRAM. Parity is generated and verified internally. MDP0 is the parity for the low byte and MDP1 is the parity for the high byte.

# **MWENH**

#### Memory Write Enable High (Output; Active Low)

Memory Write Enable High is an active Low output for the high byte DRAM write enable.

# MWENL

#### Memory Write Enable Low (Output; Active Low)

Memory Write Enable Low is an active Low output for the low byte DRAM write enable.

# DLYOUT

# Delay Line Out (Output; Active High)

Delay Line Out is an active High output to the delay line for generating DRAM control signals.

# DL1-DL0

# Delay Line (Inputs; Active High)

Delay Line inputs 1 and 0 are active High inputs from two taps of a delay line that generate DRAM control signals.

# **X-Bus Interface**

#### XA17–XA0 X-Bus Address (Outputs)

X-Bus Address lines provide addressing for the BIOS ROM, keyboard controller, AMD 80C287 math coprocessor, and other X-bus peripherals.

# XD7-XD0

# X-Bus Data (Inputs/Outputs)

X-Bus Data lines are used to transfer the low 8 bits of data to/from X-bus devices such as the keyboard controller, BIOS ROM, and other X-bus peripherals.



# XIOW

#### X-Bus I/O Write (Output; Active Low)

X-Bus I/O Write is an active Low control signal directing an I/O port to accept data from the XD Bus.

# XIOR

# X-Bus I/O Read (Output; Active Low)

X-Bus I/O Read is an active Low control signal directing an I/O port to place data on the XD Bus.

### **XMEMW**

#### X-Bus Memory (Output; Active Low)

X-Bus Memory Write is an active Low control signal for memory write cycles on the X Bus.

# **XMEMR**

#### X-Bus Memory Read (Output; Active Low)

X-Bus Memory Read is an active Low control signal for memory read cycles on the X Bus, such as BIOS ROM reads.

# **Coprocessor Interface**

#### P287CLK 287 Clock (Output)

287 Clock provides the output clock to the math coprocessor (AMD 80C287 math coprocessor). The clock is generated by the clock divider and multiplexer logic, and is derived from PROCLK or IOCLK.

# NPCS

#### Numeric Processor Chip Select (Output; Active Low)

Numeric Processor Chip Select is an active Low output which indicates a data transfer involving the AMD 80C287 math coprocessor.

# BUSY

# Busy (Input; Active Low)

BUSY is an active Low input from the AMD 80C287 math coprocessor indicating it is executing an instruction. There is a weak internal pull-up resistor on this pin.

# PEREQ

#### Processor Extension Request (Input; Active High)

Processor Extension Request is an active High input pin which indicates that the AMD 80C287 math coprocessor is ready to transfer data to/from the CPU. There is a weak pull-down on this pin.

# PEACK

# Processor Extension Acknowledge (Output; Active Low)

Processor Extension Acknowledge is an active Low output which indicates that the requested transfer due to an active PEREQ has been completed.

#### RESET287 287 Reset (Output; Active High)

287 Reset is an active High output signal which resets the AMD 80C287 math coprocessor.

# P287ERR

#### 287 Error (Input; Active Low)

287 Error is an active Low input which indicates an AMD 80C287 math coprocessor error condition and can trigger the coprocessor interrupt to the interrupt controller. There is a weak pull-up on this pin.

# **Keyboard Controller Interface**

# **CS8042**

# 8042 Chip Select (Input/Output; Active Low)

8042 Chip Select is an active Low signal used for selecting the external keyboard controller. If the XT keyboard interface is enabled, the pin definition changes to XTKBDATA, a bi-directional serial data transfer line with an internal pull-up.

# RC

#### Reset CPU (Input; Active Low)

Reset CPU is an active Low input signal which will activate the internal CPU's reset when active. This is generated from the 8042 keyboard controller.

#### A20G

#### Address 20 Gate (Input)

Address 20 Gate input for CPU address line 20. A logic High on this input will enable A20 pass-through from the CPU. A logic Low will force the internal A20 inactive. This signal is generated by the 8042 keyboard controller.

# RESET

#### Reset (Output; Active Low)

RESET is an active Low output, CPU clock synchronized reset signal derived from PWRGOOD. It is usually used to reset the keyboard controller. If the XT keyboard interface is enabled, the pin definition changes to XTKBRST, an I/O controlled reset output for an XT keyboard.

# KEYCLK

# Keyboard Clock (Input/Output)

Keyboard Clock provides the output clock to the keyboard controller. The clock is generated by the clock divider and multiplexer logic and can be derived from several clock sources. If the XT keyboard interface is enabled, the pin definition changes to XTKBCLK, an I/O controlled clock line with an internal pull-up.

# KBINT

#### Keyboard Interrupt (Input)

Keyboard Interrupt is a direct connection to the IRQ1 input on the master 82C59A.

# 

a up an iana mantan a

# **Miscellaneous Signals**

# LCSROM

ROM Chip Select (Output; Active Low)

ROM Chip Select is an active Low output which provides the chip select for the BIOS ROM/EPROM.

# PWRGOOD

### Power Good (Input; Active High)

Power Good is an active High input signal which indicates a stable system power condition. This is normally driven by the power supply. A logic Low on this input resets the device. There is a schmitt trigger input on this pin.

#### SPKR Speaker (Output)

Speaker output signal is the output of the internal tone generation logic which includes one channel of the internal 82C54 timer. This is a standard TTL level output.

VBATT

Negative Battery Voltage input to power the internal Real Time Clock and CMOS memory.

Vcc

Power.

Vss

Ground.

# FUNCTIONAL DESCRIPTION 80C286 and Standard Peripherals

#### 80C286 Microprocessor Core

The Am286ZX/LX integrated processor integrates AMD's CMOS 80C286 microprocessor as the core of the internal system. The 80C286 core maintains the complete functional features of a standard 80C286. This includes full 80286 instruction set, registers, status information, internal memory organization, 16 Mb of physical and 1 Gb of virtual address space, all address-ing modes, address and data segmentation, pipelining schemes, real and protected mode environments with four levels of memory protection, interrupt priorities, and halt and shut down cycles. See the 80C286 data sheet (order #11625) for more information.

In the Am286ZX/LX integrated processor, the core is designed to be fully static. This means that the Am286ZX/LX integrated processor can operate anywhere from its maximum speed down to 0 MHz. Power consumption is significantly reduced by lowering the clock speed. For maximum power saving, the clock may be shut off completely. The Am286ZX/LX integrated processor retains its state while the processor and peripheral clocks are stopped, and then continues to operate from its original state when these clocks are resumed.

# **DMA Controllers**

Two identical 9517/8237-compatible DMA controllers and a page register are integrated into the Am286ZX/LX  $\,$ 

integrated processor. DMA1 occupies addresses 000H–00FH and DMA2 occupies addresses 0C0H –0DFH. Each controller is a four channel DMA device which generates the memory addresses and control signals necessary to directly transfer information between a peripheral device and memory. This allows transfer of information at higher speeds with little CPU intervention. The two DMA controllers are internally cascaded to provide four DMA channels for 8-bit transfers (DMA1) and three DMA channels for 16-bit transfers (DMA2). DMA2 Channel 0 is internally cascaded.

The programmable registers in the Am286ZX/LX integrated processor allow independent control for both 8-bit and 16-bit transfers by inserting wait states. Each DMA channel has a pair of 16-bit counters and a pair of reload registers for each counter. This allows up to 64-kb block transfers with DMA1 and up to 128-kb block transfers with DMA2. Several modes of operations are possible using programmable features in the registers.

The page registers are used to generate the high order addresses during DMA cycles. Only eight of these registers are used, but all 16 are included to maintain PC-AT compatibility. Each DMA channel has a register associated with it, with the exception of Channel 0 of DMA2. The Am286ZX/LX integrated processor includes weak pull-downs on the DRQ input pins.



14753C-006

Figure 6. DMA Block Diagram

# Interrupt Controllers

Two identical, 8259-compatible interrupt controllers, INTC1 and INTC2, are integrated into the Am286ZX/LX integrated processor. They accept requests from peripherals, resolve priority on pending interrupts and interrupts in service, issue an interrupt request to the processor, and provide interrupt vectors for interrupt service routines.

The two devices are internally connected and must be programmed to operate in cascade mode for operation of all 15 interrupt channels. INTC1 occupies addresses 020H-021H and is configured for master operation in cascade mode. INTC2 occupies addresses 0A0H-0A1H and is configured for slave operation. The interrupt request output signal from INTC2 (INT) is internally connected to the interrupt request input Channel 2 (IRQ2) of INTC1. This configuration is compatible with the IBM PC-AT.

The output of Timer 0 in the counter/timer section is connected to Channel 0 (IRQ0) of INTC1. The interrupt request from the Real Time Clock is connected to Channel 0 (IRQ8) of INTC2. The other interrupts are also available to external peripherals, as in the AT architecture. The Am286ZX/LX integrated processor includes weak pull-ups on the interrupt input pins.



Figure 7. Interrupt Controller Block Diagram

# Counter/Timer

A three-channel, general purpose, 82C54-compatible, 16-bit counter/timer is integrated into the Am286ZX/LX integrated processor. It provides critical timing parameters for the PC system under software control. It can be programmed to count in binary or in BCD. Each counter operates independently of the other two and can be programmed for operation as a timer or a counter. All three are controlled from a common set of control logic, which provides controls to load, read, configure, and control each counter. This counter occupies I/O addresses 040H–043H. There are six modes of operation:

- Mode 0 Interrupt on terminal count
- Mode 1 Hardware re-triggerable one-shot
- Mode 2 Rate generator
- Mode 3 Square wave generator
- Mode 4 Software triggered strobe
- Mode 5 Hardware re-triggered strobe

All three counters are driven from a common clock, which is internally generated as a divide by 12 of the F14MHZ pin. The output of Counter 0 is connected to IRQ0 interrupt input of INTC1, and may be used as a software "timer tick" for time-keeping and taskswitching activities. The output of Counter 1 is internally connected as a refresh request. The output of Counter 2 is internally connected to speaker logic.

#### **Real Time Clock and CMOS Static RAM**

A Real Time Clock (RTC) function is implemented in the Am286ZX/LX integrated processor at I/O address space 070H and 071H. It combines a complete time-ofday clock with alarm, a one hundred year calendar, a programmable periodic interrupt, and 114 bytes of CMOS static RAM. The static RAM is battery backed-up to save its contents in the absence of main system power. Also, since it is battery backed-up, the clock counting continues to maintain the date and time when power is shut off.

The Am286ZX/LX integrated processor includes a lowpower CMOS crystal oscillator to handle the 32-kHz clock signal to the RTC. This feature saves board space by integrating the oscillator on-chip, and it extends the life of the system's battery.

An indexed addressing scheme is implemented to write to the 128 locations of the RTC. The index register is written with the address of the memory location, which acts as an address pointer. Data is then transferred to the location. The RTC contains 128 addressable locations which include: 10 locations for time, calendar and alarm data, 4 general purpose registers, and 114 static RAM locations.

The alarm bytes are programmed to generate an interrupt at a specific time, or can be programmed to generate a periodic interrupt. The static RAM from index addresses 0EH to 7FH are not affected by the RTC. This area can be used to store configuration and calibration information. Since this section is battery powered, it will not lose data when the system is turned off.



Figure 8. Counter/Timer Block Diagram

# System Control Logic

# **Enhanced Clock Generator**

The Am286ZX/LX integrated processor provides very flexible clock selections for the CPU clock, AT-bus clock, keyboard clock, and AMD 80C287 math coprocessor clock. Configuration registers are provided to select these clocks to suit system applications. An 82284-compatible logic block is used to generate the READY signal for the internal CPU.

PROCLK and IOCLK are the main input clock pins for the clock generator. Depending on the system design, the Am286ZX/LX integrated processor can be configured to select internal CPU clock, AMD 80C287 math coprocessor clock, AT state machine clock, and keyboard clock from either PROCLK or IOCLK. Flexible divisors are provided to select desired operational speeds. SYSCLK is always half the frequency of the AT-state machine clock (ATSMCLK).

The dividers are at the divide by four setting at power up. The default selections for clock source and divider can be modified by writing to configuration registers. The Am286ZX/LX integrated processor contains logic to prevent clock pulse width violations when changing any clock. In order to achieve maximum system performance, it is desirable to run the processor at the maximum rated speed. Internal state machines maintain asynchronous protocols for high-speed operation of the CPU while allowing slower S-bus cycles.

#### **Enhanced Bus Controller**

The Am286ZX/LX integrated processor's Enhanced Bus Controller provides the control logic for routing addresses and data through the Am286ZX/LX integrated processor for every type of data transaction. At its core, it provides analogous functions to the 82284 and 82288. The rest of the logic transforms the Am286ZX/LX integrated processor into advanced high-speed, AT-compatible products. These advanced functions include the following:

- Dual state machine design—A high-speed CPU synchronous state machine for DRAM and internal register access, and an S-bus state machine which can operate asynchronously to the CPU.
- AT-compatible, high-byte routing, and word-to-byte transaction conversion for bus transfers to 8-bit peripherals.
- Address/data routing and buffer control for all possible data transfers, including CPU, DMA, Refresh, and bus mastering.



Figure 9. Clock Generator Block Diagram



Figure 10. Bus Controller Block Diagram

# **DRAM Interface**

The Am286ZX/LX integrated processor supports a robust and easily implemented memory system providing zero or near zero wait state performance, while maintaining low system cost with inexpensive DRAMs. Its memory array is configured to directly support two banks of 16/18 bits (four 8/9 bit SIMMs). Two additional banks can be added by adding buffers on the memory address lines. Each bank consists of 16-bit data and two optional parity bits, one for each byte. They can be implemented with 256-kbit, 1-Mbit, or 4-Mbit DRAMs for a maximum of 8 Mb per bank, up to a total of 16 Mb in multiple banks.

The array supports page mode accesses to decrease memory speed requirements. If adjacent arrays are

populated with the same DRAM size, two or four way interleaving may be selected to increase the page mode hit ratio. The Am286ZX/LX integrated processor can handle memory size mixing. If interleaving is enabled, only the same size banks are interleaved.

In page mode operation, consecutive accesses within DRAM page boundaries are reduced to zero wait states. Wait states occur only when changing pages or crossing page boundaries. In the case of identical banks, interleaving may be enabled to double (2 way) or quadruple (4 way) the page size. This increases the page mode hit ratio. The following table shows the average number of wait states, plus the recommended memory speeds.

| CPU<br>Speed | Mode            | Average<br>Wait States | DRAM<br>Speed |
|--------------|-----------------|------------------------|---------------|
| 12 MHz       | Normal          | 0                      | 80 ns         |
| 12 MHz       | Page/Interleave | 0.6                    | 120 ns        |
| 12 MHz       | Normal          | 1                      | 100 ns        |
| 16 MHz       | Normal          | 1                      | 80 ns         |
| 16 MHz       | Page/Interleave | 0.6                    | 100 ns        |

The Am286ZX/LX integrated processor can also interface to SRAM via the S Bus or the high-speed memory bus that normally connects to DRAM.

#### Shadow RAM/384-kb Relocation

Typically, system ROM BIOS and other ROM extensions require multiple wait states for access, presenting a significant system performance bottleneck. Shadow RAM is a method to eliminate this slow speed path. Using the ROM chip-select control facilities, slow access ROMs can be disabled and replaced with fast access write protected RAM in the 384 kb of unused RAM area. Three 8-bit registers provide Shadow RAM mapping control of 384-kb shadow memory. This area is divided into 24 blocks of 16 kb.

Upon system initialization, the BIOS copies itself and any ROM extensions into a temporary location in system memory. The ROMs are then disabled with the appropriate bits in the ROM control register, while at the same time the shadow RAM is enabled. The ROM contents are then copied into the RAM at original locations, and the appropriate 16-kb pages are write protected. Other sections of RAM can be moved and write protected for other system functions, such as consolidating ROM extensions and write protecting system scratch-pad RAM.

However, if only 1 Mb of RAM is present, the 384 kb between 640 kb and 1 Mb can be relocated to above the 1-Mb boundary, providing 384 kb of extended memory to the user. This feature is enabled by the REL bit in the DRAM Control Register (DRC). The Am286ZX/LX integrated processor provides the flexibility of offering either Shadow RAM or 384-kb relocation by setting the appropriate configuration registers. These two features are mutually exclusive.



b. 384-kb Relocation



#### **EMS 4.0 Memory Management**

The principle behind EMS 4.0 is that any 16-kb page within a large protected memory area can be mapped to a location within the IBM-PC address space (0–1 Mb). This provides a method to implement extremely large data sets and multi-tasking within the memory limitations of MS-DOS. The Am286ZX/LX Address Translation Unit (ATU) provides all the basic hardware functionality to completely map the entire PC address space. The DRAM controller can be programmed to reserve up to 15.5 Mb of local memory for use with EMS. Using the ATU, any 16-kb page in the lower 1 Mb of memory can be mapped to any page in the reserved EMS address space.

The PC logical memory space of 1 Mb is considered as 64 pages, with each page 16 kb ( $64 \times 16 \text{ kb} = 1 \text{ Mb}$ ). The EMS memory mapping involves allocating one or more of these pages as a page frame. Accesses to this page frame are translated to addresses in the reserved memory area via a set of pointers in hardware. These

pointers are stored in 2 sets of 64 Address Translation Registers (Main and Alternate sets), which are read and written by means of an address translation control register and four address translation register I/O address locations.

MS-DOS application software takes advantage of EMS 4.0 by writing code that conforms to the LIM EMS 4.0 specification.

The Am286ZX/LX integrated processor has two sets of 64 EMS registers. Each set of 64 registers forms a translation set which can map the entire 0–1 Mb address space. By having two sets, EMS software can perform high-speed switching between the two translation sets of EMS memory. When performing this type of multitasking, the addresses (pointers) of EMS memory for each task are loaded into both the primary and alternate EMS registers. This allows for a task switch to occur without reloading the pointers to each task. This greatly improves performance of task switching which is utilized by multitasking EMS software.



14753C-012

#### Figure 12. EMS Address Translation

#### Power Saving (Am286LX Processor Only)

Power saving modes are included in the Am286LX processor to allow the system BIOS to control power consumption. Power consumption is controlled by selectively turning off on-chip clocks. The Am286LX processor has two power saving modes—CPU stop clock and system standby. CPU stop clock mode shuts down the CPU clock until the next interrupt. By stopping CPU activity the system draws less current. In this way the system can stop the CPU when CPU interaction is not required. For example, in a keyboard polling loop, the system can stop the CPU between keyboard interrupts.

System standby mode goes even further by stopping all clocks that are not essential for DRAM refresh. This mode could be used in conjunction with slowrefresh DRAMs to basically turn the system off, except for maintaining data in the RAMs. The system can be switched into system standby mode during long periods of inactivity to substantially improve battery life. Normal implementation of the Am286LX processor's power saving modes requires no external circuitry. Instead, the modes are enabled by software.

The Am286LX processor also incorporates staggered DRAM refresh. By staggering the refresh of the DRAMs, instantaneous current demands are greatly reduced, providing a lower current surge on the system's power source. The Am286LX processor also has support for slow-refresh DRAMs. With slow-refresh memory, data does not have to be refreshed as often, which reduces power consumption.

#### **External Interfaces**

#### AT System Bus

The Am286ZX/LX integrated processor can directly drive the AT Bus within the limits of the DC current drive specification. For a fully buffered AT Bus, the Am286ZX/LX integrated processor provides three buffer control output pins. They are SBENA, HDATDIR, and LDATDIR.



14753C-013







#### **Keyboard Controller**

The Am286ZX/LX integrated processor provides a direct interface for an AT-type keyboard controller (8042), or an XT-type keyboard. The type of keyboard interface is selected with a configuration register. The KEYCLK output is driven by the clock generation logic, with four selectable clock inputs (see Enhanced Clock Generation). The keyboard controller is attached as an X-bus device.

#### AMD 80C287 Math Coprocessor

The Am286ZX/LX integrated processor provides a direct interface to the AMD 80C287 math coprocessor. The clock generation for the AMD 80C287 math coprocessor is driven by the clock generation logic, with two selectable clock inputs (see Enhanced Clock Generator). The AMD 80C287 math coprocessor is attached with the X-bus address lines and the M-bus data lines. The Am286ZX/LX integrated processor provides AT-standard I/O command decodes for "clear busy" (port 0F1h). Standard coprocessor interconnect is shown in the following diagram.

#### ROM/EPROM

The Am286ZX/LX integrated processor provides support for 8- or 16-bit EPROM configurations. The EPROM(s) are attached as an X-bus device, with highbyte data off the M Bus for 16-bit configurations.

#### Expansion Bus (X Bus)

In addition to the EPROM, keyboard controller, and AMD 80C287 math coprocessor peripherals, the Am286ZX/LX integrated processor's X Bus can be used to attach other I/O devices. Eight configuration registers are available to map any 8-byte I/O address range onto the X Bus. 16-bit I/O is also supported.

Any I/O device such as serial ports, parallel ports, and floppy disk controllers may be attached to the Am286ZX/LX integrated processor's X Bus. Any of the four 8-byte DMA channels (0–3) can be mapped to the X Bus as well. For example, a floppy disk controller would use DMA Channel 2.



14753C-015

# Figure 15. Keyboard Controller Interface



14753C-016

#### Figure 16. AMD 80C287 Math Coprocessor Interface



Note: This is the default configuration.





Note: Open-collector buffer between RESET and IOCS16.

Figure 18. 16-Bit EPROM Configuration

#### **Additional Features**

#### Fast RESET and Fast GATEA20

The Am286ZX/LX integrated processor provides two features which enhance the system's performance fast RESET and fast GATEA20. Normally, system software calls for a BIOS routine which issues two commands to switch the processor from protected mode to real mode. First, a RESET command is written to the 8042-keyboard controller; then the GATEA20 command is written to the 8042 controller. This imposes a performance limitation due to the slow 8042. The Am286ZX/LX integrated processor provides the fast RESET and fast GATEA20 features to bypass the keyboard controller and reduce the mode switch time. The Am286ZX/LX integrated processor conforms to the industry standard port 92h location to perform a reset to real mode.

These features greatly improve performance in operating environments like OS/2 and DOS extenders that frequently switch between real and protected mode during execution.

#### **Bus Master Mode**

The Am286ZX/LX integrated processor is normally the main CPU of an AT-architecture motherboard. However, the Am286ZX/LX integrated processor's Bus Master Mode allows it to act as a Bus Master peripheral connected to the expansion bus of a host system. This allows the Am286ZX/LX integrated processor to be the main CPU on a high-performance bus-master add-in card. The Am286ZX/LX integrated processor directly supports industry standard architecture (ISA) bus mastering and, with extended logic, MCA and EISA systems. Selecting bus master mode changes the operating mode of some of the S-bus pins to allow direct connection of the Am286ZX/LX integrated processor to the system.

#### NMI and Port B Logic

Industry standard non-maskable interrupt (NMI) logic is provided. This includes the AT-standard port B register at I/O address 061h, and the NMI enable register at I/O address 070h.

14753C-017

#### **ABSOLUTE MAXIMUM RATINGS**

| Ambient Temperature under Bias55°C to +125°C |
|----------------------------------------------|
| Storage Temperature65°C to +150°C            |
| Junction Temperature +175°C                  |
| Lead Temperature (10 seconds) +275°C         |
| Supply Voltage to Ground Potential           |
| Continuous                                   |
| DC Voltage Applied to Outputs0.5 to Vcc Max  |
| DC Input Voltage –0.5 to Vcc Max             |
| DC Output Current ±30 mA                     |
| DC Input Current10 mA to +10 mA              |

Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability.

#### OPERATING RANGES

| Ambient Temperature (T <sub>A</sub> ) | 0°C to +70°C       |
|---------------------------------------|--------------------|
| Supply Voltage (Vcc)                  | +4.75 V to +5.25 V |
| Battery Voltage (VBATT)               | 3.0 V to -4.5 V    |

Operating ranges define those limits between which the functionality of the device is guaranteed.

DC CHARACTERISTICS over COMMERCIAL operating ranges

| Parameter<br>Symbol | Parameter Descriptions             | Notes and Conditions                              | Min   | Max                   | Unit |
|---------------------|------------------------------------|---------------------------------------------------|-------|-----------------------|------|
| V <sub>IL</sub>     | Input Low Voltage                  |                                                   | 0.5   | 0.8                   | V    |
| V <sub>IH</sub>     | Input High Voltage                 |                                                   | 2.0   | V <sub>cc</sub> + 0.5 | V    |
| VILC                | CLK Input Low Voltage (Note 11)    |                                                   | -0.5  | 0.8                   | v    |
| VIHC                | CLK Input High Voltage (Note 11)   |                                                   | 3.6   | V <sub>cc</sub> +0.5  | v    |
| Vol                 | Output Low Voltage                 | I <sub>oL</sub> = See Note 10                     |       | 0.4                   | V    |
| V <sub>он</sub>     | Output High Voltage                | I <sub>он</sub> =See Note 10                      | 3.0   | -                     | V    |
| I,                  | Input Leakage Current              | V <sub>IN</sub> =GND or V <sub>cc</sub>           | -10   | 10                    | μA   |
| l <sub>oz</sub>     | Output Leakage Current             | $V_o = GND \text{ or } V_{cc}$                    | -10   | 10                    | μA   |
| I <sub>ccsc</sub>   | Supply Current (Notes 1, 13)       | 16 MHz CPU<br>12.5 MHz CPU                        |       | 30<br>28              | mA   |
| I <sub>ccss</sub>   | Supply Current (Notes 2, 13)       | 16 MHz CPU<br>12.5 MHz CPU                        |       | 24<br>22              | mA   |
| I <sub>CCFS</sub>   | Supply Current (Notes 3, 13)       | 16 MHz CPU<br>12.5 MHz CPU                        |       | 5<br>5                | mA   |
| Icc                 | Supply Current (Note 14)           | 16 MHz CPU<br>12.5 MHz CPU                        |       | 240<br>190            | mA   |
| I <sub>CCBATT</sub> | RTC Battery Backup Supply Current  | V <sub>BATT</sub> = -3.0 V (Note 12)              |       | 20                    | μA   |
|                     | Pull Up Loading Current (Note 4)   | $V_{IN} = 0.4 \text{ V}, V_{CC} = 5.25 \text{ V}$ | -0.40 | -0.10                 | mA   |
|                     | Pull Up Loading Current (Note 5)   | $V_{IN} = 0.4 \text{ V}, V_{cc} = 5.25 \text{ V}$ | -4.50 | -1.50                 | mA   |
| IL <sub>load3</sub> | Pull Up Loading Current (Note 6)   | $V_{IN} = 0.4 \text{ V}, V_{cc} = 5.25 \text{ V}$ | -9.0  | -3.0                  | mA   |
| $IL_{load4}$        | Pull Up Loading Current (Note 7)   | $V_{iN} = 3.0 \text{ V}, V_{cc} = 5.25 \text{ V}$ | -0.30 | -0.05                 | mA   |
| $IL_{load5}$        | Pull Up Loading Current (Note 8)   | $V_{IN} = 0.4 \text{ V}, V_{cc} = 5.25 \text{ V}$ | -14.0 | -5.0                  | mA   |
|                     | Pull Down Loading Current (Note 9) | $V_{IN} = 3.0 \text{ V}, V_{CC} = 5.25 \text{ V}$ | 0.05  | 0.40                  | μA   |

Notes:1. Stop Clock Mode (Am286LX processor only): CTSC bit set, input clocks running, CPU clock stopped, peripheral clocks and

- System Standby Mode (Am286LX processor only): SSBY bit set, input clocks running, CPU and Peripheral clocks stopped,
- set, input clocks running, GPO and Peripheral Social Support, refresh running.
  Full Standby Mode: All input clocks stopped, including 32KHz and F14MHz. This is traditional CMQS standby current.
  Pull up current for the SA, SD, IRQ, MEMR, MEMW, IOR, IOW, SBHE, BUSY, and P287ERR pins.
  Pull up current for the MASTER, IOCHRDY, IOCHK pins.
  Pull up current for the REFRESH, IOCS16, MEMCS16, and POWS pins.
  Pull up current for the XA pin.

- Pull up current for the XA pin.
   Pull up current for the KEYCLK and CS8042 pins.
- Pull down current for the DRQ and PEREQ pins.
   The Am286ZX/LX integrated processors have several output buffer types, each with different IoL/IoH characteristics.
- They are characterized by the following table.
   Includes <u>pins PROCLK</u>, IOCLK, KEYCLK (XT keyboard mode), CS8042 (XT keyboard mode), and PWRGOOD, IOCHK.
- 12. See Battery Backup Test diagram. 13.  $V_{IN}$  = Vcc or GND, Vcc = 5.25 V, outputs loaded with 50 pF.
- 14. VIN = 0 V or 4 V, Vcc = 5.25 V, outputs loaded with 50 pF.
- 0.05 0.40 uΑ Pin Group CL IOL, IOH SA, SD, MEMR, MEMW, IOR, IOW, RESETDRY 100 pF 6 mA LA, SMEMR, SMEMW, SYSCLK, MASTER, REFRESH, SBHE, DMATC, BALE, AEN, SBENA, 4 mA 100 pF XD, XA, XIOR, XIOW, RESET, DACK XMEMR. XMEMW. LCSROM 4 mA 50 pF SPKR 4 mA 150 pF MA 2 mA 260 pF MD, MDP 2 mA 100 pF MWENH, MWENL 2 mA 260 pF RAS. CAS 2 mA 200 pF DLYOUT, P287CLK, NPCS, RESET287, PEACK, 2 mA 50 pF HDATDIR, LDATDIR

### CAPACITANCE

T<sub>A</sub> = +25°C; all measurements referenced to device GND.

| Parameter<br>Symbol | Parameter Descriptions         | Тур | Unit |
|---------------------|--------------------------------|-----|------|
| C <sub>IN</sub>     | Input Pin Capacitance          | 10  | pf   |
| C <sub>io</sub>     | Bi-directional Pin Capacitance | 10  | pf   |
| C <sub>out</sub>    | Output Pin Capacitance         | 10  | pf   |

Note: Pin capacitance is characterized at a frequency of 1 MHz, and is tested on a sample basis only.

#### SWITCHING CHARACTERISTICS over operating range Method of Specification

The Am286ZX/LX integrated processor has several modes of operation. Given the number of options available and the internal generation of clocks, some explanation of the specification method is in order. The following points must be noted:

- 1. In order to test and verify the timing parameters, the specifications are from external input to output definitions.
- The designator "srcCLK" refers to the input clocks PROCLK or IOCLK. Internal and external clocks are generated from these input clock signals. KEYCLK may use the 14.318 MHz input clock as its source. It is assumed for all diagrams that all PROCLK and IOCLK related dividers are set for divide by 1.
- 3. Output invalid delay times (Min and Max) not specified track the corresponding valid delay time (Min and Max) within ±5 ns. There are two exception on the M bus for non-paged mode accesses. The RAS invalid delay timing tracks the valid delay timing by +10 ns. The MA10–MA0 invalid timing tracks the valid delay timing by ±8 ns.
- 4. The AT-bus timing diagrams assume a programmed configuration of no command delays for 16-bit memory accesses, one command delay for 8-bit memory accesses, and one command delay for I/O commands. The timing parameters are referenced to clocks and are independent of command delays.

Note: Switching characteristics are targeted numbers and are subject to change without notice.





## Input Clocks

| Parameter<br>Symbol | Parameter Descriptions  | Notes and Conditions       | Min      | Max | Unit |
|---------------------|-------------------------|----------------------------|----------|-----|------|
| t1                  | PROCLK, IOCLK Period    | 16 MHz CPU<br>12.5 MHz CPU | 31<br>40 |     | ns   |
| t2                  | PROCLK, IOCLK Low Time  | 16 MHz CPU<br>12.5 MHz CPU | 14<br>16 |     | ns   |
| t3                  | PROCLK, IOCLK High Time | 16 MHz CPU<br>12.5 MHz CPU | 13<br>16 |     | ns   |
| t4                  | RTCCLK Period (Note 1)  |                            | 30.518   |     | μs   |
| t5                  | F14 MHz Period          |                            | 69.8     |     | ns   |
| t6                  | F14 MHz High, Low Time  |                            | 25       |     | ns   |

Note 1. 32.768 kHz ±100 ppm crystal input across RTCLKX1 and RTCLKX2 for AT compatibility.



Figure 19. Input Clocks

## AT System Bus Interface: Referenced to srcCLK

| Parameter<br>Symbol | Parameter Descriptions       | Notes and Conditions | Min  | Мах | Unit |
|---------------------|------------------------------|----------------------|------|-----|------|
| t7                  | SYSCLK Period                | Note 2               | 125  |     | ns   |
| t8                  | ATSMCLK Period               |                      | 62.5 |     | ns   |
| t9                  | SYSCLK High/Low Time         |                      | 50   |     | ns   |
| t10                 | SYSCLK Delay from srcCLK     | Note 1               | 9    | 31  | ns   |
| t11                 | SMEMR/SMEMW from srcCLK      | Note 1               |      | 70  | ns   |
| t12                 | IOR/IOW from srcCLK          | Note 1               |      | 50  | ns   |
| t13                 | REFRESH Active from srcCLK   | Note 1               |      | 90  | ns   |
| t14                 | REFRESH Inactive from srcCLK | Note 1               |      | 90  | ns   |
| t15                 | BALE from srcCLK             | Note 1               |      | 45  | ns   |
| t16                 | IOCHK Active Pulse Width     | Note 3               | 10   |     | ns   |
| t17                 | IOCHRDY Setup to srcCLK      | Notes 1, 3           | 5    |     | ns   |
| t18                 | IOCHRDY Hold from srcCLK     | Notes 1, 3           | 17   |     | ns   |
| t19                 | RESETDRV from srcCLK         | Note 4               |      | 65  | ns   |
| t20                 | MEMCS16 Setup to srcCLK      | Note 1               | 5    |     | ns   |
| t21                 | MEMCS16 Hold to srcCLK       | Note 1               | 30   |     | ns   |
| t22                 | IOCS16 Setup to srcCLK       | Note 1               | 10   |     | ns   |
| t23                 | IOCS16 Hold to srcCLK        | Note 1               | 25   |     | ns   |
| t24                 | POWS Setup to srcCLK         | Note 1               | 11   |     | ns   |
| t25                 | POWS Hold to srcCLK          | Note 1               | 15   |     | ns   |
| t26                 | MEMR/MEMW from srcCLK        | Note 1               |      | 47  | ns   |
| t27                 | IRQ Inactive Pulse Width     | Notes 3, 5, 6        | 100  |     | ns   |
| t28                 | SA, SBHE Valid from srcCLK   | Note 1               |      | 60  | ns   |
| t29                 | LA Valid from srcCLK         | Note 1               |      | 52  | ns   |
| t30                 | SD Read Setup to srcCLK      | Note 1               | 13   |     | ns   |
| t31                 | SD Read Hold to srcCLK       | Note 1               | 35   |     | ns   |
| t32                 | SD Write Valid from srcCLK   | Note 1               |      | 60  | ns   |
| t33                 | SBENA from srcCLK            | Note 1               |      | 52  | ns   |
| t34                 | (H,L)DATDIR from srcCLK      | Note 1               |      | 54  | ns   |

Notes: 1. ATSMCLK reference.

2. The maximum frequency for SYSCLK is 8 MHz.

3. Asynchronous inputs not requiring setup or hold times. This specification given for testing purposes.

4. Duration of RESETDRV active is dependent on PWRGOOD and can be software controlled.

5. Low time required to clear the input latch of the interrupt controller.

6. IRQs must remain High until after the first interrupt acknowledge cycle to prevent spurious interrupts.



Figure 20. AT System Bus Interface (Processor) Memory 8-Bit-1WS, 16-Bit-0WS



Figure 21. AT System Bus Interface (Processor) I/O 16- and 8-Bit-2WS

## 



Figure 22. AT System Bus Interface (Processor)

## AT System Bus Interface (DMA): Referenced to srcCLK

| Parameter<br>Symbol | Parameter Descriptions        | Notes and Conditons | Min | Max | Unit |
|---------------------|-------------------------------|---------------------|-----|-----|------|
| t35                 | MEMR Active from srcCLK       | Note 2              |     | 50  | ns   |
| t36                 | MEMR Inactive from srcCLK     | Note 2              |     | 75  | ns   |
| t37                 | IOR from srcCLK               | Note 2              |     | 60  | ns   |
| t38                 | DMATC from srcCLK             | Note 2              |     | 75  | ns   |
| t39                 | BALE from srcCLK              | Note 1              |     | 55  | ns   |
| t40                 | AEN from srcCLK               | Note 1              |     | 60  | ns   |
| t41                 | MEMW, IOW from srcCLK         | Note 2              |     | 60  | ns   |
| t42                 | DACK from srcCLK              | Note 2              |     | 65  | ns   |
| t43                 | SA Valid from srcCLK          | Note 2              |     | 120 | ns   |
| t44                 | SBHE from srcCLK              | Note 2              |     | 80  | ns   |
| t45                 | LA Valid from srcCLK          | Note 2              |     | 105 | ns   |
| t46                 | MD Valid from SD Valid (IOR)  |                     |     | 25  | ns   |
| t47                 | SD Valid from MD Valid (MEMR) |                     |     | 27  | ns   |
| t48                 | SD Valid from XD Valid (IOR)  |                     |     | 27  | ns   |
| t49                 | IOCHRDY Setup to srcCLK       | Notes 2, 3          | 5   |     |      |
| t50                 | IOCHRDY Hold from srcCLK      | Notes 2, 3          | 25  |     |      |
| t51                 | SMEMR Active from srcCLK      | Note 2              |     | 50  |      |
| t52                 | SMEMR Inactive from srcCLK    | Note 2              |     | 80  |      |
| t53                 | SMEMW from srcCLK             | Note 2              |     | 65  |      |

Notes: 1. CPUCLK reference. 2. DMACLK reference.

3. Asynchronous inputs not requiring setup or hold times. This specification given for testing purposes.



14753C-023

Figure 23. AT System Bus Interface (DMA) Local I/O Write/Memory Read, X Bus I/O Read/Memory Write

## AT System Bus Interface (External Master): Referenced to srcCLK

| Parameter<br>Symbol | Parameter Descriptions             | Notes and<br>Conditions | Min | Max | Unit |
|---------------------|------------------------------------|-------------------------|-----|-----|------|
| t54                 | SMEMR/SMEMW from MEMR/MEMW         |                         |     | 50  | ns   |
| t55                 | IOR/IOW Float from MASTER Active   | Note 3                  |     | 40  | ns   |
| t56                 | REFRESH Setup to srcCLK            | Note 1, 2               | 5   |     | ns   |
| t57                 | REFRESH Hold from srcCLK           | Note 1, 2               | 20  |     | ns   |
| t58                 | AEN from MASTER                    |                         |     | 40  | ns   |
| t59                 | MEMR/MEMW Float from MASTER Active | Note 3                  |     | 40  | ns   |
| t60                 | SA, SBHE Float from MASTER Active  | Note 3                  |     | 55  | ns   |
| t61                 | LA Float from MASTER Active        | Note 3                  |     | 30  | ns   |
| t62                 | SD Hold from MEMR                  |                         | 12  |     | ns   |
| t63                 | (H,L)DATDIR from MASTER Active     |                         |     | 44  | ns   |
| t64                 | (H,L)DATDIR from IOR/MEMR Active   |                         |     | 44  | ns   |
| t65                 | SA Setup to Command                |                         | 40  |     | ns   |
| t66                 | SA Hold from Command               |                         | 10  |     | ns   |

Notes: 1. ATSMCLK reference.

2. Asynchronous inputs not requiring setup or hold times. This specification given for testing purposes.

3. Not 100% tested.







14753C--024

Figure 24. AT System Bus Interface (External Bus Master)

#### **Coprocessor Interface**

| Parameter<br>Symbol | Parameter Descriptions         | Notes and<br>Conditions | Min | Max | Unit |
|---------------------|--------------------------------|-------------------------|-----|-----|------|
| t68                 | P287CLK Period                 | Note 2                  | 30  |     | ns   |
| t69                 | P287CLK Low Time               |                         | 12  |     | ns   |
| t70                 | P287CLK Delay from srcCLK      |                         |     | 20  | ns   |
| t71                 | NPCS from srcCLK               | Notes 1, 3              |     | 47  | ns   |
| t72                 | BUSY Setup to srcCLK           | Notes 1, 3              | 5   |     | ns   |
| t73                 | BUSY Hold from srcCLK          | Notes 1, 3              | 5   |     | ns   |
| t74                 | PEREQ Setup to srcCLK          | Notes 1, 3              | 5   |     | ns   |
| t75                 | PEREQ Hold from srcCLK         | Notes 1, 3              | 20  |     | ns   |
| t76                 | PEACK Active from srcCLK       | Note 1                  |     | 35  | ns   |
| t77                 | PEACK Inactive from srcCLK     | Note 1                  |     | 247 | ns   |
| t78                 | RESET287 from srcCLK           | Note 1                  |     | 40  | ns   |
| t79                 | BUSY to P287ERR Active Overlap |                         | 5   | 1   | ns   |

Notes: 1. CPUCLK reference.

2. This 50% duty cycle is internally divided by 3 within the AMD 80C287 math coprocessor.

Asynchronous inputs not requiring setup or hold times. This specification given for testing purposes.



Figure 25. Coprocessor Interface

## XBUS-ROM, RAM, KBD, I/O, MEM

| Parameter<br>Symbol | Parameter Descriptions                    | Notes and<br>Conditions | Min | Max | Unit |
|---------------------|-------------------------------------------|-------------------------|-----|-----|------|
| t83                 | LCSROM from srcCLK                        | Note 1                  |     | 60  | ns   |
| t84                 | XMEMR/XMEMW from srcCLK<br>Non-DMA cycles | Note 1                  |     | 45  | ns   |
| t85                 | MD, XD Read Setup to srcCLK               | Note 1                  | 15  |     | ns   |
| t86                 | MD, XD Read Hold from srcCLK              | Note 1                  | 30  |     | ns   |
| t87                 | MD, XD Write from srcCLK                  | Note 1                  |     | 60  | ns   |
| t88                 | CS8042 from srcCLK                        | Note 1                  |     | 47  | ns   |
| t89                 | XIOR/XIOW from srcCLK                     | Note 1                  |     | 60  | ns   |
| t90                 | XA from srcCLK                            | Note 1                  |     | 40  | ns   |
| t91                 | RC Setup to srcCLK                        | Notes 1, 2              | 5   |     | ns   |
| t92                 | RC Hold to srcCLK                         | Notes 1, 2              | 5   | 1   | ns   |
| t93                 | RESET from srcCLK                         | Note 1                  |     | 25  | ns   |
| t94                 | KEYCLK Period                             |                         | 32  |     | ns   |
| t95                 | KEYCLK High Time                          |                         | 12  | 1   | ns   |
| t96                 | KEYCLK Low Time                           |                         | 8   |     | ns   |
| t97                 | KEYCLK Delay from srcCLK                  | Note 1                  |     | 31  | ns   |
| t98                 | KBINT Inactive Pulse Width                | Notes 2, 3, 4           |     | 100 | ns   |

Notes: 1. CPUCLK reference.

2. Asynchronous inputs not requiring setup or hold times. This specification given for testing purposes.

3. This Low time is required to clear the input latch in edge triggered mode.

4. In all modes KBINT must remain High until the first Interrupt Acknowledge.







## XBUS—I/O (DMA/External Master)

| Parameter<br>Symbol | Parameter Descriptions                 | Notes and<br>Conditions | Min                                   | Max | Unit |
|---------------------|----------------------------------------|-------------------------|---------------------------------------|-----|------|
| t99                 | XD Valid from SD Valid                 |                         | · · · · · · · · · · · · · · · · · · · | 30  | ns   |
| t100                | XD Valid from MD Valid                 |                         |                                       | 30  | ns   |
| t101                | MD Valid from XD Valid                 |                         |                                       | 30  | ns   |
| t102                | XIOR/XIOW Valid from srcCLK            | Note 1                  |                                       | 60  | ns   |
| t103                | XMEMR/XMEMW Valid from MEMR/MEMW Valid |                         |                                       | 40  | ns   |
| t104                | XIOR/XIOW Valid from IOR/IOW Valid     |                         |                                       | 30  | ns   |
| t105                | XA Valid from SA Valid                 |                         |                                       | 20  | ns   |

Notes: 1. DMACLK reference.



Figure 27. X Bus—I/O Device (DMA)



Figure 28. X Bus-RAM, Keyboard, I/O Device (External Bus Master)

## **Miscellaneous Signals**

| Parameter<br>Symbol | Parameter Descriptions  | Notes and<br>Conditions | Min        | Max | Unit |
|---------------------|-------------------------|-------------------------|------------|-----|------|
| t106                | PWRGOOD Setup to srcCLK | Notes 1, 2              | 15         |     | ns   |
| t107                | PWRGOOD Pulse Width     | Notes 1, 2, 3           | 65 · TPCLK |     | ns   |

Notes: 1. CPUCLK reference. 2. Asynchronous inputs not requiring setup or hold times. This specification given for testing purposes. 3. TPCLK is the period of PROCLK.

### Am286ZX/LX Integrated Processor as a Bus Master

| New<br>Parameter<br>Symbol | Parameter Descriptions         | Notes and<br>Conditions | Min | Max | Unit |
|----------------------------|--------------------------------|-------------------------|-----|-----|------|
| t108                       | MASTER Active from DACK Active |                         |     | 25  | ns   |
| t109                       | MASTER Inactive from srcCLK    |                         |     | 40  | ns   |
| t111                       | IOR/IOW from srcCLK            | Note 1                  |     | 50  | ns   |
| t113                       | MEMR/MEMW from srcCLK          | Note 1                  |     | 50  | ns   |
| t115                       | SA, SBHE from srcCLK           | Note 1                  |     | 60  | ns   |
| t117                       | LA Valid from srcCLK           | Note 1                  |     | 45  | ns   |
| t119                       | SD Write from srcCLK           | Note 1                  |     | 63  | ns   |
| t120                       | SD Write Setup to MEMW Active  |                         | 12  |     | ns   |

Notes: 1. ATSMCLK reference.









an all constants

## Memory Bus

| Parameter<br>Symbol | Parameter Descriptions         | Notes and<br>Conditions | Min | Max | Unit |
|---------------------|--------------------------------|-------------------------|-----|-----|------|
| t121                | srcCLK to RAS Active           |                         |     | 36  | ns   |
| t122                | srcCLK to RAS Inactive         |                         |     | 43  | ns   |
| t123                | srcCLK to CAS Active           |                         |     | 35  | ns   |
| t124                | srcCLK to CAS Inactive         |                         |     | 35  | ns   |
| t125                | srcCLK to MA Valid             |                         |     | 50  | ns   |
| t126                | srcCLK to MA Invalid           |                         | 9   |     | ns   |
| t127                | MWENL, MWENH Active Delay      |                         |     | 40  | ns   |
| t128                | MWENL, MWENH Inactive Delay    |                         |     | 40  | ns   |
| t129                | srcCLK to MD Valid             |                         |     | 47  | ns   |
| t130                | srcCLK to MD FLOAT             | Note 1                  |     | 40  | ns   |
| t131                | MD Read Setup to srcCLK        |                         | 6   |     | ns   |
| t132                | MD Hold from srcCLK            |                         | 20  |     | ns   |
| t133                | srcCLK to MDP Valid            |                         |     | 47  | ns   |
| t134                | MDP Setup to srcCLK            |                         | 6   |     | ns   |
| t135                | MDP Hold from srcCLK           |                         | 20  |     | ns   |
| t136                | srcCLK to MDP FLOAT            | Note 1                  |     | 40  | ns   |
| t137                | SA to MA Valid Delay           |                         |     | 73  | ns   |
| t139                | SBUS cmd to DLYOUT Delay       |                         | 5   | 35  | ns   |
| t140                | DL0 to MA Valid Delay          |                         |     | 25  | ns   |
| t141                | SBUS cmd to RAS Delay          |                         |     | 50  | ns   |
| t142                | SBUS cmd to MWENL, MWENH Delay |                         |     | 49  | ns   |
| t143                | DL1 to CAS Delay               |                         | 4   | 22  | ns   |

Notes: 1. Not 100% tested.





















Figure 35. M Bus: Page Mode, Page—Hit RAS Inactive/Write/OWS

Figure 37. M Bus: Page Mode, Page—Hit/Write/0WS



AMD



Figure 36. M Bus: Page Mode, Page—Hit RAS Inactive/Read/0WS











Am286ZX/LX Integrated Processor



14753C-036

Figure 40. M Bus: Page Mode, Page—Hit RAS Active/1WS/Read



14753C-037

Figure 41. M Bus: Page Mode, Page—Miss/Write/0WS

Am286ZX/LX Integrated Processor





14753C-038

Figure 42. M Bus: Page Mode, Page—Miss/Write/1WS



Figure 43. M Bus: Page Mode, Page—Hit RAS Inactive/Read/0WS



\*T0 and T1 are user selectable via an external delay circuit.

Figure 44. M Bus: S-Bus Master/DMA Access to Local Memory

# Am386™DXL

## High-Performance, Low-Power, 32-Bit Microprocessor

## DISTINCTIVE CHARACTERISTICS

#### Ideal for portable PCs

- -True static design for long battery life
- -Typical standby lcc < 0.02 mA at DC (0 MHz)
- -Typical operating Icc < 275 mA at 33 MHz
- -Lower power consumption than Intel i386DX or Intel i386SX
- -Small footprint 132-pin PQFP package
- -Wide range of chip sets and BIOS available to support standby mode capabilities
- -Performance on demand (0 to 40 MHz)

## **GENERAL DESCRIPTION**

The Am386DXL microprocessor is a high-speed, true static implementation of the Intel i386DX microprocessor. It is ideal for both desktop and battery-powered portable personal computers. For desktop PCs, the Am386DXL microprocessor offers a 21% increase in the maximum operating speed from 33 to 40 MHz. Also, this device offers lower heat dissipation, allowing system designers to remove or reduce the size and cost of the system cooling fan.

For portables, the Am386DXL microprocessor's true static design offers longer battery life with low operating

#### Ideal for desktop PCs

-40-, 33-, 25-, and 20-MHz operating speeds -Lower heat dissipation facilitates fan reduction or elimination for cost savings and noise reduction -Pin-for-pin replacement for Intel i386DX

- Compatible with 386DX systems and software
- Supports 387DX-compatible math coprocessors
- AMD® advanced 0.8 micron CMOS technology

power consumption and standby mode. At 33 MHz, this device has 40% lower operating lcc than the Intel i386DX. Standby mode allows the Am386DXL microprocessor to be clocked down to 0 MHz (DC) and retain full register contents. In standby mode, typical current draw is less than 0.02 mA, a nearly 1000× reduction in power consumption versus the Intel i386DX or Intel i386SX.

Additionally, the Am386DXL microprocessor will be available in a small footprint 132-pin plastic quad flat pack (PQFP) package. This surface-mount package is 40% smaller than PGA, allowing smaller, lower-cost board designs without the need for a socket.



#### **BLOCK DIAGRAM**



15021B-001

### INTRODUCTION

AMD is proud to provide the Am386DXL microprocessor at a time when the personal computer market requires alternatives. Alternate source manufacturers traditionally increase availability, add features, and broaden the market. AMD has focused significant engineering resources to bring you these benefits.

AMD's track record with the 80286 shows that we were first to raise the performance of the 80286 from 8 MHz to 10, 12, and 16 MHz. We were first to offer new packaging technology with a smaller, lower cost PLCC. Today, over 90% of all 80286s sold use PLCC packaging. AMD is committed to similar advances with the Am386DXL microprocessor.

The Am386DXL microprocessor is more than just a re-creation of the Intel i386DX. Highly skilled engineers in our Austin, Texas facility added enhancements to the microprocessor, through the use of our advanced 0.8 micron CMOS technology. These enhancements include a true static design, and an increase in the maximum operating speed to 40 MHz. The true static design allows for lower operating power consumption, as well as standby mode for lower heat dissipation in desktop PCs and longer battery life in portables.

AMD engineered the Am386DXL microprocessor to insure compatibility with the installed base of hardware and software for the 386-based personal computers. The Am386DXL microprocessor is your solution to meet the demand for high-performance, 32-bit desktop and portable personal computers.

#### FUNCTIONAL DESCRIPTION

#### **True Static Operation**

The Am386DXL microprocessor incorporates a true static design. Unlike dynamic circuit design, the Am386DXL device eliminates the minimum operating frequency restriction. It may be clocked from its maximum speed of 40 MHz all the way down to 0 MHz (DC). System designers can use this feature to design true 32-bit battery-powered portable PCs with long battery life.

#### Standby Mode

This true static design allows for a standby mode. At any of its operating speeds (40 MHz to DC), the Am386DXL microprocessor will retain its state (i.e., the contents of all of its registers). By shutting off the clock completely, the device enters standby mode. Since power consumption is a function of clock frequency, operating power consumption is reduced as the frequency is low-ered. In standby mode, typical current draw is reduced to less than 0.02 mA at DC.

Not only does this feature save battery life, but it also simplifies the design of power-conscious notebook computers in the following ways.

- 1. Eliminates the need for software in BIOS to save and restore the contents of registers.
- Allows simpler circuitry to control stopping of the clock (since) the system does not need to know what state the processor is in.

#### Lower Operating Icc

True static design also allows lower operating lcc when operating at any speed. See the following graph for typical current at operating speeds.

#### Performance On Demand

The Am386DXL microprocessor retains its state at any speed from 0 MHz (DC) to its maximum operating speed (20, 25, 33, or 40 MHz). With this feature, system designers may vary the operating speed of the system to extend the battery life in portable systems.

For example, the system could operate at low speeds during inactivity or polling operations. However, upon interrupt, the system clock can be increased up to its maximum speed. After a user-defined time-out period, the system can be returned to a low (or 0 MHz) operating speed without losing its state. This design maximizes life while achieving optimal performance.



## 

er om alde der solet um er er

## CONNECTION DIAGRAMS 132-Lead Ceramic Pin Grid Array (PGA) Package

|                                     |                                                                                                                         |                     |                      |          |                | Тс              | op Si                | ide \                                                                                     | /iew                 | ,                                            |                                |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                               |
|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------|---------------------|----------------------|----------|----------------|-----------------|----------------------|-------------------------------------------------------------------------------------------|----------------------|----------------------------------------------|--------------------------------|----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
|                                     | P                                                                                                                       | N                   | М                    | L        | ĸ              | J               | н                    | G                                                                                         | F                    |                                              | E                              | D                                      | С                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                               |
| 1                                   | ( O<br>( A30                                                                                                            | O<br>A27            | O<br>A26             | O<br>A23 | 0<br>A21       | O<br>A20        | O<br>A17             | O<br>A16                                                                                  | 0<br>A1:             |                                              | D<br>14                        | O<br>A11                               | O<br>A8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0<br>V <sub>56</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0 \<br>v                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 1                                             |
| 2                                   | 0                                                                                                                       | 0                   | 0                    | 0        | 0              | ο               | 0                    | 0                                                                                         | 0                    | ) (                                          | C                              | 0                                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 2                                             |
| 3                                   | v <sub>∞</sub><br>0                                                                                                     | A31<br>O            | A29 .<br>O           | A24<br>O | A22<br>O       | V<br>0          | A18<br>O             | v <sub>∞</sub>                                                                            | v.<br>O              | -                                            | 13<br>D                        | A10<br>O                               | А7<br>О                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | А5<br>О                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | V.28<br>O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 3                                             |
|                                     |                                                                                                                         |                     |                      | A28      | A25            | Vas             | A19                  | V <sub>cc</sub>                                                                           | Va                   | , A                                          | 12                             | A9                                     | A6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | A4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | A3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                               |
| 4                                   | 0<br>D29                                                                                                                | O<br>v∞             | O<br>Vss             |          |                |                 |                      |                                                                                           |                      |                                              |                                |                                        | O<br>A2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | O<br>NC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | O<br>NC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 4                                             |
| 5                                   | 0<br>D26                                                                                                                | O<br>D27            | O<br>D31             |          |                |                 |                      |                                                                                           |                      |                                              |                                |                                        | O<br>v∞                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | O<br>Vas                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | O<br>v∞                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 5                                             |
| 6                                   | 0                                                                                                                       | <b>O</b><br>D25     | <b>O</b><br>D28      |          |                |                 |                      |                                                                                           |                      |                                              |                                |                                        | O<br>NC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0<br>NC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 6                                             |
| 7                                   | V <sub>∞</sub>                                                                                                          | 0                   | 0                    |          |                |                 |                      |                                                                                           |                      |                                              |                                |                                        | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | v <sub>ss</sub><br>O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 7                                             |
| 8                                   | D24                                                                                                                     | v <sub>∞</sub><br>Õ | v <sub>∞</sub><br>O  |          |                |                 |                      |                                                                                           |                      |                                              |                                |                                        | NC<br>O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | v∝<br>O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 8                                             |
| 9                                   | v <sub>∞</sub><br>Õ                                                                                                     | D23<br>O            | V <sub>ss</sub><br>O |          |                |                 |                      |                                                                                           |                      |                                              |                                | P                                      | EREQ<br>O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | NMI Ì<br>O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ERROR<br>O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 9                                             |
|                                     | D22                                                                                                                     | D21                 | D20                  |          |                |                 |                      |                                                                                           |                      |                                              |                                | R                                      | ESET                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | BUSY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Vas                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                               |
| 10                                  | 0<br>D19                                                                                                                | O<br>D17            | O<br>Vas             |          |                |                 |                      |                                                                                           |                      |                                              |                                | 1                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | O<br>w/R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | O<br>v∝                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 10                                            |
| 11                                  | 0<br>D18                                                                                                                | <b>O</b><br>D16     | O<br>D15             |          |                |                 |                      |                                                                                           |                      |                                              |                                |                                        | O<br>Vas                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0<br>Vss                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | O<br>D/C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 11                                            |
| 12                                  | 0<br>D14                                                                                                                | <b>O</b><br>D12     | <b>O</b><br>D10      | O<br>v∞  | <b>O</b><br>D7 | 0<br>V35        | 0                    | O<br>v∞                                                                                   | O<br>CLF             | 2 B                                          |                                | O<br>v∝                                | O<br>V∝                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | O<br>NC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | <b>О</b><br>м/Ю                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 12                                            |
| 13                                  | 0                                                                                                                       | 0                   | 0                    | 0        | Ο              | 0               | 0                    | 0                                                                                         | 0                    | ) (                                          | C                              | 0                                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Ο                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 13                                            |
| 14                                  | D13                                                                                                                     | D11<br>O            | v<br>O               | D8<br>O  | D5<br>O        | V <sub>as</sub> | 0                    | READ                                                                                      | 7 NC<br>O            |                                              | ю<br>Э                         |                                        | BET                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | BE2<br>O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | BES                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 14                                            |
|                                     | V.ss                                                                                                                    |                     | -                    | D6       | D4             | D3              | D2                   | Vcc                                                                                       | Va                   |                                              | -                              | IOLD                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Vas                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Vcc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | J                                             |
|                                     | Ρ                                                                                                                       | N                   | М                    | L        | к              | J               | н                    | G                                                                                         | F                    | 1                                            | E                              | D                                      | С                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | в                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                               |
|                                     | A                                                                                                                       | в                   | с                    | C        | ,              | Pl<br>E         | n Si<br>F            | de V<br>G                                                                                 | lew<br>н             | J                                            | к                              | L                                      | м                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | P                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                               |
| 1                                   | ٦<br>آ                                                                                                                  | ō                   | ō                    |          |                | <u></u> 0       | 0                    | ů,                                                                                        |                      | ò                                            | Ô                              | ō                                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | $\overline{\mathbf{a}}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1                                             |
|                                     | Vcc                                                                                                                     | Vas                 | A8                   | A        | 11 /           | 14              | A15                  | A16                                                                                       | A17 /                | A20                                          | A21                            | A23                                    | A26                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | A27                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | A30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                               |
| 2                                   |                                                                                                                         | 0<br>A5             | 0<br>A7              |          |                | O<br>\13        | О<br><sub>Væ</sub>   | O<br>∨∝                                                                                   |                      | 0<br>Væ                                      | 0<br>A22                       | 0<br>A24                               | O<br>A29                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | O<br>A31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | O<br>v∞                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 2                                             |
| 3                                   | O<br>A3                                                                                                                 | 0<br>A4             | 0<br>A6              | -        |                | 0               | 0                    | 0                                                                                         | 0                    | Ο                                            | 0                              | Ο                                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Ο                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 3                                             |
| 4                                   | 0                                                                                                                       | -                   |                      |          |                | 12              | Vaa                  |                                                                                           | A19 '                | Vaa                                          |                                |                                        | Vcc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                               |
| _                                   |                                                                                                                         | 0                   | 0                    |          |                | 12              | V.88                 |                                                                                           | A19                  | V.as                                         | A25                            | A28                                    | V <sub>cc</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | V <sub>as</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | D30<br>O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 4                                             |
| 5                                   | NC<br>O                                                                                                                 |                     | 0<br>A2<br>0         |          |                | .12             | V <sub>38</sub>      |                                                                                           | A19                  | V.as                                         |                                |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Vas                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | D30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 4<br>5                                        |
|                                     | O<br>V∝                                                                                                                 |                     | A2<br>0<br>V         |          |                | .12             | V <sub>as</sub>      |                                                                                           | A19 '                | V.as.                                        |                                |                                        | O<br>V <sub>as</sub><br>O<br>D31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | D30<br>D29<br>O<br>D26                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 5                                             |
| 6                                   |                                                                                                                         |                     |                      |          |                | .12             | Vas                  |                                                                                           | A19 '                | V.36                                         |                                |                                        | O<br>Vas<br>O<br>D31<br>O<br>D28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | V <sub>38</sub><br>O<br>V <sub>00</sub><br>O<br>D27<br>O<br>D25                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | D30<br>D29<br>D26<br>O<br>Vas                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 5<br>6                                        |
| 6<br>7                              |                                                                                                                         |                     |                      |          |                | .12             |                      |                                                                                           |                      | V.as.                                        |                                |                                        | O<br>Vss<br>D31<br>O<br>D28<br>O<br>Voc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | V <sub>38</sub><br>O<br>V <sub>00</sub><br>D27<br>O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | D30<br>D29<br>D26<br>D26<br>Vas<br>O<br>D24                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 5                                             |
| 6                                   | 0<br>V <sub>cc</sub><br>0<br>V <sub>88</sub><br>0                                                                       |                     |                      |          |                |                 |                      | V <sub>cc</sub>                                                                           |                      | V.as.                                        |                                |                                        | O<br>V <sub>ss</sub><br>O<br>D31<br>O<br>D28<br>O<br>V <sub>cc</sub><br>O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | V <sub>38</sub><br>O<br>V <sub>00</sub><br>O<br>D27<br>O<br>D25<br>O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | D30<br>D29<br>D26<br>O<br>Vas<br>D24<br>O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 5<br>6                                        |
| 6<br>7                              |                                                                                                                         |                     |                      | EQ       |                |                 |                      | V <sub>cc</sub>                                                                           |                      | V.85                                         |                                |                                        | O<br>Vas<br>O<br>D31<br>O<br>D28<br>O<br>Vas<br>O<br>Vas                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | V as 0 V oc 0 D27 0 D25 0 V oc 0 D23 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | D30<br>D29<br>D26<br>Vss<br>D24<br>O<br>Vcc<br>O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 5<br>6<br>7                                   |
| 6<br>7<br>8                         |                                                                                                                         |                     |                      | ĒQ       |                |                 |                      | V <sub>cc</sub>                                                                           |                      |                                              |                                |                                        | O<br>Vas<br>D31<br>D28<br>Vas<br>D28<br>Vas<br>D20<br>D20                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | D30<br>D29<br>D26<br>O<br>Vas<br>D24<br>O<br>Voc<br>D22<br>O<br>D22<br>O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 5<br>6<br>7<br>8                              |
| 6<br>7<br>8<br>9                    | 0<br>Vas<br>0<br>Vas<br>0<br>Voc<br>0<br>ERRO<br>0<br>Vas                                                               |                     |                      |          |                |                 |                      | V <sub>cc</sub>                                                                           |                      | Vas                                          |                                |                                        | O<br>Vas<br>D31<br>O<br>D28<br>O<br>Vas<br>O<br>D20                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | D30<br>D29<br>D26<br>O<br>Vas<br>D24<br>O<br>Vcc<br>O<br>D22                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 5<br>6<br>7<br>8<br>9                         |
| 6<br>7<br>9<br>10<br>11             |                                                                                                                         |                     |                      |          |                |                 | М                    | V <sub>cc</sub>                                                                           | d                    |                                              | A25                            | A28                                    | O<br>Vas<br>O<br>D<br>28<br>O<br>Vas<br>O<br>D<br>20<br>Vas<br>O<br>D<br>20<br>Vas<br>O<br>D<br>15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | V <sub>as</sub><br>O<br>V <sub>cc</sub><br>O<br>D27<br>O<br>D25<br>O<br>V <sub>cc</sub><br>O<br>D25<br>O<br>V <sub>cc</sub><br>O<br>D25<br>O<br>D23<br>O<br>D21<br>O<br>D21<br>O<br>D21<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D25<br>O<br>D2<br>D2<br>D2<br>D2<br>D2<br>D2<br>D2<br>D2<br>D2<br>D2<br>D2<br>D2<br>D2 | D30<br>D29<br>D26<br>O<br>D26<br>D24<br>O<br>D24<br>O<br>D22<br>D22<br>D19<br>D18                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 5<br>6<br>7<br>8<br>9<br>10<br>11             |
| 6<br>7<br>8<br>9<br>10<br>11        |                                                                                                                         |                     |                      |          |                | 0               |                      | V <sub>cc</sub><br>letal Li                                                               | ď                    | V <sub>36</sub>                              |                                |                                        | O<br>Vas<br>D31<br>D28<br>O<br>Vas<br>D20<br>Vas<br>O<br>Vas<br>O<br>Vas<br>O<br>Vas                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Vas<br>OVac<br>OD27<br>OD25<br>OVac<br>OD25<br>OVac<br>OD23<br>OD23<br>OD21<br>OD17<br>OD16<br>O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | D30<br>D29<br>D26<br>O<br>D26<br>D24<br>O<br>D24<br>O<br>D22<br>D22<br>D19<br>D19<br>O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 5<br>6<br>7<br>8<br>9<br>10                   |
| 6<br>7<br>9<br>10<br>11             |                                                                                                                         |                     |                      |          |                | 000             | M<br>O<br>CLK2<br>O  | V <sub>cc</sub><br>letal Li<br>V <sub>cc</sub>                                            | d<br>0 20 0          | 0.20                                         | A25                            | A28                                    | O<br>Vas<br>D<br>D<br>D<br>D<br>D<br>D<br>D<br>D<br>D<br>D<br>D<br>D<br>D<br>D<br>D<br>D<br>D<br>D<br>D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Vas<br>OVac<br>D27<br>D25<br>OZ5<br>OZ2<br>D25<br>OZ2<br>D27<br>OZ2<br>D27<br>OZ2<br>OZ2<br>OZ2<br>OZ2<br>OZ2<br>OZ2<br>OZ2<br>OZ2<br>OZ2<br>OZ2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | D30<br>D29<br>D26<br>Vas<br>D24<br>D24<br>D22<br>D24<br>D22<br>D22<br>D22<br>D19<br>D18<br>D14<br>O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 5<br>6<br>7<br>8<br>9<br>10<br>11             |
| 6<br>7<br>8<br>9<br>10<br>11        | O <sup>3</sup> |                     |                      |          |                |                 | M<br>OCLK2<br>OCLK2  | V <sub>cc</sub><br>lietal Li<br>V <sub>cc</sub><br>O<br>V <sub>cc</sub><br>O<br>EADY<br>O | d<br>O D0<br>D1<br>O |                                              | A25<br>0<br>D7<br>0<br>D5<br>0 | A28<br>0<br>V <sub>60</sub><br>D8<br>0 | O<br>Vasa<br>O<br>D28<br>O<br>Voc<br>O<br>Vas<br>O<br>D20<br>Vas<br>O<br>D20<br>O<br>Vas<br>O<br>D20<br>O<br>Vas<br>O<br>D20<br>O<br>Vas<br>O<br>D20<br>O<br>Vas<br>O<br>D28<br>O<br>Voc<br>O<br>Vas<br>O<br>D28<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>O<br>Voc<br>Voc<br>Voc<br>O<br>Voc<br>Voc<br>Voc<br>Voc<br>Voc<br>Voc<br>Voc<br>Voc<br>Voc<br>Voc | $\begin{array}{c} V_{ass} \\ O \\ V_{cc} \\ O \\ D27 \\ O \\ D25 \\ O \\ D27 \\ O \\ D27 \\ O \\ D27 \\ O \\ D27 \\ O \\ D17 \\ O \\ D16 \\ O \\ D12 \\ O \\ D11 \\ O \\ O \\ D11 \\ O \\ O \\ D11 \\ O \\$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | $\begin{array}{c} D30 \\ O \\ D29 \\ O \\ D26 \\ O \\ V_{35} \\ O \\ D24 \\ O \\ D22 \\ O \\ D20 \\ O \\ D19 \\ O \\ D19 \\ O \\ D10 \\ O \\ $ | 5<br>6<br>7<br>8<br>9<br>10<br>11<br>12       |
| 6<br>7<br>9<br>10<br>11<br>12<br>13 |                                                                                                                         |                     |                      |          |                |                 | M<br>OCLK2<br>O NC F |                                                                                           | d<br>O D0<br>D1<br>O | 0<br>V <sub>35</sub><br>0<br>V <sub>35</sub> | A25<br>0<br>D7<br>0<br>D5      | A28<br>0<br>V <sub>60</sub><br>D8<br>0 | O<br>Vasa<br>O<br>D28<br>O<br>Voc<br>O<br>Vas<br>O<br>D20<br>O<br>Vas<br>O<br>D20<br>O<br>Vas<br>O<br>D20<br>O<br>Vas<br>O<br>D20<br>O<br>Vas                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $\begin{array}{c} V_{ass} \\ O \\ V_{cc} \\ O \\ D27 \\ O \\ D25 \\ O \\ D27 \\ O \\ D27 \\ O \\ D27 \\ O \\ D27 \\ O \\ D17 \\ O \\ D16 \\ O \\ D12 \\ O \\ D11 \\ O \\ O \\ O \\ D11 \\ O \\$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | D30<br>D29<br>D26<br>O<br>Vas<br>O<br>D24<br>O<br>D24<br>O<br>D22<br>O<br>D22<br>O<br>D19<br>O<br>D18<br>O<br>D14<br>O<br>D13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13 |

| Pin<br>Name | Pin<br>No. | Pin<br>Name | Pin<br>No. | Pin<br>Name | Pin<br>No. | Pin<br>Name     | Pin<br>No. | Pin<br>Name     | Pin<br>No. | Pin<br>Name | Pin<br>No. |
|-------------|------------|-------------|------------|-------------|------------|-----------------|------------|-----------------|------------|-------------|------------|
| A2          | C4         | A24         | L2         | D6          | L14        | D28             | M6         | V <sub>cc</sub> | C12        | Vss         | F2         |
| A3          | A3         | A25         | K3         | D7          | K12        | D29             | P4         |                 | D12        |             | F3         |
| A4          | B3         | A26         | M1         | D8          | L13        | D30             | P3         |                 | G2         |             | F14        |
| A5          | B2         | A27         | N1         | D9          | N14        | D31             | M5         |                 | G3         |             | J2         |
| A6          | C3         | A28         | L3         | D10         | M12        | D/C             | A11        |                 | G12        |             | J3         |
| A7          | C2         | A29         | M2         | D11         | N13        | ERROR           | A8         |                 | G14        |             | J12        |
| A8          | C1         | A30         | P1         | D12         | N12        | HLDA            | M14        |                 | L12        |             | J13        |
| A9          | D3         | A31         | N2         | D13         | P13        | HOLD            | D14        |                 | MЗ         |             | M4         |
| A10         | D2         | ADS         | E14        | D14         | P12        | INTR            | B7         |                 | M7         |             | M8         |
| A11         | D1         | BEO         | E12        | D15         | M11        | LOCK            | C10        |                 | M13        |             | M10        |
| A12         | E3         | BE1         | C13        | D16         | N11        | M/IO            | A12        |                 | N4         |             | N3         |
| A13         | E2         | BE2         | B13        | D17         | N10        | NA              | D13        |                 | N7         |             | P6         |
| A14         | E1         | BE3         | A13        | D18         | P11        | NMI             | B8         |                 | P2         |             | P14        |
| A15         | F1         | <b>BS16</b> | C14        | D19         | P10        | PEREQ           | C8         |                 | P8         | W/R         | B10        |
| A16         | G1         | BUSY        | B9         | D20         | M9         | READY           | G13        | V <sub>ss</sub> | A2         | NC          | A4         |
| A17         | H1         | CLK2        | F12        | D21         | N9         | RESET           | C9         |                 | A6         |             | B4         |
| A18         | H2         | D0          | H12        | D22         | P9         | V <sub>cc</sub> | A1         |                 | A9         |             | B6         |
| A19         | H3         | D1          | H13        | D23         | N8         |                 | A5         |                 | B1         |             | B12        |
| A20         | J1         | D2          | H14        | D24         | P7         |                 | A7         |                 | B5         |             | C6         |
| A21         | K1         | D3          | J14        | D25         | N6         |                 | A10        |                 | B11        |             | C7         |
| A22         | K2         | D4          | K14        | D26         | P5         |                 | A14        |                 | B14        |             | E13        |
| A23         | L1         | D5          | K13        | D27         | N5         |                 | C5         |                 | C11        |             | F13        |

## PGA Pin Designations (Functional Grouping)

## PGA Pin Designations (Sorted by Pin No.)

| Pin<br>No. | Pin<br>Name            | Pin<br>No. | Pin<br>Name            | Pin<br>No. | Pin<br>Name           | Pin<br>No. | Pin<br>Name     | Pin<br>No. | Pin<br>Name     | Pin<br>No. | Pin<br>Name     |
|------------|------------------------|------------|------------------------|------------|-----------------------|------------|-----------------|------------|-----------------|------------|-----------------|
| A1         | V <sub>cc</sub>        | B9         | BUSY                   | D3         | A9                    | H1         | A17             | L13        | D8              | N7         | V <sub>cc</sub> |
| A2         | Vss                    | B10        | W/R                    | D12        | Vcc                   | H2         | A18             | L14        | D6              | N8         | D23             |
| A3         | A3                     | B11        | Vss                    | D13        | V <sub>cc</sub><br>NA | НЗ         | A19             | M1         | A26             | N9         | D21             |
| A4         | NC                     | B12        | NĈ                     | D14        | HOLD                  | H12        | DO              | M2         | A29             | N10        | D17             |
| A5         | V <sub>cc</sub>        | B13        | BE2                    | E1         | A14                   | H13        | D1              | MЗ         | V <sub>cc</sub> | N11        | D16             |
| A6         | Vss                    | B14        | V <sub>ss</sub>        | E2         | A13                   | H14        | D2              | M4         | Vss             | N12        | D12             |
| A7         | V <sub>cc</sub>        | C1         | A8                     | E3         | A12                   | J1         | A20             | M5         | D31             | N13        | D11             |
| A8         | ERROR                  | C2         | A7                     | E12        | BE0                   | J2         | Vss             | M6         | D28             | N14        | D9              |
| A9         | V <sub>ss</sub>        | C3         | A6                     | E13        | NC                    | J3         | Vss             | M7         | V <sub>cc</sub> | P1         | A30             |
| A10        | V <sub>cc</sub><br>D/C | C4         | A2                     | E14        | ADS                   | J12        | Vss             | M8         | Vss             | P2         | V <sub>cc</sub> |
| A11        |                        | C5         | V <sub>cc</sub>        | F1         | A15                   | J13        | Vss             | M9         | D20             | P3         | D30             |
| A12        | M/IO                   | C6         | NC                     | F2         | Vss                   | J14        | D3              | M10        | Vss             | P4         | D29             |
| A13        | BE3                    | C7         | NC                     | F3         | Vss                   | K1         | A21             | M11        | D15             | P5         | D26             |
| A14        | V <sub>cc</sub>        | C8         | PEREQ                  | F12        | CLK2                  | K2         | A22             | M12        | D10             | P6         | V <sub>ss</sub> |
| B1         | Vss                    | C9         | RESET                  | F13        | NC                    | КЗ         | A25             | M13        | V <sub>cc</sub> | P7         | D24             |
| B2         | A5                     | C10        | LOCK                   | F14        | Vss                   | K12        | D7              | M14        | HLDA            | P8         | V <sub>cc</sub> |
| B3         | A4                     | C11        | Vss                    | G1         | A16                   | K13        | D5              | N1         | A27             | P9         | D22             |
| B4         | NC                     | C12        | V <sub>cc</sub><br>BE1 | G2         | V <sub>cc</sub>       | K14        | D4              | N2         | A31             | P10        | D19             |
| B5         | Vss                    | C13        |                        | G3         | V <sub>cc</sub>       | L1         | A23             | N3         | Vss             | P11        | D18             |
| B6         | NC                     | C14        | BS16                   | G12        | V <sub>cc</sub>       | L2         | A24             | N4         | V <sub>cc</sub> | P12        | D14             |
| B7         | INTR                   | D1         | A11                    | G13        | READY                 | L3         | A28             | N5         | D27             | P13        | D13             |
| B8         | NMI                    | D2         | A10                    | G14        | V <sub>cc</sub>       | L12        | V <sub>cc</sub> | N6         | D25             | P14        | V <sub>ss</sub> |

## CONNECTION DIAGRAMS 132-Lead Plastic Quad Flat Pack (PQFP) Package



150228-002

Note: Pin 1 is marked for orientation.

#### CONNECTION DIAGRAMS (continued) 132-Lead Plastic Quad Flat Pack (PQFP) Package



15022B-002

Notes: Pin 1 is marked for orientation.

| Pin<br>Name | Pin<br>No. | Pin<br>Name | Pin<br>No. | Pin<br>Name | Pin<br>No. | Pin<br>Name     | Pin<br>No. | Pin<br>Name     | Pin<br>No. | Pin<br>Name     | Pin<br>No. |
|-------------|------------|-------------|------------|-------------|------------|-----------------|------------|-----------------|------------|-----------------|------------|
| A2          | 67         | A24         | 96         | D6          | 13         | D28             | 112        | V <sub>cc</sub> | 56         | V <sub>ss</sub> | 64         |
| A3          | 68         | A25         | 97         | D7          | 12         | D29             | 109        | • cc            | 58         | * \$\$          | 65         |
| A4          | 69         | A26         | 98         | D8          | 9          | D30             | 108        |                 | 73         |                 | 66         |
| A5          | 70         | A27         | 100        | D9          | 7          | D31             | 107        |                 | 85         |                 | 80         |
| A6          | 71         | A28         | 101        | D10         | 6          | D/C             | 41         |                 | 99         |                 | 83         |
| A7          | 72         | A29         | 102        | D11         | 5          | ERROR           | 47         |                 | 106        |                 | 90         |
| A8          | 74         | A30         | 103        | D12         | 4          | HLDA            | 8          |                 | 110        |                 | 91         |
| A9          | 75         | A31         | 104        | D13         | 3          | HOLD            | 28         |                 | 117        |                 | 92         |
| A10         | 76         | ADS         | 27         | D14         | 131        | INTR            | 53         |                 | 123        |                 | 105        |
| A11         | 77         | BEO         | 31         | D15         | 130        | LOCK            | 42         |                 | 127        |                 | 111        |
| A12         | 78         | BE1         | 32         | D16         | 129        | M/IO            | 40         | V <sub>ss</sub> | 1          |                 | 114        |
| A13         | 79         | BE2         | 33         | D17         | 128        | NA              | 30         | - 55            | 10         |                 | 122        |
| A14         | 81         | BE3         | 38         | D18         | 126        | NMI             | 52         |                 | 11         |                 | 132        |
| A15         | 82         | BS16        | 29         | D19         | 125        | PEREQ           | 50         |                 | 21         | W/R             | 43         |
| A16         | 84         | BUSY        | 46         | D20         | 124        | READY           | 26         |                 | 23         | NC              | 36         |
| A17         | 86         | CLK2        | 24         | D21         | 121        | RESET           | 45         |                 | 25         |                 | 37         |
| A18         | 87         | DO          | 20         | D22         | 120        | V <sub>cc</sub> | 2          |                 | 35         |                 | 39         |
| A19         | 88         | D1          | 19         | D23         | 119        |                 | 16         |                 | 44         | 1               | 59         |
| A20         | 89         | D2          | 18         | D24         | 118        |                 | 22         |                 | 48         |                 | 60         |
| A21         | 93         | D3          | 17         | D25         | 116        |                 | 34         |                 | 51         |                 | 61         |
| A22         | 94         | D4          | 15         | D26         | 115        |                 | 49         |                 | 55         |                 | 62         |
| A23         | 95         | D5          | 14         | D27         | 113        | FLT             | 54         |                 | 57         |                 | 63         |

## PQFP Pin Designations (Functional Grouping)

AMD

## PQFP Pin Designations (Sorted by Pin No.)

| Pin<br>No. | Pin<br>Name     |
|------------|-----------------|------------|-----------------|------------|-----------------|------------|-----------------|------------|-----------------|------------|-----------------|
| 1          | Vss             | 23         | Vss             | 45         | RESET           | 67         | A2              | 89         | A20             | 111        | V <sub>ss</sub> |
| 2          | V <sub>cc</sub> | 24         | CLK2            | 46         | BUSY            | 68         | A3              | 90         | V <sub>ss</sub> | 112        | D28             |
| 3          | D13             | 25         | V <sub>ss</sub> | 47         | ERROR           | 69         | A4              | 91         | Vss             | 113        | D27             |
| 4          | D12             | 26         | READY           | 48         | Vss             | 70         | A5              | 92         | Vss             | 114        | VSS             |
| 5          | D11             | 27         | ADS             | 49         | V <sub>cc</sub> | 71         | A6              | 93         | A21             | 115        | D26             |
| 6          | D10             | 28         | HOLD            | 50         | PEREQ           | 72         | A7              | 94         | A22             | 116        | D25             |
| 7          | D9              | 29         | BS16            | 51         | Vss             | 73         | V <sub>cc</sub> | 95         | A23             | 117        | V <sub>cc</sub> |
| 8          | HLDA            | 30         | NA              | 52         | NMI             | 74         | A8              | 96         | A24             | 118        | D24             |
| 9          | D8              | 31         | BEO             | 53         | INTR            | 75         | A9              | 97         | A25             | 119        | D23             |
| 10         | Vss             | 32         | BE1             | 54         | FLT             | 76         | A10             | 98         | A26             | 120        | D22             |
| 11         | Vss             | 33         | BE2             | 55         | V <sub>ss</sub> | 77         | A11             | 99         | V <sub>cc</sub> | 121        | D21             |
| 12         | D7              | 34         | V <sub>cc</sub> | 56         | V <sub>cc</sub> | 78         | A12             | 100        | A27             | 122        | Vss             |
| 13         | D6              | 35         | Vss             | 57         | V <sub>ss</sub> | 79         | A13             | 101        | A28             | 123        | V <sub>cc</sub> |
| 14         | A5              | 36         | NC              | 58         | V <sub>cc</sub> | 80         | Vss             | 102        | A29             | 124        | D20             |
| 15         | D4              | 37         | NC              | 59         | NC              | 81         | A14             | 103        | A30             | 125        | D19             |
| 16         | V <sub>cc</sub> | 38         | BE3             | 60         | NC              | 82         | A15             | 104        | A31             | 126        | D18             |
| 17         | D3              | 39         | NC              | 61         | NC              | 83         | Vss             | 105        | V <sub>ss</sub> | 127        | V <sub>cc</sub> |
| 18         | D2              | 40         | M/IO            | 62         | NC              | 84         | A16             | 106        | V <sub>cc</sub> | 128        | D17             |
| 19         | D1              | 41         | D/Ĉ             | 63         | NC              | 85         | $V_{cc}$        | 107        | D31             | 129        | D16             |
| 20         | D0              | 42         | LOCK            | 64         | Vss             | 86         | A17             | 108        | D30             | 130        | D15             |
| 21         | V <sub>ss</sub> | 43         | W/R             | 65         | Vss             | 87         | A18             | 109        | D29             | 131        | D14             |
| 22         | V <sub>cc</sub> | 44         | V <sub>ss</sub> | 66         | V <sub>ss</sub> | 88         | A19             | 110        | V <sub>cc</sub> | 132        | V <sub>ss</sub> |

## LOGIC SYMBOL



## 

#### **ORDERING INFORMATION**

#### **Standard Products**

AMD standard products are available in several packages and operating ranges. The order number (Valid Combination) is formed by a combination of the elements below.



A = 132-Lead Ceramic Pin Grid Array (CGX 132) NG = 132-Lead Plastic Quad Flat Pack (PQ132, PQB132)

| Valid Combinations |                                        |  |  |  |  |  |
|--------------------|----------------------------------------|--|--|--|--|--|
| A80386DXL          | -40<br>-33<br>-25<br>-20               |  |  |  |  |  |
| NG80386DXL         | -33F, -33S<br>-25F, -25S<br>-20F, -20S |  |  |  |  |  |

#### Valid Combinations

Valid Combinations lists configurations planned to be supported in volume for this device. All speeds may not be available in all package combinations. Consult the local AMD sales office to confirm availability of specific valid combinations and to check on newly released combinations.

#### **PIN DESCRIPTION**

#### A31-A2

#### Address Bus (Outputs)

Outputs physical memory or port I/O addresses.

#### ADS

#### Address Status (Active Low; Output)

Indicates that a valid bus cycle definition and address  $(W/\bar{R}, D/C, M/\bar{IO}, BE0, BE1, BE2, BE3, and A31-A2)$  are being driven at the Am386DXL microprocessor pins.

#### BE3-BE0

#### Byte Enables (Active Low; Outputs)

Indicate which data bytes of the data bus take part in a bus cycle.

#### **BS16**

#### Bus Size 16 (Active Low; Input)

Allows direct connection of 32-bit and 16-bit data buses.

## BUSY

#### Busy (Active Low; Input)

Signals a busy condition from a processor extension.

#### CLK2

#### Clock (Input)

Provides the fundamental timing for the Am386DXL microprocessor.

#### D31-D0

#### Data Bus (Inputs/Outputs)

Inputs data during memory, I/O, and interrupt acknowledge read cycles and outputs data during memory and I/O write cycles.

#### D/Ĉ

#### Data/Control (Output)

A bus cycle definition pin that distinguishes data cycles, either memory or I/O from control cycles which are: interrupt acknowledge, halt, and instruction fetching.

#### ERROR

#### Error (Active Low; Input)

Signals an error condition from a processor extension.

#### FLT

#### Float (Active Low; Input)

An input signal which forces all bi-directional and output signals, including HLDA, to the three-state condition.  $\overline{FLT}$  has an internal pull-up resistor, and if it is not used it

should be unconnected.

#### HLDA

#### Bus Hold Acknowledge (Active High; Output)

Indicates that the Am386DXL microprocessor has surrendered control of its local bus to another bus master.

#### HOLD

#### **Bus Hold Request (Active High; Input)**

Allows another bus master to request control of the local bus.

#### INTR

#### Interrupt Request (Active High; Input)

A maskable input that signals the Am386DXL microprocessor to suspend execution of the current program and execute an interrupt acknowledge function.

#### LOCK

#### Bus Lock (Active Low; Output)

A bus cycle definition pin that indicates that other system bus masters are denied access to the system bus while it is active.

#### M/IO

#### Memory I/O (Output)

A bus cycle definition pin that distinguishes memory cycles from input/output cycles.

#### NA

#### Next Address (Active Low; Input)

Used to request address pipelining.

#### NC

#### No Connect

Should always remain unconnected. Connection of a NC pin may cause the processor to malfunction or be incompatible with future steppings of the Am386DXL microprocessor.

#### NMI

#### Non-Maskable Interrupt Request (Active High; Input)

A non-maskable input that signals the Am386DXL microprocessor to suspend execution of the current program and execute an interrupt acknowledge function.

#### PEREQ

Processor Extension Request (Active High; Input) Indicates that the processor extension has data to be transferred by the Am386DXL microprocessor.

#### READY

#### Bus Ready (Active Low; Input)

Terminates the bus cycle.

#### RESET

#### Reset (Active High; Input)

Suspends any operation in progress and places the Am386DXL microprocessor in a known reset state.

#### Vcc

#### System Power (Active High; Input)

Provides the +5-V nominal DC supply input.

#### Vss

#### System Ground (Input)

Provides 0 V connection from which all inputs and outputs are measured.

## W/R

Write/Read (Output)

A bus cycle definition pin that distinguishes write cycles from read cycles.

# **BASE ARCHITECTURE**

# Introduction

The Am386DXL microprocessor consists of a central processing unit, a memory management unit, and a bus interface.

The central processing unit consists of the execution unit and instruction unit. The execution unit contains the eight 32-bit general purpose registers that are used for both address calculation, data operations, and a 64-bit barrel shifter used to speed shift, rotate, multiply and divide operations. The multiply and divide logic uses a 1-bit per cycle algorithm. The multiply algorithm stops the iteration when the most significant bits of the multiplier are all zero. This allows typical 32-bit multiplies to be executed in under 1 ms. The instruction unit decodes the instruction op-codes and stores them in the decoded instruction queue for immediate use by the execution unit.

The Memory Management Unit (MMU) consists of a segmentation unit and a paging unit. Segmentation allows the managing of the logical address space by providing an extra addressing component, one that allows easy code and data relocatability and efficient sharing. The paging mechanism operates beneath and is transparent to the segmentation process to allow management of the physical address space. Each segment is divided into one or more 4-Kb pages. To implement a virtual memory system, the Am386DXL microprocessor supports full restartability for all page and segment faults.

Memory is organized into one or more variable length segments, each up to 4 Gb in size. A given region of the linear address space, a segment, can have attributes associated with it. These attributes include its location, size, type (i.e., stack, code or data), and protection characteristics. Each task on an Am386DXL microprocessor can have a maximum of 16,381 segments of up to 4 Gb each, thus providing 64 tb (trillion bytes) or virtual memory to each task.

The segmentation unit provides four levels of protection for isolating and protecting applications and the operating system from each other. The hardware enforced protection allows the design of system with a high degree of integrity.

The Am386DXL microprocessor has two modes of operation: Real Address Mode (Real Mode) and Protected Virtual Address Mode (Protected Mode). In Real Mode, the Am386DXL device operates as a very fast 8086 but with 32-bit extensions, if desired. Real Mode is required primarily to setup the processor for Protected Mode operation. Protected Mode provides address to

the sophisticated memory management, paging, and privilege capabilities of the processor.

Within Protected Mode, software can perform a task switch to enter into tasks designated as Virtual 8086 Mode tasks. Each such tasks behaves with 8086 semantics, thus allowing 8086 software (an application program or an entire operating system) to execute. The Virtual 8086 tasks can be isolated and protected from one another and the host Am386DXL microprocessor operating system by the use of paging and the I/O Permission Bitmap.

Finally, to facilitate high-performance system hardware designs, the Am386DXL microprocessor bus interface offers address pipelining, dynamic data bus sizing, and direct Byte Enable signals for each byte of the data bus. These hardware features are described fully beginning in the Functional Data section.

### **Register Overview**

The Am386DXL microprocessor has 32 register resources in the following categories.

- General Purpose Registers
- Segment Registers
- Instruction Pointer and Flags
- Control Registers
- System Address Registers
- Debug Registers
- Test Registers

The registers are a superset of the 8086, 80186, and 80286 registers, so all 16-bit 80186 and 80286 registers are contained within the 32-bit Am386DXL microprocessor.

Figure 1 shows all of Am386DXL microprocessor base architecture registers that include the general address and data registers, the instruction pointer, and the flags register. The contents of these registers are task-specific, so these registers are automatically loaded with a new context upon a task switch operation.

The base architecture also includes six directly accessible segments, each up to 4 Gb in size. The segments are indicated by the selector values placed in Am386DXL CPU segment registers of Figure 1. Various selector values can be loaded as a program executes, if desired.

The selectors are also task specific, so the segment registers are automatically loaded with new context upon a task switch operation.

The other types of registers Control, System Address, Debug, and Test are primarily used by system software.



#### Figure 1. Base Architecture Registers

# **Register Descriptions**

#### **General-Purpose Registers**

The eight general-purpose registers of 32 bits hold data or address quantities. The general registers, Figure 2, support data operands of 1, 8, 16, 32, and 64 bits and bit fields of 1 to 32 bits. They support address operands of 16 and 32 bits. The 32-bit registers are named EAX, EBX, ECX, EDX, ESI, EDI, EBP, and ESP.

The least significant 16 bits of the registers can be accessed separately. This is done by using the 16-bit names of the registers AX, BX, CX, DX, SI, DI, BP, and SP. When accessed as a 16-bit operand, the upper 16 bits of the register are neither used nor changed.

Finally, 8-bit operations can individually access the lower byte (bits 7–0) and the higher byte (bits 15–8) of general purpose registers AX, BX, CX, and DX. The lower bytes are named AL, BL, CL, and DL, respectively. The higher bytes are named AH, BH, CH, and DH, respectively. The individual byte accessibility offers additional flexibility for data operations, but is not used for effective address calculation.



Figure 2. General Registers and Instruction Pointer

#### **Instruction Pointer**

The instruction pointer, Figure 2, is a 32-bit register named EIP. EIP holds the offset of the next instruction to be executed. The offset is always relative to the base of the code segment (CS). The lower 16 bits (bits 15–0) of EIP contain the 16-bit instruction pointer named IP, which is used by 16-bit addressing.

#### Flags Register

The Flags Register is a 32-bit register named EFLAGS. The defined bits and bit fields within EFLAGS shown in Figure 3 control certain operations and indicate status of the Am386DXL microprocessor. The lower 16 bits (bits 15–0) of EFLAGS contain the 16-bit flag register named FLAGS, which is most useful when executing 8086 and 80286 code.

VM (Virtual 8086 Mode, bit 17)

The VM bit provides Virtual 8086 Mode within Protected Mode. If set while the Am386DXL microprocessor is in Protected Mode, the Am386DXL microprocessor will switch to Virtual 8086 operation, handling segment loads as the 8086 does, but generating Exception 13 faults on privileged op-codes. The VM bit can be set only in Protected Mode by the IRET instruction (if current privilege level = 0) and by task switches at any privilege level. The VM bit is unaffected by POPF. PUSHF always pushes a 0 in this bit, even if executing in virtual 8086 Mode. The EFLAGS image pushed during interrupt processing or saved during task switches will contain a 1 in this bit if the interrupted code was executing as a Virtual 8086 task.

RF (Resume Flag, bit 16)

The RF flag is used in conjunction with the debug register breakpoints. It is checked at instruction

boundaries before breakpoint processing. When RF is set, it causes any debug fault to be ignored on the next instruction. RF is then automatically reset at the successful completion of every instruction (no faults are signaled) except the IRET instruction, the POPF instruction, (JMP, CALL, and INT instructions causing a task switch). These instructions set RF to the value specified by the memory image. For example, at the end of the breakpoint service routine the IRET instruction can pop an EFLAGS image having the RF bit set and resume the program's execution at the breakpoint address without generating another breakpoint fault on the same location.

#### NT (Nested Task, bit 14)

This flag applies to Protected Mode. NT is set to indicate that the execution of this task is nested within another task. If set, it indicates that the current nested task's Task State Segment (TSS) has a valid back link to the previous task's TSS. This bit is set or reset by control transfers to other tasks. The value of NT in EFLAGS is tested by the IRET instruction to determine whether to do an inter-task return or an intra-task return. A POPF or an IRET instruction will affect the setting of this bit according to the image popped at any privilege level.

IOPL (Input/Output Privilege Level, bits 12-13)

This two-bit field applies to Protected Mode. IOPL indicates the numerically maximum CPL (current privilege level) value permitted to execute I/O instructions without generating an Exception 13 fault or consulting the I/O Permission Bitmap. It also indicates the maximum CPL value allowing alteration of the IF (INTR Enable Flag) bit when new values are popped into the EFLAGS register. POPF and IRET instruction can alter the IOPL field when executed at CPL=0. Task switches can always alter the IOPL field when the new flag image is loaded from the incoming task's TSS.

OF (Overflow Flag, bit 11)

OD is set if the operation resulted in a signed overflow. Signed overflow occurs when the operation resulted in carry/borrow into the sign bit (highorder bit) of the result but did not result in a carry/ borrow out of the high-order bit or vice-versa. For 8-, 16-, 32-bit operations, OF is set according to overflow at bits 7, 15, 31, respectively.

DF (Direction Flag, bit 10)

DF defines whether ESI and/or EDI registers postdecrement or postincrement during the sg

instructions. Postincrement occurs if DF is reset. Postdecrement occurs if DF is set.

## IF (INTR Enable Flag, bit 9)

The IF flag, when set, allows recognition of external interrupts signaled on the INTR pin. When IF is reset, external interrupts signaled on the INTR are not recognized. IOPL indicates the maximum CPL value allowing alteration of the IF bit when new values are popped into EFLAGS or FLAGS.

TF (Trap Enable Flag, bit 8)

TF controls the generation of Exception 1 trap when single-stepping through code. When TF is set, the Am386DXL microprocessor generates an Exception 1 trap after the next instruction is executed. When TF is reset, Exception 1 traps occur only as a function of the breakpoint addresses loaded into debug register DR3–DR0.

SF (Sign Flag, bit 7)

SF is set if the high-order bit of the result is set; it is reset otherwise. For 8-, 16-, 32-bit operations, SF reflects the state of bits 7, 15, 31, respectively.

ZF (Zero Flag, bit 6)

ZF is set if all bits of the result are 0. Otherwise it is reset.

AF (Auxiliary Carry Flag, bit 4)

The Auxiliary Flag is used to simplify the addition and subtraction of packed BCD quantities. AF is set if the operation resulted in a carry out of bit 3 (addition) or a borrow into bit 3 (subtraction). Otherwise AF is reset. AF is affected by carry out of, or borrow into bit 3 only, regardless of overall operand length: 8, 16, or 32 bits.

PF (Parity flags, bit 2)

PF is set if the low-order 8 bits of the operation contain an even number of 1s (even parity). PF is reset if the low-order 8 bits have odd parity. PF is a function of only the low-order 8 bits, regardless of operand size.

CF (Carry Flag, bit 0)

CF is set if the operation resulted in a carry out of (addition) or a borrow into (subtraction) the high-order bit. Otherwise CF is reset. For 8-, 16-, or 32-bit operations, CF is set according to carry/ borrow at bits 7, 15, or 31, respectively.

Note in these descriptions, set means set to 1 and reset means reset to 0.



Note: 0 indicates "Reserved for Future Use." Do not define; see Section Compatibility.

15021B-006

| Segment<br>Registers |     |                               |       |       |  |                        |       |      |    |
|----------------------|-----|-------------------------------|-------|-------|--|------------------------|-------|------|----|
| 5                    | 0   | Physical Base Address Segment | Limit | Attri |  | ther<br>iment<br>om De | scrip | otor |    |
| Selector             | CS- |                               |       |       |  |                        |       |      | Γ  |
| Selector             | ss- |                               |       |       |  |                        | _     |      | -  |
| Selector             | DS- |                               |       |       |  |                        | _     | _    | Γ_ |
| Selector             | ES- |                               |       | T     |  |                        | _     | _    | Γ- |
| Selector             | FS- |                               |       |       |  |                        | -     | _    | -  |
| Selector             | GS- | -                             |       |       |  |                        | _     |      | -  |

#### Figure 3. FLAGS Registers

15021B-007

#### Figure 4. Segment Registers and Associated Descriptor Registers

#### Segment Registers

Six 16-bit segment registers hold segment selector values identifying the currently addressable memory segments. Segment registers are shown in Figure 4. In Protected Mode, each segment may range in size from one byte up to the entire linear and physical space of the machine, 4 Gb (2<sup>32</sup> bytes). If a maximum sized segment is used (limit = FFFFFFH) it should be Dword aligned (i.e., the least two significant bits of the segment base should be zero). This will avoid a segment limit violation (Exception 13) caused by the wrap around. In Real Address Mode, the maximum segment size is fixed at 64 Kb (2<sup>16</sup> bytes).

The six segments addressable at any given moment are defined by the segment registers: CS, SS, DS, ES, FS, and GS. The selector in SS indicates the current stack

segment; the selectors in DS, ES, FS, and GS indicate the current data segments.

#### **Segment Descriptor Registers**

The segment descriptor registers are not programmer visible, yet it is very useful to understand their content. Inside the Am386DXL microprocessor, a descriptor register (programmer invisible) is associated with each programmer-visible segment register, as shown by Figure 4. Each descriptor register holds a 32-bit segment base address, a 32-bit segment limit, and the other necessary segment attributes.

When a selector value is loaded into a segment register, the associated descriptor register is automatically updated with the correct information. In Real Address Mode, only the base address is updated directly (by

shifting the selector value four bits to the left), since the segment maximum limit and attributes are fixed in Real Mode. In Protected Mode, the base address, the limit, and the attributes are all updated per the contents of the segment descriptor indexed by the selector.

Whenever a memory reference occurs, the segment descriptor register associated with the segment being used is automatically involved with the memory reference. The 32-bit segment base address becomes a component of the linear address calculation, the 32-bit limit is used for the limit-check operation, and the attributes are checked against the type of memory reference requested.

# **Control Registers**

The Am386DXL microprocessor has three control registers of 32 bits: CR0, CR2, and CR3 to hold machine state of a global nature (not specific to an individual task). These registers, along with System Address Registers described in the next section, hold machine state that affects all tasks in the system. To access the Control Registers, load and store instructions are defined.

#### CR0: Machine Control Register (Includes 80286 Machine Status Word)

CR0, shown in Figure 5, contains 6 defined bits for control and status purposes. The low-order 16 bits of CR0 are also known as the Machine Status Word (MSW) for compatibility with 80286 Protected Mode. LMSW and SMSW instructions are taken as special aliases of the load and store CR0 operations, where only the loworder 16 bits of CR0 are involved. For compatibility with 80286 operating systems, the Am386DXL microprocessor LMSW instructions work in an identical fashion to the LMSW instruction on the 80286 (i.e., it only operates on the low-order 16 bits of CR0 and it ignores the new bits in CR0). New Am386DXL microprocessor operating systems should use the MOV CR0, Reg instruction.

The defined CR0 bits are described below.

PG (Paging Enable, bit 31)

The PG bit is set to enable the on-chip paging unit. It is reset to disable the on-chip paging unit. R (Reserved, bit 4)

This bit is Reserved for Future Use. When loading CR0 care should be taken to not alter the value of this bit.

TS (Task Switched, bit 3)

TS is automatically set whenever a task switch operation is performed. If TS is set, a coprocessor ESCape op-code will cause a Coprocessor Not Available trap (Exception 7). The trap handler typically saves a 387DX math coprocessor context belonging to a previous task, loads a 387DX math coprocessor state belonging to the current task, and clears the TS bit before returning to the faulting coprocessor op-code.

EM (Emulate Coprocessor, bit 2)

The Emulate coprocessor bit is set to cause all coprocessor op-codes to generate a Coprocessor Not Available fault (Exception7). It is reset to allow coprocessor op-codes to be executed on an actual 387DX math coprocessor (this is the default case after reset). Note that the WAIT op-code is not affected by the EM bit setting.

MP (Monitor Coprocessor, bit 1)

The MP bit is used in conjunction with the TS bit to determine if the WAIT op-code will generate a Coprocessor Not Available fault (Exception 7) when TS = 1. When both MP = 1 and TS = 1, the WAIT op-code generates a trap. Otherwise, the WAIT op-code does not generate a trap. Note that TS is automatically set whenever a task switch operation is performed.

PE (Protection Enable, bit 0)

The PE bit is set to enable the Protected Mode. If PE is reset, the processor operates again in Real Mode. PE may be set by loading MSW or CR0. PE can be reset only by a load into CR0. Resetting the PE bit is typically part of a longer instruction sequence needed for proper transition from Protected Mode to Real Mode. Note that for strict 80286 compatibility, PE cannot be reset by the LMSW instruction.



Note: 0 indicates "Reserved for Future Use." Do not define; see Section Compatibility.

Figure 5. Control Register 0

#### CR1: Reserved

CR1 is reserved for future processors.

#### CR2: Page Fault Linear Address

CR2, shown in Figure 6, holds the 32-bit linear address that caused the last page fault detected. The error code pushed onto the page fault handler's stack when it is invoked provides additional status information on this page fault.

#### CR3: Page Directory Base Address

CR3, shown in Figure 6, contains the physical base address of the page directory table. The Am386DXL microprocessor page directory table is always pagealigned (4 Kb-aligned). Therefore the lowest 12 bits of CR3 are ignored when written and they store as undefined.

A task switch through a TSS that changes the value in CR3, or an explicit load into CR3 with any value, will invalidate all cached page table entries in the paging unit cache. Note that if the value in CR3 does not change during the task switch, the cached page table entries are not flushed.

#### System Address Registers

Four special registers are defined to reference the tables or segments supported by the 80286 CPU and Am386DXL microprocessor protection model. These tables or segments are: GDT (Global Descriptor Table);

IDT (Interrupt Descriptor Table);

LDT (Local Descriptor Table);

TSS (Task State Segment).

The addresses of these tables and segments are stored in special registers, the System Address and System Segment Registers illustrated in Figure 7. These registers are named GDTR, IDTR, LDTR, and TR, respectively. The Protected Mode Architecture section describes the use of these registers.

#### GDTR and IDTR

These registers hold the 32-bit linear base address and 16-bit limit of the GDT and IDT, respectively.

The GDT and IDT segments, since they are global to all tasks in the system, are defined by 32-bit linear addresses (subject to page translation if paging is enabled) and 16-bit limit values.

#### LDTR and TR

These registers hold the 16-bit selector for the LDT descriptor and the TSS descriptor, respectively.

The LDT and TSS segments, since they are taskspecific segments, are defined by selector values stored in the system segment registers. Note that a segment descriptor register (programmer-invisible) is associated with each system segment register.



Note: 0 indicates "Reserved for Future Use." Do not define; see Section Compatibility.

15021B-009

#### Figure 6. Control Registers 2 and 3



15021B-010

Figure 7. System Address and System Segment Registers

#### **Debug and Test Registers**

**Debug Registers**: The six programmer accessible debug registers provide on-chip support for debugging. Debug Registers DR3–DR0 specify the four linear breakpoints. The Debug Control Register DR7 is used to set the breakpoints, and the Debug Status Register DR6 displays the current state of the breakpoints. The use of the debug registers is described in the Debugging Support section.

Test Registers: Two registers are used to control the testing of the RAM/CAM (Content Addressable Memories) in the Translation Look-Aside Buffer portion of the Am386DXL microprocessor. TR6 is the command test register, and TR7 is the data register that contains the data of the Translation Look-Aside buffer test. Their use is discussed in the Testability section. Figure 8 shows the Debug and Test registers.

Dahara Dautatan

| 310                                     |     |
|-----------------------------------------|-----|
| Linear Breakpoint Address 0             | DR0 |
| Linear Breakpoint Address 1             | DR1 |
| Linear Breakpoint Address 2             | DR2 |
| Linear Breakpoint Address 3             | DR3 |
| Reserved for Future use. Do not define. | DR4 |
| Reserved for Future use. Do not define. | DR5 |
| Breakpoint Status                       | DR6 |
| Breakpoint Control                      | DR7 |

#### Test Registers (For Page Cache)

| <u>31</u>    |     |
|--------------|-----|
| Test Control | TR6 |
| Test Status  | TR7 |

15021B-011

#### Figure 8. Debug and Test Registers

#### **Register Accessibility**

There are a few differences regarding the accessibility of the registers in Real and Protected Mode. Table 1 summarizes these differences. See the Protected Mode Architecture section for further details.

#### Compatibility

#### VERY IMPORTANT NOTE: COMPATIBILITY WITH FUTURE PROCESSORS

In the preceding register descriptions, note certain Am386DXL microprocessor register bits are Reserved for Future Use. When reserved bits are called out, treat them as fully undefined. This is essential for your software compatibility with future processors! Follow the guidelines below:

- 1. Do not depend on the state of any undefined bits when testing the values of defined register bits. Mask them out when testing.
- 2. Do not depend on the state of any undefined bits when storing them to memory or another register.
- 3. Do not depend on the ability to retain information written into any undefined bits.
- 4. When loading registers always load the undefined bits as zeros.
- 5. However, registers which have been previously stored may be reloaded without masking.

Depending upon the values of undefined register bits will make your software dependent upon the unspecified Am386DXL microprocessor handling of these bits. Depending on undefined values risks making your software incompatible with future processors that define usages for the Am386DXL CPU undefined bits. Avoid any software dependence upon the state of undefined Am386DXL CPU register bits.

| Register          | Use In<br>Real Mode |       | Use In<br>Protected Mode |        | Use In<br>Virtual 8086 Mode |       |
|-------------------|---------------------|-------|--------------------------|--------|-----------------------------|-------|
|                   | Load                | Store | Load                     | Store  | Load                        | Store |
| General Registers | Yes                 | Yes   | Yes                      | Yes    | Yes                         | Yes   |
| Segment Registers | Yes                 | Yes   | Yes                      | Yes    | Yes                         | Yes   |
| Flag Registers    | Yes                 | Yes   | Yes                      | Yes    | IOPL                        | IOPL  |
| Control Registers | Yes                 | Yes   | PL = 0                   | PL = 0 | No                          | Yes   |
| GDTR              | Yes                 | Yes   | PL = 0                   | Yes    | No                          | Yes   |
| DTR               | Yes                 | Yes   | PL = 0                   | Yes    | No                          | Yes   |
| DTR               | No                  | No    | PL = 0                   | Yes    | No                          | No    |
| ſR                | No                  | No    | PL = 0                   | Yes    | No                          | No    |
| Debug Control     | Yes                 | Yes   | PL = 0                   | PL = 0 | No                          | No    |
| Test Registers    | Yes                 | Yes   | PL = 0                   | PL = 0 | No                          | No    |

Table 1. Register Usage

Notes:PL = 0: The registers can be accessed only when the current privilege level is zero.

IOPL: The PUSHF and POPF instructions are made I/O Privilege Level sensitive in Virtual 8086 Mode.

~ 4

# Instruction Set

#### Instruction Set Overview

The instruction set is divided into nine categories of operations.

- Data Transfer
- Arithmetic
- Shift/Rotate
- String Manipulation
- Bit Manipulation
- Control Transfer
- High Level Language Support
- **Operating System Support**
- Processor Control

These Am386DXL microprocessor instructions are listed in Table 2.

All Am386DXL microprocessor instructions operate on either 0, 1, 2, or 3 operands where an operand resides in a register in the instruction itself or in memory. Most zero operand instructions (e.g., CLI, STI) take only one byte. One operand instructions generally are two bytes long. The average instruction is 3.2-bytes long. Since the Am386DXL device has a 16-byte instruction queue, an average of 5 instructions will be prefetched. The use of two operands permits the following types of common instructions.

Register to Register Memory to Register Immediate to Register Register to Memory Immediate to Memory

The operands can be either 8-, 16-, or 32-bits long. As a general rule, when executing code written for the Am386DXL microprocessor (32-bit code), operands are 8 or 32 bits; when executing existing 80286 or 8086 code (16-bit code), operands are 8 or 16 bits. Prefixes can be added to instructions that override the default length of the operands (i.e., use 32-bit operands for 16-bit code).

# **Addressing Modes**

#### Addressing Modes Overview

The Am386DXL microprocessor provides a total of 11 addressing modes for instructions to specify operands. The addressing modes are optimized to allow the efficient execution of high-level languages such as C and FORTRAN, and they cover the vast majority of data references needed by high-level languages.

#### **Register and Immediate Modes**

Two of the addressing modes provide for instructions that operate on register or immediate operands:

**Register Operand Mode**: The operand is located in one of the 8-, 16-, or 32-bit general registers.

**Immediate Operand Mode**: The operand is included in the instruction as part of the op-code.

#### 32-Bit Memory Addressing Modes

The remaining nine modes provide a mechanism for specifying the effective address of an operand. The linear address consists of two components: the segment base address and an effective address. The effective address is calculated by using combinations of the following four address elements.

**Displacement**: An 8- or 32-bit immediate value following the instruction.

**Base**: The contents of any general-purpose register. The Base registers are generally used by compilers to point to the start of the local variable area.

Index: The contents of any general-purpose register except for ESP. The Index registers are used to access the elements of an array, or a string of characters.

Scale: The index register's value can be multiplied by a scale factor either 1, 2, 4, or 8. Scaled index mode is especially useful for accessing arrays or structures.

Combinations of these 4 components make up the 9 additional addressing modes. There is no performance penalty for using any of these addressing combinations, since the effective address calculation is pipelined with the execution of other instructions.

The one exception is the simultaneous use of Base and Index components that requires one additional clock.

As shown in Figure 9, the effective address (EA) of an operand is calculated according to the following formula.

EA = Base Reg + (Index Reg · Scaling) + Displacement

Direct Mode: The operand's offset is contained as part of the instruction as an 8-, 16-, or 32-bit displacement.

#### EXAMPLE: INC Word PTR [500]

Register Indirect Mode: A Base register contains the address of the operand.

#### EXAMPLE: MOV [ECX], EDX

Based Mode: A Base register's contents is added to a Displacement to form the operands offset.

#### EXAMPLE: MOV ECX, [EAX + 24]

### Table 2a. Data Transfer

| [     | General Purpose                              |  |  |  |
|-------|----------------------------------------------|--|--|--|
| MOV   | Move operand                                 |  |  |  |
| PUSH  | Push operand onto stack                      |  |  |  |
| POP   | Pop operand off stack                        |  |  |  |
| PUSHA | Push all registers on stack                  |  |  |  |
| POPA  | Pop all registers off stack                  |  |  |  |
| XCHG  | Exchange operand register                    |  |  |  |
| XLAT  | Translate                                    |  |  |  |
|       | Conversion                                   |  |  |  |
| MOVZX | Move byte or Word, Dword with zero extension |  |  |  |
| MOVSX | Move byte or Word, Dword, sign extended      |  |  |  |
| CBW   | Convert byte to Word, or Word to Dword       |  |  |  |
| CWD   | Convert Word to Dword                        |  |  |  |
| CWDE  | Convert Word to Dword extended               |  |  |  |
| CDQ   | Convert Dword to Qword                       |  |  |  |
|       | Input/Output                                 |  |  |  |
| IN    | Input operand from I/O space                 |  |  |  |
| OUT   | OUT Output operand to I/O space              |  |  |  |
|       | Address Object                               |  |  |  |
| LEA   | Load effective address                       |  |  |  |
| LDS   | Load pointer into D segment register         |  |  |  |
| LES   | Load pointer into E segment register         |  |  |  |
| LFS   | Load pointer into F segment register         |  |  |  |
| LGS   | Load pointer into G segment register         |  |  |  |
| LSS   | Load pointer into S (Stack) segment register |  |  |  |
|       | Flag Manipulation                            |  |  |  |
| LAHF  | Load A register from Flags                   |  |  |  |
| SAHF  | Store A register in Flags                    |  |  |  |
| PUSHF | Push flags onto stack                        |  |  |  |
| POPF  | Pop flags off stack                          |  |  |  |
| PUSHF | Push EFLAGS onto stack                       |  |  |  |
| POPFD | Pop EFLAGS off stack                         |  |  |  |
| CLC   | Clear Carry Flag                             |  |  |  |
| CLD   | Clear Direction Flag                         |  |  |  |
| СМС   | Complement Carry Flag                        |  |  |  |
| STC   | Set Carry Flag                               |  |  |  |
| STD   | Set Direction Flag                           |  |  |  |

#### Table 2b. Arithmetic Instructions

| Addition |                                  |  |
|----------|----------------------------------|--|
| ADD      | Add operands                     |  |
| ADC      | Add with carry                   |  |
| INC      | Increment operand by 1           |  |
| AAA      | ASCII adjust for addition        |  |
| DAA      | Decimal adjust for addition      |  |
|          | Subtraction                      |  |
| SUB      | Subtract operands                |  |
| SBB      | Subtract with borrow             |  |
| DEC      | Decrement operand by 1           |  |
| NEG      | Negate operand                   |  |
| CMP      | Compare operands                 |  |
| DAS      | Decimal adjust for subtraction   |  |
| AAS      | ASCII adjust for subtraction     |  |
|          | Multiplication                   |  |
| MUL      | Multiply Double/Single Precision |  |
| IMUL     | Integer multiply                 |  |
| AAM      | ASCII adjust after multiply      |  |
| Division |                                  |  |
| DIV      | Divide unsigned                  |  |
| IDIV     | Integer divide                   |  |
| AAD      | ASCII adjust before division     |  |

# Table 2c. String Instructions

| MOVS           | Move byte or Word, Dword string    |
|----------------|------------------------------------|
| INS            | Input string from I/O space        |
| OUTS           | Output string to I/O space         |
| CMPS           | Compare byte or Word, Dword string |
| SCAS           | Scan Byte or Word, Dword string    |
| LODS           | Load byte or Word, Dword string    |
| STOS           | Store byte or Word, Dword string   |
| REP            | Repeat                             |
| REPE/<br>REPZ  | Repeat while equal/zero            |
| RENE/<br>REPNZ | Repeat while not equal/not zero    |

# Table 2d. Logical Instructions

| Logicals      |                                 |  |
|---------------|---------------------------------|--|
| NOT           | "NOT" operand                   |  |
| AND           | "AND" operands                  |  |
| OR            | "Inclusive OR" operands         |  |
| XOR           | "Exclusive OR" operands         |  |
| TEST          | "Test" operands                 |  |
| Shifts        |                                 |  |
| SHL/SHR       | Shift logical left or right     |  |
| SAL/SAR       | Shift arithmetic left or right  |  |
| SHLD/<br>SHRD | Double shift left or right      |  |
| Rotates       |                                 |  |
| ROL/ROR       | Rotate left/right               |  |
| RCL/RCR       | Rotate through carry left/right |  |

# Table 2e. Bit Manipulation Instructions

| Single Bit Instructions |                         |  |
|-------------------------|-------------------------|--|
| BT                      | Bit Test                |  |
| BTS                     | Bit Test and Set        |  |
| BTR                     | Bit Test and Reset      |  |
| BTC                     | Bit Test and Complement |  |
| BSF                     | Bit Scan Forward        |  |
| BSR                     | Bit Scan Reverse        |  |

#### Table 2f. Program Control Instructions

| Conditional Transfers |                                    |  |
|-----------------------|------------------------------------|--|
| SETCC                 | Set byte equal to condition code   |  |
| JA/JNBE               | Jump if above/not below nor equal  |  |
| JAE/JNB               | Jump if above or equal/not below   |  |
| JB/JNAE               | Jump if below/not above nor equal  |  |
| JBE/JNA               | Jump if below or equal/not above   |  |
| JC                    | Jump if carry                      |  |
| JE/JZ                 | Jump if equal/zero                 |  |
| JG/JNLE               | Jump if greater/not less nor equal |  |
| JGE/JNL               | Jump if greater or equal/not less  |  |
| JL/JNGE               | Jump if less/not greater nor equal |  |
| JLE/JNG               | Jump if less or equal/not greater  |  |
| JNC                   | Jump if not carry                  |  |
| JNE/JNZ               | Jump if not equal/not zero         |  |
| JNO                   | Jump if not overflow               |  |
| JNP/JPO               | Jump if not parity/parity odd      |  |
| JNS                   | Jump if not sign                   |  |
| JO                    | Jump if overflow                   |  |
| JP/JPE                | Jump if parity/parity even         |  |
| JS                    | Jump if sign                       |  |

# Table 2f. Program Control Instructions (continued)

|                    | (0011111100)               |  |
|--------------------|----------------------------|--|
|                    | Unconditional Transfers    |  |
| CALL               | Call procedure/task        |  |
| RET                | Return from procedure      |  |
| JMP                | Jump                       |  |
| Iteration Controls |                            |  |
| LOOP               | Loop                       |  |
| LOOPE/<br>LOOPZ    | Loop if equal/zero         |  |
| LOOPNE/<br>LOOPNZ  | Loop if not equal/not zero |  |
| JCXZ               | JUMP if register CX = 0    |  |
| Interrupts         |                            |  |
| INT                | Interrupt                  |  |
| INTO               | Interrupt if overflow      |  |
| IRET               | Return from interrupt/task |  |
| CLI                | Clear interrupt enable     |  |
| STI                | Set interrupt enable       |  |
|                    |                            |  |

#### Table 2g. High Level Language Instructions

| BOUND | Check array bounds                           |
|-------|----------------------------------------------|
| ENTER | Setup parameter block for entering procedure |
| LEAVE | Leave procedure                              |

#### Table 2h. Protection Model

| SGDT          | Store global descriptor table                      |
|---------------|----------------------------------------------------|
| SIDT          | Store interrupt descriptor table                   |
| STR           | Store task register                                |
| SLDT          | Store local descriptor table                       |
| LGDT          | Load global descriptor table                       |
| LIDT          | Load interrupt descriptor table                    |
| LTR           | Load task register                                 |
| LLDT          | Load local descriptor table                        |
| ARPL          | Adjust requested privilege level                   |
| LAR           | Load access rights                                 |
| LSL           | Load segment limit                                 |
| VERR/<br>VERW | Verify segment for reading or writing              |
| LMSW          | Load machine status word (lower 16 bits<br>of CR0) |
| SMSW          | Store machine status word                          |

#### Table 2i. Processor Control Instructions

| HLT  | Halt                    |
|------|-------------------------|
| WAIT | Wait until BUSY negated |
| ESC  | Escape                  |
| LOCK | Lock Bus                |

Index Mode: An Index register's contents is added to a Displacement to form the operands offset.

## EXAMPLE: ADD EAX, TABLE [ESI]

Scaled Index Mode: An Index register's contents is multiplied by a scaling factor that is added to a Displacement to form the operands offset.

#### EXAMPLE: IMUL EBX, TABLE [ESI • 4], 7

Based Index Mode: The contents of a Base register is added to the contents of an Index register to form the effective address of an operand.

# EXAMPLE: MOV EAX, [ESI] [EBX]

Based Scaled Index Mode: The contents of an Index register is multiplied by a Scaling factor and the result is added to the contents of a Base register to obtain the operands offset.

# EXAMPLE: MOV ECX, [EDX • 8] [EAX]

Based Index Mode with Displacement: The contents of an Index Register and a Base register's contents and a Displacement are all summed together to form the operand offset.

## EXAMPLE: ADD EDX, [ESI] [EBP+00FFFFF0H]

Based Scaled Index Mode with Displacement: The contents of an Index register are multiplied by a Scaling factor, the result is added to the contents of a Base register and a Displacement to form the operand's offset.

EXAMPLE: MOV EAX, LOCALTABLE[EDI • 4] [EBP + 80]





#### Differences Between 16- and 32-Bit Addresses

In order to provide software compatibility with the 80286 and the 8086, the Am386DXL microprocessor can execute 16-bit instructions in Real and Protected Modes. The processor determines the size of the instructions it is executing by examining the D bit in the CS segment descriptor. If the D bit is 0 then all operand lengths and effective addresses are assumed to be 16 bits long. If the D bit is 1 then the default length for operands and addresses is 32 bits. In Real Mode, the default size for operands and addresses is 16 bits.

Regardless of the default precision of the operands or addresses, the Am386DXL microprocessor is able to execute either 16- or 32-bit instructions. This is specified via the use of override prefixes. Two prefixes, the Operand Size Prefix and the Address Length Prefix, override the value of the D bit on an individual instruction basis.

Example: The processor is executing in Real Mode and the programmer needs to access the EAX registers. The assembler code for this might be MOV EAX, 32-bit MEMORYOP. An assembler automatically determines that an Operand Size Prefix is needed and generates it.

Example: The D bit is 0, and the programmer wishes to use Scaled Index addressing mode to access an array. The Address Length Prefix allows the use of MOV DX, TABLE [ESI  $\bullet$  2]. The assembler uses an Address Length Prefix, since with D = 0, the default addressing mode is 16 bits.

Example: The D bit is 1, and the program wants to store a 16-bit quantity. The Operand Length Prefix is used to specify only a 16-bit value: MOV MEM16, DX.

The Operand Length and Address Length prefixes can be applied separately or in combination to any instruction. The Address Length Prefix does not allow addresses over 64 Kb to be accessed in Real Mode. A memory address that exceeds FFFFH will result in a General Protection Fault. An Address Length Prefix only allows the use of the additional Am386DXL microprocessor addressing modes.

When executing 32-bit code, the Am386DXL microprocessor uses either 8- or 32-bit displacements, and any register can be used as base or index registers. When executing 16-bit code, the displacements are either 8 or 16 bits, and the base and index register conform to the 80286 model. Table 3 illustrates the differences.

#### Data Types

The Am386DXL microprocessor supports all of the data types commonly used in high-level languages.

Bit: A single bit quantity.

Bit Field: A group of up to 32 contiguous bits that spans a maximum of four bytes.

Bit String: A set of contiguous bits on the Am386DXL microprocessor bit strings can be up to 4 Gb long.

Byte: A signed 8-bit quantity.

Unsigned Byte: An unsigned 8-bit quantity.

Integer (Word): A signed 16-bit quantity.

Long Integer (Double Word): A signed 32-bit quantity. All operations assume a 2's complement representation.

Unsigned Integer (Word): An unsigned 16-bit quantity.

Unsigned Long Integer (Double Word): An unsigned 32-bit quantity.

Signed Quad Word: A signed 64-bit quantity.

Unsigned Quad Word: An unsigned 64-bit quantity.

Offset: A 16- or 32-bit offset only quantity that indirectly references another memory location.

Pointer: A full pointer which consists of a 16-bit segment selector and either a 16- or 32-bit offset.

Char: A byte representation of an ASCII alphanumeric or control character.

String: A contiguous sequence of bytes, words or Dword. A string may contain between 1 byte and 4 Gb.

BCD: A byte (unpacked) representation of decimal digits 0–9.

Packed BCD: A byte (packed) representation of two decimal digits 0–9 storing one digit in each nibble.

When the Am386DXL microprocessor is coupled with a 387DX math coprocessor then the following common Floating Point types are supported.

Floating Point: A signed 32-, 64-, or 80-bit real number representation. Floating point numbers are supported by a 387DX compatible math coprocessor.

Figure 10 illustrates the data types supported by the Am386DXL microprocessor and a 387DX compatible math coprocessor.

|                | 16-Bit Addressing | 32-Bit Addressing      |
|----------------|-------------------|------------------------|
| Base Register  | BX, BP            | Any 32-bit GP Register |
| Index Register | SI, DI            | Any 32-bit GP Register |
|                |                   | Except ESP             |
| Scale Factor   | None              | 1, 2, 4, 8             |
| Displacement   | 0, 8, 16 bits     | 0, 8, 32 bits          |

#### Table 3. Base and Index Registers for 16- and 32-Bit Addresses



15021B-013

Figure 10. Supported Data Types



\*Supported by 387DX-compatible math coprocessor.

15021B-013

Figure 10. Supported Data Types (continued)

# **Memory Organization**

## Introduction

Memory on the Am386DXL microprocessor is divided up into 8-bit quantities (Bytes), 16-bit quantities (Words), and 32-bit quantities (Dword). Words are stored in two consecutive bytes in memory with the loworder byte at the lowest address, the high-order byte at the highest address. Dwords are stored in four consecutive bytes in memory with the low-order byte at the lowest address, the high-order byte at the lowest address, the high-order byte at the highest address. The address of a word or Dword is the byte address of the low-order byte.

In addition to these basic data types, the Am386DXL microprocessor supports two larger units of memory: pages and segments. Memory can be divided up into one or more variable length segments, which can be swapped to disk or shared between programs. Memory can also be organized into one or more 4-Kb pages. Finally, both segmentation and paging can be combined, gaining the advantages of both systems. The Am386DXL microprocessor supports both pages and segments in order to provide maximum flexibility to the system designer. Segmentation and paging are complementary. Segmentation is useful for organizing memory in logical modules, and as such is a tool for the application programmer, while pages are useful for the system programmer for managing the physical memory of a system.

#### **Address Spaces**

The Am386DXL microprocessor has three distinct address spaces: logical, linear, and physical. A logical

address (also known as a virtual address) consists of a selector and an offset. A selector is the contents of a segment register. An offset is formed by summing all of the addressing components (Base, Index, Displacement) discussed in Section Memory Address Modes into an effective address. Since each task on Am386DXL CPU has a maximum of 16K (2<sup>14</sup>-1) selectors, and offsets can be 4 Gb (2<sup>32</sup> bits), this gives a total of 2<sup>46</sup> bits or 64 tb of logical address space per task. The programmer sees this virtual address space.

The segmentation unit translates the logical address space into a 32-bit linear address space. If the paging unit is not enabled then the 32-bit linear address corresponds to the physical address. The paging unit translates the linear address space into the physical address space. The physical address is what appears on the address pins.

The primary difference between Real Mode and Protected Mode is how the segmentation unit performs the translation of the logical address into the linear address. In Real Mode, the segmentation unit shifts the selector left four bits and adds the result to the offset to form the linear address. While in Protected Mode, every selector has a linear base address associated with it. The linear base address is stored in one of two operating system tables (i.e., the Local Descriptor Table or Global Descriptor Table). The selector's linear base address is added to the offset to form the final linear address.

Figure 11 shows the relationship between the various address spaces.



Figure 11. Address Translation

#### Segment Register Usage

The main data structure used to organize memory is the segment. On the Am386DXL microprocessor, segments are variable sized blocks of linear addresses that have certain attributes associated with them. There are two main types of segments: code and data. The segments are of variable size and can be as small as 1 byte or as large as 4 Gb (2<sup>32</sup> bytes).

In order to provide compact instruction encoding and increase processor performance, instructions do not need to explicitly specify which segment register is used. A default segment register is automatically chosen according to the rules of Table 4 (Segment Register Selection Rules). In general, data references use the selector contained in the DS register; Stack references use the SS register; and Instruction fetches use the CS register. The contents of the Instruction Pointer provides the offset. Special segment override prefixes allow the explicit use of a given segment register, and override the implicit rules listed in Table 4. The override prefixes also allow the use of the ES, FS, and GS segment registers.

There are no restrictions regarding the overlapping of the base addresses of any segments. Thus, all 6 segments could have the base address set to zero and create a system with a 4-Gb linear address space. This creates a system where the virtual address space is the same as the linear address space. Further details of segmentation are discussed in Section Protected Mode Architecture.

### I/O Space

The Am386DXL microprocessor has two distinct physical address spaces: Memory and I/O. Generally, peripherals are placed in I/O space although the Am386DXL CPU also supports memory-mapped peripherals. The I/O space consists of 64 Kb, it can be divided into 64K 8-bit ports, 32K 16-bit ports, or 16K 32-bit ports, or any combination of ports that add up to less than 64 Kb. The 64K I/O address space refers to physical memory rather than linear address since I/O instructions do not go through the segmentation or paging hardware. The  $M/\overline{IO}$  pin acts as an additional address line, thus allowing the system designer to easily determine which address space the processor is accessing.

The I/O ports are accessed via the IN and OUT I/O instructions, with the port address supplied as an immediate 8-bit constant in the instruction or in the DX register. All 8- and 16-bit port addresses are zero extended on the upper address lines. The I/O instructions cause the M/IO pin to be driven Low.

I/O port addresses 00F8H through 00FFH are reserved.

#### Interrupts

#### Interrupts and Exceptions

Interrupts and exceptions alter the normal program flow, in order to handle external events, to report errors or exceptional conditions. The difference between interrupts and exceptions is that interrupts are used to

| Type of<br>Memory Reference                                                            | Implied (Default)<br>Segment Use | Segment Override<br>Prefixes Possible    |
|----------------------------------------------------------------------------------------|----------------------------------|------------------------------------------|
| Code Fetch                                                                             | CS                               | None                                     |
| Destination of PUSH, PUSHF, INT,<br>CALL, PUSHA Instructions                           | SS                               | None                                     |
| Source of POP, POPA, POPF,<br>IRET, RET Instructions                                   | SS                               | None                                     |
| Destination of STOS, MOVS, REP<br>STOS, REP MOVS Instructions<br>(DI is Base Register) | ES                               | None                                     |
| Other Data References with<br>Effective Address Using Base<br>Register of:             |                                  |                                          |
| [EAX]                                                                                  | DS                               | CS, SS, ES, FS, GS                       |
| [EBX]<br>[ECX]                                                                         | DS<br>DS                         | CS, SS, ES, FS, GS<br>CS, SS, ES, FS, GS |
| [ECX]                                                                                  | DS                               | CS, SS, ES, FS, GS<br>CS, SS, ES, FS, GS |
| [ESI]                                                                                  | DS                               | CS, SS, ES, FS, GS                       |
| (EDI)                                                                                  | DS                               | CS, SS, ES, FS, GS                       |
| [EBP]                                                                                  | SS                               | CS, SS, ES, FS, GS                       |
| [ESP]                                                                                  | SS                               | CS, SS, ES, FS, GS                       |

#### **Table 4. Segment Register Selection Rules**

handle asynchronous external events while exceptions handle instruction faults. Although a program can generate a software interrupt via an INT n instruction, the processor treats software interrupts as exceptions.

Hardware interrupts occur as the result of an external event and are classified into two types: maskable or non-maskable. Interrupts are serviced after the execution of the current instruction. After the interrupt handler is finished servicing the interrupt, execution proceeds with the instruction immediately after the interrupted instruction. The differences between the interrupts are discussed in Sections Maskable Interrupt and Non-Maskable Interrupt.

Exceptions are classified as faults, traps, or aborts depending on the way they are reported, and whether or not restart of the instruction causing the exception is supported. Faults are exceptions that are detected and serviced before the execution of the faulting instruction. A fault would occur in a virtual memory system, when the processor referenced a page or a segment that was not present. The operating system would fetch the page or segment from disk, and then the Am386DXL microprocessor would restart the instruction. Traps are exceptions that are reported immediately after the execution of the instruction that caused the problem. User defined interrupts are examples of traps. Aborts are exceptions that do not permit the precise location of the instruction causing the exception to be determined. Aborts are used to report severe errors, such as a hardware error or illegal values in system tables.

Thus, when an interrupt service routine has been completed, execution proceeds from the instruction immediately following the interrupted instruction. On the other hand, the return address from an exception fault routine will always point at the instruction causing the exception and include any leading instruction prefixes. Table 5 summarizes the possible interrupts for the Am386DXL microprocessor and shows where the return address points.

The Am386DXL microprocessor has the ability to handle up to 256 different interrupts/exceptions. In order to service the interrupts, a table with up to 256 interrupt vectors must be defined. The interrupt vectors are simply pointers to the appropriate interrupt service routine. In Real Mode (see Section Real Mode Introduction), the vectors are 4 byte quantities, a Code Segment plus a 16-bit offset; in Protected Mode, the interrupt vectors are 8 byte quantities that are put in an Interrupt Descriptor Table (see Section Introduction). Of the 256 possible interrupts, 32 are Reserved for Future Use, the remaining 224 are free to be used by the system designer.

| Function                    | Interrupt<br>Number | Instruction Which Can<br>Cause Exception       | Return Address<br>Points to<br>Faulting<br>Instruction | Туре  |
|-----------------------------|---------------------|------------------------------------------------|--------------------------------------------------------|-------|
| Divide Error                | 0                   | DIV, IDIV                                      | Yes                                                    | FAULT |
| Debug Exception             | 1                   | Any instruction                                | Yes                                                    | TRAP* |
| NMI Interrupt               | 2                   | INT 2 or NMI                                   | No                                                     | NMI   |
| One Byte Interrupt          | 3                   | INT                                            | No                                                     | TRAP  |
| Interrupt on Overflow       | 4                   | INTO                                           | No                                                     | TRAP  |
| Array Bounds Check          | 5                   | BOUND                                          | Yes                                                    | FAULT |
| Invalid Op-Code             | 6                   | Any illegal instruction                        | Yes                                                    | FAULT |
| Device Not Available        | 7                   | ESC, WAIT                                      | Yes                                                    | FAULT |
| Double Fault                | 8                   | Any instruction that can generate an Exception |                                                        | ABORT |
| Coprocessor Segment Overrun | 9                   | ESC                                            | No                                                     | ABORT |
| Invalid TSS                 | 10                  | JMP, CALL, IRET, INT                           | Yes                                                    | FAULT |
| Segment Not Present         | 11                  | Segment register instructions                  | Yes                                                    | FAULT |
| Stack Fault                 | 12                  | Stack references                               | Yes                                                    | FAULT |
| General Protection Fault    | 13                  | Any memory reference                           | Yes                                                    | FAULT |
| Page Fault                  | 14                  | Any memory access or code fetch                | Yes                                                    | FAULT |
| Reserved for Future Use     | 15                  |                                                |                                                        |       |
| Coprocessor Error           | 16                  | ESC, WAIT                                      | Yes                                                    | FAULT |
| Reserved for Future Use     | 17-31               |                                                |                                                        |       |
| Two Byte Interrupt          | 0-255               | INT n                                          | No                                                     | TRAP  |

#### **Table 5. Interrupt Vector Assignments**

\*Some debug exceptions may report both traps on the previous instruction and faults on the next instruction.

#### Interrupt Processing

When an interrupt occurs the following actions happen.

- First, the current program address and the Flags are saved on the stack to allow resumption of the interrupted program.
- Next, an 8-bit vector is supplied to the Am386DXL microprocessor that identifies the appropriate entry in the interrupt table. The table contains the starting address of the interrupt service routine. Then, the user supplied interrupt service routine is executed.
- Finally, when an IRET instruction is executed the old processor state is restored and program execution resumes a the appropriate instruction.

The 8-bit interrupt vector is supplied to the Am386DXL microprocessor in several different ways: exceptions supply the interrupt vector internally; software INT instructions contain or imply the vector; maskable hardware interrupts supply the 8-bit vector via the interrupt acknowledge bus sequence. Non-Maskable hardware interrupts are assigned to interrupt vector 2.

#### Maskable Interrupt

Maskable interrupts are the most common way used by the Am386DXL microprocessor to respond to asynchronous external hardware events. A hardware interrupt occurs when the INTR is pulled High and the Interrupt Flag bit (IF) is enabled. The processor only responds to interrupts between instructions (REPeat String instructions have an interrupt window between memory moves, which allows interrupts during long string moves). When an interrupt occurs, the processor reads an 8-bit vector supplied by the hardware that identifies the source of the interrupt (one of 224 user defined interrupts). The exact nature of the interrupt sequence is discussed in Section Functional Data.

The IF bit in the EFLAGS register is reset when an interrupt is being serviced. This effectively disables servicing additional interrupts during an interrupt service routine. However, the IF bit may be set explicitly by the interrupt handler to allow the nesting of interrupts. When an IRET instruction is executed the original state of the IF bit is restored.

#### Non-Maskable Interrupt

Non-maskable interrupts provide a method of servicing very high priority interrupts. A common example of the use of a non-maskable interrupt (NMI) would be to activate a power failure routine. When the NMI input is pulled High it causes an interrupt with an internally supplied vector value of 2. Unlike a normal hardware interrupt, no interrupt acknowledgment sequence is performed for NMI.

While executing the NMI servicing procedure, the Am386DXL microprocessor will not service further NMI requests until an interrupt return (IRET) instruction is executed or the processor is reset. If NMI occurs while currently servicing an NMI, its presence will be saved for

servicing after executing the first IRET instruction. The IF bit is cleared at the beginning of an NMI interrupt to inhibit further INTR interrupts.

#### Software Interrupts

A third type of interrupt/exception for the Am386DXL microprocessor is the software interrupt. An INT n instruction causes the processor to execute the interrupt service routine pointed to by the nth vector in the interrupt table.

A special case of the two byte software interrupt INT n is the one byte INT 3 or breakpoint interrupt. By inserting this one byte instruction in a program, the user can set breakpoints in his program as a debugging tool.

A final type of software interrupt is the single step interrupt. It is discussed in Section Debugging Support.

#### Interrupt and Exception Priorities

Interrupts are externally-generated events. Maskable Interrupts (on the INTR input) and Non-Maskable Interrupts (on the NMI input) are recognized at instruction boundaries. When NMI and maskable INTR are both recognized at the same instruction boundary, the Am386DXL microprocessor invokes the NMI service routine first. If after the NMI service routine has been invoked, maskable interrupts are still enabled, then the Am386DXL CPU will invoke the appropriate interrupt service routine.

#### Table 6a. Am386DXL Microprocessor Priority for Invoking Service Routines in Case of Simultaneous External Interrupts

| 1. | NMI  |
|----|------|
| 2. | INTR |

Exceptions are internally-generated events. Exceptions are detected by the Am386DXL microprocessor if in the course of executing an instruction, the Am386DXL CPU detects a problematic condition. The Am386DXL microprocessor then immediately invokes the appropriate exception service routine. The state of the Am386DXL CPU is such that the instruction causing the exception can be restarted. If the exception service routine has taken care of the problematic condition, the instruction will execute without causing the same exception.

It is possible for a single instruction to generate several exceptions (for example, transferring a single operand could generate two page faults if the operand location spans two not present pages). However, only one exception is generated upon each attempt to execute the instruction. Each exception service routine should correct its corresponding exception, and restart the instruction. In this manner, exceptions are serviced until the instruction executes successfully.

As the Am386DXL microprocessor executes instructions, it follows a consistent cycle in checking for exceptions, as shown in Table 6b. This cycle is repeated as each instruction is executed and occurs in parallel with instruction decoding and execution.

### Instruction Restart

The Am386DXL microprocessor fully supports restarting all instructions after faults. If an exception is detected in the instruction to be executed (Exception Categories 4 through 10 in Table 6b), the Am386DXL device invokes the appropriate exception service routine. The Am386DXL microprocessor is in a state that permits restart of the instruction, for all cases but those in Table 6c. Note that all such cases are easily avoided by proper design of the operating system.

#### Table 6b. Sequence of Exception Checking

Consider the case of the Am386DXL microprocessor having just completed an instruction. It then performs the following checks before reaching the point where the next instruction is completed:

- 1. Check for Exception 1 Traps from the instruction just completed (single-step via Trap Flag or Data Breakpoints set in the Debug Registers).
- Check for Exception 1 Faults in the next instruction (Instruction Execution Breakpoint set in the Debug Registers for the next instruction).
- 3. Check for external NMI and INTR.
- 4. Check for Segmentation Faults that prevented fetching the entire next instruction (Exceptions 11 and 13).
- 5. Check for Paging Faults that prevented fetching the entire next instruction (Exception 14).
- Check for Faults decoding the next instruction (Exception 6 if illegal op-code; Exception 6 if in Real Mode or in Virtual 8086 Mode and attempting to execute an instruction for Protected Mode only (see Section Protection and I/O Permission Bitmap); or Exception 13 if instruction is longer than 15 bytes, or privilege violation in Protected Mode (i.e., not at IOPL or at CPL=0)).
- If WAIT op-code, check if TS = 1 and MP = 1 (Exception 7 if both are 1).
- If ESCAPE op-code for numeric coprocessor, check if EM=1 or TS=1 (Exception 7 if either are 1).
- If WAIT op-code or ESCAPE op-code for numeric coprocessor, check ERROR input signal (Exception 16 if ERROR input is asserted).
- 10. Check in the following order for each memory reference required by the instruction.
  - Check for Segmentation Faults that prevent transferring the entire memory quantity (Exceptions 11, 12, 13).
  - b. Check for Page Faults that prevent transferring the entire memory quantity (Exception 14).

#### Table 6c. Conditions Preventing Instruction Restart

- An instruction causes a task switch to a task whose Task State Segment (TSS) is partially not present. (An entire not present TSS is restartable.) Partially present TSS's can be avoided either by keeping the TSS's of such tasks present in memory or by aligning TSS segments to reside entirely within a single 4K page (for TSS segments of 4 Kb or less).
- 2. A coprocessor operand wraps around the top of a 64-Kb segment or a 4-Gb segment and spans three pages; and the page holding the middle portion of the operand is not present. This condition can be avoided by starting at a page boundary any segments containing coprocessor operands if the segments are approximately 64–200 Kb or larger (i.e., large enough for wraparound of the coprocessor operand to possibly occur).

Note that these conditions are avoided by using the operating system designs mentioned in this table.

#### **Double Fault**

A Double Fault (Exception 8) results when the processor attempts to invoke an exception service routine for the segment exceptions (10, 11, 12, or 13), but in the process of doing so, detects an exception other than a Page Fault (Exception 14).

A Double Fault (Exception 8) will also be generated when the processor attempts to invoke the Page Fault (Exception 14) service routine, and detects an exception other than a second Page Fault. In any functional system, the entire Page Fault service routine must remain present in memory.

Double Page faults however do not raise the Double Fault exception. If a second Page Fault occurs while the processor is attempting to enter the service routine for the first time, then the processor will invoke the Page Fault (Exception 14) handler a second time rather than the Double Fault (Exception 8) handler. A subsequent fault, though, will lead to shutdown.

When a Double Fault occurs, the Am386DXL microprocessor invokes the exception service routine for Exception 8.

#### **Reset and Initialization**

When the processor is initialized or Reset, the registers have the values shown in Table 7. The Am386DXL microprocessor will then start executing instructions near the top of physical memory, at location FFFFFFOH. When the first Inter-Segment Jump or Call is executed, address lines A31–A20 will drop Low for CS-relative memory cycles, and the Am386DXL microprocessor will only execute instructions in the lower 1 Mb of physical memory. This allows the system designer to use a ROM at the top of physical memory to initialize the system and take care of Resets.

Note that the order stated supports the concept of the paging mechanism being underneath the segmentation mechanism. Therefore, for any given code or data reference in memory, segmentation exceptions are generated before paging exceptions are generated.

RESET forces the Am386DXL microprocessor to terminate all execution and local bus activity. No instruction execution or bus activity will occur as long as Reset is active. Between 350- and 450-CLK2 periods after Reset becomes inactive, the Am386DXL device will start executing instructions at the top of physical memory.

#### Table 7. Register Values after Reset

| Flag Word               | UUUU0002H     | Note 1 |
|-------------------------|---------------|--------|
| Machine Status Word (CR | 0) UUUUUUU0H  | Note 2 |
| Instruction Pointer     | 0000FFF0H     |        |
| Code Segment            | FOOOH         | Note 3 |
| Data Segment            | 0000H         |        |
| Stack Segment           | 0000H         |        |
| Extra Segment (ES)      | 0000H         |        |
| Extra Segment (FS)      | 0000H         |        |
| Extra Segment (GS)      | 0000H         |        |
| DX Register             | Component and | Note 5 |
|                         | Stepping ID   |        |
| All Other Registers     | Undefined     | Note 4 |

Notes:

- 1. EFLAGS Register. The upper 14 bits of the EFLAGS register are undefined, VM (Bit 17) and RF (Bit 16) and 0 as are all other defined flag bits.
- CR0: (Machine Status Word). All of the defined fields in the CR0 are 0 (PG Bit 31, TS Bit 3, EM Bit 2, MP Bit 1, and PE Bit 0).
- 3. The code Segment Register (CS) will have its Base Address set to FFFF0000H and Limit set to 0FFFFH.
- 4. All undefined bits are Reserved for Future Use and should not be used.
- DX register always holds component and stepping identifier (see Section Component and Revision Identifiers). EAX register holds self-test signature if self-test was requested (see Section Self-Test Signature).

# Testability

#### Self-Test

The Am386DXL microprocessor has the capability to perform a self-test. The self-test checks the function of all the Control ROM and most of the non-random logic of the part. Approximately one-half of the Am386DXL microprocessor can be tested during self-test.

Self-Test is initiated on the Am386DXL microprocessor when the RESET pin transitions from High to Low, and the BUSY pin is Low. The self-test takes about 2\*\*19 clocks or approximately 26 ms with a 20-MHz Am386DXL device. At the completion of self-test, the processor performs reset and begins normal operation. The part has successfully passed self-test if the contents of the EAX register are zero (0). If the results of EAX are not zero then the self-test has detected a flaw in the part.

#### **TLB Testing**

The Am386DXL microprocessor provides a mechanism for testing the Translation Look-Aside Buffer (TLB) if

desired. This particular mechanism is unique to the Am386DXL CPU and may not be continued in the same way in future processors. When testing the TLB, paging must be turned off (PG = 0 in CR0) to enable the TLB testing hardware and avoid interference with the test data being written to the TLB.

There are two TLB testing operations:

- 1. Write entries into the TLB; and,
- Perform TLB lookups. Two test registers, shown in Figure 12, are provided for the purpose of testing. TR6 is the test command register and TR7 is the test data register. The fields within these registers are defined below.

C: This is the command bit. For a write into TR6 to cause an immediate write into the TLB entry, write a 0 to this bit. For a write into TR6 to cause an immediate TLB lookup, write a 1 to this bit.

Linear Address: This is the tag field of the TLB . On a TLB write, a TLB entry is allocated to this linear address and the rest of that TLB entry is set per the value of TR7 and the value just written into TR6. On a TLB lookup, the TLB is interrogated per this value and if one and only one TLB entry matches, the rest of the fields of TR6 and TR7 are set from the matching TLB entry.

**Physical Address**: This is the data field of the TLB. On a write to the TLB, the TLB entry allocated to the linear address in TR6 is set to this value. On a TLB lookup, the data field (physical address) from the TLB is read out to here.

**PL**: On a TLB write, PL = 1 causes the REP field of TR7 to select which of four associative blocks of the TLB is to be written, but PL = 0 allows the internal pointer in the paging unit to select which TLB block is written. On a TLB lookup, the PL bit indicated whether the lookup was a hit (PL gets set to 1) or a miss (PL gets reset to 0).

V: The valid bit for this TLB entry. All valid bits can also be cleared by writing to CR3.

- **D**,  $\overline{\mathbf{D}}$ : The dirty bit for/from the TLB entry.
- U, U: The user bit for/from the TLB entry.

W,  $\overline{W}$ : The writable bit for/from the TLB entry.

For D, U and W, both the attribute and its complement are provided as tag bits to permit the option of a don't care on TLB lookups. The meaning of these pairs of bits is given in the following table.

| x | X# | Effect During<br>TLB Lookup | Value of Bit<br>X after TLB Write |
|---|----|-----------------------------|-----------------------------------|
| 0 | 0  | Miss All                    | Bit X becomes undefined           |
| 0 | 1  | Match if X = 0              | Bit X becomes 0                   |
| 1 | 0  | Match if X = 1              | Bit X becomes 1                   |
| 1 | 1  | Match All                   | Bit X becomes undefined           |

# 

For writing a TLB entry:

- 1. Write TR7 for the desired physical address, PL and REP values; and,
- 2. Write TR6 with the appropriate linear address, etc., (be sure to write C = 0 for write command).

For looking up (reading) a TLB entry:

- 1. Write TR6 with the appropriate linear address (be sure to write C = 1 for lookup command); and,
- 2. Read TR7 and TR6. If the PL bit in TR7 indicates a hit, then the other values reveal the TLB contents. If PL indicates a miss, then the other values in TR7 and TR6 are indeterminate.

# **Debugging Support**

The Am386DXL microprocessor provides several features that simplify the debugging process. The three categories of on-chip debugging aids are:

- 1. The code execution breakpoint op-code (0CCH);
- 2. The single-step capability provided by the TF bit in the flag register; and,
- 3. The code and data breakpoint capability provided by the Debug Registers DR3–DR0, DR6, and DR7.

#### **Breakpoint Instruction**

A single-byte-op-code breakpoint instruction is available for use by software debuggers. The breakpoint opcode is 0CCh and generates an Exception 3 trap when executed. In typical use, a debugger program can plant the breakpoint instruction at all desired code execution breakpoints. The single-byte breakpoint op-code is an alias for the two-byte general software interrupt instruction, INT n, where n = 3. The only difference between INT 3 (0CCh) and INT n is that INT 3 is never IOPL-sensitive but INT n is IOPL-sensitive in Protected Mode and Virtual 8086 Mode.

| 3. | 112              | 12 11 |   |   |   |   |   |   | 0      |    |   |   |   |     |
|----|------------------|-------|---|---|---|---|---|---|--------|----|---|---|---|-----|
|    | Linear Address   | ۷     | D | D | U | Ū | w | W | 0      | 0  | 0 | 0 | С | TR6 |
|    | Physical Address | 0     | 0 | 0 | 0 | 0 | 0 | 0 | P<br>L | RE | P | 0 | 0 | TR7 |

Note: 0 indicates "Reserved for Future Use." Do not define; see Section Compatibility.

15021B-015

#### Figure 12. Test Registers

#### Single-Step Trap

If the single-step flag (TF, bit 8) in the EFLAGS register is found to be set at the end of an instruction, a singlestep exception occurs. The single-step exception is auto vectored to Exception 1. Precisely, Exception 1 occurs as a trap after the instruction following the instruction that set TF. In typical practice, a debugger sets the TF bit of a flag register image on the debugger's stack. It then typically transfers control to the user program and loads the flag image with a signal instruction, the IRET instruction. The single-step trap occurs after executing one instruction of the user program.

Since the Exception 1 occurs as a trap (that is, it occurs after the instruction has already executed), the CS:EIP pushed onto the debugger's stack points to the next unexecuted instruction of the program being debugged. An Exception 1 handler, merely by ending with an IRET instruction, can therefore efficiently support single-stepping through a user program.

#### **Debug Registers**

The Debug Registers are an advanced debugging feature of the Am386DXL microprocessor. They allow data access breakpoints as well as code execution breakpoints. Since the breakpoints are indicated by on-chip registers, an instruction execution breakpoint can be placed in ROM code or in code shared by several tasks, neither of which can be supported by the INT 3 breakpoint op-code.

The Am386DXL microprocessor contains 6 Debug Registers, providing the ability to specify up to four distinct breakpoint addresses, breakpoint control options, and read breakpoint status. Initially after reset, breakpoints will occur unless the debug registers are programmed. Breakpoints set up in the Debug Registers are auto vectored to Exception 1.

#### Linear Address Breakpoint Registers (DR3–DR0)

Up to four breakpoint addresses can be specified by writing into Debug Registers DR3–DR0, shown in Figure 13. The breakpoint addresses specified are 32-bit linear addresses. Am386DXL microprocessor hardware continuously compares the linear breakpoint

addresses in DR3–DR0 with the linear addresses generated by executing software (a linear address is the result of computing the effective address and adding the 32-bit segment base address). Note that if paging is not enabled the linear address equals the physical address. If paging is enabled, the linear address is translated to a physical 32-bit address by the on-chip paging unit. Regardless of whether paging is enabled or not, however, the breakpoint registers hold linear addresses.

#### Debug Control Register (DR7)

A Debug Control Register, DR7, shown in Figure 13, allows several debug control functions, such as enabling the breakpoints and setting up other control options for the breakpoints. The fields within the Debug Control Register, DR7, are as follows.

#### LENi (Breakpoint Length Specification Bits)

A 2-bit LEN field exists for each of the four breakpoints. LEN specifies the length of the associated breakpoint field. The choices for data breakpoints are: 1 byte, 2 bytes, and 4 bytes. Instruction execution breakpoints must have a length of 1 (LENi = 00). Encoding of the LENi field is as follows.

| LENi<br>Encoding | Breakpoint<br>Field Width                                   | Usage of Least<br>Significant Bits in<br>Breakpoint Address<br>Register i, (i = 0 − 3)                                                 |  |  |
|------------------|-------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 00               | 1 byte                                                      | All 32-bits used to specify<br>a single-byte breakpoint<br>field.                                                                      |  |  |
| 01               | 01 2 bytes A31–A1<br>a two-b<br>breakp<br>Breakp<br>Registe |                                                                                                                                        |  |  |
| 10               | Undefined—<br>do not use<br>this encoding                   |                                                                                                                                        |  |  |
| 11               | 4 bytes                                                     | A31–A2 used to specify<br>a four-byte, Dword-aligned<br>breakpoint field. A0 and<br>A1 in Breakpoint Address<br>Register are not used. |  |  |



Note: 0 indicates "Reserved for Future Use." Do not define; see Section Compatibility.

Figure 13. Debug Registers

15021B-016

The LENi field controls the size of breakpoint field i by controlling whether all low-order linear address bits in the breakpoint address register are used to detect the breakpoint event. Therefore, all breakpoint fields are aligned; 2-byte breakpoint fields begin on Word boundaries and 4-byte breakpoint fields begin on Dword boundaries.

The following is an example of various size breakpoint fields. Assume the breakpoint linear address in DR2 is 0000005H. In that situation, the following illustration indicates the region of the breakpoint field for lengths of 1, 2, or 4 bytes.



| DR2 = 00 |  | LEN2 | 2 = <b>01 B</b><br>0 |        |           |
|----------|--|------|----------------------|--------|-----------|
|          |  |      |                      |        | 0000008н  |
|          |  | ←    | bkpt                 | fld2 🔶 | 00000004H |
|          |  |      |                      |        | Ооооооон  |

| DR2 = 00<br>31 | 000005H; | LEN2    | 2=11B<br>0 |           |
|----------------|----------|---------|------------|-----------|
|                |          |         |            | 00000008н |
|                | 🔶 bkp    | ot fld2 | 00000004H  |           |
|                |          |         |            | ооооооон  |

#### **RWi (Memory Access Qualifier Bits)**

A 2-bit RW field exists for each of the four breakpoints. The 2-bit RW field specifies the type of usage that must occur in order to activate the associated breakpoint.

| RW<br>Encoding | Usage<br>Causing Breakpoint        |
|----------------|------------------------------------|
| 00             | Instruction execution only         |
| 01             | Data writes only                   |
| 10             | Undefined-do not use this encoding |
| 11             | Data reads and writes only         |

RW encoding 00 is used to set up an instruction execution breakpoint. RW encodings 01 or 11 are used to set up write-only or read/write data breakpoints.

Note that instruction execution breakpoints are taken as faults (i.e., before the instruction executes), but data breakpoints are taken as traps (i.e., after the data transfer takes place).

#### Using LENi and RWi to Set Data Breakpoint I

A data breakpoint can be set up by writing the linear address into DRi (i = 0-3). For data breakpoints, RWi can = 01 (write only) or 11 (write/read). LEN can = 00, 01, or 11.

If a data access entirely or partly falls within the data breakpoint field, the data breakpoint condition has occurred, and if the breakpoint is enabled, an Exception 1 trap will occur.

# Using LENi and RWi to Set Instruction Execution Breakpoint I

An instruction execution breakpoint can be set up by writing address of the beginning of the instruction (including prefixes if any) into DRi (i=0-3). RWi

must = 00 and LEN must = 00 for instruction execution breakpoints.

If the instruction beginning at the breakpoint address is about to be executed, the instruction execution breakpoint condition has occurred, and if the breakpoint is enabled, an Exception 1 fault will occur before the instruction is executed.

Note that an instruction execution breakpoint address must be equal to the beginning byte address of an instruction (including prefixes) in order for the instruction execution breakpoint to occur.

#### GD (Global Debug Register Access Detect)

The Debug Registers can only be accessed in Real Mode or at privilege level 0 in Protected Mode. The GD bit, when set, provides extra protection against any Debug Register access even in Real Mode or at privilege level 0 in Protected Mode. This additional protection feature is provided to guarantee that a software debugger (or ICE-386) can have full control over the Debug Register resources when required. The GD bit, when set, causes an Exception 1 fault if an instruction attempts to read or write any Debug Register. The GD bit is then automatically cleared when the Exception 1 handler is invoked, allowing the Exception 1 handler free access to the debug registers.

# GE and LE (Exact Data Breakpoint Match, Global and Local)

If either GE or LE is set, any data breakpoint trap will be reported exactly after completion of the instruction that caused the operand transfer. Exact reporting is provided by forcing the Am386DXL microprocessor execution unit to wait for completion of data operand transfers before beginning execution of the next instruction.

If exact data breakpoint match is not selected, data breakpoints may not be reported until several instructions later or may not be reported at all. When enabling a data breakpoint, it is therefore recommended to enable the exact data breakpoint match.

When the Am386DXL microprocessor performs a task switch, the LE bit is cleared. Thus, the LE bit supports fast task switching out of tasks that have enabled the exact data breakpoint match for their task-local breakpoints. The LE bit is cleared by the processor during a task switch to avoid having exact data breakpoint match enabled in the new task. Note that exact data breakpoint match must be re-enabled under software control.

The Am386DXL microprocessor GE bit is unaffected during a task switch. The GE bit supports exact data breakpoint match that is to remain enabled during all tasks executing in the system.

Note that instruction execution breakpoints are always reported exactly, whether or not exact data breakpoint match is selected.

#### Gi and Li (Breakpoint Enable, Global and Local)

If either Gi or Li is set, then the associated breakpoint (as defined by the linear address in DRi, the length in LENi and the usage criteria in RWi) is enabled. If either Gi or Li is set and the Am386DXL microprocessor detects the ith breakpoint condition, then the Exception 1 handler is invoked.

When the Am386DXL microprocessor performs a task switch to a new Task State Segment (TSS), all Li bits are cleared. Thus, the Li bits support fast task switching out of tasks that use some task-local breakpoint registers. The Li bits are cleared by the processor during a task switch to avoid spurious exceptions in the new task. Note that the breakpoints must be enabled under software control.

All Am386DXL microprocessor Gi bits are unaffected during a task switch. The Gi bits support breakpoints that are active in all tasks executing in the system.

#### Debug Status Register (DR6)

A Debug Status Register, DR6, shown in Figure 13, allows the Exception 1 handler to easily determine why it was invoked. Note the Exception 1 handler can be invoked as a result of one of several events.

- 1. DR0 Breakpoint fault/trap.
- 2. DR1 Breakpoint fault/trap.
- 3. DR2 Breakpoint fault/trap.
- 4. DR3 Breakpoint fault/trap.
- 5. Single-step (TF) trap.
- 6. Task switch trap.
- 7. Fault due to attempted debug register access when GD = 1.

The Debug Status Register contains single-bit flags for each of the possible events invoking Exception 1. Note below that some of these events are faults (exception taken before the instruction is executed), while other events are traps (exception taken after the debug events occurred).

The flags in DR6 are set by the hardware but never cleared by hardware. Exception 1 handler software should clear DR6 before returning to the user program to avoid future confusion in identifying the source of Exception 1.

The fields within the Debug Status Register, DR6 are as follows.

#### Bi (Debug Fault/Trap Due to Breakpoint 0-3)

Four breakpoint indicator flags, B3–B0, correspond one-to-one with the breakpoint registers in DR3–DR0. A flag Bi is set when the condition described by DRi, LENi, and RWi occurs.

If Gi or Li is set, and if the ith breakpoint is detected, the processor will invoke the Exception 1 handler. The

# 

exception is handled as a fault if an instruction execution breakpoint occurred or as a trap if a data breakpoint occurred.

**Important Note**: A flag, Bi, is set whenever the hardware detects a match condition on enabled breakpoint i. Whenever a match is detected on at least one enabled breakpoint i, the hardware immediately sets all Bi bits corresponding to breakpoint conditions matching at that instant, whether enabled or not. Therefore, the Exception 1 handler may see that multiple Bi bits are set, but only set Bi bits corresponding to enabled breakpoints (Li or Gi set) are true indications of why the Exception 1 handler was invoked.

# BD (Debug Fault Due to Attempted Register Access When GD Bit Set)

This bit is set if the Exception 1 handler was invoked due to an instruction attempting to read or write to the debug registers when GD bit was set. If such an event occurs, then the GD bit is automatically cleared when the Exception 1 handler is invoked, allowing handler access to the debug registers.

# BS (Debug Trap Due to Single-Step)

This bit is set if the Exception 1 handler was invoked due to the TF bit in the flag register being set (for single-stepping). See Section Single-Step Trap.

# BT (Debug Trap Due to Task Switch)

This bit is set if the Exception 1 handler was invoked due to a task switch occurring to a task having a Am386DXL microprocessor TSS with the T-bit set. (See Figure 29.) Note the task switch into the new task occurs normally, but before the first instruction of the task is executed, the Exception 1 handler is invoked. With respect to the task switch operation, the operation is considered to be a trap.

## Use of Resume Flag (RF) In Flag Register

The Resume Flag (RF) in the flag word can suppress an instruction execution breakpoint when the Exception 1 handler returns to a user program at a user address that is also an instruction execution breakpoint. See Section Flags Register.

# REAL MODE ARCHITECTURE Real Mode Introduction

When the processor is reset or powered up, it is initialized in Real Mode. Real Mode has the same base architecture as the 8086, but allows access to the 32-bit register set of the Am386DXL microprocessor. The addressing mechanism, memory size, and interrupt handling are all identical to the Real Mode on the 80286.

All of the Am386DXL microprocessor instructions are available in Real Mode (except those instructions listed in Protection and I/O Permission Bitmap). The default operand size in Real Mode is 16 bits, just like the 8086. In order to use the 32-bit registers and addressing modes, override prefixes must be used. In addition, the segment size on the Am386DXL CPU in Real Mode is 64 Kb so 32-bit effective addresses must have a value less the 0000FFFFH. The primary purpose of Real Mode is to set up the processor for Protected Mode Operation.



Figure 14. Real Address Mode Addressing

# **LOCK** Operation

The LOCK prefix on the Am386DXL microprocessor, even in Real Mode, is more restrictive than on the 80286. This is due to the addition of paging on the Am386DXL CPU in Protected Mode and Virtual 8086 Mode. Paging makes it impossible to guarantee that repeated string instructions can be LOCKed. The Am386DXL CPU can not require that all pages holding the string be physically present in memory. Hence, a Page Fault (Exception 14) might have to be taken during the repeated string instruction. Therefore the LOCK prefix can not be supported during repeated string instructions.

These are the only instruction forms where the LOCK prefix is legal on the Am386DXL microprocessor.

| Op-code                              | Operands<br>(Dest, Source) |
|--------------------------------------|----------------------------|
| BIT TEST and<br>SET/RESET/COMPLEMENT | Mem, Reg/immed             |
| XCHG<br>XCHG                         | Reg, Mem<br>Mem, Reg       |
| ADD, OR, ADC, SBB,<br>AND, SUB, XOR  | Mem, Reg/immed             |
| NOT, NEG, INC, DEC                   | Mem                        |

An Exception 6 will be generated if a LOCK prefix is placed before any instruction form or op-code not listed above. The LOCK prefix allows indivisible read/modify/ write operations on memory operands using the instructions above. For example, even the ADD Reg, Mem is not LOCKable, because the Mem operand is not the destination (and therefore no memory read/modify/operation is being performed).

Since, on the Am386DXL microprocessor, repeated string instructions are not LOCKable, it is not possible to LOCK the bus for a long period of time. Therefore, the LOCK prefix is not IOPL-sensitive on the Am386DXL device. The LOCK prefix can be used at any privilege level, but only on the instruction forms listed above.

# **Memory Addressing**

In Real Mode, the maximum memory size is limited to 1 Mb. Thus, only address lines A19-A2 are active.

Exception, the High address lines A31–A20 are High during CS-relative memory cycles until an intersegment jump or call is executed (see Section Reset and Initialization).

Since paging is not allowed in Real Mode, the linear addresses are the same as physical addresses. Physical addresses are formed in Real Mode by adding the contents of the appropriate segment register that is shifted left by 4 bits to an effective address. This addition results in a physical address from 00000000H to 0010FFEFH. This is compatible with 80286 Real Mode. Since segment registers are shifted left by 4 bits, this implies that Real Mode segments always start on 16-byte boundaries.

All segments in Real Mode are exactly 64-Kb long and may be read, written, or executed. The Am386DXL microprocessor will generate an Exception 13 if a data operand or instruction fetch occurs past the end of a segment (i.e., if an operand has an offset greater than FFFFH; for example, a word with a low byte at FFFFH and the high byte at 0000H).

Segments may be overlapped in Real Mode. Thus, if a particular segment does not use all 64 Kb another segment can be overlayed on top of the unused portion of the previous segment. This allows the programmer to minimize the amount of physical memory needed for a program.

### **Reserved Locations**

There are two fixed areas in memory that are reserved in Real address mode: system initialization area and the interrupt table area. Locations 00000H through 003FFH are reserved for interrupt vectors. Each one of the 256 possible interrupts has a 4-byte jump vector reserved for it. Locations FFFFFF0H through FFFFFFFH are reserved for system initialization.

#### Interrupts

Many of the exceptions shown in Table 5 and discussed in Section Interrupts are not applicable to Real Mode operation; in particular, Exceptions 10, 11, and 14 will not happen in Real Mode. Other exceptions have slightly different meanings in Real Mode. Table 8 identifies these exceptions.

| Function                                        | Interrupt<br>Number | Related<br>Instructions                                                                                | Return<br>Address Location |
|-------------------------------------------------|---------------------|--------------------------------------------------------------------------------------------------------|----------------------------|
| Interrupt table limit too small                 | 8                   | INT Vector is not within table limit.                                                                  | Before<br>Instruction      |
| CS, DS, ES, FS, GS<br>Segment overrun exception | 13                  | Word memory reference<br>beyond offset = FFFH.<br>An attempt to execute<br>past the end of CS segment. | Before<br>Instruction      |
| SS Segment overrun exception                    | 12                  | Stack Reference<br>beyond offset = FFFFH.                                                              | Before<br>Instruction      |

#### Table 8. Other Exceptions in Real Mode

# Shutdown and Halt

The HLT instruction stops program execution and prevents the processor from using the local bus until restarted. Either NMI, FLT, INTR with interrupts enabled (IF = 1), or RESET will force the Am386DXL microprocessor out of halt. If interrupted, the saved CS:IP will point to the next instruction after the HLT.

Shutdown will occur when a severe error is detected that prevents further processing. In Real Mode, shutdown can occur under two conditions:

- An interrupt or an exception occur (Exception 8 or 13) and the interrupt vector is larger than the Interrupt Descriptor Table (i.e., there is not an interrupt handler for the interrupt);
- A CALL, INT, or PUSH instruction attempts to wrap around the stack segment when SP is not even (e.g., pushing a value on the stack when SP = 0001 resulting in a stack segment greater than FFFFH).

An NMI input can bring the processor out of shutdown if the Interrupt Descriptor Table limit is large enough to contain the NMI interrupt vector (at least 0017H) and the stack has enough room to contain the vector and flag information (i.e., SP is greater than 0005H). Otherwise shutdown can only be exited via the RESET input.

# PROTECTED MODE ARCHITECTURE Introduction

The complete capabilities of the Am386DXL microprocessor are unlocked when the processor operates in Protected Virtual Address Mode (Protected Mode). Protected Mode vastly increases the linear address space to 4 Gb (2<sup>32</sup> bytes) and allows the running of virtual memory programs of almost unlimited size (64 tb or 2<sup>46</sup> bytes). In addition, Protected Mode allows the Am386DXL CPU to run all of the existing 8086 and 80286 software, while providing a sophisticated memory management and a hardware-assisted protection mechanism. Protected Mode allows the use of additional instructions especially optimized for supporting multitasking operating systems. The base architecture of the Am386DXL CPU remains the same; the registers, instructions, and addressing modes described in the previous sections are retained. The main differences between Protected Mode and Real Mode from a programmer's view is the increased address space and a different addressing mechanism.

# Addressing Mechanism

Like Real Mode, Protected Mode uses two components to form the logical address: a 16-bit selector is used to determine the linear base address of a segment; the base address is added to a 32-bit effective address to form a 32-bit linear address. The linear address is then either used as the 32-bit physical address or if paging is enabled the paging mechanism maps the 32-bit linear address into a 32-bit physical address.

The difference between the two modes lies in calculating the base address. In Protected Mode, the selector is used to specify an index into an operating system defined table (see Figure 15). The table contains the 32-bit base address of a given segment. The physical address is formed by adding the base address obtained from the table to the offset.

Paging provides an additional memory management mechanism that operates only in Protected Mode. Paging provides a means of managing the very large segments of the Am386DXL microprocessor. As such, paging operates beneath segmentation. The paging mechanism translates the protected linear address that comes from the segmentation unit into a physical address. Figure 16 shows the complete Am386DXL device addressing mechanism with paging enabled.

# Segmentation

# Segmentation Introduction

Segmentation is one method of memory management. Segmentation provides the basis for protection. Segments are used to encapsulate regions of memory that have common attributes. For example, all of the code of a given program could be contained in a segment or an operating system table may reside in a segment. All information about a segment is stored in an 8-byte data structure called a descriptor. All of the descriptors in a system are contained in tables recognized by hardware.



15021B-018





15021B-019

### Figure 16. Paging and Segmentation

#### Terminology

The following terms are used throughout the discussion of descriptors, privilege levels, and protection:

PL: Privilege Level—One of the four hierarchical privilege levels. Level 0 is the most privileged level and level 3 is the least privileged. More privileged levels are numerically smaller than less privileged levels.

**RPL**: Requester Privilege Level—The privilege level of the original supplier of the selector. RPL is determined by the least two significant bits of a selector.

**DPL**: Descriptor Privilege Level—This is the least privileged level at which a task may access that descriptor (and the segment associated with that descriptor). Descriptor Privilege Level is determined by bits 6–5 in the Access Right Byte of a descriptor.

**CPL**: Current Privilege Level—The privilege level at which a task is currently executing, which equals the privilege level of the code segment being executed. CPL can also be determined by examining the lowest 2 bits of the CS register, except for conforming code segments.

**EPL**: Effective Privilege Level—The effective privilege level is the least privileged of the RPL and DPL. Since small privilege level values indicate greater privilege, EPL is the numerical maximum of RPL and DPL.

**Task**: One instance of the execution of a program. Tasks are also referred to as processes.

#### **Descriptor Tables**

#### **Descriptor Tables Introduction**

The descriptor tables define all of the segments which are used in an Am386DXL microprocessor system.

There are three types of tables on the Am386DXL microprocessor that hold descriptors: the Global Descriptor Table, Local Descriptor Table, and the Interrupt Descriptor Table. All of the tables are variable length memory arrays. They can range in size between 8 bytes and 64 Kb. Each table can hold up to 8192 eight byte descriptors. The upper 13 bits of a selector are used as an index into the descriptor table. The tables have registers associated with them that hold the 32-bit linear base address, and the 16-bit limit of each table.

Each of the tables has a register associated with it: the GDTR, LDTR, and the IDTR (see Figure 17). The LGDT, LLDT, and LIDT instructions load the base and limit of the Global, Local, and Interrupt Descriptor Tables, respectively, into the appropriate register. The SGDT, SLDT, and SIDT instructions store the base and limit values. These tables are manipulated by the operating system. Therefore, the load descriptor table instructions are privileged instructions.

#### **Global Descriptor Table**

The Global Descriptor Table (GDT) contains descriptors that are possibly available to all of the tasks in a system. The GDT can contain any type of segment descriptor except for descriptors that are used for servicing interrupts (i.e., interrupt and trap descriptors). Every Am386DXL microprocessor contains a GDT. Generally, the GDT contains code and data segments used by the operating systems and task state segments and descriptors for the LDTs in a system.

The first slot of the Global Descriptor Table corresponds to the null selector and is not used. The null selector defines a null pointer value.



15021B-020

Figure 17. Descriptor Table Registers

#### Local Descriptor Table

LDTs contain descriptors that are associated with a given task. Generally, operating systems are designed so that each task has a separate LDT. The LDT may contain only code, data, stack, task gate, and call gate descriptors. LDTs provide a mechanism for isolating a given task's code and data segments from the rest of the operating system, while the GDT contains descriptors for segments that are common to all tasks. A segment cannot be accessed by a task if its segment descriptor does not exist in either the current LDT or the GDT. This provides both isolation and protection for a task's segments, while still allowing global data to be shared among tasks.

Unlike the 6-byte GDT or IDT registers that contain a base address and limit, the visible portion of the LDT register contains only a 16-bit selector. This selector refers to a Local Descriptor Table descriptor in the GDT.

#### Interrupt Descriptor Table

The third table needed for Am386DXL microprocessor systems is the Interrupt Descriptor Table (see Figure 18). The IDT contains the descriptors that point to the location of up to 256 interrupt service routines. The IDT may contain only task gates, interrupt gates, and trap gates. The IDT should be at least 256 bytes in size in order to hold the descriptors for the 32, Reserved for Future Use, interrupts. Every interrupt used by a system must have an entry in the IDT. The IDT entries are referenced via INT instructions, external interrupt vectors, and exceptions. (See Interrupts.)

#### Descriptors

#### **Descriptor Attribute Bits**

The object to which the segment selector points is called a descriptor. Descriptors are 8-byte quantities that contain attributes about a given region of linear address space (i.e., a segment). These attributes include the 32-bit base linear address of the segment, the 20-bit length and granularity of the segment, the protection level, read, write or execute privileges, the default size of the operands (16 bit or 32 bit), and the type of seqment. All of the attribute information about a segment is contained in 12 bits in the segment descriptor. Figure 19 shows the general format of a descriptor. All segments on the Am386DXL microprocessor have three attribute fields in common: the P bit, the DPL bit, and the S bit. The Present P bit is 1 if the segment is loaded in physical memory; if P = 0 then any attempt to access this seqment causes a not present exception (Exception 11). The Descriptor Privilege Level DPL is a 2-bit field that specifies the protection levels 0-3 associated with a seament.



15021B-021

#### Figure 18. Interrupt Descriptor Table Register Use



Base Base Address of the segment

Limit The length of the segment

P Present Bit: 1 = Present, 0 = Not Present

DPL Descriptor Privilege Levels 0-3

S Segment Descriptor: 0 = System Descriptor, 1 = Code or Data Segment Descriptor

Type Type of Segment

A Accessed Bit

G Granularity Bit: 1 = Segment length is page granular, 0 = Segment length is byte granular

- D Default Operation Size (recognized in code segment descriptors only): 1 = 32-bit segment, 0 = 16-bit segment
- 0 Bit must be zero (0) for compatibility with future processors

AVL Available field for user or OS

Note: In a maximum-size segment (i.e., segment with G = 1 and segment limit 19-0 = FFFFH), the lowest 12 bits of the segment base should be zero (i.e., segment base 11-000 = 000H).

15021B-022

Figure 19. General Format of Segment Descriptors

The Am386DXL microprocessor has two main categories of segments: system segments and non-system segments (for code and data). The segment S bit in the segment descriptor determines if a given segment is a system segment or a code or data segment. If the S bit is 1, then the segment is either a code or data segment; if it is 0, then the segment is a system segment.

# Am386DXL Microprocessor Code and Data Descriptors (S = 1)

Figure 20 shows the general format of a code and data descriptor and Table 9 illustrates how the bits in the Access Rights Byte are interpreted.

Code and data segments have several descriptor fields in common. The accessed A bit is set whenever the processor accesses a descriptor. The A bit is used by operating systems to keep usage statistics on a given segment. The G bit, or granularity bit, specifies if a segment length is byte-granular or page-granular. Am386DXL microprocessor segments can be 1 Mb long with byte granularity (G=0) or 4 Gb with page granularity (G=1), (i.e.,  $2^{20}$  pages—each page is 4 Kb in length). The granularity is totally unrelated to paging. An Am386DXL CPU system can consist of segments with byte granularity and page granularity, whether or not paging is enabled.

The executable E bit tells if a segment is a code or data segment. A code segment (E = 1, S = 1) may be execute-only or execute/read as determined by the Read R bit. Code segments are execute only if R = 0 and execute/read if R = 1. Code segments may never be written into.

**Note:** Code segments may be modified via aliases. Aliases are writeable data segments that occupy the same range of linear address space as the code segment.

The D bit indicates the default length for operands and effective addresses. If D = 1, then 32-bit operands and 32-bit addressing modes are assumed. If D = 0, then 16-bit operands and 16-bit addressing modes are assumed. Therefore all existing 80286 code segments will execute on the Am386DXL microprocessor assuming the D bit is set 0.

Another attribute of code segments is determined by the conforming C bit. Conforming segments, C = 1, can be executed and shared by programs at different privilege levels (see Section Protection).

#### Table 9. Access Rights Byte Definition for Code and Data Descriptions

| Bit<br>Position |                                      |                                                                                                                              |                                                                                                                             |                                           |  |  |  |  |  |  |
|-----------------|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|--|--|--|--|--|--|
| 7               | Present (P)                          | P = 1 Segment is mapped into physical memory.<br>P = 0 No mapping to physical memory exists, base and limit are<br>not used. |                                                                                                                             |                                           |  |  |  |  |  |  |
| 6–5             | Descriptor Privilege<br>Levels (DPL) |                                                                                                                              | Segment privilege attribute used in privilege tests.                                                                        |                                           |  |  |  |  |  |  |
| 4               | Segment Descriptor (S)               |                                                                                                                              |                                                                                                                             |                                           |  |  |  |  |  |  |
| 3               | Executable (E)                       | E=0                                                                                                                          | Descriptor type is data segment.                                                                                            | ) If Data                                 |  |  |  |  |  |  |
| 2               | Expansion Direction (ED)             | ED = 0                                                                                                                       | Expand up segment, offsets must be ≤ limit.                                                                                 | Segment                                   |  |  |  |  |  |  |
| 1               | Writeable (W)                        | ED = 1<br>W = 0<br>W = 1                                                                                                     | Expand down segment, offsets must be > limit.<br>Data segment may not be written into.<br>Data segment may be written into. | $\begin{cases} (S=1, \\ E=0) \end{cases}$ |  |  |  |  |  |  |
| 32              | Executable (E)                       | E=1                                                                                                                          | Descriptor type is code segment.                                                                                            | ) If Code                                 |  |  |  |  |  |  |
| 2               | Conforming (C)                       | C = 1                                                                                                                        | Code segment may only be executed when                                                                                      | Segment                                   |  |  |  |  |  |  |
| 1               | Readable (R)                         | R=0<br>R=1                                                                                                                   | CPL≥DPL and CPL remains unchanged.<br>Code segment may not be read.<br>Code segment may be read.                            | (S=1,<br>E=1)                             |  |  |  |  |  |  |
| 0               | Accessed (A)                         | A = 0<br>A = 1                                                                                                               | Segment has not been accessed.<br>Segment selector has been loaded into segment<br>or used by selector test instructions.   | t register                                |  |  |  |  |  |  |



D/B 1 = Default Instructions Attributes are 32 bits

0 = Default Instructions Attributes are 16 bits

AVL Available field for user or OS

G Granularity Bit: 1 = Segment length is page granular, 0 = Segment length is byte granular

0 Bit must be zero (0) for compatibility with future processors

Note: In a maximum-size segment (i.e., a segment with G = 1 and segment limit 19–0 = FFFFH), the lowest 12 bits of the segment base should be zero (i.e., segment base 11–000 = 000H).

15021B-023

#### Figure 20. Code and Data Segment Descriptors

Segments identified as data segments (E = 0, S = 1) are used for two types of Am386DXL microprocessor segments: stack and data segments. The expansion direction (ED) bit specifies if a segment expands downward (stack) or upward (data). If a segment is a stack segment, all offsets must be greater than the segment limit. On a data segment all offsets must be less than or equal to the limit. In other words, stack segments start at the base linear address plus the maximum segment limit. On the other hand, data segments start at the base linear address and expand to the base linear address plus limit. The write (W) bit controls the ability to write into a segment. Data segments are read-only if W=0. The stack segment must have W=1.

The B bit controls the size of the stack pointer register. If B = 1, then PUSHes, POPs, and CALLs all use the 32-bit ESP register for stack references and assume an upper limit of FFFFFFFH. If B = 0, stack instructions all use the 16-bit SP register and assume an upper limit of FFFFH.

#### System Descriptor Formats

System segments describe information about operating system tables, tasks, and gates. Figure 21 shows the

general format of system segment descriptors, and the various types of system segments. The Am386DXL microprocessor system descriptors contain a 32-bit base linear address and a 20-bit segment limit. 80286 system descriptors have a 24-bit base address and a 16-bit segment limit. 80286 system descriptors are identified by the upper 16 bits being all zeros.

#### LDT Descriptors (S = 0, Type = 2)

LDT descriptors (S=0, TYPE=2) contain information about Local Descriptor Tables. LDTs contain a table of segment descriptors, unique to a particular task. Since the instruction to load the LDTR is only available at privilege level 0, the DPL field is ignored. LDT descriptors are only allowed in the Global Descriptor Table (GDT).

### TSS Descriptors (S = 0, Type = 1, 3, 9, B)

A Task State Segment (TSS) descriptor contains information about the location, size, and privilege level of a TSS. A TSS in turn is a special fixed format segment that contains all the state information for a task and a linkage field to permit nesting tasks. The Type field is used to indicate whether the task is currently BUSY (i.e., on a chain of active tasks) or the TSS is available. The Type field also indicates if the segment contains a 80286 or a Am386DXL microprocessor TSS. The Task Register (TR) contains the selector that points to the current TSS.

### Gate Descriptors (S = 0, Type = 4–7, C, F)

Gates are used to control access to entry points within the target code segment. The various types of gate descriptors are call gates, task gates, interrupt gates, and trap gates. Gates provide a level of indirection between the source and destination of the control transfer. This indirection allows the processor to automatically perform protection checks. It also allows system designers to control entry points to the operating system. Call gates are used to change privilege levels (see Section Protection), task gates are used to perform a task switch, and interrupt and trap gates are used to specify interrupt service routines.

Figure 22 shows the format of the four types of gate descriptors. Call gates are primarily used to transfer program control to a more privileged level. The call gate descriptor consists of three fields: the access byte; a long pointer (selector and offset) that points to the start of a routine; and a word count that specifies how many parameters are to be copied from the caller's stack to the stack of the called routine. The word count field is only used by call gates when there is a change in the privilege level, other types of gates ignore the word count field.

Interrupt and trap gates use the destination selector and destination offset fields of the gate descriptor as a pointer to the start of the interrupt or trap handler routines. The difference between interrupt gates and trap gates is that the interrupt gate disables interrupts (resets the IF bit) while the trap gate does not.

Task gates are used to switch tasks. Task gates may only refer to a task state segment (see Section Task Switching); therefore, only the destination selector portion of a task gate descriptor is used, and the destination offset is ignored.

Exception 13 is generated when a destination selector does not refer to a correct descriptor type, i.e., a code segment for an interrupt, trap or call gate, a TSS for a task gate.

The access byte format is the same for all gate descriptors. P = 1 indicates that the gate contents are valid. P = 0 indicates the contents are not valid and causes Exception 11 if referenced. DPL is the descriptor privilege level and specifies when this descriptor may be used by a task (see Section Protection). The S field, bit 4 of the access rights byte, must be 0 to indicate a system control descriptor. The type field specifies the descriptor type as indicated in Figure 22.



Note: In a maximum-size segment (i.e., segment with G = 1 and segment limit 19-0 = FFFFH), the lowest 12 bits of the segment base should be zero (i.e., segment base 11-000 = 000H).

15021B-024

Figure 21. System Segments Descriptors



| Name | Value | Description                                |
|------|-------|--------------------------------------------|
| Туре | 4     | 80286 Call Gate                            |
|      | 5     | Task Gate (for 80286 or Am386DXL CPU Task) |
|      | 6     | 80286 Interrupt Gate                       |
|      | 7     | 80286 Trap Gate                            |
|      | С     | Am386DXL CPU Call Gate                     |
|      | E     | Am386DXL CPU Interrupt Gate                |
|      | F     | Am386DXL CPU Trap Gate                     |
| Р    | 0     | Descriptor contents are not valid          |
|      | 1     | Descriptor contents are valid              |

DPL—Least privileged level at which a task may access the gate. WORD COUNT 0-31—the number of parameters to copy from caller's stack to the called procedure's stack. The parameters are 32-bit quantities for Am386DXL CPU gates, and 16-bit quantities for 80286 gates.

| DESTINATION<br>SELECTOR | 16-Bit<br>Selector                            | Selector to the target code segment<br>or<br>Selector to the target state segment for task gate |
|-------------------------|-----------------------------------------------|-------------------------------------------------------------------------------------------------|
| DESTINATION<br>OFFSET   | Offset<br>16-bit 80286<br>32-bit Am386DXL CPU | Entry point within the target code segment                                                      |

15021B-025

#### Figure 22. Gate Descriptor Formats

#### Difference Between Am386DXL Microprocessor and 80286 Descriptors

In order to provide operating system compatibility between the 80286 and Am386DXL microprocessor, the Am386DXL CPU supports all of the 80286 segment descriptors. Figure 23 shows the general format of an 80286 system segment descriptor. The only differences between 80286 and Am386DXL device descriptor formats are that the values of the type fields and the limit and base address fields have been expanded for the Am386DXL device. The 80286 system segment descriptors contained a 24-bit base address and 16-bit limit, while the Am386DXL microprocessor system segment descriptors have a 32-bit base address, a 20-bit limit field, and a granularity bit.

By supporting 80286 system segments, the Am386DXL microprocessor is able to execute 80286 application programs on a Am386DXL CPU operating system. This is possible because the processor automatically understands which descriptors are 80286-style descriptors and which are Am386DXL microprocessor-style descriptors. In particular, if the upper word of a descriptor is zero, then that descriptor is a 80286-style descriptor.

The only other differences between 80286-style descriptors and Am386DXL microprocessor descriptors is the interpretation of the word count field of call gates and the B bit. The word count field specifies the number of 16-bit quantities to copy for 80286 call gates and 32-bit quantities for Am386DXL device call gates. The B bit controls the size of PUSHes when using a call gate; if B = 0, PUSHes are 16 bits, if B = 1, PUSHes are 32 bits.

#### Selector Fields

A selector in Protected Mode has three fields: Local or Global Descriptor Table Indicator (TI), Descriptor Entry Index (Index), and Requestor (the selector's) Privilege Level (RPL) as shown in Figure 24. The TI bits select one of two memory-based tables of descriptors (the Global Descriptor Table or the Local Descriptor Table). The Index selects one of 8K descriptors in the appropriate descriptor table. The RPL bits allow high speed testing of the selector's privilege attributes.

#### Segment Descriptor Cache

In addition to the selector value, every segment register has a segment descriptor cache register associated with it. Whenever a segment register's contents are changed, the 8-byte descriptor associated with that selector is automatically loaded (cached) on the chip. Once loaded, all references to that segment use the cached descriptor information instead of reaccessing the descriptor. The contents of the descriptor cache are not visible to the programmer. Since descriptor caches only change when a segment register is changed, programs that modify the descriptor tables must reload the appropriate segment registers after changing a descriptor's value.



| Base  | Base Address of the Segment               |
|-------|-------------------------------------------|
| Limit | The length of the Segment                 |
| Р     | Present Bit: 1 = Present, 0 = Not Present |
| DPL   | Descriptor Privilege Levels 0–3           |
| S     | System Descriptor: 0 = System, 1 = User   |
| Туре  | Type of Segment                           |

15021B--026





Figure 24. Example Descriptor Selection

15021B-027

#### Segment Descriptor Register Settings

The contents of the segment descriptor cache vary depending on the mode the Am386DXL microprocessor is operating in. When operating in Real Address Mode, the segment base, limit, and other attributes within the segment cache registers are defined as shown in Figure 25.

For compatibility with the 8086 architecture, the base is set to 16 times the current selector value, the limit is fixed at 0000FFFFH, and the attributes are fixed so as to

-----

indicate the segment is present and fully usable. In Real Address Mode, the internal privilege level is always fixed to the highest level, level 0, so I/O and other privileged op-codes may be executed.

When operating in Protected Mode, the segment base, limit, and other attributes within the segment cache registers are defined as shown in Figure 26. In Protected Mode, each of these fields are defined according to the contents of the segment descriptor indexed by the selector value loaded into the segment register.

| L      | 32-Bit Base<br>(Updated During Selector 32-Bit Limit Other Attributes<br>Load into Segment Register) (Fixed) (Fixed) |              |         |   |   |   |   |   |   |   |   |   |
|--------|----------------------------------------------------------------------------------------------------------------------|--------------|---------|---|---|---|---|---|---|---|---|---|
| Confo  | rming Privilege                                                                                                      |              |         |   |   |   |   |   |   |   |   | 7 |
| Stack  | Size                                                                                                                 |              |         |   |   |   |   |   |   |   |   |   |
| Execu  | table                                                                                                                |              |         |   |   |   |   |   |   |   |   |   |
| Writea | ble                                                                                                                  |              |         |   |   |   |   |   | 7 |   |   |   |
| Reada  | able                                                                                                                 |              |         |   |   |   |   |   |   |   |   |   |
|        | sion Direction                                                                                                       |              |         |   |   |   | 7 |   |   |   |   |   |
| Granu  | larity                                                                                                               |              |         |   |   | 1 |   |   |   |   |   |   |
| Acces  |                                                                                                                      |              |         |   | 7 |   |   |   |   |   |   |   |
|        | ge Level                                                                                                             |              |         |   |   |   |   |   |   |   |   |   |
| Prese  | nt                                                                                                                   |              |         |   |   |   |   |   |   |   |   |   |
|        | BASE                                                                                                                 | LIMIT        | ¥       | ₩ | ₩ | ₩ | ₩ | ₩ | ₩ | ₩ | ₩ | * |
| CS     | 16X Current CS Selector*                                                                                             | 0000FFFFH    | Y       | 0 | Y | В | υ | Y | Y | Y | _ | N |
| SS     | 16X Current SS Selector                                                                                              | 0000FFFFH    | Y       | 0 | Y | В | U | Y | Y | N | w | - |
| DS     | 16X Current DS Selector                                                                                              | 0000FFFFH    | Y       | 0 | Y | В | U | Υ | Y | Ν | - | - |
| ES     | 16X Current ES Selector                                                                                              | 0000FFFFH    | Υ       | 0 | Υ | В | U | Y | Υ | Ν | - | - |
| FS     | 16X Current FS Selector                                                                                              | 0000FFFFH    | Y       | 0 | Υ | В | U | Υ | Υ | Ν | - | - |
| GS     | 16X Current GS Selector                                                                                              | 0000FFFFH    | Y       | 0 | Y | В | U | Υ | Υ | Ν | - | - |
|        |                                                                                                                      |              | • • • • |   |   |   |   |   |   |   |   |   |
| Y = Y  | es                                                                                                                   | D = Expand c | lown    |   |   |   |   |   |   |   |   |   |

#### Segment Descriptor Cache Register Contents

- Key: Y = Yes
  - N = No
  - 0 = Privilege level 0
  - 1 = Privilege level 1
  - 2 = Privilege level 2
  - 3 = Privilege level 3
  - U = Expand up

- D = Expand down
- B = Byte granularity
- P = Page granularity
- W = Push/pop 16-bit words
- F = Push/pop 32-bit Dwords
- = Does not apply to that segment cache register

\*Except the 32-bit CS base is initialized to FFFFF000H after reset until first intersegment control transfer (e.g., intersegment CALL, or intersegment JMP, or INT). (See Figure 27 Example.)

15021B-028

Figure 25. Segment Descriptor Caches for Real Address Mode (Segment Limit and Attributes are Fixed)

#### Segment Descriptor Cache Register Contents

| L       | 32-Bit Base<br>(Updated During Selecto<br>oad into Segment Regist | imit<br>g Sel<br>ent Re | ector<br>giste | or)    | Ŀ        |            | Other Attributes<br>pdated During Selector<br>d Into Segment Register) |          |   |          |          |   |   |  |
|---------|-------------------------------------------------------------------|-------------------------|----------------|--------|----------|------------|------------------------------------------------------------------------|----------|---|----------|----------|---|---|--|
| Confo   | rming Privilege                                                   |                         |                |        |          |            |                                                                        |          |   | -        |          |   |   |  |
| Stack   | Size                                                              |                         |                |        |          |            |                                                                        |          |   |          | _        |   |   |  |
| Execu   | table                                                             |                         |                |        |          |            |                                                                        |          |   |          |          |   |   |  |
| Writea  | ble                                                               |                         |                |        |          |            |                                                                        |          | - |          |          |   |   |  |
| Reada   | ble                                                               |                         |                |        |          |            |                                                                        | 7        |   |          |          |   |   |  |
| Expan   | sion Direction                                                    |                         |                |        |          |            | _                                                                      |          |   |          |          |   |   |  |
| Granu   | larity                                                            |                         |                |        |          |            |                                                                        |          |   |          |          |   |   |  |
| Acces   | Accessed                                                          |                         |                |        |          |            |                                                                        |          |   |          |          |   |   |  |
| Privile | Privilege Level                                                   |                         |                |        |          |            |                                                                        |          |   |          |          |   |   |  |
| Prese   | nt                                                                |                         |                |        |          |            |                                                                        |          |   |          |          |   |   |  |
|         | BASE                                                              | LIMIT                   | ¥              | ↓<br>↓ | <u> </u> | . <b>.</b> | <u> </u>                                                               | <b>.</b> | ¥ | <b>.</b> | <b>.</b> | + | - |  |
| cs      | Base per Seg Descr                                                | Limit per Seg Descr     | р              | d      | d        | d          | d                                                                      | d        | N | Y        | -        | d |   |  |
| SS      | Base per Seg Descr                                                | Limit per Seg Descr     | р              | d      | d        | d          | d                                                                      | r        | w | N        | d        | - | • |  |
| DS      | Base per Seg Descr                                                | Limit per Seg Descr     | р              | d      | d        | d          | d                                                                      | d        | d | Ν        | -        | - |   |  |
| ES      | Base per Seg Descr                                                | Limit per Seg Descr     | р              | d      | d        | d          | d                                                                      | d        | d | Ν        | -        | - | _ |  |
| FS      | Base per Seg Descr                                                | Limit per Seg Descr     | р              | d      | d        | d          | d                                                                      | d        | d | Ν        | -        | - | _ |  |
| GS      | Base per Seg Descr                                                | Limit per Seg Descr     | р              | d      | d        | d          | d                                                                      | d        | d | N        | -        | - |   |  |

#### Key: Y = Fixed Yes

- N = Fixed No
- d = Per segment descriptor
- p = Per segment descriptor; descriptor must indicate "present" to avoid Exception 11 (Exception 12 in case of SS)
- r = Per segment descriptor, but descriptor must indicate "readable" to avoid Exception 13 (special case for SS)
- w = Per segment descriptor, but descriptor must indicate "writeable" to avoid Exception 13 (special case for SS)
- = Does not apply to that segment cache register

15021B-029

#### Figure 26. Segment Descriptor Caches for Protected Mode (Loaded per Descriptor)

When operating in a Virtual 8086 Mode within the Protected Mode, the segment base, limit, and other attributes within the segment cache registers are defined as shown in Figure 27. For compatibility with the 8086 architecture, the base is set to 16 times the current selector value, the limit is fixed at 0000FFFFH, and the attributes are fixed so as to indicate the segment is present and fully usable. The virtual program executes at lowest privilege level, level 3, to allow trapping of all IOPL-sensitive instructions and level 0 only instructions.

#### Segment Descriptor Cache Register Contents



Key: Y = Yes

- N = No
- 0 = Privilege level 0
- 1 = Privilege level 1
- 2 = Privilege level 2
- 3 = Privilege level 3
- U = Expand up

- D = Expand down
- B = Byte granularity
- P = Page granularity
- W = Push/pop 16-bit words
- F = Push/pop 32-bit Dwords
- = Does not apply to that segment cache register

15021B-030

#### Figure 27. Segment Caches for Virtual 8086 Mode within Protected Mode (Segment Limit and Attributes are Fixed)

# Protection

#### **Protection Concepts**

The Am386DXL microprocessor has four levels of protection that are optimized to support the needs of a multitasking operating system to isolate and protect user programs from each other and the operating system. The privilege levels control the use of privileged instructions, I/O instructions, and access to segments and segment descriptors. Unlike traditional microprocessor based systems where this protection is achieved only through the use of complex external hardware and software, the Am386DXL CPU provides the protection on a page basis when paging is enabled (see Section Page Level Protection).

The four-level hierarchical privilege system is illustrated in Figure 28. It is an extension of the user/supervisor privilege mode commonly used by minicomputers and, in fact, the user/supervisor mode is fully supported by the Am386DXL microprocessor paging mechanism. The privilege levels (PL) are numbered 0 through 3. Level 0 is the most privileged or trusted level.



15021B-031

Figure 28. Four-Level Hierarchical Protection

# **Rules of Privilege**

The Am386DXL microprocessor controls access to both data and procedures between levels of a task, according to the following rules.

- Data stored in a segment with privilege level p can be accessed only by code executing at a privilege level at least as privileged as p.
- A code segment/procedure with privilege level p can only be called by a task executing at the same or a lesser privilege level than p.

# Privilege Levels

# Task Privilege

At any point in time, a task on the Am386DXL microprocessor always executes at one of the four privilege levels. The Current Privilege Level (CPL) specifies the task's privilege level. A task's CPL may only be changed by control transfers through gate descriptors to a code segment with a different privilege level (see Section Privilege Level Transfers). Thus, an application program running at PL=3 may call an operating system routine at PL=1 (via a gate) that would cause the task's CPL to be set to 1 until operating system routine is finished.

# Selector Privilege (RPL)

The privilege level of a selector is specified by the RPL field. The RPL is the two least significant bits of the selector. The selector's RPL is only used to establish a less trusted privilege level than the current privilege level for the use of a segment. This level is called the task's effective privilege level (EPL). The EPL is defined as being the least privileged (i.e., numerically larger) level of a task's CPL and a selector's RPL. Thus, if selector's RPL = 0, then the CPL always specifies the privilege level for making an access using the selector. On the other hand if RPL = 3, then a selector can only access segments at level 3 regardless of the task's CPL. The RPL is most commonly used to verify that pointers passed to an operating system procedure do not access data that is of higher privilege than the procedure that originated the pointer. Since the originator of a selector can specify any RPL value, the Adjust RPL (ARPL) instruction is provided to force the RPL bits to the originator's CPL.

# I/O Privilege and I/O Permission Bitmap

The I/O privilege level (IOPL, a 2-bit field in the EFLAGS register) defines the least privileged level at which I/O instructions can be unconditionally performed. I/O instructions can be unconditionally performed when CPL≤ IOPL. (The I/O instructions are IN, OUT, INS, OUTS, REP INS, and REP OUTS.) When CPL > IOPL, and the current task is associated with a 286 TSS, attempted I/O instructions cause an Exception 13 fault. When CPL > IOPL, and the current task is associated with a Am386DXL CPU TSS, the I/O Permission Bitmap (part of a Am386DXL microprocessor TSS) is consulted on whether I/O to the port is allowed, or an Exception 13 fault is to be generated instead. For diagrams of the I/O Permission Bitmap, refer to Figures 29a and 29b. For further information on how the I/O Permission Bitmap is used in Protected Mode or in Virtual 8086 Mode, refer to Section Protection and I/O Permission Bitmap.

The I/O privilege level (IOPL) also affects whether several other instructions can be executed or cause an Exception 13 fault instead. These instructions are called IOPL-sensitive instructions and they are CLI and STI. (Note that the LOCK prefix is not IOPL-sensitive on the Am386DXL microprocessor.) The IOPL also affects whether the IF bit (interrupts enable flag) can be changed by loading a value into the EFLAGS register. When CPL  $\leq$  IOPL, the IF bit can be changed by loading a new value into the EFLAGS register. When CPL > IOPL, the IF bit cannot be changed by a new value POP'ed into (or otherwise loaded into) the EFLAGS register; the IF bit merely remains unchanged and no exception is generated.

| Instruction | Operands              | Function                                                                                                                                                                                                                    |
|-------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ARPL        | Selector,<br>Register | Adjust Requested Privilege<br>Level; adjusts the RPL of<br>the selector to the numeric<br>maximum of current selec-<br>tor RPL value and the RPL<br>value in the register. Set<br>zero flag if selector RPL<br>was changed. |
| VERR        | Selector              | VERify for Read: sets the<br>zero flag if the segment<br>referred to by the selector<br>can be read.                                                                                                                        |
| VERW        | Selector              | VERify for Write: sets the<br>zero flag if the segment<br>referred to by the selector<br>can be written.                                                                                                                    |
| LSL         | Register,<br>Selector | Load Segment Limit: reads<br>the segment limit into the<br>register if privilege rules<br>and descriptor type allow.<br>Set zero flag if successful.                                                                        |
| LAR         | Register,<br>Selector | Load Access Rights: reads<br>the descriptor access<br>rights byte into the register<br>if privilege rules allow. Set<br>zero flag if successful.                                                                            |

# Privilege Validation

The Am386DXL CPU provides several instructions to speed pointer testing and help maintain system integrity by verifying that the selector value refers to an appropriate segment. Table 10 summarizes the selector validation procedures available for the Am386DXL microprocessor.

This pointer verification prevents the common problem of an application at PL = 3 calling an operating-systems routine at PL = 0 and passing the operating-systems routine a bad pointer that corrupts a data structure belonging to the operating system. If the operating-systems routine uses the ARPL instruction to ensure that the RPL of the selector has no greater privilege than that of the caller, then this problem can be avoided.

#### **Descriptor Access**

There are basically two types of segment accesses: those involving code segments, such as control trans-

fers; and those involving data accesses. Determining the ability of a task to access a segment involves the type of segment to be accessed, the instruction used, the type of descriptor used, and CPL, RPL, and DPL as described above.

Any time an instruction loads data segment registers (DS, ES, FS, GS) the Am386DXL microprocessor makes protection validation checks. Selectors loaded in the DS, ES, FS, GS registers must refer only to data segments or readable code segments. The data access rules are specified in Section Rules of Privilege. The only exception to those rules is readable conforming code segments which can be accessed at any privilege level.

Finally, the privilege validation checks are performed. The CPL is compared to the EPL and if the EPL is more privileged than the CPL an Exception 13 (General Protection fault) is generated.

The rules regarding the stack segment are slightly different than those involving data segments. Instructions that load selectors into SS must refer to data segment descriptors for writeable data segments. The DPL and RPL must equal the CPL. All other descriptor types or a privilege level violation will cause Exception 13. A stack not present fault causes Exception 12. Note that an Exception 11 is used for a not-present code or data segment.

## Privilege Level Transfers

Intersegment control transfers occur when a selector is loaded in the CS register. For a typical system most of these transfers are simply the result of a call or a jump to another routine. There are five types of control transfers, which are summarized in Table 11.

Many of these transfers result in a privilege level transfer. Changing privilege levels is done only via control transfers by using gates, task switches, and interrupt or trap gates.

Control transfers can only occur if the operation that loaded the selector references the correct descriptor type. Any violation of these descriptor usage rules will cause an Exception 13 (e.g., JMP through a call gate or IRET from a normal subroutine call).

In order to provide further system security, all control transfers are also subject to the privilege rules.

The privilege rules require that:

- Privilege level transitions can only occur via gates.
- JMPs can be made to a non-conforming code segment with the same privilege or to a conforming code segment with greater or equal privilege.
- CALLs can be made to a non-conforming code segment with the same privilege or via a gate to a more privileged level.
- Interrupts handled within the task obey the same privilege rules as CALLs.

| Control Transfer Types                                    | Operation Types                                                 | Descriptor<br>Referenced | Descriptor<br>Table |
|-----------------------------------------------------------|-----------------------------------------------------------------|--------------------------|---------------------|
| Intersegment within the same privilege level              | JMP, CALL, RET, IRET*                                           | Code Segment             | GDT/LDT             |
| Intersegment to the same or higher privilege level        | CALL                                                            | Call Gate                | GDT/LDT             |
| Interrupt within task may change CPL                      | Interrupt Instruction,<br>Exception, External Interrupt         | Trap or Interrup<br>Gate | IDT                 |
| Intersegment to a lower privilege level (change task CPL) | RET, IRET*                                                      | Code Segment             | GDT/LDT             |
|                                                           | CALL, JMP                                                       | Task State Segment       | GDT                 |
|                                                           | CALL, JMP                                                       | Task Gate                | GDT/LDT             |
| Task Switch                                               | IRET**, Interrupt Instruction,<br>Exception, External Interrupt | Task Gate                | IDT                 |

#### Table 11. Descriptor Types Used for Control Transfer

\*NT (Nested Task bit of flag register) = 0 \*\*NT (Nested Task bit of flag register) = 1

- Conforming Code segments are accessible by privilege levels that are the same or less privileged than the conforming-code segment's DPL.
- Both the requested privilege level (RPL) in the selector pointing to the gate and the task's CPL must be of equal or greater privilege than the gate's DPL.
- The code segment selected in the gate must be the same or more privileged than the task's CPL.
- Return instructions that do not switch tasks can only return control to a code segment with same or less privilege.
- Task switches can be performed by a CALL, JMP, or INT that references either a task gate or task state segment whose DPL is less privileged or the same privilege as the old task's CPL.

Any control transfer that changes CPL within a task causes a change of stacks as a result of the privilege level change. The initial values of SS:ESP for privilege levels 0, 1, and 2 are retained in the task state segment (see Section Task Switching). During a JMP or CALL control transfer, the new stack pointer is loaded in the SS and ESP registers and the previous stack pointer is pushed onto the new stack.

When returning to the original privilege level, use of the lower-privilege stack is restored as part of the RET or IRET instruction operation. For subroutine calls that pass parameters on the stack and cross privilege levels, a fixed number of words (as specified in the gate's word count field) are copied from the previous stack to the current stack. The intersegment RET instruction with a stack adjustment value will correctly restore the previous stack pointer upon return.

#### **Call Gates**

Gates provide protected, indirect CALLs. One of the major uses of gates is to provide a secure method of

privilege transfers within a task. Since the operating system defines all of the gates in a system, it can ensure that all gates only allow entry into a few trusted procedures (such as those that allocate memory or perform I/O).

Gate descriptors follow the data access rules of privilege; that is, gates can be accessed by a task if the EPL is equal to or more privileged than the gate descriptor's DPL. Gates follow the control transfer rules of privilege and therefore may only transfer control to a more privileged level.

Call gates are accessed via a CALL instruction and are syntactically identical to calling a normal subroutine. When an interlevel Am386DXL microprocessor call gate is activated, the following actions occur:

- 1. Load CS:EIP from gate check for validity;
- 2. SS is pushed zero-extended to 32 bits;
- 3. ESP is pushed;
- Copy word count 32-bit parameters from the old stack to the new stack;
- 5. Push return address on stack.

The procedure is identical for 80286 Call gates, except that 16-bit parameters are copied and 16-bit registers are pushed.

Interrupt gates and Trap gates work in a similar fashion as the call gates, except there is no copying of parameters. The only difference between Trap and Interrupt gates is that control transfers through an Interrupt gate, disable further interrupts (i.e., the IF bit is set to 0), and Trap gates leave the interrupt status unchanged.



|     | 31     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31  | 1      | 1  | 1  | 1  | 0  | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 0  | 1  | 0  | 0  | 1  | 1  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |
| 63  | 0      | 0  | 1  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 0  | 0  | 1  | 0  | 1  | 0  | 1  | 1  | 1  | 1  | 1  | 1  | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |
| 95  | 1      | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 127 | 0      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|     |        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|     |        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 6   | Y.     |    |    |    |    |    |    |    |    |    |    | ot | ~  |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 2 |
| ?   | L<br>K |    |    |    |    |    |    |    |    |    |    | et | c. |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

I/O Ports Accessible:  $2 \rightarrow 9$ , 12, 13, 15,  $20 \rightarrow 24$ , 27, 33, 34, 40, 41, 48, 50, 52, 53, 58  $\rightarrow 60$ , 62, 63,  $96 \rightarrow 127$ 

Figure 29b. Sample I/O Permission Bit Map

# **Task Switching**

A very important attribute of any multitasking/multi-user operating systems is its ability to rapidly switch between tasks or processes. The Am386DXL microprocessor directly supports this operation by providing a task switch instruction in hardware. The Am386DXL CPU task switch operation saves the entire state of the machine (all of the registers, address space, and a link to the previous task), loads a new execution state, performs protection checks, and commences execution in the new task, in about 17 ms. Like transfer of control via gates, the task switch operation is invoked by executing an intersegment JMP or CALL instruction that refers to a Task State Segment (TSS), or a task gate descriptor in the GDT or LDT. An INT n instruction, exception, trap, or external interrupt may also invoke the task switch operation if there is a task gate descriptor in the associated IDT descriptor slot.

The TSS descriptor points to a segment (see Figure 29a) containing the entire Am386DXL microprocessor execution state while a task gate descriptor contains a TSS selector. The Am386DXL CPU supports both 80286 and Am386DXL CPU style TSSs. Figure 30 shows a 80286 TSS. The limit of a Am386DXL microprocessor TSS must be greater than 0064H (002BH for a 80286 TSS) and can be as large as 4 Gb. In the additional TSS space, the operating system is free to store additional information, such as the reason the task is inactive, time the task has spent running, and open files belonging to the task.

Each task must have a TSS associated with it. The current TSS is identified by a special register in the Am386DXL microprocessor called the Task State Segment Register (TR). This register contains a selector referring to the task state segment descriptor that defines the current TSS. A hidden base and limit register associated with TR are loaded whenever TR is loaded with a new selector. Returning from a task is accomplished by the IRET instruction. When IRET is executed, control is returned to the task which was interrupted. The current executing task's state is saved in the TSS and the old task state is restored from its TSS. Several bits in the flag register and machine status word (CR0) give information about the state of a task that are useful to the operating system. The Nested Task (NT) (bit 14 in EFLAGS) controls the function of the IRET instruction. If NT = 0, the IRET instruction performs the regular return; when NT = 1, IRET performs a task switch operation back to the previous task. The NT bit is set or reset in the following fashion.

When a CALL or INT instruction initiates a task switch, the new TSS will be marked busy and the back link field of the new TSS set to the old TSS selector. The NT bit of the new task is set by CALL or INT initiated task switches. An interrupt that does not cause a task switch will clear NT. (The NT bit will be restored after execution of the interrupt handler.) NT may also be set or cleared by POPF or IRET instructions.

The Am386DXL microprocessor Task State Segment is marked busy by changing the descriptor type field from Type 9H to Type BH. An 80286 TSS is marked busy by changing the descriptor type field from Type 1 to Type 3. Use of a selector that references a busy task state segment causes an Exception 13.

The Virtual Mode (VM) bit 17 is used to indicate if a task is a virtual 8086 task. If VM = 1, then the tasks will use the Real Mode addressing mechanism. The virtual 8086 environment is only entered and exited via a task switch (see Section Virtual Mode).

The coprocessor's state is not automatically saved when a task switch occurs, because the incoming task may not use the coprocessor. The Task Switched (TS) Bit (bit 3 in the CR0) helps deal with the coprocessor's state in a multitasking environment. Whenever the Am386DXL microprocessor switches tasks, it sets the TS bit. The Am386DXL CPU detects the first use of a processor extension instruction after a task switch and causes the processor extension not available Exception 7. The exception handler for Exception 7 may then decide whether to save the state of the coprocessor. A processor extension not present Exception 7 will occur when attempting to execute an ESC or WAIT instruction if the Task Switched and Monitor coprocessor extension bits are both set (i.e., TS = 1 and MP = 1).

<sup>15021</sup>B--032b



The T bit in the Am386DXL microprocessor TSS indicates that the processor should generate a debug exception when switching to a task. If T = 1, then upon entry to a new task, a debug Exception 1 will be generated.

#### Initialization and Transition to Protected Mode

Since the Am386DXL microprocessor begins executing in Real Mode immediately after RESET, it is necessary to initialize the system tables and registers with the appropriate values.

The GDT and IDT registers must refer to a valid GDT and IDT. The IDT should be at least 256-bytes long, and GDT must contain descriptors for the initial code and data segments. Figure 31 shows the tables and Figure 32 shows the descriptors needed for a simple Protected Mode Am386DXL microprocessor system. It has a single code and single data/stack segment each 4 Gb long and a single privilege level PL = 0.

The actual method of enabling Protected Mode is to load CR0 with PE bit set, via the MOV CR0, R/M instruction.

This puts the Am386DXL microprocessor in Protected Mode.

After enabling Protected Mode, the next instruction should execute an intersegment JMP to load the CS register and flush the instruction decode queue. The final step is to load all of the data segment registers with the initial selector values.

An alternate approach to entering Protected Mode that is especially appropriate for multitasking operating systems is to use the built in task-switch to load all of the registers. In this case, the GDT would contain two TSS descriptors in addition to the code and data descriptors needed for the first task. The first JMP instruction in Protected Mode would jump to the TSS causing a task switch and loading all of the registers with the values stored in the TSS. The TR should be initialized to point to a valid TSS descriptor since a task switch saves the state of the current task in a task state segment.

# Paging

# **Paging Concepts**

Paging is another type of memory management useful for virtual memory multitasking operating systems. Unlike segmentation that modularizes programs and data into variable length segments, paging divides programs into multiple uniform size pages. Pages bear no direct relation to the logical structure of a program. While segment selectors can be considered the logical name of a program module or data structure, a page most likely corresponds to only a portion of a module or data structure.

By taking advantage of the locality of reference displayed by most programs, only a small number of pages from each active task need be in memory at any one moment.

# **Paging Organization**

#### Page Mechanism

The Am386DXL microprocessor uses two levels of tables to translate the linear address (from the segmentation unit) into a physical address. There are three components to the paging mechanism of the Am386DXL CPU: the page directory, the page tables, and the page itself (page frame). All memory-resident elements of the Am386DXL CPU paging mechanism are the same size, namely, 4 Kb. A uniform size for all of the elements simplifies memory allocation and reallocation schemes, since there is no problem with memory fragmentation. Figure 33 shows how the paging mechanism works.



15021B-034





15021B-035

Figure 32. GDT Descriptors for Simple System

#### Page Descriptor Base Register

CR2 is the Page Fault Linear Address register. It holds the 32-bit linear address that caused the last Page Fault detected.

CR3 is the Page Directory Physical Base Address Register. It contains the physical starting address of the Page Directory. The lower 12 bits of CR3 are always zero to ensure that the Page Directory is always page aligned. Loading it via a MOV CR3, reg instruction causes the Page Table entry cache to be flushed, as will a task switch through a TSS that changes the value of CR0. (See Translation Look-Aside Buffer.)

#### Page Directory

The Page Directory is 4-Kb long and allows up to 1024 Page Directory entries. Each Page Directory entry contains the address of the next level of tables, the Page Tables and information about the page table. The contents of a Page Directory entry are shown in Figure 34. The upper 10 bits of the linear address (A31–A22) are used as an index to select the correct Page Directory entry.



15021B-036

Figure 33. Paging Mechanism

| 31                       | 12 11 | 10          | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2      | 1      | 0 |
|--------------------------|-------|-------------|----|---|---|---|---|---|---|--------|--------|---|
| Page Table Address 31–12 | R     | OS<br>eserv | ed | 0 | 0 | D | A | 0 | 0 | U<br>s | R<br>Ŵ | Ρ |



15021B-037

| 31 12                    | : 11 | 10          | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2      | 1      | 0 |
|--------------------------|------|-------------|----|---|---|---|---|---|---|--------|--------|---|
| Page Frame Address 31–12 | R    | OS<br>eserv | ed | 0 | 0 | D | A | 0 | 0 | U<br>s | R<br>W | Р |

Figure 35. Page Table Entry (Points to Page)

15021B-038

# Page Tables

Each Page Table is 4 Kb and holds up to 1024 Page Table entries. Page Table entries contain the starting address of the page frame and statistical information about the page (see Figure 35). Address bits A21–A12 are used as an index to select one of the 1024 Page Table entries. The 20 upper-bit page frame address is concatenated with the lower 12 bits of the linear address to form the physical address. Page tables can be shared between tasks and swapped to disks.

#### Page Directory/Table Entries

The lower 12 bits of the Page Table entries and Page Directory entries contain statistical information about pages and page tables respectively. The P (Present) bit 0 indicates if a Page Directory or Page Table entry can be used in address translation. If P = 1, the entry can be used for address translation; if P = 0, the entry can not be used for translation. Note that the present bit of the page table entry that points to the page where code is currently being executed should always be set. Code that marks its own page not present should not be written. All of the other bits are available for use by the software. For example the remaining 31 bits could be used to indicate where on the disk the page is stored.

The A (Accessed) bit 5 is set by the Am386DXL microprocessor for both types of entries before a read or write access occurs to an address covered by the entry. The D (Dirty) bit 6 is set to 1 before a write to an address covered by that page table entry occurs. The D bit is undefined for Page Directory entries. When the P, A, and D bits are updated by the Am386DXL CPU, the microprocessor generates a Read-Modify-Write cycle that locks the bus and prevents conflicts with other processors or peripherals. Software that modifies these bits should use the LOCK prefix to ensure the integrity of the page tables in multi-master systems.

The 3 bits marked OS Reserved in Figures 34 and 35 (bits 11–9) are software definable. OSs are free to use these bits for whatever purpose they wish. An example use of the OS Reserved bits would be to store information about page aging. By keeping track of how long a page has been in memory since being accessed, an operating system can implement a page replacement algorithm like Least Recently Used.

The (User/Supervisor) U/S bit 2 and the (Read/Write) R/W bit 1 are used to provide protection attributes for individual pages.

#### Page Level Protection (R/W, U/S Bits)

The Am386DXL microprocessor provides a set of protection attributes for paging systems. The paging mechanism distinguishes between two levels of protection: user, which corresponds to level 3 of the segmentation based protection, and supervisor, which encompasses all of the other protection levels (0, 1, 2). Programs executing at level 0, 1, or 2 bypass the page protection, although segmentation based protection is still enforced by the hardware.

The U/S and R/W bits are used to provide User/Supervisor and Read/Write protection for individual pages or for all pages covered by a Page Table Directory entry. The U/S and R/W bits in the first level Page Directory Table apply to all pages described by the page table pointed to by that directory entry. The U/S and R/W bits in the second level Page Table entry apply only to the page described by that entry. The U/S and R/W bits for a given page are obtained by taking the most restrictive of the U/S and R/W bits from the Page Directory Table entries and using these bits to address the page.

Example: If the U/S and R/W bits for the Page Directory entry were 10 and the U/S and R/W bits for the Page Table entry were 01, the access rights for the page would be 01, the numerically smaller of the two. Table 12 shows the effect of the U/S and R/W bits on accessing memory.

Table 12. Protection Provided by R/W and U/S

| U/S | R/W | Permitted<br>Level 3 | Permitted Access<br>Levels 0, 1, or 2 |
|-----|-----|----------------------|---------------------------------------|
| 0   | 0   | None                 | Read/Write                            |
| 0   | 1   | None                 | Read/Write                            |
| 1   | 0   | Read-Only            | Read/Write                            |
| 1   | 1   | Read/Write           | Read/Write                            |

However, a given segment can be easily made readonly for level 0, 1, or 2 via the use of segmented protection mechanisms (see Section Protection).

#### **Translation Look-Aside Buffer**

The Am386DXL microprocessor paging hardware is designed to support demand paged virtual memory systems. However, performance would degrade substantially if the processor was required to access two levels of tables for every memory reference. To solve this problem, the Am386DXL device keeps a cache of the most recently accessed pages, this cache is called the Translation Look-Aside Buffer (TLB). The TLB is a fourway set associative 32-entry page table cache. It automatically keeps the most commonly used Page Table entries in the processor. The 32-entry TLB coupled with a 4K-page size results in coverage of 128 Kb of memory addresses. For many common multitasking systems, the TLB will have a hit rate of about 98%. This means that the processor will only have to access the two-level page structure on 2% of all memory references. Figure 36 illustrates how the TLB complements the Am386DXL microprocessor's paging mechanism.



# **Paging Operation**

The paging hardware operates in the following fashion: the paging unit hardware receives a 32-bit linear address from the segmentation unit. The upper 20 linear address bits are compared with all 32 entries in the TLB to determine if there is a match. If there is a match (i.e., a TLB hit), then the 32-bit physical address is calculated and will be placed on the address bus.

However, if the Page Table entry is not in the TLB, the Am386DXL microprocessor will read the appropriate Page Directory entry. If P = 1 on the Page Directory entry indicating that the page table is in memory, then the Am386DXL device will read the appropriate Page Table entry and set the Access bit. If P = 1 on the Page Table entry indicating that the page is in memory, the Am386DXL device will update the Access and Dirty bits as needed and fetch the operand. The upper 20 bits of the linear address, read from the page table, will be stored in the TLB for future accesses. However, if P = 0 for either the Page Directory entry or the Page Table Entry, then the processor will generate a Page Fault, an Exception 14.

The processor will also generate an Exception 14, Page Fault, if the memory reference violated the page protection attributes (i.e., U/S or R/W; trying to write to a readonly page). CR2 will hold the linear address that caused the page fault. If a second page fault occurs while the processor is attempting to enter the service routine for the first, then the processor will invoke the Page Fault (Exception 14) handler a second time, rather than the Double Fault (Exception 8) handler. Since Exception 14 is classified as a fault, CS:EIP will point to the instruction causing the page fault. The 16-bit error code pushed as part of the page fault handler will contain status bits which indicate the cause of the Page Fault.

The 16-bit error code is used by the operating system to determine how to handle the Page Fault. Figure 37 shows the format of the page-fault error code and the interpretation of the bits.

Note: Even though the bits in the error code (U/S, R/W, and P) have similar names as the bits in the Page Directory/Table entries, the interpretation of the error code bits is different. Figure 38 indicates what type of access caused the Page Fault.



15021B-040

#### Figure 37. Page Fault Error Code Format

U/S: The U/S bit indicates whether the access causing the fault occurred when the processor was executing the User Mode (U/S = 1) or in Supervisor mode (U/S = 0).

**R/W**: The R/W bit indicates whether the access causing the fault was a Read (R/W = 0) or a Write (R/W = 1).

**P**: The P bit indicates whether a Page Fault was caused by a not-present page (P = 0) or by a page level protection violation (P = 1).

U: Undefined.

| U/S | R/W | Access Type      |
|-----|-----|------------------|
| 0   | 0   | Supervisor* Read |
| 0   | 1   | Supervisor Write |
| 1   | 0   | User Read        |
| 1   | 1   | User Write       |

\*Descriptor table access will fault with U/S = 0, even if the program is executing at level 3.

15021B-041

#### Figure 38. Type of Access Causing Page Fault

#### **Operating System Responsibilities**

The Am386DXL microprocessor takes care of the page address translation process, relieving the burden from an operating system in a demand-paged system. The operating system is responsible for setting up the initial page tables and handling any page faults. The operating system also is required to invalidate (i.e., flush) the TLB when any changes are made to any of the Page Table entries. The operating system must reload CR3 to cause the TLB to be flushed. Setting up the tables is simply a matter of loading CR3 with the address of the Page Directory and allocating space for the Page Directory and the Page Tables. The primary responsibility of the operating system is to implement a swapping policy and handle all of the page faults.

A final concern of the operating system is to ensure that the TLB cache matches the information in the paging tables. In particular, any time the operating system sets the P present bit of page table entry to zero, the TLB must be flushed. Operating systems may want to take advantage of the fact that CR3 is stored as part of a TSS to give every task or group of tasks its own set of page tables.

# Virtual 8086 Environment

# **Executing 8086 Programs**

The Am386DXL microprocessor allows the execution of 8086 application programs in both Real Mode and in the Virtual 8086 Mode (Virtual Mode). Of the two methods, Virtual 8086 Mode offers the system designer the most flexibility. The Virtual 8086 Mode allows the execution of 8086 applications, while still allowing the system designer to take full advantage of the Am386DXL device protection mechanism. In particular, the Am386DXL CPU allows the simultaneous execution of 8086 operating systems and its applications, and a Am386DXL CPU operating system and both 80286 and Am386DXL microprocessor applications. Thus, in a multi-user Am386DXL CPU computer, one person could be running a MS-DOS spreadsheet, another person using MS-DOS, and a third person could be running multiple UNIX utilities and applications. Each person in this scenario would believe that he had the computer completely to himself. Figure 39 illustrates this concept.

# Virtual 8086 Mode Addressing Mechanism

One of the major differences between Am386DXL microprocessor Real and Protected Modes is how the segment selectors are interpreted. When the processor is executing in Virtual 8086 Mode, the segment registers are used in an identical fashion to Real Mode. The contents of the segment register is shifted left 4 bits and added to the offset to form the segment base linear address.

The Am386DXL microprocessor allows the operating system to specify which programs use the 8086 style address mechanism, and which programs use Protected Mode addressing, on a per task basis. Through the use of paging, the 1-Mb address space of the Virtual Mode task can be mapped to anywhere in the 4-Gb linear address space of the Am386DXL device. Like Real Mode, Virtual Mode effective addresses (i.e., segment offsets) that exceed 64 Kb will cause an Exception 13. However, these restrictions should not prove to be important because most tasks running in Virtual 8086 Mode will simply be existing 8086 application programs.

## Paging In Virtual Mode

The paging hardware allows the concurrent running of multiple Virtual Mode tasks and provides protection and operating system isolation. Although it is not strictly necessary to have the paging hardware enabled to run Virtual Mode tasks, it is needed in order to run multiple Virtual Mode tasks or to relocate the address space of a Virtual Mode task to physical address space greater than 1 Mb.

The paging hardware allows the 20-bit linear address produced by a Virtual Mode program to be divided into up to 256 pages. Each one of the pages can be located anywhere within the maximum 4-Gb physical address space of the Am386DXL microprocessor. In addition, since CR3 (the Page Directory Base Register) is loaded by a task switch, each Virtual Mode task can use a different mapping scheme to map pages to different physical locations. Finally, the paging hardware allows the sharing of the 8086 operating system code between multiple 8086 applications. Figure 39 shows how the Am386DXL device paging hardware enables multiple 8086 programs to run under a virtual memory demand paged system.

# Protection and I/O Permission Bitmap

All Virtual 8086 Mode programs execute at privilege level 3, the level of least privilege. As such, Virtual 8086 Mode programs are subject to all of the protection checks defined in Protected Mode. (This is different from Real Mode which implicitly is executing at privilege level 0, the level of greatest privilege.) Thus, an attempt to execute a privileged instruction when in Virtual 8086 Mode will cause an Exception 13 fault.

The following are privileged instructions, which may be executed only at Privilege Level 0. Therefore, attempting to execute these instructions in Virtual 8086 Mode (or anytime CPL > 0) causes an Exception 13 fault.

| LIDT; | MOV | DRn, reg; | MOV | reg,DRn;            |  |
|-------|-----|-----------|-----|---------------------|--|
| LGDT; | MOV | TRn, reg; | MOV | <pre>reg,TRn;</pre> |  |
| LMSW; | MOV | CRn, reg; | MOV | reg, CRn;           |  |
| CLTS; |     |           |     |                     |  |
| HLT;  |     |           |     |                     |  |

Several instructions, particularly those applying to the multitasking model and protection model, are available only in Protected Mode. Therefore, attempting to execute the following instructions in Real Mode or in Virtual 8086 Mode generates an Exception 6 fault.

| LTR;  | STR;  |
|-------|-------|
| LLDT; | SLDT; |
| LAR;  | VERR; |
| LSL;  | VERW; |
| ARPL. |       |



15021B-042

#### Figure 39. Virtual 8086 Environment Memory Management

The instructions that are IOPL-sensitive in Protected Mode are:

IN; STI; OUT; CLI; INS; OUTS; REP INS; REP OUTS.

In Virtual 8086 Mode, a slightly different set of instructions are made IOPL-sensitive. The following instructions are IOPL-sensitive in Virtual 8086 Mode:

| INT n; | STI;  |
|--------|-------|
| PUSHF; | CLI;  |
| POPF;  | IRET. |

The PUSHF, POPF, and IRET instructions are IOPLsensitive in Virtual 8086 Mode only. This provision allows the IF flag (interrupt enable flag) to be virtualized to the Virtual 8086 Mode program. The INT n software interrupt instruction is also IOPL-sensitive in Virtual 8086 Mode. Note, however, that the INT 3 (op-code 0CCH), INTO, and BOUND instructions are not IOPL-sensitive in Virtual 8086 Mode (they are not IOPL sensitive in Protected Mode either).

Note that the I/O instructions (IN, OUT, INS, OUTS, REP INS, and REP OUTS) are not IOPL-sensitive in Virtual 8086 Mode. Rather, the I/O instructions become automatically sensitive to the I/O Permission Bitmap contained in the Am386DXL CPU TSS. The I/O Permission Bitmap, automatically used by the Am386DXL microprocessor in Virtual 8086 Mode, is illustrated by Figures 29a and 29b.

The I/O Permission Bitmap can be viewed as a 0–64K bit string, that begins in memory at offset Bit\_Map\_Offset in the current TSS. Bit\_Map\_Offset must be  $\leq$  DFFFH so the entire bit map and the byte FFH that follows the bit map are all at offset  $\leq$  FFFFH from the TSS base. The 16-bit pointer Bit\_Map\_Offset (15–0) is found in the word beginning at offset 66H (102 decimal) from the TSS base, as shown in Figure 29a.

Each bit in the I/O Permission Bitmap corresponds to a single byte-side I/O port, as illustrated in Figure 29a. If a bit is 0, I/O to the corresponding byte-wide port can occur without generating an exception. Otherwise the I/O instruction causes an Exception 13 fault. Since every byte-wide I/O port must be protectable, all bits corresponding to a Word-wide or Dword-wide port must be 0 for the Word-wide or Dword-wide I/O to be permitted. If all the referenced bits are 0, the I/O will be allowed. If any referenced bits are 1, the attempted I/O will cause an Exception 13 fault.

Due to the use of a pointer to the base of the I/O Permission Bitmap, the bitmap may be located anywhere within the TSS or may be ignored completely by pointing the Bit\_Map\_Offset (15–0) beyond the limit of the TSS segment. In the same manner, only a small portion of the 64K I/O space need have an associated map bit by adjusting the TSS limit to truncate the bitmap. This eliminates the commitment of 8K of memory when a complete bitmap is not required, while allowing the fully general case if desired.

Example of Bitmap for I/O Ports 0–255: Setting the TSS limit to {Bit\_Map\_Offset + 31 +1\*\*} [\*\*see note below] will allow a 32-byte bitmap for the I/O ports 0–255, plus a terminator byte of all 1s [\*\*see note below]. This allows the I/O bitmap to control I/O Permission to I/O ports 0–255 while causing an Exception 13 fault on attempted I/O to any I/O port 256 through 65,565.

\*\*Important Implementation Note: Beyond the last byte of I/O mapping, information in the I/O Permission Bitmap must be a byte containing all 1s. The byte of all 1s must be within the limit of the Am386DXL CPU TSS segment (see Figure 29a).

#### Interrupt Handling

In order to fully support the emulation of an 8086 machine, interrupts in Virtual 8086 Mode are handled in a unique fashion. When running in Virtual Mode, all interrupts and exceptions involve a privilege change back to the host Am386DXL CPU operating system. The Am386DXL microprocessor operating system determines if the interrupt comes from a Protected Mode application or from a Virtual Mode program by examining the VM bit in the EFLAGS image stored on the stack.

When a Virtual Mode program is interrupted and execution passes to the interrupt routine at level 0, the VM bit is cleared. However, the VM bit is still set in the EFLAGS image on the stack.

The Am386DXL microprocessor operating system in turn handles the exception or interrupt and then returns control to the 8086 program. The Am386DXL CPU operating system may choose to let the 8086 operating system handle the interrupt or it may emulate the function of the interrupt handler. For example, many 8086 operating system calls are accessed by PUSHing parameters on the stack, and then executing an INT n instruction. If the IOPL is set to 0 then all INT n instructions will be intercepted by the Am386DXL microprocessor operating system. The Am386DXL CPU operating system could emulate the 8086 operating system's call. Figure 40 shows how the Am386DXL microprocessor operating system could intercept an 8086 operating system's call to Open a File.

The Am386DXL microprocessor operating system can provide a Virtual 8086 Environment that is totally transparent to the application software via intercepting and then emulating 8086 operating system's calls, and intercepting IN and OUT instructions.

# Entering and Leaving Virtual 8086 Mode

Virtual 8086 Mode is entered by executing an IRET instruction (at CPL = 0), or Task Switch (at any CPL) to a Am386DXL microprocessor task whose Am386DXL microprocessor TSS has a EFLAGS image containing a 1 in the VM bit position while the processor is executing in Protected Mode. That is, one way to enter Virtual 8086 Mode is to switch to a task with a Am386DXL device TSS that has a 1 in the VM bit in the EFLAGS image. The other way is to execute a 32-bit IRET instruction at privilege level 0, where the stack has a 1 in the VM bit in the EFLAGS image. POPF does not affect the VM bit even if the processor is in Protected Mode or level 0, and so cannot be used to enter Virtual 8086 Mode. PUSHF always pushes a 0 in the VM bit, even if the processor is in Virtual 8086 Mode, so that a program cannot tell if it is executing in Real Mode or in Virtual 8086 Mode.

The VM bit can be set by executing an IRET instruction only at privilege level 0 or by any instruction or interrupt that causes a task switch in Protected Mode (with VM = 1 in the new FLAGS image), and can be cleared only by an interrupt or exception in Virtual 8086 Mode. IRET and POPF instructions executed in Real Mode or Virtual 8086 Mode will not change the value in the VM bit.

The transition out of Virtual 8086 Mode to Am386DXL microprocessor Protected Mode occurs only on receipt of an interrupt or exception (such as due to a sensitive instruction). In Virtual 8086 Mode, all interrupts and exceptions vector through the Protected Mode IDT, and enter an interrupt handler in Am386DXL CPU Protected Mode. That is, as part of interrupt processing, the VM bit is cleared.

Because the matching IRET must occur from level 0, if an Interrupt or Trap gate is used to field an interrupt or exception out of Virtual 8086 Mode, the gate must perform an interlevel interrupt only to level 0. Interrupt or Trap gates through conforming segments or through segments with DPL > 0, will raise a GP fault with the CS selector as the error code.

# Task Switches To/From Virtual 8086 Mode

Tasks which can execute in Virtual 8086 Mode must be described by a TSS with the new Am386DXL microprocessor format (Type 9 or 11 descriptor).

A task switch out of Virtual 8086 Mode will operate exactly the same as any other task switch out of a task with an Am386DXL CPU TSS. All of the programmer visible state, including the FLAGS register with the VM bit set to 1, is stored in the TSS. The segment registers in the TSS will contain 8086 segment base values rather than selectors.

A task switch into a task described by a Am386DXL microprocessor TSS will have an additional check to determine if the incoming task should be resumed in Virtual 8086 Mode. Tasks described by 80286 format TSSs cannot be resumed in Virtual 8086 Mode, so no check is required there (the FLAGS image in 80286 format TSS has only the low-order 16 FLAGS bits). Before loading the segment register images from a Am386DXL CPU TSS, the FLAGS image is loaded so that the segment registers are loaded from the TSS image as 8086 segment base values. The task is now ready to resume in Virtual 8086 Execution Mode.

#### Transitions Through Trap and Interrupt Gates, and IRET

A task switch is one way to enter or exit Virtual 8086 Mode. The other method is to exist through a Trap or Interrupt gate, as part of handling an interrupt, and to enter as part of executing an IRET instruction. The transition out must use a Am386DXL microprocessor Trap gate (Type 14) or Interrupt gate (Type 15) that must point to a non-conforming level 0 segment (DPL = 0) in order to permit the trap handler to IRET back to the Virtual 8086 program. The gate must point to a non-conforming level 0 segment to perform a level switch to level 0 so that the matching IRET can change the VM bit. Am386DXL device gates must be used, since 80286 gates save only the lower 16 bits of the FLAGS register, so that the VM bit will not be saved on transitions through the 80286 gates. Also, the 16-bit IRET (presumably) used to terminate the 80286 interrupt handler will pop only the lower 16 bits from FLAGS, and will not affect the VM bit. The action taken for a Am386DXL microprocessor Trap or Interrupt gate if an interrupt occurs while the task is executing in Virtual 8086 Mode is given by the following sequence.

- Save the FLAGS register in a temp to push later. Turn off the VM and TF bits, and if the interrupt is serviced by an Interrupt gate, turn off IF bit, also.
- 2. Interrupt and Trap gates must perform a level switch from 3 (where the VM86 program executes) to level 0 (so IRET can return). This process involves a stack switch to the stack given in the TSS for privilege level 0. Save the Virtual 8086 Mode SS and ESP registers to push in a later step. The segment register load of SS will be done as a Protected Mode segment load since the VM bit was turned off above.
- Push the 8086 segment register values onto the new stack, in the order: GS, FS, DS, ES. These are pushed as 32-bit quantities with undefined values in the upper 16 bits. Then load these 4 registers with null selectors (0).
- 4. Push the old 8086 stack pointer onto the new stack by pushing the SS register (as 32-bit, high bits

undefined), then pushing the 32-bit ESP register saved above.

- 5. Push the 32-bit FLAGS register saved in step 1.
- 6. Push the old 8086 instruction pointer onto the new stack by pushing the CS register (as 32-bits, high bits undefined), then pushing the 32-bit EIP register.
- 7. Load up the new CS:EIP value from the interrupt gate and begin execution of the interrupt routine in Protected Am386DXL Microprocessor Mode.

The transition out of Virtual 8086 Mode performs a level change and stack switch, in addition to changing back to Protected Mode. In addition, all of the 8086 segment register images are stored on the stack (behind the SS:ESP image), and then loaded with null (0) selectors before entering the interrupt handler. This will permit the handler to safely save and restore the DS, ES, FS, and GS registers as 80286 selectors. This is needed so that interrupt handlers that "don't care" about the mode of the interrupted program can use the same prolog and epilog code for state saving (i.e., push all registers in prolog, pop all in epilog) regardless of whether or not a native mode or Virtual 8086 Mode program was interrupted. Restoring null selectors to these registers before executing the IRET will not cause a trap in the interrupt handler. Interrupt routines that expect values in the segment registers or return values in segment registers will have to obtain/return values from the 8086 register images pushed onto the new stack. They will need to know the mode of the interrupted program in order to know where to find/return segment registers, and also to know how to interpret segment register values.

The IRET instruction will perform the inverse of the above sequence. Only the extended Am386DXL microprocessor IRET instruction (operand size = 32) can be used and must be executed at level 0 to change the VM bit to 1.

 If the NT bit in the FLAGS register is on, an inter-task return is performed. The current state is stored in the current TSS, and the link field in the current TSS is used to locate the TSS for the interrupted task which is to be resumed.

Otherwise, continue with the following sequence.

- 2. Read the FLAGS image from SS:8[ESP] into the FLAGS register. This will set VM to the value active in the interrupted routine.
- Pop off the instruction pointer CS:EIP. EIP is popped first, then a 32-bit word is popped that contains the CS value in the lower 16 bits. If VM = 0, this CS load is done as a Protected Mode segment load. If VM = 1, this will be done as an 8086 segment load.
- 4. Increment the ESP register by 4 to bypass the FLAGS image which was popped in step 1.
- If VM=1, load segment registers ES, DS, FS, and GS from memory locations SS:[ESP+8], SS:[ESP+12], SS:[ESP+16], and SS:[ESP+20],

respectively, where the new value of ESP stored in step 4 is used. Since VM = 1, these are done as 8086 segment register loads.

Else if VM = 0, check that the selectors in ES, DS, FS, and GS are valid in the interrupted routine. Null out invalid selectors to trap if an attempt is made to access through them.

 If (RPL(CS) > CPL), pop the stack pointer SS:ESP from the stack. The ESP register is popped first, followed by 32-bits containing SS in the lower 16 bits. If VM = 0, SS is loaded as a Protected Mode segment register load. If VM = 1, an 8086 segment register load is used.

 Resume execution of the interrupted routine. The VM bit in the FLAGS register (restored from the interrupt routine's stack image in step 1) determines whether the processor resumes the interrupted routine in Protected Mode of Virtual 8086 Mode.



8086 Application makes "Open File Call" → causes General Protection Fault (Arrow #1) Virtual 8086 Monitor intercepts call. Calls Am386DXL CPU OS (Arrow #2) Am386DXL CPU OS "Opens File" returns control to 8086 OS (Arrow #3) 8086 OS returns control to application (Arrow #4) Transparent to Application

15021B--043

#### Figure 40. Virtual 8086 Environment Interrupt and Call Handling

# FUNCTIONAL DATA Introduction

The Am386DXL microprocessor features a straight forward functional interface to the external hardware. The Am386DXL CPU has separate parallel buses for data and address. The data bus is 32 bits in width and bi-directional. The address bus outputs 32-bit address values in the most directly usable form for the highspeed local bus: 4 individual Byte Enable signals and the 30 upper-order bits as a binary value. The data and address buses are interpreted and controlled with their associated control signals.

A dynamic data bus sizing feature allows the processor to handle a mix of 32- and 16-bit external buses on a cycle-by-cycle basis (see Data Bus Sizing). If 16-bit bus size is selected, the Am386DXL microprocessor automatically makes any adjustment needed even performing another 16-bit bus cycle to complete the transfer if that is necessary. Any 8-bit peripheral devices may be connected to 32- or 16-bit buses with no loss of performance. A new address pipelining option is provided and applies to 32- and 16-bit buses for substantially improved memory utilization, especially for the most heavily used memory resources.

The address pipelining option, when selected, typically allows a given memory interface to operate with one less wait state than would otherwise be required (see Address Pipelining). The pipelined bus is also well suited to interleaved memory designs. When address pipelining is requested by the external hardware, the Am386DXL microprocessor will output the address and bus cycle definition of the next bus cycle (if it is internally available) even while waiting for the current cycle to be acknowledged.

Non-pipelined address timing, however, is ideal for external cache designs, since the cache memory will typically be fast enough to allow non-pipelined cycles. For maximum design flexibility, the address pipelining option is selectable on a cycle-by-cycle basis.

The processor's bus cycle is the basic mechanism for information transfer, either from system to processor or from processor to system. Am386DXL microprocessor bus cycles perform data transfer in a minimum of only two clock periods. On a 32-bit data bus, the maximum Am386DXL device transfer at 20-MHz band-width is therefore 40 Mb/s, at 25-MHz bandwidth is 50 Mb/s, at 33-MHz bandwidth is 66 Mb/s, and at 40-MHz bandwidth is 80 Mb/s. Any bus cycle will be extended for more than two clock periods, however, if external hardware withholds acknowledgment of the cycle. At the appropriate time, acknowledgment is signaled by asserting the Am386DXL microprocessor READY input.

The Am386DXL CPU can relinquish control of its local buses to allow mastership by other devices, such as

direct memory access channels. When relinquished, HLDA is the only output pin driven by the Am386DXL microprocessor providing near-complete isolation of the processor from its system. The near-complete isolation characteristic is ideal when driving the system from test equipment and in fault-tolerant applications.

Functional data covered in this section describes the processor's hardware interface. First, the set of signals available at the processor pins is described (see Signal Description). Following that are the signal waveforms occurring during bus cycles (see Bus Transfer Mechanism, Bus Functional Description, and Other Functional Descriptions).

# **Signal Description**

# Introduction

Ahead is a brief description of the Am386DXL CPU input and output signals arranged by functional groups.

Example signal:

M/IO—High voltage indicates Memory selected —Low voltage indicates I/O selected

The signal descriptions sometimes refer to AC timing parameters, such as t25 RESET Setup Time and t26 RESET Hold Time.

# Clock (CLK2)

CLK2 provides the fundamental timing for the Am386DXL microprocessor. It is divided by two internally to generate the internal processor clock used for instruction execution. The internal clock is comprised of two phases, phase one and phase two. Each CLK2 period is a phase of the internal clock. Figure 42 illustrates the relationship. If desired, the phase of the internal processor clock can be synchronized to a known phase by ensuring the RESET signal falling edge meets its applicable setup and hold times, t25 and t26.

# Data Bus (D31–D0)

These three-state, bi-directional signals provide the general purpose data path between the Am386DXL microprocessor and other devices. Data bus inputs and outputs indicate 1 when High. The data bus can transfer data on 32- and 16-bit buses using a data bus sizing feature controlled by the BS16 input. See Section Bus Control. Data bus reads require that read data setup and hold times, t21 and t22, be met for correct operation. In addition, the Am386DXL microprocessor requires that all data bus pins be at a valid logic state (High or Low) at the end of each read cycle, when READY is asserted. During any write operation (and during halt cycles and









shut down cycles), the Am386DXL microprocessor always drives all 32 signals of the data bus even if the current bus size is 16 bits.

# Address Bus (BE3-BE0, A31-A2)

These three-state outputs provide physical memory addresses or I/O port addresses. The address bus is capable of addressing 4 Gb of physical memory space (0000000H–FFFFFFH), and 64 Kb of I/O address space (0000000H–0000FFFH) for programmed I/O. I/O transfers automatically generated for Am386DXL microprocessor-to-coprocessor communication use I/O addresses 800000F8H–800000FFH, so A31 is High in conjunction with M/IO Low allows simple generation of the coprocessor select signal.

The Byte Enable outputs, BE3–BE0, directly indicate which bytes of the 32-bit data bus are involved with the current transfer. This is most convenient for external hardware.

BE0applies to D7–D0BE1applies to D15–D8BE2applies to D23–D16BE3applies to D31–D24

The number of Byte Enables asserted indicates the physical size of the operand being transferred (1, 2, 3, or 4 bytes). Refer to Section Operand Alignment.

When a memory write cycle or I/O write cycle is in progress and the operand being transferred occupies only the upper 16 bits of the data bus (D31–D16), duplicate data is simultaneously presented on the corresponding lower 16 bits of the data bus (D15–D0). This duplication is performed for optimum write performance on 16 bit buses. The pattern of write data duplication is a function of the Byte Enables asserted during the write cycle. Table 13 lists the write data present on D31–D0, as a function of the asserted Byte Enable outputs  $\overline{BE3}$ – $\overline{BE0}$ .

# Bus Cycle Definition Signals (W/ $\overline{R}$ , D/ $\overline{C}$ , M/ $\overline{IO}$ , LOCK)

These three-state outputs define the type of bus cycle being performed. W/ $\overline{R}$  distinguishes between write and read cycles. D/ $\overline{C}$  distinguishes between data and control cycles. M/ $\overline{IO}$  distinguishes between memory and I/O cycles. LOCK distinguishes between locked and unlocked bus cycles.

The primary bus cycle definition signals are  $W/\overline{R}$ ,  $D/\overline{C}$ , and  $M/\overline{IO}$ , since these are the signals driven valid as the  $\overline{ADS}$  (Address Status output) is driven asserted. The  $\overline{LOCK}$  is driven valid at the same time as the first locked bus cycle begins, which due to address pipelining, could be later than  $\overline{ADS}$  is driven asserted. See Pipelined Address. The  $\overline{LOCK}$  is negated when the  $\overline{READY}$  input terminates the last bus cycle that was locked.

Exact bus cycle definitions, as a function of  $W/\overline{R}$ ,  $D/\overline{C}$ , and  $M/\overline{IO}$ , are given in Table14. Note one combination of  $W/\overline{R}$ ,  $D/\overline{C}$ , and  $M/\overline{IO}$  is never given when  $\overline{ADS}$  is asserted (however, that combination, which is listed as does not occur, may occur during idle bus states when  $\overline{ADS}$  is not asserted). If  $M/\overline{IO}$ ,  $D/\overline{C}$ , and  $W/\overline{R}$  are qualified by  $\overline{ADS}$  asserted, then a decoding scheme may be simplified by using this definition of the does not occur combination.

| Am   | 386DXL C        | PU Byte E | nables  | A       | Automatic |       |              |     |
|------|-----------------|-----------|---------|---------|-----------|-------|--------------|-----|
| BE3  | BE3 BE2 BE1 BE0 |           | D31-D24 | D23–D16 | D15–D8    | D7D0  | Duplication? |     |
| High | High            | High      | Low     | Undef   | Undef     | Undef | A            | No  |
| High | High            | Low       | High    | Undef   | Undef     | B     | Undef        | No  |
| High | Low             | High      | High    | Undef   | C         | Undef | C            | Yes |
| Low  | High            | High      | High    | D       | Undef     | D     | Undef        | Yes |
| High | High            | Low       | Low     | Undef   | Undef     | B     | A            | No  |
| High | Low             | Low       | High    | Undef   | C         | B     | Undef        | No  |
| Low  | Low             | High      | High    | D       | C         | D     | C            | Yes |
| High | Low             | Low       | Low     | Undef   | с         | B     | A            | No  |
| Low  | Low             | Low       | High    | D       | с         | B     | Undef        | No  |
| Low  | Low             | Low       | Low     | D       | С         | В     | Α            | No  |

Table 13. Write Data Duplication as a Function of  $\overline{\text{BE3}}-\overline{\text{BE0}}$ 

Key: D = Logical Write Data D31–D24 C = Logical Write Data D23–D16 B = Logical Write Data D15-D8 A = Logical Write Data D7-D0

| M/ĪŌ | D/Ĉ  | W/R  | Bus Cycle Type                                                                             | Locked?     |
|------|------|------|--------------------------------------------------------------------------------------------|-------------|
| Low  | Low  | Low  | Interrupt Acknowledge                                                                      | Yes         |
| Low  | Low  | High | Does Not Occur                                                                             |             |
| Low  | High | Low  | I/O Data Read                                                                              | No          |
| Low  | High | High | I/O Data Write                                                                             | No          |
| High | Low  | Low  | Memory Code Read                                                                           | No          |
| High | Low  | High | Halt:Shutdown:Address = 2Address = 0BE0HighBE0BE1HighBE1BE2LowBE2BE3HighBE3A31-A2LowA31-A2 | No          |
| High | High | Low  | Memory Data Read                                                                           | Some Cycles |
| High | High | High | Memory Data Write                                                                          | Some Cycles |

#### Table 14. Bus Cycle Definition

# Bus Control Signals (ADS, READY, NA, BS16)

# Introduction

The following signals allow the processor to indicate when bus cycle has begun and allow other system hardware to control address pipelining, data bus width, and bus cycle termination.

# Address Status (ADS)

This three-state output indicates that a valid bus cycle definition and address (W/ $\overline{R}$ , D/ $\overline{C}$ , M/ $\overline{IO}$ ,  $\overline{BE3}$ – $\overline{BE0}$ , and A31–A2) is being driven at the Am386DXL microprocessor pins. It is asserted during T1 and T2P bus states (see Non-pipelined Address and Pipelined Address for additional information on bus states).

#### Transfer Acknowledge (READY)

This input indicates the current bus cycle is complete, and the active bytes indicated by BE3–BE0 and BS16 are accepted or provided. When READY is sampled asserted during a read cycle or interrupt acknowledge cycle, the Am386DXL microprocessor latches the input data and terminates the cycle. When READY is sampled asserted during a write cycle, the processor terminates the bus cycle.

READY is ignored on the first bus state of all bus cycles, and sampled each bus state thereafter until asserted. READY must eventually be asserted to acknowledge every bus cycle, including Halt Indication and Shutdown Indication bus cycles. When being sampled, READY must always meet setup and hold times, t19 and t20, for correct operation. See all sections of Bus Functional Description.

# Next Address Request (NA)

This is used to request address pipelining. This input indicates the system is prepared to accept new values of  $\overline{BE3}$ – $\overline{BE0}$ , A31–A2, W/R, D/C, and M/IO from the Am386DXL microprocessor even if the end of the

current cycle is not being acknowledged on READY. If this input is asserted when sampled, the next address is driven onto the bus provided the next bus request is already pending internally. See Address Pipelining and Read and Write Cycles. NA must always meet setup and hold times, t15 and t16, for correct operation.

# Bus Size 16 (BS16)

The BS16 feature allows the Am386DXL microprocessor to directly connect to 32- and 16-bit data buses. Asserting this input constrains the current bus cycle to use only the lower-order half (D15–D0) of the data bus, corresponding to BE0 and BE1. Asserting BS16 has no additional effect if only BE0 and/or BE1 are asserted in the current cycle. However, during bus cycles asserting BE2 or BE3, asserting BS16 will automatically cause the Am386DXL microprocessor to make adjustments for correct transfer of the upper byte(s) using only physical data signals D15–D0.

If the operand spans both halves of the data bus and BS16 is asserted, the Am386DXL microprocessor will automatically perform another 16-bit bus cycle. BS16 must always meet setup and hold times, t17 and t18, for correct operation.

Am386DXL CPU I/O cycles are automatically generated for coprocessor communication. Since the Am386DXL microprocessor must transfer 32-bit quantities between itself and a 387DX math coprocessor, BS16 must not be asserted during 387DX math coprocessor communication cycles.

# **Bus Arbitration Signals (HOLD, HLDA)**

# Introduction

This section describes the mechanism by which the processor relinquishes control of its local buses when requested by another bus master device. See Entering and Exiting Hold Acknowledge for additional information.

### Bus Hold Request (HOLD)

This input indicates some device other than the Am386DXL microprocessor requires bus mastership.

HOLD must remain asserted as long as any other device is a local bus master. HOLD is not recognized while RESET is asserted. If RESET is asserted while HOLD is asserted, RESET has priority and places the bus into an idle state, rather than the hold acknowledge (high impedance) state. HOLD is level-sensitive and is a synchronous input. HOLD signals must always meet setup and hold times, t23 and t24, for correct operation.

#### Bus Hold Acknowledge (HLDA)

Assertion of this output indicates the Am386DXL microprocessor has relinquished control of its local bus in response to HOLD asserted, and is in the Bus Hold Acknowledge state.

The Hold Acknowledge state offers near-complete signal isolation. In the Hold Acknowledge state, HLDA is the only signal being driven by the Am386DXL microprocessor. The other output signals or bi-directional signals (D31–D0, BE3–BE0, A31–A2, W/R, D/C, M/IO, LOCK, and ADS) are in a high-impedance state so the requesting bus master may control them. Pullup resistors may be desired on several signals to avoid spurious activity when no bus master is driving them. See Resistor Recommendations. Also, one rising edge occurring on the NMI input during Hold Acknowledge is remembered for processing after the HOLD input is negated.

In addition to the normal usage of Hold Acknowledge with DMA controllers or master peripherals, the nearcomplete isolation has particular attractiveness during system test when test equipment drives the system and in hardware-fault-tolerant applications.

# Coprocessor Interface Signals (PEREQ, BUSY, ERROR)

# Introduction

In the following sections are descriptions of signals dedicated to the numeric coprocessor interface. In addition to the data bus, address bus, and bus cycle definition signals, these following signals control communication between the Am386DXL microprocessor and its 387DX math coprocessor extension.

#### Coprocessor Request (PEREQ)

When asserted, this input signal indicates a coprocessor request for a data operand to be transferred to/from memory by the Am386DXL microprocessor. In response, the Am386DXL CPU transfers information between the coprocessor and memory. Because Am386DXL microprocessor has internally stored the coprocessor op-code being executed, it performs the requested data transfer with the correct direction and memory address. PEREQ is level-sensitive and is allowed to be asynchronous to the CLK2 signal.

# Coprocessor Busy (BUSY)

When asserted, this input indicates the coprocessor is still executing an instruction and is not yet able to accept another. When the Am386DXL microprocessor encounters any coprocessor instruction that operates on the numeric stack (e.g., load, pop, or arithmetic operation) or the WAIT instruction, this input is first automatically sampled until it is seen to be negated. This sampling of the BUSY input prevents overrunning the execution of a previous coprocessor instruction.

The FNINIT and FNCLEX coprocessor instructions are allowed to execute even if  $\overline{\text{BUSY}}$  is asserted, since these instructions are used for coprocessor initialization and exception-clearing.

BUSY is level-sensitive and is allowed to be asynchronous to the CLK2 signal.

BUSY serves an additional function. If BUSY is sampled Low at the falling edge of RESET, the Am386DXL microprocessor performs an internal self-test (see Bus Activity During and Following Reset). If BUSY is sampled High, no self-test is performed.

# Coprocessor Error (ERROR)

This input signal indicates that the previous coprocessor instruction generated a coprocessor error of a type not masked by the coprocessor's control register. This input is automatically sampled by the Am386DXL microprocessor when a coprocessor instruction is encountered, and if asserted, the Am386DXL device generates Exception 16 to access the error-handling software.

Several coprocessor instructions, generally those that clear the numeric error flags in the coprocessor or save coprocessor state, do execute without the Am386DXL microprocessor generating Exception 16 even if ERROR is asserted. These instructions are FNINIT, FNCLEX, FSTSW, FSTSWAX, FSTCW, FSTENV, FSAVE, FESTENV, and FESAVE.

ERROR is level-sensitive and is allowed to be asynchronous to the CLK2 signal.

# Interrupt Signals (INTR, NMI, RESET)

# Introduction

The following descriptions cover inputs that can interrupt or suspend execution of the processor's current instruction stream.

#### Maskable Interrupt Request (INTR)

When asserted, this input indicates a request for interrupt service, which can be masked by the Am386DXL CPU Flag Register IF bit. When the Am386DXL microprocessor responds to the INTR input, it performs two interrupt acknowledge bus cycles, and at the end of the second, latches an 8-bit interrupt vector on D17–D0 to identify the source of the interrupt. INTR is level-sensitive and is allowed to be asynchronous to the CLK2 signal. To assure recognition of an INTR request, INTR should remain asserted until the first interrupt acknowledge bus cycle begins.

#### Non-Maskable Interrupt Request (NMI)

This input indicates a request for interrupt service, which cannot be masked by software. The non-maskable interrupt request is always processed according to the pointer or gate in slot 2 of the interrupt table. Because of the fixed NMI slot assignment, no interrupt acknowledge cycles are performed when processing NMI.

NMI is rising edge-sensitive and is allowed to be asynchronous to the CLK2 signal. To assure recognition of NMI, it must be negated for at least eight CLK2 periods, and then be asserted for at least eight CLK2 periods.

Once NMI processing has begun, no additional NMI's are processed until after the next IRET instruction, which is typically the end of the NMI service routine. If NMI is re-asserted prior to that time, however, one rising edge on NMI will be remembered for processing after executing the next IRET instruction.

#### Reset (RESET)

This input signal suspends any operation in progress and places the Am386DXL microprocessor in a known reset state. The Am386DXL device is reset by asserting RESET for 15 or more CLK2 periods (80 or more CLK2 periods before requesting self-test). When RESET is asserted, all other input pins, except FLT, are ignored, and all other bus pins are driven to an idle bus state as shown in Table 15. If RESET and HOLD are both asserted at a point in time, RESET takes priority even if the Am386DXL device was in a Hold Acknowledge state prior to RESET asserted.

RESET is level-sensitive and must be synchronous to the CLK2 signal. If desired, the phase of the internal processor clock and the entire Am386DXL microprocessor state can be completely synchronized to external circuitry by ensuring the RESET signal falling edge meets its applicable setup and hold times, t25 and t26.

# Table 15. Pin State (Idle Bus) During Reset

| Pin Name | Signal Level During Reset |
|----------|---------------------------|
| ADS      | High                      |
| D31–D0   | High Impedance            |
| BE3-BE0  | Low                       |
| A31–A2   | High                      |
| ₩/R      | Low                       |
| D/C      | High                      |
| M/ĪŌ     | Low                       |
| LOCK     | High                      |
| HLDA     | Low                       |
|          | 1                         |

| Signal<br>Name   | Function                    | Active<br>State | Input/<br>Output | Input Synch<br>or Asynch to<br>CLK2 | Output High<br>Impedance During<br>HLDA? |
|------------------|-----------------------------|-----------------|------------------|-------------------------------------|------------------------------------------|
| CLK2             | Clock                       |                 | I                |                                     |                                          |
| D31–D0           | Data Bus                    | High            | I/O              | S                                   | Yes                                      |
| BE3-BE0          | Byte Enables                | Low             | 0                |                                     | Yes                                      |
| A31–A2           | Address Bus                 | High            | 0                |                                     | Yes                                      |
| W/R              | Write-Read Indication       | High            | 0                | —                                   | Yes                                      |
| D/C              | Data-Control Indication     | High            | 0                | -                                   | Yes                                      |
| M/ <del>IO</del> | Memory-I/O Indication       | High            | 0                | —                                   | Yes                                      |
| LOCK             | Bus Lock Indication         | Low             | 0                | —                                   | Yes                                      |
| ADS              | Address Status              | Low             | 0                | _                                   | Yes                                      |
| NA               | Next Address Request        | Low             | 1                | S                                   | —                                        |
| BS16             | Bus Size 16                 | Low             | 1                | S                                   |                                          |
| READY            | Transfer Acknowledge        | Low             | 1                | S                                   | -                                        |
| HOLD             | Bus Hold Request            | High            | I                | S                                   |                                          |
| HLDA             | Bus Hold Acknowledge        | High            | 0                | _                                   | No                                       |
| PEREQ            | Coprocessor Request         | High            | 1                | A                                   | _                                        |
| BUSY             | Coprocessor Busy            | Low             | 1                | A                                   | _                                        |
| ERROR            | Coprocessor Error           | Low             | 1                | A                                   | -                                        |
| INTR             | Maskable Interrupt Request  | High            | 1                | A                                   |                                          |
| NMI              | Non-Maskable Intrpt Request | High            |                  | A                                   | -                                        |
| RESET            | Reset                       | High            | 1                | S                                   | _                                        |
|                  |                             |                 |                  |                                     |                                          |

# Table 16. Am386DXL Microprocessor Signal Summary

# **Bus Transfer Mechanism**

#### Introduction

All data transfers occur as a result of one or more bus cycles. Logical data operands of byte, word, and double-word lengths may be transferred without restrictions on physical address alignment. Any byte boundary may be used, although two or even three physical bus cycles are performed as required for unaligned operand transfers. See Dynamic Data Bus Sizing and Operand Alignment.

The Am386DXL microprocessor address signals are designed to simplify external system hardware. Higherorder address bits are provided by A31–A2. Lowerorder address in the form of BE3–BE0 directly provides linear selects for the four bytes of the 32-bit data bus. Physical operand size information is thereby implicitly provided each bus cycle in the most usable form.

Byte Enable outputs,  $\overline{BE3}$ – $\overline{BE0}$ , are asserted when their associated data bus bytes are involved with the present bus cycle, as listed in Table 17. During a bus cycle, any possible pattern of contiguous asserted Byte Enable outputs can occur, but never patterns having a negated Byte Enable separating two or three asserted Enables.

Address bits A0 and A1 of the physical operand's base address can be created when necessary (for instance,

for MULTIBUS I or MULTIBUS II interface), as a function of the lowest-order asserted Byte Enable. This is shown by Table 18. Logic to generate A0 and A1 is given by Figure 43.

| Table 17. Byte | Enables and | Associated |
|----------------|-------------|------------|
| Data an        | d Operand E | 3ytes      |

| Byte Enable Signal | Associated Data Bus Signals       |  |  |  |  |  |
|--------------------|-----------------------------------|--|--|--|--|--|
| BEO                | D7–D0 (Byte 0—least significant)  |  |  |  |  |  |
| BE1                | D15–D8 (Byte 1)                   |  |  |  |  |  |
| BE2                | D23–D16 (Byte 2)                  |  |  |  |  |  |
| BE3                | D31–D24 (Byte 3—most significant) |  |  |  |  |  |
|                    |                                   |  |  |  |  |  |

Each bus cycle is composed of at least two bus states. Each bus state requires one processor clock period. Additional bus states added to a single bus cycle are called wait states. See Bus Functional Description.

Since a bus cycle requires a minimum of two bus states (equal to two processor clock periods), data can be transferred between external devices and the Am386DXL CPU at a maximum rate of one 4-byte Dword every two processor clock periods, for a maximum bus bandwidth of 80 Mb/s (Am386DXL microprocessor operating at 40-MHz processor clock rate).

A0



15021B-046

#### Figure 43. Logic to Generate A0, A1 from BE3-BE0

| Am386DXL CPU Address Signals |                          |    |    |     |     |      |      |      |  |  |  |
|------------------------------|--------------------------|----|----|-----|-----|------|------|------|--|--|--|
| A31                          | •••••                    | 2  |    | BE3 | BE2 | BE1  | BE0  |      |  |  |  |
|                              | Physical Base<br>Address |    |    |     |     |      |      |      |  |  |  |
| A31                          |                          | A2 | A1 | A0  |     |      |      |      |  |  |  |
| A31                          |                          | A2 | 0  | 0   | x   | x    | x    | Low  |  |  |  |
| A31                          | •••••                    | A2 | 0  | 1   | ×   | x    | Low  | High |  |  |  |
| A31                          |                          | A2 | 1  | 0   | x   | Low  | High | High |  |  |  |
| A31                          |                          | A2 | 1  | 1   | Low | High | High | High |  |  |  |

Table 18. Generating A31–A0 from BE3–BE0 and A31–A2



Note: Since A31 is High during automatic communication with coprocessor, A31 High and M/IO Low can be used to easily generate a coprocessor select signal.

15021B-047

Figure 44. Physical Memory and I/O Spaces

Am386DXL Microprocessor

#### Memory and I/O Spaces

Bus cycles may access physical memory space or I/O space. Peripheral devices in the system may either be memory-mapped, or I/O-mapped, or both. As shown in Figure 44, physical memory addresses range from 0000000H to FFFFFFH (4 Gb) and I/O addresses from 0000000H to 0000FFFH (64 Kb) for programmed I/O. Note the I/O addresses used by the automatic I/O cycles for coprocessor communication are 800000F8H to 800000FFH, beyond the address range of programmed I/O, to allow easy generation of a coprocessor chip select signal using the A31 and M/IO signals.

#### Memory and I/O Organization

The Am386DXL microprocessor datapath to memory and I/O spaces can be 32- or 16-bits wide. When 32-bits wide, memory and I/O spaces are organized naturally as arrays of physical 32-bit Dwords. Each memory or I/O Dword has four individually addressable bytes at consecutive byte addresses. The lowest-addressed byte is associated with data signals D17–D0; the highestaddressed byte with D31–D24.

The Am386DXL microprocessor includes a bus control input, BS16, that also allows direct connection to 16-bit memory or I/O spaces organized as a sequence of 16-bit word. Cycles to 32- and 16-bit memory or I/O devices may occur in any sequence, since the BS16 control is sampled during each bus cycle. (See Dynamic Data Bus Sizing.) The Byte Enable signals, BE3–BE0, allow byte granularity when addressing any memory or I/O structure, whether 32- or 16-bits wide.

#### **Dynamic Data Bus Sizing**

Dynamic Data Bus Sizing is a feature allowing direct processor connection to 32- or 16-bit data buses for memory or I/O. A single processor may connect to both size buses. Transfers to or from 32- or 16-bit ports are supported by dynamically determining the bus width during each bus cycle. During each bus cycle an address decoding circuit or the slave device itself may assert BS16 for 16-bit ports, or negate BS16 for 32-bit ports.

With BS16 asserted, the processor automatically converts operand transfers larger than 16 bits, or misaligned 16-bit transfers, into two or three transfers as required. All operand transfers physically occur on D15–D0 when BS16 is asserted. Therefore, 16-bit memories or I/O devices only connect on data signals D15–D0. No extra transceivers are required.

Asserting  $\overline{BS16}$  only affects the processor when  $\overline{BE2}$  and/or  $\overline{BE3}$  are asserted during the current cycle. If only D15–D0 are involved with the transfer, asserting  $\overline{BS16}$  has no affect since the transfer can proceed normally over a 16-bit bus whether  $\overline{BS16}$  is asserted or not. In other words, asserting  $\overline{BS16}$  has no effect when only the lower half of the bus is involved with the current cycle.

There are two types of situations where the processor is affected by asserting  $\overline{BS16}$ , depending on which Byte Enables are asserted during the current bus cycle.

# Upper Half Only:

Only BE2 and/or BE3 asserted.

Upper and Lower Half:

At least  $\overline{BE1}$ ,  $\overline{BE2}$  asserted (and perhaps also  $\overline{BE0}$  and/or  $\overline{BE3}$ ).

Effect of asserting BS16 during Upper Half Only read cycles:

Asserting BS16 during Upper Half Only reads causes the Am386DXL microprocessor to read data on the lower 16 bits of the data bus and ignore data on the upper 16 bits of the data bus. Data that would have been read from D31–D16 (as indicated by BE2 and BE3) will instead be read from D15–D0, respectively.

Effect of asserting BS16 during Upper Half Only write cycles:

Asserting  $\overline{BS16}$  during Upper Half Only writes does not affect the Am386DXL microprocessor. When only  $\overline{BE2}$ and/or  $\overline{BE3}$  are asserted during a Write cycle, the Am386DXL microprocessor always duplicates data signals D31–D16 onto D15–D0 (see Table 13). Therefore, no further Am386DXL CPU action is required to perform these writes on 32- or 16-bit buses.

Effect of asserting BS16 during Upper and Lower Half read cycles:

Asserting BS16 during Upper and Lower Half reads causes the processor to perform two 16-bit read cycles for complete physical operand transfer. Bytes 0 and 1 (as indicated by BE0 and BE1) are read on the first cycle using D15–D0. Bytes 2 and 3 (as indicated by BE2 and BE3) are read during the second cycle, again using D15–D0. D31–D16 are ignored during both 16-bit cycles. BE0 and BE1 are always negated during the second 16-bit cycle. See Figure 54 Cycles 2 and 2a.

Effect of asserting BS16 during Upper and Lower Half write cycles:

Asserting BS16 during Upper and Lower Half writes causes the Am386DXL microprocessor to perform two 16-bit write cycles for complete physical operand transfer. All bytes are available the first write cycle allowing external hardware to receive Bytes 0 and 1 (as indicated by BE0 and BE1) using D15–D0. On the second cycle the Am386DXL microprocessor duplicates Bytes 2 and 3 on D15–D0 and Bytes 2 and 3 (as indicated by BE2 and BE3) are written using D15–D0. BE0 and BE1 are always negated during the second 16-bit cycle. See Figure 54 Cycles 1 and 1a.

# Interfacing with 32- and 16-Bit Memories

In 32-bit-wide physical memories such as Figure 45, each physical Dword begins at a byte address that is a multiple of 4. A31–A2 are directly used as a Dword selects and  $\overline{BE3}$ – $\overline{BE0}$  as byte selects.  $\overline{BS16}$  is negated for all bus cycles involving the 32-bit array.

When 16-bit-wide physical arrays are included in the system, as in Figure 46, each 16-bit physical word begins at an address that is a multiple of 2. Note the address is decoded to assert  $\overline{BS16}$  only during bus cycles involving the 16-bit array. If desiring to use pipelined address with 16-bit memories, then  $\overline{BE3}$ - $\overline{BE0}$  and W/R are also decoded to determine when  $\overline{BS16}$  should be

asserted. (See Pipelined Address with Dynamic Data Bus Sizing.)

A31–A2 are directly usable for addressing 32- and 16-bit devices. To address 16-bit devices, A1 and two Byte Enable signals are also needed.

To generate an A1 signal and two Byte Enable signals for 16-bit access,  $\overline{BE3}$ - $\overline{BE0}$  should be decoded as in Table 19. Note certain combinations of  $\overline{BE3}$ - $\overline{BE0}$  are never generated by the Am386DXL microprocessor, leading to don't care conditions in the decoder. Any  $\overline{BE3}$ - $\overline{BE0}$ decoder, such as shown in Figure 47, may use the nonoccurring  $\overline{BE3}$ - $\overline{BE0}$  combinations to its best advantage.



#### Figure 45. Am386DXL Microprocessor with 32-Bit Memory

15021B-048



15021B-049

#### Figure 46. Am386DXL Microprocessor with 32-Bit and 16-Bit Memory

| Am  | 386DXL | . CPU Si | gnals      | 16-Bit Bus Signals |     | Signals  | Comments               |
|-----|--------|----------|------------|--------------------|-----|----------|------------------------|
| BE3 | BE2    | BE1      | <b>BEO</b> | A1                 | BHE | BLE (A0) | Commenta               |
| H.  | H⁺     | H.       | н⁺         | х                  | х   | х        | Xno active bytes       |
| н   | н      | н        | L          | L                  | н   | L        |                        |
| н   | н      | L        | н          | L                  | L   | н        |                        |
| н   | н      | L        | L          | L                  | L   | L        |                        |
| н   | L      | н        | н          | н                  | н   | L        |                        |
| H*  | Ľ      | н•       | Ľ          | х                  | х   | x        | X—not contiguous bytes |
| Н   | L      | L        | н          | L                  | L   | н        |                        |
| н   | L      | L        | L          | L                  | L   | L        |                        |
| L   | н      | н        | н          | н                  | L   | н        |                        |
| L*  | H*     | H*       | L*         | х                  | х   | х        | X—not contiguous bytes |
| L*  | H*     | L*       | H*         | х                  | Х   | Х        | X—not contiguous bytes |
| L*  | н∙     | L        | L.         | х                  | х   | Х        | X—not contiguous bytes |
| L   | L      | н        | н          | н                  | L   | L        |                        |
| L*  | L*     | H•       | L*         | х                  | х   | Х        | X—not contiguous bytes |
| L   | L      | L        | н          | L                  | L   | н        |                        |
| L   | L      | L        | L          | L                  | L   | L        |                        |
|     |        |          |            |                    |     |          |                        |
|     |        |          |            |                    |     |          |                        |

Table 19. Generating A1, BHE and BLE for Addressing 16-Bit Devices

BLE asserted when D7-D0 of 16-bit bus is active.

BHE asserted when D15-D8 of 16-bit bus is active.

A1 Low for all even words; A1 High for all odd words.

Key: X = Don't care

H = High voltage level

L = Low voltage level

\* = A non-occurring pattern of Byte Enables; either none are asserted or the pattern has Byte Enables asserted for non-contiguous bytes.

# **Operand Alignment**

With the flexibility of memory addressing on the Am386DXL microprocessor, it is possible to transfer a logical operand that spans more than one physical Dword or Word of memory or I/O. Examples are 32-bit Dword operands beginning at addresses not evenly divisible by 4- or a 16-bit Word operand split between two physical Dwords of memory array.

Operand alignment and data bus size dictates when multiple bus cycles are required. Table 20 describes the transfer cycles generated for all combinations of logical operand lengths, alignment, and data bus sizing. When multiple bus cycles are required to transfer a multi-byte logical operand, the highest-order bytes are transferred first (but if BS16 asserted requires two 16-bit cycles be performed, that part of the transfer is lowest-order first).

# **Bus Functional Description**

#### Introduction

The Am386DXL microprocessor has separate, parallel buses for data and address. The data bus is 32 bits in width and bi-directional. The address bus provides a 32-bit value using 30 signals for the 30 upper-order address bits and 4 Byte Enable signals to directly indicate the active bytes. These buses are interpreted and controlled via several associated definition or control signals.

The definition of each bus cycle is given by three definition signals:  $M/\overline{O}$ ,  $W/\overline{R}$ , and  $D/\overline{C}$ . At the same time, a valid address is present on the Byte Enable signals  $\overline{BE3}$ – $\overline{BE0}$  and other address signals, A31–A2. A status signal,  $\overline{ADS}$ , indicates when the Am386DXL CPU issues a new bus cycle definition and address.

Collectively, the address bus, data bus, and all associated control signals are referred to simply as the bus.

When active, the bus performs one of the bus cycles below.

- 1. Read from memory space.
- 2. Locked read from memory space.
- 3. Write to memory space.
- 4. Locked write to memory space.
- 5. Read from I/O space (or coprocessor).
- 6. Write to I/O space (or coprocessor).
- 7. Interrupt acknowledge.
- 8. Indicate halt or indicate shutdown.

Table 14 shows the encoding of the bus cycle definition signals for each bus cycle. See Section Bus Cycle Definition.

The data bus has a dynamic sizing feature supporting 32- and 16-bit bus size. Data bus size is indicated to the Am386DXL microprocessor using its Bus Size 16 (BS16) input. All bus functions can be performed with either data bus size.

÷.





K -- Map for A1 Signal (same as Figure 43)





K – Map for 16-bit BHE signal



K - Map for 16-bit BLE signal (same as A0 signal in Figure 43).

15021B-050

BLE (or A0)

Figure 47. Logic to Generate A1, BHE and BLE for 16-Bit Buses

|                                                                                                                                                                                                                                                        | Table 20. Transfer Bus Cycles for Bytes, words, and Dwords |                                |            |           |    |            |           |            |           |            |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|--------------------------------|------------|-----------|----|------------|-----------|------------|-----------|------------|--|
|                                                                                                                                                                                                                                                        |                                                            | Byte-Length of Logical Operand |            |           |    |            |           |            |           |            |  |
|                                                                                                                                                                                                                                                        |                                                            | 1 2 4                          |            |           |    |            |           |            |           |            |  |
|                                                                                                                                                                                                                                                        | Physical Byte Addres<br>in Memory (low-order bits)         | xx                             | 00         | 01        | 10 | 11         | 00        | 01         | 10        | 11         |  |
|                                                                                                                                                                                                                                                        | Transfer Cycles over<br>32-Bit Data Bus                    | b                              | w          | w         | w  | hb,*<br>Ib | d         | hd<br>I3   | hw,<br>Iw | h3,<br>Ib  |  |
|                                                                                                                                                                                                                                                        | Transfer Cycles over<br>16-Bit Data Bus                    | b                              | w          | lb,<br>hb | w  | hb,<br>Ib  | lw,<br>hw | hb,<br>lb, | hw,<br>Iw | mw,<br>hb, |  |
|                                                                                                                                                                                                                                                        |                                                            |                                |            |           |    |            |           | mw         |           | lb         |  |
| Key:     b = Byte transfer     3 = 3-byte transfer       w = Word transfer     d = Dword transfer       l = low-order portion     h = high-order portion       m = mid-order portion     x = Don't care       = BS16 asserted causes second bus cycle. |                                                            |                                |            |           |    |            |           |            |           |            |  |
| *For this case, 8                                                                                                                                                                                                                                      | 086, 8088, 80186, 80188, 8028                              | 6 transf                       | er Ib firs | t, then h | b. |            |           |            |           |            |  |

# Table 20. Transfer Bus Cycles for Bytes, Words, and Dwords



Figure 48. Fastest Read Cycles with Non-Pipelined Address Timing

When the Am386DXL CPU bus is not performing one of the activities listed above, it is either Idle or in the Hold Acknowledge state, which may be detected by external circuitry. The Idle state can be identified by the Am386DXL microprocessor giving no further assertions on its address strobe output (ADS) since the beginning of its most recent bus cycle, and the most recent bus cycle has been terminated. The Hold Acknowledge state is identified by the Am386DXL CPU asserting its Hold Acknowledge (HLDA) output.

The shortest time unit of bus activity is a bus state. A bus state is one processor clock period (two CLK2 periods) in duration. A complete data transfer occurs during a bus cycle, composed of two or more bus states.

The fastest Am386DXL microprocessor bus cycle requires only two bus states. For example, three consecutive bus read cycles, each consisting of two bus states, are shown by Figure 48. The bus states in each cycle are named T1 and T2. Any memory or I/O address may be accessed by such a two-state bus cycle, if the external hardware is fast enough. The high-bandwidth, twoclock bus cycle realizes the full potential of fast main memory, or cache memory.

Every bus cycle continues until it is acknowledged by the external system hardware, using the Am386DXL microprocessor READY input. Acknowledging the bus cycle at the end of the first T2 results in the shortest bus cycle, requiring only T1 and T2. If READY is not immediately asserted, however, T2 states are repeated indefinitely until the READY input is sampled asserted.

# Address Pipelining

The address pipelining option provides a choice of bus cycle timings. Pipelined or non-pipelined address timing is selectable on a cycle-by-cycle basis with the Next Address (NA) input.

When address pipelining is not selected, the current address and bus cycle definition remain stable throughout the bus cycle.

When address pipelining is selected, the address ( $\overline{BE3}$ - $\overline{BE0}$ , A31-A2) and definition (W/ $\overline{R}$ , D/ $\overline{C}$ , and M/ $\overline{O}$ ) of the next cycle are available before the end of the current cycle. To signal their availability, the Am386DXL microprocessor address status output ( $\overline{ADS}$ ) is also asserted. Figure 49 illustrates the fastest read cycles with pipelined address timing.

Note from Figure 49, the fastest bus cycles using pipelined address require only two bus states, named T1P and T2P. Therefore, cycles with pipelined address timing allow the same data bandwidth as non-pipelined cycles, but address-to-data access time is increased compared to that of a non-pipelined cycle.



Figure 49. Fastest Read Cycles with Pipelined Address Timing

15021B-052

By increasing the address-to-data access time, pipelined address timing reduces wait state requirements. For example, if one wait state is required with non-pipelined address timing, no wait states would be required with pipelined address.

Pipelined address timing is useful in typical systems having address latches. In those systems, once an address has been latched, pipelined availability of the next address allows decoding circuitry to generate chip selects (and other necessary select signals) in advance. so selected devices are accessed immediately when the next cycle begins. In other words, the decode time for the next cycle can be overlapped with the end of the current cycle.

If a system contains a memory structure of two or more interleaved memory banks, pipelined address timing potentially allows even more overlap of activity. This is true when the interleaved memory controller is designed to allow the next memory operation to begin in one memory bank while the current bus cycle is still activating another memory bank. Figure 50 shows the general structure of the Am386DXL microprocessor with twobank and four-bank interleaved memory. Note each memory bank of the interleaved memory has full data bus width (32-bit data width typically, unless 16-bit bus size is selected).

Further details of pipelined address timing are given in Pipelined Address: Initiating and Maintaining Pipelined Address: Pipelined Address with Dynamic Bus Sizing: and, Maximum Pipelined Address Usage With 16-bit Bus Size.

# **Read and Write Cycles**

#### Introduction

Data transfers occur as a result of bus cycles, classified as Read or Write cycles. During Read cycles, data is transferred from an external device to the processor. During Write cycles, data is transferred in the other direction, from the processor to an external device.

Two choices of address timing are dynamically selectable: non-pipelined or pipelined. After a bus idle state, the processor always uses non-pipelined address timing. However, the NA (Next Address) input may be asserted to select pipelined address timing for the next bus cycle. When pipelining is selected and the Am386DXL microprocessor has a bus request pending internally, the address and definition of the next cycle is made available even before the current bus cycle is acknowledged by READY. Generally, the NA input is sampled each bus cycle to select the desired address timing for the next bus cycle.

Two-Bank Interleaved Memory:

- a. Address signal A2 selects bank
- b. 32-bit datapath to each bank



Four-Bank Interleaved Memory:

- a. Address signals A3 and A2 selects bank
- b. 32-bit datapath to each bank



15021B-053

Figure 50. Two-Bank and Four-Bank Interleaved Memory Structure

Two choices of physical data bus width are dynamically selectable: 32 bits or 16 bits. Generally, the BS16 (Bus Size 16) input is sampled near the end of the bus cycle to confirm the physical data bus size applicable to the current cycle. Negation of BS16 indicates a 32-bit size and assertion indicates a 16-bit bus size.

If 16-bit bus size is indicated, the Am386DXL CPU automatically responds as required to complete the transfer on a 16-bit data bus. Depending on the size and alignment of the operand, another 16-bit bus cycle may be required. Table 19 provides all details. When necessary, the Am386DXL microprocessor performs an additional 16-bit bus cycle, using D15–D0 in place of D31–D16.

Terminating a Read cycle or Write cycle, like any bus cycle, requires acknowledging the cycle by asserting the READY input. Until acknowledged, the processor inserts wait states into the bus cycle to allow adjustment for the speed of any external device. External hardware, that has decoded the address and bus cycle type asserts the READY input at the appropriate time.

At the end of the second bus state within the bus cycle, READY is sampled. At that time, if external hardware acknowledges the bus cycle by asserting READY, the bus cycle terminates as shown in Figure 51. If READY is negated as in Figure 52, the cycle continues another bus state (a wait state) and READY is sampled again at the end of that state. This continues indefinitely until the cycle is acknowledged by READY asserted.

When the current cycle is acknowledged, the Am386DXL microprocessor terminates it. When a Read cycle is acknowledged, the Am386DXL CPU latches the information present at its data pins. When a Write cycle is acknowledged, the Am386DXL CPU write data remains valid throughout phase one of the next bus state to provide write data hold time.



Note: Idle states are shown here for diagram variety only. Write cycles are not always followed by an idle state. An active bus cycle can immediately follow the write cycle.

15021B-054

# Figure 51. Various Bus Cycles and Idle States with Non-Pipelined Address (Zero Wait States)

#### Non-Pipelined Address

Any bus cycle may be performed with non-pipelined address timing. For example, Figure 51 shows a mixture of Read and Write cycles with non-pipelined address timing. Figure 51 shows that the fastest possible cycles with non-pipelined address have two bus states per bus cycle. The states are named T1 and T2. In phase one of the T1, the address signals and bus cycle definition signals are driven valid, and to signal their availability, address status (ADS) is simultaneously asserted. During Read or Write cycles, the data bus behaves as follows. If the cycle is a read, the Am386DXL microprocessor floats its data signals to allow driving by the external device being addressed. The Am386DXL device requires that all data bus pins be at a valid logic state (High or Low) at the end of each read cycle, when READY is asserted, even if all byte enables are not asserted. The system **must** be designed to meet this requirement. If the cycle is a write, data signals are driven by the Am386DXL device beginning in phase two of T1

until phase one of the bus state following cycle acknowledgment.

Figure 52 illustrates non-pipelined bus cycles with one wait added to Cycles 2 and 3.  $\overrightarrow{\mathsf{READY}}$  is sampled negated at the end of the first T2 in Cycles 2 and 3. Therefore, Cycles 2 and 3 have T2 repeated. At the end of the second T2,  $\overrightarrow{\mathsf{READY}}$  is sampled asserted.

When address pipelining is not used, the address and bus cycle definition remain valid during all wait states.

When wait states are added and you desire to maintain non-pipelined address timing, it is necessary to negate NA during each T2 state except the last one, as shown in Figure 52 Cycles 2 and 3. If NA is sampled asserted during a T2 other than the last one, the next state would be T21 (for pipelined address) or T2P (for pipelined address) instead of another T2 (for non-pipelined address).



Note: Idle states are shown here for diagram variety only. Write cycles are not always followed by an idle state. An active bus cycle can immediately follow the Write cycle.

15021B-055

Figure 52. Various Bus Cycles and Idle States with Non-Pipelined Address (Various Number of Wait States)



T1 --- First clock of a non-pipelined bus cycle (Am386DXL microprocessor drives new address and asserts ADS).

T2— Subsequent clocks of a bus cycle when NA has not been sampled asserted in the current bus cycle.

Ti - Idle state

Th-Hold Acknowledge state (Am386DXL microprocessor asserts HLDA).

15022B-017

The fastest bus cycle consists of two states: T1 and T2.

Four basic bus states describe bus operation when not using pipelined address. These states do include BS16 usage for 32-bit and 16-bit bus size. If asserting BS16 requires second 16-bit bus cycle to be performed, it is performed before HOLD asserted acknowledged.

#### Figure 53, Bus States (Not Using Pipelined Address)

Figure 53 illustrates the bus states and transitions when address pipelining is not used. The bus transitions between four possible states: T1, T2, Ti, and Th. Bus cycles consist of T1 and T2, with T2 being repeated for wait states. Otherwise, the bus may be idle in the Ti state, or in hold acknowledge, the Th state.

When address pipelining is not used, the bus state diagram is as shown in Figure 53. When the bus is idle, it is in state Ti. Bus cycles always begin with T1. T1 always leads to T2. If a bus cycle is not acknowledged during T2 and NA is negated, T2 is repeated. When a cycle is acknowledged during T2, the following state will be T1 of the next bus cycle if a bus request is pending internally, or Ti if there is no bus request pending, or Th if the HOLD input is being asserted.

The bus state diagram in Figure 53 also applies to the use of BS16. If the Am386DXL microprocessor makes internal adjustments for 16-bit bus size, the adjustments do not affect the external bus states. If an additional 16-bit bus cycle is required to complete a transfer on a 16-bit bus, it also follows the state transitions shown in Figure 53.

Use of pipelined address allows the Am386DXL CPU to enter three additional bus states not shown in Figure 53. Figure 59 in Pipelined Address is the complete bus state diagram, including pipelined address cycles.

#### Non-Pipelined Address With Dynamic Data Bus Sizing

The physical data bus width for any non-pipelined bus cycle can be either 32 or 16 bits. At the beginning of the bus cycle, the processor behaves as if the data bus is 32-bits wide. When the bus cycle is acknowledged by asserting READY at the end of a T2 state, the most recent sampling of BS16 determines the data bus size for the cycle being acknowledged. If BS16 was most recently negated, the physical data bus size is defined as 32 bits. If BS16 was most recently asserted, the size is defined as 16 bits.

When BS16 is asserted and two 16-bit bus cycles are required to complete the transfer, BS16 must be asserted during the second cycle; 16-bit bus size is not assumed. Like any bus cycle, the second 16-bit cycle must be acknowledged by asserting READY.



15021B-057

# Figure 54. Asserting BS16 (Zero-Wait-States, Non-Pipelined Address)



15021B-058

## Figure 55. Asserting BS16 (One-Wait-State, Non-Pipelined Address)

When a second 16-bit bus cycle is required to complete the transfer over a 16-bit bus, the addresses generated for the two 16-bit bus cycles are closely related to each other. The addresses are the same, except  $\overline{BE0}$  and  $\overline{BE1}$  are always negated for the second cycle. This is because data on D15–D0 was already transferred during the first 16-bit cycle.

Figures 54 and 55 show cases where assertion of  $\overline{BS16}$  requires a second 16-bit cycle for complete operand transfer. Figure 54 illustrates cycles without wait states. Figure 55 illustrates cycles with one wait state. In Figure 55 Cycle 1, the bus cycle during which  $\overline{BS16}$  is asserted, note that  $\overline{NA}$  must be negated in the T2 state(s) prior to the last T2 state. This is to allow the recognition of  $\overline{BS16}$  asserted in the final T2 state. The relation of  $\overline{NA}$  and  $\overline{BS16}$  is given fully in Pipelined Address, but Figure 55 illustrates this only precaution you need to know when using  $\overline{BS16}$  with non-pipelined address.

## **Pipelined Address**

Address pipelining is the option of requesting the address and the bus cycle definition of the next internally pending bus cycle before the current bus cycle is acknowledged with READY asserted. ADS is asserted by the Am386DXL microprocessor when the next address is issued. The address pipelining option is controlled on a cycle-by-cycle basis with the NA input signal.

Once a bus cycle is in progress and the current address has been valid for at least one entire bus state, the  $\overline{NA}$  input is sampled at the end of every phase one until the bus cycle is acknowledged. During non-pipelined bus cycles, therefore,  $\overline{NA}$  is sampled at the end of phase one in every T2. An example is Cycle 2 in Figure 56, during which  $\overline{NA}$  is sampled at the end of phase one of every T2 (it was asserted once during the first T2 and has no further effect during that bus cycle).

If NA is sampled asserted, the Am386DXL microprocessor is free to drive the address and bus cycle definition of the next bus cycle, and assert ADS, as soon as it has a bus request internally pending. It may drive the next address as early as the next bus state, whether the current bus cycle is acknowledged at that time or not.

Regarding the details of address pipelining, the Am386DXL CPU has the following characteristics.

 For NA to be sampled asserted, BS16 must be negated at the sampling window (see Figure 56 Cycles 2 through 4, and Figure 57 Cycles 1 through 4). If NA and BS16 are both sampled asserted during the last T2 period of a bus cycle,  $\overline{BS16}$  asserted has priority. Therefore, if both are asserted, the current bus size is taken to be 16 bits and the next address is not pipelined.

- 2. The next address may appear as early as the bus state after NA was sampled asserted (see Figure 56 or 57). In that case, state T2P is entered immediately, However, when there is not an internal bus request already pending, the next address will not be available immediately after NA is asserted and T2I is entered instead of T2P (see Figure 58 Cycle 3). Provided the current bus cycle is not yet acknowledged by READY asserted, T2P will be entered as soon as the Am386DXL microprocessor does drive the next address. External hardware should therefore observe the ADS output as confirmation the next address is actually being driven on the bus.
- 3. Once NA is sampled asserted, the Am386DXL microprocessor commits itself to the highest priority bus request that is pending internally. It can no longer perform another 16-bit transfer to the same address should BS16 be asserted externally, so thereafter must assume the current bus size is 32 bits. Therefore, if NA is sampled asserted within a bus cycle, BS16 must be negated thereafter in that bus cycle (see Figures 56, 57, 58). Consequently, do not assert NA during bus cycles that must have BS16 driven asserted. See Dynamic Bus Sizing with Pipelined Address.
- 4. Any address which is validated by a pulse on the Am386DXL CPU ADS output will remain stable on the address pins for at least two processor clock periods. The Am386DXL microprocessor can not produce a new address more frequently than every two processor clock periods (see Figures 56, 57, 58).
- Only the address and bus cycle definition of the very next bus cycle is available. The pipelining capability cannot look further than one bus cycle ahead (see Figure 58 Cycle 1).

The complete bus state transition diagram, including operation with pipelined address is given by Figure 59. Note it is a superset of the diagram for non-pipelined address only and the three additional bus states for pipelined address are drawn in bold.

The fastest bus cycle with pipelined address consists of just two bus states, T1P and T2P (recall for non-pipelined address it is T1 and T2). T1P is the first bus state of a pipelined cycle.



Note: Following any idle bus state (Ti), addresses are non-pipelined. Within non-pipelined bus cycles, NA is only sampled during wait states. Therefore, to begin address pipelining during a group of non-pipelined bus cycles requires a non-pipelined cycle with at least one wait state (Cycle 2 above).

15021B-059

## Figure 56. Transitioning to Pipelined Address During Burst of Bus Cycles

# 



Note: Following any idle bus state (Ti) the address is always non-pipelined and NA is only sampled during wait states. To start address pipelining after an idle state requires a non-pipelined cycle with at least one wait state (Cycle 1 above). The pipelined cycles (2, 3, 4 above) are shown with various numbers of wait states.

15021B-060

#### Figure 57. Fastest Transition to Pipelined Address Following Idle Bus State

# Initiating and Maintaining Pipelined Address

Using the state diagram Figure 59, observe the transitions from an idle state, Ti, to the beginning of a pipelined bus cycle, T1P. From an idle state Ti, the first bus cycle must begin with T1, and is therefore a nonpipelined bus cycle. The next bus cycle will be pipelined, however, provided  $\overline{NA}$  is asserted and the first bus cycle ends in a T2P state (the address for the next bus cycle is driven during T2P). The fastest path from an idle state to a bus cycle with pipelined address is shown in below:

| Ti, Ti, Ti | T1-T2-T2P     | T1P-T2P   |
|------------|---------------|-----------|
| Idle       | Non-Pipelined | Pipelined |
| States     | Cycle         | Cycle     |

T1-T2-T2P are the states of the bus cycle that establishes address pipelining for the next bus cycle, which begins with T1P. The same is true after a bus hold state, shown below:

| Th, Th, Th                    | T1-T2-T2P              | T1P-T2P            |
|-------------------------------|------------------------|--------------------|
| Hold<br>Acknowledge<br>States | Non-Pipelined<br>Cycle | Pipelined<br>Cycle |

The transition to pipelined address is shown functionally by Figure 57 Cycle 1. Note that Cycle 1 is used to transition into pipelined address timing for the subsequent Cycles 2, 3, and 4 that are pipelined. The  $\overline{NA}$  input is asserted at the appropriate time to select address pipelining for Cycles 2, 3, and 4.

Once a bus cycle is in progress and the current address has become valid, the NA input is sampled at the end of every phase one, beginning with the next bus state, until the bus cycle is acknowledged. During Figure 57 Cycle 1 therefore, sampling begins in T2. Once NA is sampled asserted during the current cycle, the Am386DXL microprocessor is free to drive a new address and bus cycle definition on the bus as early as the next bus state. In Figure 56 Cycle 1 for example, the next address is driven during state T2P. Thus, Cycle 1 makes the transition to pipelined address timing, since it begins with T1 but ends with T2P. Because the address for Cycle 2 is available before Cycle 2 begins, Cycle 2 is called a pipelined bus cycle, and it begins with T1P. Cycle 2 begins as soon as READY asserted terminates Cycle 1.

Example transition bus cycles are Figure 57 Cycle 1 and Figure 56 Cycle 2. Figure 57 shows transition during the very first cycle after an idle bus state, which is the fastest possible transition into address pipelining. Figure 56 Cycle 2, shows a transition cycle occurring during a burst of bus cycles. In any case, a transition cycle is the same whenever it occurs: it consists at least of T1, T2 (you assert NA at that time), and T2P (provided the Am386DXL microprocessor has an internal bus request already pending, which it almost always has). T2P states are repeated if wait states are added to the cycle.

Note three states (T1, T2, and T2P) are only required in a bus cycle performing a transition from non-pipelined address into pipelined address timing; for example, Figure 57 Cycle 1. Figure 57 Cycles 2, 3, and 4 show that address pipelining can be maintained with two-state bus cycles consisting only of T1P and T2P.

Once a pipelined bus cycle is in progress, pipelined timing is maintained for the next cycle by asserting NA and detecting that the Am386DXL CPU enters T2P during the current bus cycle. The current bus cycle must end in state T2P for pipelining to be maintained in the next cycle. T2P is identified by the assertion of  $\overline{ADS}$ . Figures 56 and 57 however, show pipelining ending after Cycle 4, because Cycle 4 ends in T2P. This indicates the Am386DXL CPU did not have an internal bus request prior to the acknowledgment of Cycle 4. If a cycle ends with a T2 or T2I, the next cycle will not be pipelined.

Realistically, address pipelining is almost always maintained as long as NA is sampled asserted. This is so, because in the absence of any other request a code prefetch request is always internally pending until the instruction decoder and code prefetch queue are completely full. Therefore, address pipelining is maintained for long bursts of bus cycles, if the bus is available (i.e., HOLD negated) and NA is sampled asserted in each of the bus cycles.

# 



15021B-061

#### Figure 58. Details of Address Pipelining During Cycles with Wait States



Using pipelined address, the fastest bus cycle consists of T1P and T2P.

15021B-062

#### Figure 59. Am386DXL Microprocessor Complete Bus States (Including Pipelined Address)

#### Pipelined Address With Dynamic Data Bus Sizing

The BS16 feature allows easy interface to 16-bit data buses. When asserted, the Am386DXL microprocessor bus interface hardware performs appropriate action to make the transfer using a 16-bit data bus connected on D15–D0.

There is a degree of interaction, however, between the use of Address Pipelining and the use of Bus Size 16. The interaction results from the multiple bus cycles required when transferring 32-bit operands over a 16-bit bus. If the operand requires both 16-bit halves of the 32-bit bus, the appropriate Am386DXL microprocessor action is a second bus cycle to complete the operand's transfer. It is this necessity that conflicts with NA usage.

When  $\overline{\text{NA}}$  is sampled asserted, the Am386DXL microprocessor commits itself to perform the next internally pending bus request, and is allowed to drive the next internally pending address onto the bus. Asserting  $\overline{\text{NA}}$ therefore makes it impossible for the next bus cycle to again access the current address on A31–A2, such as may be required when  $\overline{\text{BS16}}$  is asserted by the external hardware.

To avoid conflict, the Am386DXL microprocessor is designed with following two provisions.

- 1. To avoid conflict,  $\overline{BS16}$  must be negated in the current bus cycle if  $\overline{NA}$  has already been sampled asserted in the current cycle. If  $\overline{NA}$  is sampled asserted, the current data bus size is assumed to be 32 bits.
- Also to avoid conflict, if NA and BS16 are both asserted during the same sampling window, BS16 asserted has priority and the Am386DXL microprocessor acts as if NA was negated at that time.

Certain types of 16- or 8-bit operands require no adjustment for correct transfer on a 16-bit bus. Those are read or write operands using only the lower half of the data bus, and write operands using only the upper half of the bus, since the Am386DXL CPU simultaneously duplicates the write data on the lower half of the data bus. For these patterns of Byte Enables and the W/R signals,  $\overline{BS16}$  need not be asserted at the Am386DXL CPU allowing  $\overline{NA}$  to be asserted during the bus cycle if desired.

#### Interrupt Acknowledge (INTA) Cycles

In response to an interrupt request on the INTR input when interrupts are enabled, the Am386DXL microprocessor performs two interrupt acknowledge cycles. These bus cycles are similar to read cycles in that bus definition signals define the type of bus activity taking place, and each cycle continues until acknowledged by READY sampled asserted. The state of A2 distinguishes the first and second interrupt acknowledge cycles. The byte address driven during the first interrupt acknowledge cycle is 4 (A31–A3 Low, A2 High,  $\overline{BE3}$ – $\overline{BE1}$  High, and  $\overline{BE0}$  Low). The address driven during the second interrupt acknowledge cycle is 0 (A31–A2 Low,  $\overline{BE3}$ – $\overline{BE1}$  High,  $\overline{BE0}$  Low).

The LOCK output is asserted from the beginning of the first interrupt acknowledge cycle until the end of the second interrupt acknowledge cycle. Four idle bus states, Ti, are inserted by the Am386DXL microprocessor between the two interrupt acknowledge cycles, allowing for compatibility with spec TRHRL of the 8259A Interrupt Controller.

During both interrupt acknowledge cycles, D31–D0 float. No data is read at the end of the first interrupt acknowledge cycle. At the end of the second interrupt acknowledge cycle, the Am386DXL microprocessor will read an external interrupt vector from D7–D0 of the data bus. The vector indicates the specific interrupt number (from 0–255) requiring service.

#### Halt Indication Cycle

The Am386DXL microprocessor halts as a result of executing a HALT instruction. Signaling its entrance into the halt state, a halt indication cycle is performed. The halt indication cycle is identified by the state of the bus definition signals shown in Bus cycle Definition and a byte address of 2.  $\overline{BE0}$  and  $\overline{BE2}$  are the only signals distinguishing halt indication from shutdown indication, that drives an address of 0. During the halt cycle undefined data is driven on D31–D0. The halt indication cycle must be acknowledged by  $\overline{READY}$  asserted.

A halted Am386DXL CPU resumes execution when INTR (if interrupts are enabled) or NMI or RESET is asserted.

#### **Shutdown Indication Cycle**

The Am386DXL microprocessor shuts down as a result of a protection fault while attempting to process a double fault. Signaling its entrance into the shutdown state, a shutdown indication cycle is performed. The shutdown indication cycle is identified by the state of the bus definition signals shown in Bus Cycle Definition and a byte address of 0. BE0 and BE2 are the only signals distinguishing shutdown indication from halt indication, which drives an address of 2. During the shutdown cycle undefined data is driven on D31–D0. The shutdown indication cycle must be acknowledged by READY

A shutdown Am386DXL microprocessor resumes execution when NMI or RESET is asserted.



Key: Dn = Physical data pin n dn = Logical data pin n

Cycle 1 is pipelined. Cycle 1A cannot be pipelined, but its address can be inferred from that of Cycle 1, to externally simulate address pipelining during Cycle 1A.

15021B-063

Figure 60. Using NA and BS16



Interrupt Vector (0-255) is read on D7-D0 at end of second Interrupt Acknowledge bus cycle. Because each Interrupt Acknowledge bus cycle is followed by idle bus states, asserting NA has no practical effect. Choose the approach that is simplest for your system hardware design.

15021B-064

Figure 61. Interrupt Acknowledge Cycles



15021B--065

Figure 62. Halt Indication Cycle



15021B-066

Figure 63. Shutdown Indication Cycle

# Other Functional Descriptions Entering and Exiting Hold Acknowledge

The Bus Hold Acknowledge State, Th, is entered in response to the HOLD input being asserted. In the Bus Hold Acknowledge state, the Am386DXL microprocessor floats all output or bi-directional signals, except for HLDA. HLDA is asserted as long as the Am386DXL

CPU remains in the bus hold acknowledge state. In the Bus Hold Acknowledge state, all inputs except HOLD, FLT, RESET, BUSY, ERROR, and PEREQ are ignored (also up to one rising edge on NMI is remembered for processing when HOLD is no longer asserted).



Note: For maximum design flexibility the Am386DXL CPU has no internal pullup resistors on its outputs. Your design may require an external pullup on ADS and other Am386DXL CPU outputs to keep them negated during float periods.

15021B-067

Figure 64. Requesting Hold from Idle Bus

Th may be entered from a bus idle state, as in Figure 64, or after the acknowledgment of the current physical bus cycle if the LOCK signal is not asserted, as in Figures 65 and 66. If HOLD is asserted during a locked bus cycle, the Am386DXL microprocessor may execute one unlocked bus cycle before acknowledging HOLD. If asserting BS16 requires a second 16-bit bus cycle to complete a physical operand transfer, it is performed before HOLD is acknowledged, although the bus state diagrams in Figures 53 and 59 do not indicate that detail.

Th is exited in response to the HOLD input being negated. The following state will be Ti as in Figure 64 if no bus request is pending. The following bus state will be T1 if a bus request is internally pending, as in Figures 65 and 66.

Th is also exited in response to RESET being asserted.

If a rising edge occurs on the edge-triggered NMI input while in Th, the event is remembered as a non-maskable interrupt 2 and is serviced when Th is exited, unless of course, the Am386DXL microprocessor is reset before Th is exited.

#### **RESET During HOLD Acknowledge**

RESET being asserted takes priority over HOLD being asserted. Therefore, Th is exited in response to the RESET input being asserted. If RESET is asserted while HOLD remains asserted, the Am386DXL microprocessor drives its pins to defined states during reset, as in Table 15 Pin State During RESET, and performs internal reset activity as usual.

If HOLD remains asserted when RESET is negated, the Am386DXL microprocessor enters the hold acknowledge state before performing its first bus cycle, provided HOLD is still asserted when the Am386DXL microprocessor would otherwise perform its first bus cycle. If HOLD remains asserted when RESET is negated, the BUSY input is still sampled as usual to determine whether a self test is being requested, and ERROR is still sampled as usual to determine whether a 387DX math coprocessor versus an 80287 (or none) is present.

#### Float

Activating the  $\overline{FLT}$  input floats all Am386DXL CPU bi-directional and output signals, including HLDA. Asserting  $\overline{FLT}$  isolates the Am386DXL CPU from the surrounding circuitry.

As the Am386DXL microprocessor is packaged in a surface mount PQFP, it cannot be removed from the motherboard when In-Circuit Emulation (ICE) is needed. The FLT input allows the Am386DXL CPU to be electrically isolated from the surrounding circuitry. This allows connection of an emulator to the Am386DXL microprocessor PQFP without removing it from the PCB. This method of emulation is referred to as ON-Circuit Emulation (ONCE).

# **Entering and Exiting Float**

FLT is an asynchronous, active Low input. It is recognized on the rising edge of CLK2. When recognized, it aborts the current bus cycle and floats the outputs of the Am386DXL microprocessor (Figure 68). FLT must be held Low for a minimum of 16-CLK2 cycles. Reset should be asserted and held asserted until after FLT is deasserted. This will ensure that the Am386DXL CPU will exit Float in a valid state.

Asserting the FLT input unconditionally aborts the current bus cycle and forces the Am386DXL microprocessor into the Float mode. Since activating FLT unconditionally forces the Am386DXL CPU into Float mode, the Am386DXL CPU is not guaranteed to enter Float in a valid state. After deactivating FLT, the Am386DXL CPU is not guaraneeted to exit Float mode in a valid state. This is not a problem, as the FLT pin is meant to be used only during ONCE. After exiting Float, the Am386DXL CPU must be reset to return it to a valid state. Reset should be asserted before FLT is deasserted. This will ensure that the Am386DXL CPU will exist Float in a valid state.

FLT has an internal pull-up resistor, and if it is not used it should be unconnected.

#### **Bus Activity During and Following Reset**

RESET is the highest priority input signal capable of interrupting any processor activity when it is asserted. A bus cycle in progress can be aborted at any stage; or idle states or bus hold acknowledge states discontinued so that the RESET state is established.

RESET should remain asserted for at least 15-CLK2 periods to ensure it is recognized throughout the Am386DXL microprocessor, and at least 80-CLK2 periods if Am386DXL device self-test is going to be requested at the falling edge. RESET asserted pulses less than 15-CLK2 periods may not be recognized. RESET pulses less than 80-CLK2 periods followed by a self-test may cause the self-test to report a failure when no true failure exists.

The additional RESET pulse width is required to clear additional state prior to valid self-test.

Provided the RESET falling edge meets setup and hold times, t25 and t26, the internal processor clock phase is defined at that time, as illustrated by Figure 67.

An Am386DXL microprocessor self-test may be requested at the time RESET is negated by having the BUSY input at a Low level, as shown in Figure 67. The self-test requires ( $2^{20}$ ) + approximately 60-CLK2 periods to complete. The self-test duration is not affected by the test results. Even if the self-test indicates a problem, the Am386DXL device attempts to proceed with the reset sequence afterward. After the RESET falling edge (and after the self-test if it was requested) the Am386DXL microprocessor performs an internal initialization sequence for approximately 350- to 450-CLK2 periods.

The Am386DXL microprocessor samples its ERROR input some time after the falling edge of RESET and before executing the first ESC instruction. During this sampling period BUSY must be High. If ERROR was sampled active, the Am386DXL device employs the 32-bit protocol of a 387DX math coprocessor. Even though this protocol was selected, it is still necessary to use a software recognition test to determine the presence or identity of the coprocessor and to assure compatibility with future processors.



Note: HOLD is a synchronous input and can be asserted at any CLK2 edge, provided setup and hold (t23 and t24) requirements are met. This waveform is useful for determining Hold Acknowledge latency.

15021B--068

#### Figure 65. Requesting Hold from Active Bus (NA Negated)



Note: HOLD is a synchronous input and can be asserted at any CLK2 edge, provided setup and hold (t23 and t24) requirements are met. This waveform is useful for determining Hold Acknowledge latency.

15021B-069



| Intel<br>i386<br>Stepping Name | Am386DXL<br>Microprocessor<br>Revision | ocessor Identifier Id |    |
|--------------------------------|----------------------------------------|-----------------------|----|
| Do                             | В                                      | 03                    | 05 |







Figure 67. Bus Activity from Reset Until First Code Fetch

15021B-070



15022B-029

Figure 68. Entering and Exiting FLT

# 

# Self-Test Signature

Upon completion of self-test, (if self-test was requested by holding BUSY Low at least eight CLK2 periods before and after the falling edge of RESET), the EAX register will contain a signature of 00000000h indicating the Am386DXL CPU passed its self-test of microcode and major PLA contents with no problems detected. The passing signature in EAX, 0000000h, applies to all Am386DXL microprocessor revision levels. Any nonzero signature indicates the Am386DXL CPU unit is faulty.

# **Component and Revision Identifiers**

To assist Am386DXL microprocessor users, the microprocessor after reset holds a component identifier and a revision identifier in its DX register. The upper 8 bits of DX hold 03h as identification of the Am386DXL CPU component. The lower 8 bits of DX hold an 8-bit unsigned binary number related to the component revision level. The revision identifier begins chronologically with a value zero and is subject to change (typically it will be incremented) with component steppings intended to have certain improvements or distinctions from previous steppings.

These features are intended to assist Am386DXL microprocessor users to a practical extent. However, the revision identifier value is not guaranteed to change with every stepping revision nor to follow a completely uniform numerical sequence, depending on the type or intention of revision or manufacturing materials required to be changed.

# **Coprocessor Interfacing**

The Am386DXL microprocessor provides an automatic interface for a 387DX floating-point math coprocessor. A 387DX math coprocessor uses an I/O-mapped interface driven automatically by the Am386DXL microprocessor and assisted by three dedicated signals: BUSY, ERROR, and PEREQ.

As the Am386DXL CPU begins supporting a coprocessor instruction, it tests the BUSY and ERROR signals to determine if the coprocessor can accept its next instruction. Thus, the BUSY and ERROR inputs eliminate the need for any preamble bus cycles for communication between processor and coprocessor. A 387DX math coprocessor can be given its command op-code immediately. The dedicated signals provide instruction synchronization, and eliminate the need of using the Am386DXL CPU WAIT op-code (9Bh) for 387DX math coprocessor instruction synchronization (the WAIT opcode was required when 8086 or 8088 was used with the 8087 coprocessor).

Custom coprocessors can be included in Am386DXL microprocessor based systems, via memory-mapped or I/O-mapped interfaces. Such coprocessor interfaces allow a completely custom protocol, and are not limited to a set of coprocessor protocol primitives. Instead, memory-mapped or I/O-mapped interfaces may use all applicable Am386DXL microprocessor instructions for highspeed coprocessor communication. The BUSY and ERROR inputs of the Am386DXL CPU may also be used for the custom coprocessor interface, if such hardware assist is desired. These signals can be tested by the Am386DXL CPU WAIT op-code (9Bh). The WAIT instruction will wait until the BUSY input is negated (interruptable by an NMI or enable INTR input), but generates an Exception 16 fault if the ERROR pin is in the asserted state when the BUSY goes (or is) negated. If the custom coprocessor interface is memory-mapped, protection of the addresses used for the interface can be provided with the Am386DXL microprocessor on-chip paging or segmentation mechanisms. If the custom interface is I/ O-mapped, protection of the interface can be provided with the Am386DXL microprocessor IOPL (I/O Privilege Level) mechanism.

A 387DX math coprocessor interface is I/O mapped as shown in Table 22. Note that a 387DX math coprocessor interface addresses are beyond the 0hFFFFh range for programmed I/O. When the Am386DXL CPU supports a 387DX math coprocessor, the Am386DXL microprocessor automatically generates bus cycles to the coprocessor interface addresses.

| Address in Am386DXL<br>CPU I/O Space | 387DX<br>Coprocessor Register     |
|--------------------------------------|-----------------------------------|
| 800000F8h                            | Opcode Register<br>(32-bit port)  |
| 800000FCh                            | Operand Register<br>(32-bit port) |

# Table 22. Math Coprocessor Port Addresses

To correctly map a 387DX math coprocessor registers to the appropriate I/O addresses, connect a 387DX math coprocessor CMD0 pin directly to the A2 output of the Am386DXL microprocessor.

# Software Testing for Coprocessor Presence

When software is used to test for coprocessor (387DX) presence, it should use only the following coprocessor op-codes: FINIT, FNINIT, FSTCW mem, FSTSW AX. To use other coprocessor op-codes when a coprocessor is known to be not present, first set EM = 1 in Am386DXL microprocessor CR0.

# **ABSOLUTE MAXIMUM RATINGS**

Storage Temperature ..... -65°C to +150°C Ambient Temperature Under Bias . . -65°C to +125°C Supply Voltage with Respect 

Voltage on Other Pins ..... -0.5 V to Vcc +0.5 V

Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to Absolute Maximum Ratings for extended periods may affect device reliabilitv.

# DC CHARACTERISTICS over COMMERCIAL operating ranges

Vcc = 5 V ±5%; Tcase = 0°C to +85°C (PGA) Vcc = 5 V ±10%; Tcase = 0°C to +100°C (PQFP)

| Symbol            | Parameter<br>Description                                                                                                                        | Notes                                                                                            | Min                          | Max                                            | Unit                 |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|------------------------------|------------------------------------------------|----------------------|
| V <sub>IL</sub>   | Input Low Voltage                                                                                                                               | (Note 1)                                                                                         | -0.3                         | 0.8                                            | V                    |
| V <sub>iH</sub>   | Input High Voltage                                                                                                                              |                                                                                                  | 2.0                          | V <sub>cc</sub> + 0.3                          | V                    |
| V <sub>ILC</sub>  | CLK2 Input Low Voltage                                                                                                                          | (Note 1)                                                                                         | -0.3                         | 0.8                                            | V                    |
| V <sub>IHC</sub>  | CLK2 Input High Voltage<br>20 MHz<br>25, 33, and 40 MHz                                                                                         |                                                                                                  | V <sub>cc</sub> – 0.8<br>3.7 | V <sub>cc</sub> + 0.3<br>V <sub>cc</sub> + 0.3 | v<br>v               |
| V <sub>oL</sub>   | Output Low Voltage<br>I <sub>oL</sub> =4 mA: A31–A2, D31–D0<br>I <sub>oL</sub> =5 mA: BE3–BE0, W/R,<br>D/C, M/IO, LOCK, ADS, HLDA               |                                                                                                  |                              | 0.45<br>0.45                                   | v<br>v               |
| V <sub>oH</sub>   | Output High Voltage<br>I <sub>он</sub> = 1 mA: A31–A2, D31–D0<br>I <sub>он</sub> = 0.9 mA: <u>ВЕ3–ВЕ0,</u><br>W/R, D/C, M/Ю, LOCK,<br>ADS, HLDA |                                                                                                  | 2.4<br>2.4                   |                                                | v<br>v               |
| l <sub>u</sub>    | Input Leakage Current<br>(All pins except BS16, PEREQ,<br>BUSY, FLT and ERROR)                                                                  | $0 V \leq V_{iN} \leq V_{cc}$                                                                    |                              | ±15                                            | μA                   |
| I <sub>IH</sub>   | Input Leakage Current<br>(PEREQ Pin)                                                                                                            | V <sub>IH</sub> = 2.4 V<br>(Note 2)                                                              |                              | 200                                            | μA                   |
| l <sub>iL</sub>   | Input Leakage Current<br>(BS16, BUSY, FLT, and ERROR)                                                                                           | V <sub>iL</sub> = 0.45<br>(Note 3)                                                               |                              | -400                                           | μA                   |
| l <sub>LO</sub>   | Output Leakage Current                                                                                                                          | 0.45 V ≤ V <sub>out</sub> ≤ V <sub>cc</sub>                                                      |                              | ±15                                            | μΑ                   |
| l <sub>cc</sub>   | Supply Current<br>CLK2 = 40 MHz: with -20<br>CLK2 = 50 MHz: with -25<br>CLK2 = 66 MHz: with -33<br>CLK2 = 80 MHz: with -40                      | (Note 4)<br>$I_{cc}$ Typ = 165<br>$I_{cc}$ Typ = 210<br>$I_{cc}$ Typ = 275<br>$I_{cc}$ Typ = 330 |                              | 200<br>250<br>330<br>400                       | mA<br>mA<br>mA<br>mA |
| I <sub>CCSB</sub> | Standby Current                                                                                                                                 | I <sub>ccsa</sub> Typ = 0.02 mA<br>(Note 5)                                                      |                              | 150                                            | μΑ                   |
| C <sub>IN</sub>   | Input or I/O Capacitance                                                                                                                        | F <sub>c</sub> =1 MHz (Note 4)                                                                   |                              | 10                                             | pF                   |
| Cout              | Output Capacitance                                                                                                                              | F <sub>c</sub> = 1 MHz (Note 4)                                                                  |                              | 12                                             | pF                   |
| C <sub>CLK</sub>  | CLK2 Capacitance                                                                                                                                | F <sub>c</sub> =1 MHz (Note 4)                                                                   |                              | 20                                             | pF                   |

Notes: 1. The Min value, -0.3, is not 100% tested.

PEREQ input has an internal pulldown resistor.
 BS16, BUSY, FLT, and ERROR inputs each have an internal pullup resistor.

4. Not 100% tested.

5. Measurement taken with inputs at rails, outputs unloaded, BS16, BUSY, FLT, and ERROR at Vcc voltage level, PEREQ at Gnd.

 $V_{CC} = 5 V \pm 5\%$ ;  $T_{CASE} = 0^{\circ}C$  to  $+85^{\circ}C$ 

| No. | Parameter<br>Description        | Notes                          | Ref<br>Figure | 40 MHz<br>Min | 40 MHz<br>Max | Unit |
|-----|---------------------------------|--------------------------------|---------------|---------------|---------------|------|
|     | Operating Frequency             | Half of CLK2 Freq              |               | 0             | 40            | MHz  |
| 1   | CLK2 Period                     |                                | 71            | 12.5          |               | ns   |
| 2a  | CLK2 High Time                  | at 2 V                         | 71            | 5             |               | ns   |
| 2b  | CLK2 High Time                  | at 3.7 V                       | 71            | 3.25          |               | ns   |
| 3a  | CLK2 Low Time                   | at 2 V                         | 71            | 5             |               | ns   |
| Зb  | CLK2 Low Time                   | at 0.8 V                       | 71            | 3.25          |               | ns   |
| 4   | CLK2 Fall Time                  | 3.7 V to 0.8 V<br>(Note 3)     | 71            |               | 4             | ns   |
| 5   | CLK2 Rise Time                  | 0.8 V to 3.7 V<br>(Note 3)     | 71            |               | 4             | ns   |
| 6   | A31–A2 Valid Delay              | C <sub>L</sub> =50 pF          | 70, 73, 81    | 4             | 13            | ns   |
| 7   | A31–A2 Float Delay              | (Note 1)                       | 81            | 4             | 20            | ns   |
| 8   | BE3-BE0, LOCK Valid Delay       | C <sub>L</sub> =50 pF          | 70, 73, 81    | 4             | 13            | ns   |
| 9   | BE3-BE0, LOCK Float Delay       | (Note 1)                       | 81            | 4             | 20            | ns   |
| 10  | W/R, M/IO, D/C Valid Delay      | C <sub>L</sub> =50 pF          | 70, 73, 81    | 4             | 13            | ns   |
| 10a | ADS Valid Delay                 | C <sub>L</sub> =50 pF          | 70, 73, 81    | 4             | 13            | ns   |
| 11  | W/R, M/IO, D/C, ADS Float Delay | (Note 1)                       | 81            | 4             | 20            | ns   |
| 12  | D31–D0 Write Data Valid Delay   | C <sub>L</sub> =50 pF (Note 4) | 70, 74, 81    | 7             | 18            | ns   |
| 12a | D31–D0 Write Data Hold Time     | С <sub>L</sub> =50 рF          | 70, 75        | 2             |               | ns   |
| 13  | D31–D0 Float Delay              | (Note 1)                       | 81            | 4             | 17            | ns   |
| 14  | HLDA Valid Delay                | С <sub>L</sub> =50 рF          | 70, 81        | 4             | 17            | ns   |
| 15  | NA Setup Time                   |                                | 72            | 5             |               | ns   |
| 16  | NA Hold Time                    |                                | 72            | 2             |               | ns   |
| 17  | BS16 Setup Time                 |                                | 72            | 5             |               | ns   |
| 18  | BS16 Hold Time                  |                                | 72            | 2             |               | ns   |
| 19  | READY Setup Time                |                                | 72            | 7             |               | ns   |
| 20  | READY Hold Time                 |                                | 72            | 4             |               | ns   |
| 21  | D31–D0 Read Setup Time          |                                | 72            | 4             |               | ns   |
| 22  | D31–D0 Read Hold Time           |                                | 72            | 3             |               | ns   |
| 23  | HOLD Setup Time                 |                                | 72            | 4             |               | ns   |
| 24  | HOLD Hold Time                  |                                | 72            | 2             |               | ns   |
| 25  | RESET Setup Time                |                                | 82            | 4             |               | ns   |
| 26  | RESET Hold Time                 |                                | 82            | 2             | 1             | ns   |
| 27  | NMI, INTR Setup Time            | (Note 2)                       | 72            | 5             | 1             | ns   |
| 28  | NMI, INTR Hold Time             | (Note 2)                       | 72            | 5             | 1             | ns   |
| 29  | PEREQ, ERROR, BUSY Setup Time   | (Note 2)                       | 72            | 5             | 1             | ns   |
| 30  | PEREQ, ERROR, BUSY Hold Time    | (Note 2)                       | 72            | 4             |               | ns   |

Notes: 1. Float condition occurs when maximum output current becomes less than I<sub>Lo</sub> in magnitude. Float delay is not 100% tested. 2. These inputs are allowed to be asynchronous to CLK2. The setup and hold specifications are given for testing purposes, to assure

recognition within a specific clock period.

Rise and fall times are not tested.
 Min time not 100% tested.

 $V_{CC} = 5 V \pm 5\%$ ;  $T_{CASE} = 0^{\circ}C$  to  $+85^{\circ}C$ 

| No. | Parameter<br>Description        | Notes                           | Ref<br>Figures | 33 MHz<br>Min | 33 MHz<br>Max | Unit |
|-----|---------------------------------|---------------------------------|----------------|---------------|---------------|------|
|     | Operating Frequency             | Half of CLK2 Freq               |                | 0             | 33.3          | MHz  |
| 1   | CLK2 Period                     |                                 | 71             | 15.0          |               | ns   |
| 2a  | CLK2 High Time                  | at 2 V                          | 71             | 6.25          |               | ns   |
| 2b  | CLK2 High Time                  | at 3.7 V                        | 71             | 4.5           |               | ns   |
| 3a  | CLK2 Low Time                   | at 2 V                          | 71             | 6.25          |               | ns   |
| 3b  | CLK2 Low Time                   | at 0.8 V                        | 71             | 4.5           |               | ns   |
| 4   | CLK2 Fall Time                  | 3.7 V to 0.8 V<br>(Note 3)      | 71             |               | 4             | ns   |
| 5   | CLK2 Rise Time                  | 0.8 V to 3.7 V<br>(Note 3)      | 71             |               | 4             | ns   |
| 6   | A31–A2 Valid Delay              | С <sub>L</sub> = 50 pF          | 70, 73, 81     | 4             | 15            | ns   |
| 7   | A31–A2 Float Delay              | (Note 1)                        | 81             | 4             | 20            | ns   |
| 8   | BE3-BE0, LOCK Valid Delay       | С <sub>L</sub> = 50 pF          | 70, 73, 81     | 4             | 15            | ns   |
| 9   | BE3-BE0, LOCK Float Delay       | (Note 1)                        | 81             | 4             | 20            | ns   |
| 10  | W/R, M/IO, D/C Valid Delay      | С <sub>L</sub> =50 рF           | 70, 73, 81     | 4             | 15            | ns   |
| 10a | ADS Valid Delay                 | С <sub>L</sub> = 50 pF          | 70, 73, 81     | 4             | 14.5          | ns   |
| 11  | W/R, M/IO, D/C, ADS Float Delay | (Note 1)                        | 81             | 4             | 20            | ns   |
| 12  | D31–D0 Write Data Valid Delay   | C <sub>L</sub> = 50 pF (Note 4) | 70, 74, 81     | 7             | 24            | ns   |
| 12a | D31–D0 Write Data Hold Time     | С <sub>L</sub> = 50 pF          | 70, 75         | 2             |               | ns   |
| 13  | D31-D0 Float Delay              | (Note 1)                        | 81             | 4             | 17            | ns   |
| 14  | HLDA Valid Delay                | C <sub>L</sub> = 50 pF          | 70, 81         | 4             | 20            | ns   |
| 15  | NA Setup Time                   |                                 | 72             | 5             |               | ns   |
| 16  | NA Hold Time                    |                                 | 72             | 2             |               | ns   |
| 17  | BS16 Setup Time                 |                                 | 72             | 5             |               | ns   |
| 18  | BS16 Hold Time                  |                                 | 72             | 2             |               | ns   |
| 19  | READY Setup Time                |                                 | 72             | 7             |               | ns   |
| 20  | READY Hold Time                 |                                 | 72             | 4             |               | ns   |
| 21  | D31–D0 Read Setup Time          |                                 | 72             | 5             |               | ns   |
| 22  | D31–D0 Read Hold Time           |                                 | 72             | 3             |               | ns   |
| 23  | HOLD Setup Time                 |                                 | 72             | 11            |               | ns   |
| 24  | HOLD Hold Time                  |                                 | 72             | 2             |               | ns   |
| 25  | RESET Setup Time                |                                 | 82             | 5             |               | ns   |
| 26  | RESET Hold Time                 |                                 | 82             | 2             |               | ns   |
| 27  | NMI, INTR Setup Time            | (Note 2)                        | 72             | 5             |               | ns   |
| 28  | NMI, INTR Hold Time             | (Note 2)                        | 72             | 5             |               | ns   |
| 29  | PEREQ, ERROR, BUSY Setup Time   | (Note 2)                        | 72             | 5             |               | ns   |
| 30  | PEREQ, ERROR, BUSY Hold Time    | (Note 2)                        | 72             | 4             |               | ns   |

Notes: 1. Float condition occurs when maximum output current becomes less than I<sub>LO</sub> in magnitude. Float delay is not 100% tested.
 2. These inputs are allowed to be asynchronous to CLK2. The setup and hold specifications are given for testing purposes, to assure recognition within a specific CLK2 period.

Rise and fall times are not tested.
 Min time not 100% tested.

 $V_{CC} = 5 V \pm 5$ ;  $T_{CASE} = 0^{\circ}C$  to +85°C (PGA)  $V_{CC} = 5 V \pm 10\%$ ;  $T_{CASE} = 0^{\circ}C$  to +100°C (PQFP)

| No.                | Parameter<br>Description              | Notes                      | Ref<br>Figures | 25 MHz<br>Min | 25 MHz<br>Max<br>25<br>7<br>7<br>21<br>30<br>24<br>21<br>30<br>24<br>21<br>30<br>21<br>30<br>27<br>22<br>22<br>22 | Unit |
|--------------------|---------------------------------------|----------------------------|----------------|---------------|-------------------------------------------------------------------------------------------------------------------|------|
| itani katopalapadi | Operating Frequency                   | Half of CLK2 Freq          |                | 0             | 25                                                                                                                | MHz  |
| 1                  | CLK2 Period                           |                            | 71             | 20            |                                                                                                                   | ns   |
| 2a                 | CLK2 High Time                        | at 2 V                     | 71             | 7             |                                                                                                                   | ns   |
| 2b                 | CLK2 High Time                        | at 3.7 V                   | 71             | 4             |                                                                                                                   | ns   |
| 3a                 | CLK2 Low Time                         | at 2 V                     | 71             | 7             |                                                                                                                   | ns   |
| 3b                 | CLK2 Low Time                         | at 0.8 V                   | 71             | 5             |                                                                                                                   | ns   |
| 4                  | CLK2 Fall Time                        | 3.7 V to 0.8 V<br>(Note 3) | 71             |               | 7                                                                                                                 | ns   |
| 5                  | CLK2 Rise Time                        | 0.8 V to 3.7 V<br>(Note 3) | 71             |               | 7                                                                                                                 | ns   |
| 6                  | A31–A2 Valid Delay                    | C <sub>L</sub> = 50 pF     | 70, 73, 81     | 4             | 21                                                                                                                | ns   |
| 7                  | A31–A2 Float Delay                    | (Note 1)                   | 81             | 4             | 30                                                                                                                | ns   |
| 8                  | BE3-BE0 Valid Delay                   | C <sub>L</sub> = 50 pF     | 70, 73, 81     | 4             | 24                                                                                                                | ns   |
| 8a                 | LOCK Valid Delay                      | CL=50 pF                   | 70, 73, 81     | 4             | 21                                                                                                                | ns   |
| 9                  | BE3-BE0, LOCK Float Delay             | (Note 1)                   | 81             | 4             | 30                                                                                                                | ns   |
| 10                 | W/R, M/IO, D/C, ADS<br>Valid Delay    | С <sub>L</sub> = 50 pF     | 70, 73, 81     | 4             | 21                                                                                                                | ns   |
| 11                 | W/R, M/IO, D/C, ADS<br>Float Delay    | (Note 1)                   | 81             | 4             | 30                                                                                                                | ns   |
| 12                 | D31–D0 Write Data Valid Delay         | С <sub>L</sub> =50 рF      | 70, 74, 81     | 7             | 27                                                                                                                | ns   |
| 12a                | D31-D0 Write Data Hold Time           | C <sub>L</sub> =50 pF      | 70, 81         | 2             |                                                                                                                   | ns   |
| 13                 | D31–D0 Float Delay                    | (Note 1)                   | 81             | 4             | 22                                                                                                                | ns   |
| 14                 | HLDA Valid Delay                      | С <sub>L</sub> = 50 pF     | 70, 81         | 4             | 22                                                                                                                | ns   |
| 15                 | NA Setup Time                         |                            | 72             | 7             |                                                                                                                   | ns   |
| 16                 | NA Hold Time                          |                            | 72             | 3             |                                                                                                                   | ns   |
| 17                 | BS16 Setup Time                       |                            | 72             | 7             |                                                                                                                   | ns   |
| 18                 | BS16 Hold Time                        |                            | 72             | 3             |                                                                                                                   | ns   |
| 19                 | READY Setup Time                      |                            | 72             | 9             |                                                                                                                   | ns   |
| 20                 | READY Hold Time                       |                            | 72             | 4             |                                                                                                                   | ns   |
| 21                 | D31-D0 Read Setup Time                |                            | 72             | 7             |                                                                                                                   | ns   |
| 22                 | D31-D0 Read Hold Time                 |                            | 72             | 5             |                                                                                                                   | ns   |
| 23                 | HOLD Setup Time                       |                            | 72             | 15            |                                                                                                                   | ns   |
| 24                 | HOLD Hold Time                        |                            | 72             | 3             |                                                                                                                   | ns   |
| 25                 | RESET Setup Time                      |                            | 82             | 10            |                                                                                                                   | ns   |
| 26                 | RESET Hold Time                       |                            | 82             | 3             |                                                                                                                   | ns   |
| 27                 | NMI, INTR Setup Time                  | (Note 2)                   | 72             | 6             |                                                                                                                   | ns   |
| 28                 | NMI, INTR Hold Time                   | (Note 2)                   | 72             | 6             |                                                                                                                   | ns   |
| 29                 | PEREQ, ERROR, BUSY, FLT<br>Setup Time | (Note 2)                   | 72             | 6             |                                                                                                                   | ns   |
| 30                 | PEREQ, ERROR, BUSY, FLT<br>Hold Time  | (Note 2)                   | 72             | 5             |                                                                                                                   | ns   |

Notes: 1. Float condition occurs when maximum output current becomes less than I<sub>LO</sub> magnitude. Float delay is not 100% tested.
2. These inputs are allowed to be asynchronous to CLK2. The setup and hold specifications are given for testing purposes, to assure recognition within a specific CLK2 period.
3. Rise and fall times are not tested.

 $V_{CC} = 5 V \pm 5\%$ ;  $T_{CASE} = 0^{\circ}C$  to  $+85^{\circ}C$  (PGA)  $V_{CC} = 5 V \pm 10\%$ ;  $T_{CASE} = 0^{\circ}C$  to  $+100^{\circ}C$  (PQFP)

| No. | Parameter<br>Description              | Notes                                         | Ref<br>Figures | 20 MHz<br>Min | 20 MHz<br>Max | Unit |
|-----|---------------------------------------|-----------------------------------------------|----------------|---------------|---------------|------|
|     | Operating Frequency                   | Half of CLK2 Freq                             |                | 0             | 20            | MHz  |
| 1   | CLK2 Period                           |                                               | 71             | 25            |               | ns   |
| 2a  | CLK2 High Time                        | at 2 V                                        | 71             | 8             | <b>1</b>      | ns   |
| 2b  | CLK2 High Time                        | at (V <sub>cc</sub> –0.8 V)                   | 71             | 5             |               | ns   |
| 3a  | CLK2 Low Time                         | at 2 V                                        | 71             | 8             |               | ns   |
| 3b  | CLK2 Low Time                         | at 0.8 V                                      | 71             | 6             |               | ns   |
| 4   | CLK2 Fall Time                        | (V <sub>cc</sub> -0.8 V) to 0.8 V<br>(Note 3) | 71             |               | 8             | ns   |
| 5   | CLK2 Rise Time                        | 0.8 V to (V <sub>cc</sub> -0.8 V)<br>(Note 3) | 71             |               | 8             | ns   |
| 6   | A31–A2 Valid Delay                    | C <sub>L</sub> = 120 pF                       | 70, 73, 81     | 4             | 30            | ns   |
| 7   | A31–A2 Float Delay                    | (Note 1)                                      | 81             | 4             | 32            | ns   |
| 8   | BE3-BE0 Valid Delay                   | С <sub>L</sub> = 75 pF                        | 70, 73, 81     | 4             | 30            | ns   |
| 9   | BE3–BE0, LOCK<br>Float Delay          | (Note 1)                                      | 81             | 4             | 32            | ns   |
| 10  | W/R, M/IO, D/C, ADS<br>Valid Delay    | С <sub>L</sub> =75 рF                         | 70, 73, 81     | 4             | 28            | ns   |
| 11  | W/R, M/IO, D/C, ADS<br>Float Delay    | (Note 1)                                      | 81             | 4             | 30            | ns   |
| 12  | D31-D0 Write Data Valid Delay         | С <sub>L</sub> = 120 pF                       | 70, 74, 81     | 4             | 38            | ns   |
| 13  | D31-D0 Float Delay                    | (Note 1)                                      | 81             | 4             | 27            | ns   |
| 14  | HLDA Valid Delay                      | C <sub>L</sub> = 75 pF                        | 70, 81         | 6             | 28            | ns   |
| 15  | NA Setup Time                         |                                               | 72             | 9             |               | ns   |
| 16  | NA Hold Time                          |                                               | 72             | 14            |               | ns   |
| 17  | BS16 Setup Time                       |                                               | 72             | 13            |               | ns   |
| 18  | BS16 Hold Time                        |                                               | 72             | 21            |               | ns   |
| 19  | READY Setup Time                      |                                               | 72             | 12            |               | ns   |
| 20  | READY Hold Time                       |                                               | 72             | 4             |               | ns   |
| 21  | D31-D0 Read Setup Time                |                                               | 72             | 11            |               | ns   |
| 22  | D31-D0 Read Hold Time                 |                                               | 72             | 6             |               | ns   |
| 23  | HOLD Setup Time                       |                                               | 72             | 17            |               | ns   |
| 24  | HOLD Hold Time                        |                                               | 72             | 5             |               | ns   |
| 25  | RESET Setup Time                      |                                               | 82             | 12            |               | ns   |
| 26  | RESET Hold Time                       |                                               | 82             | 4             |               | ns   |
| 27  | NMI, INTR Setup Time                  | (Note 2)                                      | 72             | 16            |               | ns   |
| 28  | NMI, INTR Hold Time                   | (Note 2)                                      | 72             | 16            |               | ns   |
| 29  | PEREQ, ERROR, BUSY, FLT<br>Setup Time | (Note 2)                                      | 72             | 14            |               | ns   |
| 30  | PEREQ, ERROR, BUSY, FLT<br>Hold Time  | (Note 2)                                      | 72             | 5             |               | ns   |

Notes: 1. Float condition occurs when maximum output current becomes less than I<sub>LO</sub> magnitude. Float delay is not 100% tested.
2. These inputs are allowed to be asynchronous to CLK2. The setup and hold specifications are given for testing purposes, to assure recognition within a specific CLK2 period.
3. Rise and fall times are not tested.

# SWITCHING WAVEFORMS

The switching characteristics consist of output delays, input setup requirements, and input hold requirements. All characteristics are relative to the CLK2 rising edge crossing the 2.0 V level.

Switching characteristic measurement is defined by Figure 69. Inputs must be driven to the voltage levels indicated by this diagram. Am386DXL CPU output delays are specified with minimum and maximum limits measured as shown. The minimum Am386DXL microprocessor delay times are hold times provided to external circuitry. Am386DXL microprocessor input setup and hold time are specified as minimums, defining the smallest acceptable sampling window. Within the sampling window, a synchronous input signal must be stable for correct Am386DXL microprocessor operation.

Outputs ADS, W/R, D/C, M/IO, LOCK, BE3–BE0, A31–A2, and HLDA only change at the beginning of phase one. D31–D0 (write cycles) only change at the beginning of phase two. The READY, HOLD, BUSY, ERROR, PEREQ, FLT, and D31–D0 (read cycles) inputs are sampled at the beginning of phase one. The NA, BS16, INTR, and NMI inputs are sampled at the beginning of phase two.



Note: input waveforms have tr  $\leq$  2.0 ns from 0.8 V to 2.0 V.

15021B-071

#### Figure 69. Drive Levels and Measurement Points



CL includes all parasitic capacitances.

Figure 70. AC Test Load

15021B-072



Figure 71. CLK2 Timing

15021B-073





Figure 73. Output Valid Delay Timing

15021B-075





15021B-076







15021B--078





Note: This graph will not be linear outside of the C<sub>L</sub> range shown.

15021B-079





Note: This graph will not be linear outside of the CL range shown.

15021B-080

#### Figure 78. Typical Output Valid Delay Versus Load Capacitance at Maximum Operating Temperature (CL = 75 pF)



Note: This graph will not be linear outside of the  $C_L$  range shown.

15021B-081





Note: This graph will not be linear outside of the  $C_L$  range shown.

#### Figure 80. Typical Output Rise Time Versus Load Capacitance at Maximum Operating Temperature

Am386DXL Microprocessor

15021B-082







The second internal processor phase following RESET High-to-Low transition (provided t25 and t26 are met) is ¢2. 15021B-084

Figure 82. RESET Setup and Hold Timing and Internal Phase

# **INSTRUCTION SET**

This section describes the Am386DXL microprocessor instruction set. A table lists all instructions along with instruction encoding diagrams and clock counts. Further details of the instruction encoding are then provided in the following sections, which completely describe the encoding structure and the definition of all fields occurring within Am386DXL CPU instructions.

## Am386DXL Microprocessor Instruction Encoding and Clock Count Summary

To calculate elapsed time for an instruction, multiply the instruction clock count, as listed in Table 23, by the processor clock period (e.g., 50 ns for a 20 MHz, 40 ns for a 25 MHz, 30 ns for a 33 MHz, and 25 ns for a 40 MHz Am386DXL microprocessor).

For more detailed information on the encodings of instructions refer to Section Instruction Encodings. Section Instruction Encodings explains the general structure of instruction encodings and defines exactly the encodings of all fields contained within the instruction.

#### Instruction Clock Count Assumptions

1. The instruction has been prefetched and decoded, and is ready for execution.

- 2. Bus cycles do not require wait states.
- 3. There are no local bus HOLD requests delaying processor access to the bus.
- 4. No Exceptions are detected during instruction execution.
- 5. If an effective address is calculated, it does not use two general register components. One register, scaling, and displacement can be used within the clock counts shown. However, if the effective address calculation uses two general register components, add 1 clock to the clock count shown.

#### Instruction Clock Count Notation

- If two clock counts are given, the smaller refers to a register operand and the larger refers to a memory operand.
- 2. n = number of times repeated.
- m = number of components in the next instruction executed, where the entire displacement (if any) counts as one component; the entire immediate data (if any) counts as one component; and each of the other bytes of the instruction and prefix(es) each count as one component.

|                                        |                    |                   |                |                  | Clock Count             |                                         |                         | Comments                               |  |
|----------------------------------------|--------------------|-------------------|----------------|------------------|-------------------------|-----------------------------------------|-------------------------|----------------------------------------|--|
| Instruction                            | Format             |                   |                |                  | Real<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode | Protecte<br>Virtual<br>Address<br>Mode |  |
| GENERAL DATA TRANSFER                  |                    |                   |                |                  |                         |                                         |                         |                                        |  |
| MOV = Move:                            |                    |                   |                |                  |                         |                                         |                         |                                        |  |
| Register to Register/Memory            | 1000100w           | mod reg r/m       |                |                  | 2/2                     | 2/2                                     | ь                       | h                                      |  |
| Register/Memory to Register            | 1000101w           | mod reg r/m       |                |                  | 2/4                     | 2/4                                     | ь                       | h                                      |  |
| Immediate to Register/Memory           | 1100011w           | mod 0 0 0 r/m     | immediate data |                  | 2/2                     | 2/2                                     | ь                       | h                                      |  |
| Immediate to Register (short form)     | 1011w reg          | immediate data    |                |                  | 2                       | 2                                       |                         |                                        |  |
| Memory to Accumulator (short form)     | 1010000w           | full displacement |                |                  | 4                       | 4                                       | ь                       | h                                      |  |
| Accumulator to Memory (short form)     | 1010001w           | full displacement |                |                  | 2                       | 2                                       | ь                       | h                                      |  |
| Register/Memory to Segment Register    | 10001110           | mod sreg3 r/m     |                |                  | 2/5                     | 18, 19                                  | ь                       | h, i, j                                |  |
| Segment Register to Register/Memory    | 10001100           | mod reg r/m       |                |                  | 2/2                     | 2/2                                     | ь                       | h                                      |  |
| MOVSX = Move with Sign Extension       |                    |                   |                |                  |                         |                                         |                         |                                        |  |
| Register from Register/Memory          | 0 0 0 0 1 1 1 1    | 1011111w          | mod reg r/m    |                  | 3/6                     | 3/6                                     | ь                       | h                                      |  |
| MOVZX = Move with Zero Extension       |                    |                   |                |                  |                         |                                         |                         |                                        |  |
| Register from Register/Memory          | 00001111           | 1011011w          | mod reg r/m    |                  | 3/6                     | 3/6                                     | ь                       | h                                      |  |
| PUSH = Push:                           |                    |                   |                |                  |                         |                                         |                         |                                        |  |
| Register/Memory                        | 11111111           | mod 1 1 0 r/m     |                |                  | 5                       | 5                                       | ь                       | h                                      |  |
| Register (short form)                  | 01010 reg          |                   |                |                  | 2                       | 2                                       | ь                       | h                                      |  |
| Segment Register (ES,CS,SS, or DS)     | 0 0 0 sreg 2 1 1 0 |                   |                |                  | 2                       | 2                                       | ь                       | h                                      |  |
| Segment Register (FS or GS)            | 00001111           | 1 0 sreg 3 0 0 0  |                |                  | 2                       | 2                                       | ь                       | h                                      |  |
| Immediate                              | 01101050           | immediate data    | •              |                  | 2                       | 2                                       | ь                       | h                                      |  |
| PUSHA = Push All                       | 01100000           |                   |                |                  | 18                      | 18                                      | ь                       | h                                      |  |
| POP = Pop                              |                    |                   |                |                  |                         |                                         |                         |                                        |  |
| Register/Memory                        | 10001111           | mod 0 0 0 r/m     | ]              |                  | 5                       | 5                                       | ь                       | h                                      |  |
| Register (short form)                  | 01011 reg          |                   | 1              |                  | 4                       | 4                                       | ь                       | h                                      |  |
| Segment Register (ES, SS, or DS)       | 000 sreg 2 1 1 1   |                   |                |                  | 7                       | 21                                      | ь                       | h, i, j                                |  |
| Segment Register (FS or GS)            | 00001111           | 1 0 sreg 3 0 0 1  |                |                  | 7                       | 21                                      | ь                       | h, i, j                                |  |
| POPA = Pop All                         | 01100001           |                   | •              |                  | 24                      | 24                                      | ь                       | h                                      |  |
| XCHG = Exchange                        |                    |                   |                |                  |                         |                                         |                         |                                        |  |
| Register/Memory with Register          | 1000011w           | mod reg r/m       |                |                  | 3/5                     | 3/5                                     | b, f                    | f, h                                   |  |
| Register with Accumulator (short form) | 10010 reg          |                   |                | k Count          | 3                       | 3                                       |                         |                                        |  |
| IN = Input from:                       |                    |                   |                | irtual<br>6 Mode |                         |                                         |                         |                                        |  |
| Fixed Port                             | 1110010w           | port number       |                | 26               | 12                      | 6*/26**                                 |                         | m                                      |  |
| Variable Port                          | 1110110w           |                   | 1              | 27               | 13                      | 7*/27**                                 |                         | m                                      |  |
| OUT = Output to:                       | L                  | 1                 |                |                  |                         |                                         |                         |                                        |  |
| Fixed Port                             | 1110011w           | port number       | 1 4            | 24               | 10                      | 4*/24**                                 |                         | m                                      |  |
| Variable Port                          | 1110111w           |                   | 1 4            | 25               | 11                      | 5*/25**                                 |                         | m                                      |  |
| LEA = Load EA to Register              | 10001101           | mod reg r/m       | 1              |                  | 2                       | 2                                       | 1                       |                                        |  |

Table 23. Am386DXL Microprocessor Instruction Set Summary

\* If CPL ≤ IOPL \*\* If CPL > IOPL



# Table 23. Am386DXL Microprocessor Instruction Set Summary (continued)

|                                       |                                         |                |                |  | Clock                   | Count                                   | Com                     | ments                                   |
|---------------------------------------|-----------------------------------------|----------------|----------------|--|-------------------------|-----------------------------------------|-------------------------|-----------------------------------------|
| Instruction                           | Format                                  |                |                |  | Real<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode |
| SEGMENT CONTROL                       |                                         |                |                |  |                         |                                         |                         |                                         |
| LDS = Load pointer to DS              | 11000101                                | mod reg r/m    |                |  | 7                       | 22                                      | ь                       | h, i, j                                 |
| LES=Load pointer to ES                | 11000100                                | mod reg r/m    |                |  | 7                       | 22                                      | b                       | h, i, j                                 |
| LFS = Load pointer to FS              | 00001111                                | 10110100       | mod reg r/m    |  | 7                       | 25                                      | ь                       | h, i, j                                 |
| LGS=Load pointer to GS                | 00001111                                | 10110101       | mod reg r/m    |  | 7                       | 25                                      | b                       | h, i, j                                 |
| LSS=Load pointer to SS                | 00001111                                | 10110010       | mod reg r/m    |  | 7                       | 22                                      | b                       | h, i, j                                 |
| FLAG CONTROL                          |                                         |                |                |  |                         |                                         |                         |                                         |
| CLC = Clear Carry Flag                | 11111000                                |                |                |  | 2                       | 2                                       |                         |                                         |
| CLD = Clear Direction Flag            | 11111100                                |                |                |  | 2                       | 2                                       |                         |                                         |
| CLI = Clear Interrupt Enable Flag     | 11111010                                |                |                |  | 8                       | 8                                       |                         | m                                       |
| CLTS = Clear Task Switched Flag       | 00001111                                | 00000110       |                |  | 6                       | 6                                       | c                       | i                                       |
| CMC = Complement Carry Flag           | 11110101                                |                |                |  | 2                       | 2                                       |                         |                                         |
| LAHF = Load AH into Flag              | 10011111                                | ]              |                |  | 2                       | 2                                       |                         |                                         |
| POPF = Pop Flag                       | 10011101                                |                |                |  | 5                       | 5                                       | ъ                       | h,n                                     |
| PUSHF = Push Flag                     | 10011100                                |                |                |  | 4                       | 4                                       | ь                       | h                                       |
| SAHF = Store AH into Flag             | 10011110                                |                |                |  | 3                       | 3                                       |                         |                                         |
| STC = Set Carry Flag                  | 11111001                                |                |                |  | 2                       | 2                                       |                         |                                         |
| STD = Set Direction Flag              | 11111101                                | 1              |                |  | 2                       | 2                                       |                         |                                         |
| STI = Set Interrupt Enable Flag       | 11111011                                |                |                |  | 8                       | 8                                       |                         | m                                       |
| ARITHMETIC                            |                                         |                |                |  |                         |                                         |                         |                                         |
| ADD=Add                               |                                         |                |                |  |                         |                                         |                         |                                         |
| Register to Register                  | wb000000                                | mod reg r/m    |                |  | 2                       | 2                                       |                         |                                         |
| Register to Memory                    | 0000000w                                | mod reg r/m    |                |  | 7                       | 7                                       | ъ                       | h                                       |
| Memory to Register                    | 000001w                                 | mod reg r/m    |                |  | 6                       | 6                                       | b                       | h                                       |
| Immediate to Register/Memory          | 100000sw                                | mod 0 0 0 r/m  | immediate data |  | 2/7                     | 2/7                                     | ь                       | h                                       |
| Immediate to Accumulator (short form) | 0000010w                                | immediate data |                |  | 2                       | 2                                       |                         |                                         |
| ADC = Add with carry                  | ••••••••••••••••••••••••••••••••••••••• | •              |                |  |                         |                                         |                         |                                         |
| Register to Register                  | 000100dw                                | mod reg r/m    |                |  | 2                       | 2                                       |                         |                                         |
| Register to Memory                    | 0001000w                                | mod reg r/m    |                |  | 7                       | 7                                       | ь                       | h                                       |
| Memory to Register                    | 0001001w                                | mod reg r/m    |                |  | 6                       | 6                                       | ь                       | h                                       |
| Immediate to Register/Memory          | 100000sw                                | mod 0 1 0 r/m  | immediate data |  | 2/7                     | 2/7                                     | ъ                       | h                                       |
| Immediate to Accumulator (short form) | 0001010w                                | immediate data |                |  | 2                       | 2                                       |                         |                                         |
| INC =Increment                        |                                         | 1              |                |  |                         |                                         |                         |                                         |
| Register/Memory                       | 1111111w                                | mod 0 0 0 r/m  |                |  | 2/6                     | 2/6                                     | ь                       | h                                       |
| Register (short form)                 | 01000 reg                               |                |                |  | 2                       | 2                                       |                         |                                         |
| SUB =Subtract                         |                                         | 4              |                |  |                         |                                         |                         |                                         |
| Register from Register                | 001010dw                                | mod reg r/m    |                |  | 2                       | 2                                       |                         |                                         |
| Register from Memory                  | 0010100w                                | mod reg r/m    |                |  | 7                       | 7                                       | ь                       | ħ                                       |
| Memory from Register                  | 0010101w                                | mod reg r/m    |                |  | 6                       | 6                                       | ь                       | h                                       |

|                                                                              |           |                |                | Clock Count             |                                           | Comments                |                                        |
|------------------------------------------------------------------------------|-----------|----------------|----------------|-------------------------|-------------------------------------------|-------------------------|----------------------------------------|
| Instruction                                                                  | Format    |                |                | Real<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode   | Real<br>Address<br>Mode | Protecte<br>Virtual<br>Address<br>Mode |
| ARITHMETIC (continued)                                                       |           |                |                |                         |                                           |                         |                                        |
| Immediate from Register/Memory                                               | 0010011w  | mod 1 0 1 r/m  | immediate data | 2/7                     | 2/7                                       | ь                       | h                                      |
| Immediate from Accumulator                                                   | 0001110w  | immediate data |                | 2                       | 2                                         | -                       |                                        |
| (short form)                                                                 |           | 3              |                |                         |                                           |                         |                                        |
| SBB=Subtract with Borrow                                                     |           | r              |                |                         |                                           |                         |                                        |
| Register from Register                                                       | 000110dw  | mod reg r/m    |                | 2                       | 2                                         |                         |                                        |
| Register from Memory                                                         | 0001100w  | mod reg r/m    |                | 7                       | 7                                         | b                       | h                                      |
| Memory from Register                                                         | 0001101w  | mod reg r/m    |                | 6                       | 6                                         | b                       | h                                      |
| Immediate from Register/Memory                                               | 100000sw  | mod 0 1 1 r/m  | immediate data | 2/7                     | 2/7                                       | ь                       | h                                      |
| Immediate from Accumulator                                                   | 0001110w  | immediate data |                | 2                       | 2                                         |                         |                                        |
| DEC = Decrement                                                              |           |                |                |                         |                                           |                         |                                        |
| Register/Memory                                                              | 1111111W  | reg 0 0 1 r/m  |                | 2/6                     | 2/6                                       | ь                       | h                                      |
| Register (short form)                                                        | 01001 reg | J              |                | 2                       | 2                                         |                         |                                        |
| CMP = Compare                                                                |           | •              |                |                         |                                           |                         |                                        |
| Register with Register                                                       | 001110dw  | mod reg r/m    |                | 2                       | 2                                         |                         |                                        |
| Memory with Register                                                         | 0011100w  | mod reg r/m    |                | 5                       | 5                                         | ь                       | h                                      |
| Register with Memory                                                         | 0011101w  | mod reg r/m    |                | 6                       | 6                                         | ь                       | h                                      |
| Immediate with Register/Memory                                               | 100000sw  | mod 1 1 1 r/m  | immediate data | 2/5                     | 2/5                                       | ь                       | h                                      |
| Immediate with Accumulator(short form)                                       | 0011110w  | immediate data |                | 2                       | 2                                         |                         | l                                      |
| NEG = Change Sign                                                            | 1111011w  | mod 0 1 1 r/m  |                | 2/6                     | 2/6                                       | ь                       | h                                      |
| AAA = ASCII Adjust for Add                                                   | 00110111  |                |                | 4                       | 4                                         |                         | l                                      |
| DAA = Decimal Adjust for Add                                                 | 00111111  |                |                | 4                       | 4                                         |                         |                                        |
| AAS = ASCII Adjust for Subtract                                              | 00100111  |                |                | 4                       | 4                                         |                         |                                        |
| DAS = Decimal Adjust for Subtract                                            | 00101111  |                |                | 4                       | 4                                         |                         |                                        |
| MUL = Muitiply (Unsigned)                                                    | <b>4</b>  | 3              |                |                         |                                           |                         | 1                                      |
| Accumulator with Register/Memory                                             | 1111011w  | mod 100 r/m    |                |                         |                                           |                         |                                        |
| Multiplier -Byte<br>-Word<br>-Doubleword<br>IMUL = Integer Multiply (signed) |           | <b>.</b>       |                | 12-25/15-28             | 12-17/15-20<br>12-25/15-28<br>12-41/15-44 | b,d<br>b,d<br>b,d       | d,h<br>d,h<br>d,h                      |
| Accumulator with Register/Memory                                             | 1111011w  | mod 1 0 1 r/m  |                |                         |                                           |                         |                                        |
| Multiplier -Byte<br>-Word                                                    | L         |                | ļ              | 12-25/15-28             | 12-17/15-20<br>12-25/15-28                | b,d                     | d,h<br>d,h                             |
| -Doubleword<br>Register with Register/Memory                                 | 00001111  | 10101111       | mod reg r/m    | 12-41/15-44             | 12-41/15-44                               | b,d                     | d,h                                    |
| Multiplier -Byte<br>-Word<br>-Doubleword                                     |           |                |                | 12-25/15-28             | 12-17/15-20<br>12-25/15-28<br>12-41/15-44 | b,d<br>b,d<br>b,d       | d,h<br>d,h<br>d,h                      |
| Register/Memory with Immediate to Register                                   | 011010s1  | mod reg r/m    | immediate data |                         |                                           |                         |                                        |
| -Word<br>-Doubleword                                                         |           |                |                |                         | 13-26/14-27<br>13-42/14-43                | b,d<br>b,d              | d,h<br>d,h                             |
|                                                                              |           |                |                |                         |                                           |                         |                                        |

# Table 23. Am386DXL Microprocessor Instruction Set Summary (continued)



| · · · · · · · · · · · · · · · · · · ·                                                      |                                                      |                                                                  |                                  | Clock Count             |                                         | Comments                |                                         |
|--------------------------------------------------------------------------------------------|------------------------------------------------------|------------------------------------------------------------------|----------------------------------|-------------------------|-----------------------------------------|-------------------------|-----------------------------------------|
| Instruction                                                                                | Format                                               |                                                                  |                                  | Real<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode |
| ARITHMETIC (continued)                                                                     |                                                      |                                                                  |                                  | 1                       |                                         |                         |                                         |
| DIV = Divide (Unsigned)                                                                    |                                                      |                                                                  |                                  |                         | ļ                                       |                         |                                         |
| Accumulator by Register/Memory<br>Divisor -Byte<br>-Word<br>-Doubleword                    | 1111011w                                             | mod 1 1 0 r/m                                                    |                                  | 14/17<br>22/25<br>38/41 | 14/17<br>22/25<br>38/41                 | b,e<br>b,e<br>b,e       | e, h<br>e, h<br>e, h                    |
| IDIV = Integer Divide (Signed)<br>Accumulator by Register/Memory<br>Divisor -Byte<br>-Word | 11110112                                             | mod 1 1 1 r/m                                                    |                                  | 19/22                   | 19/22                                   | b,e                     | e, h                                    |
| -Doubleword<br>AAD = ASCII Adjust for Divide                                               | 11010101                                             | 00001010                                                         |                                  | 27/30<br>43/46<br>19    | 27/30<br>43/46<br>19                    | b,e<br>b,e              | e, h<br>e, h                            |
| AAM = ASCII Adjust for Multiply                                                            | 11010100                                             | 00001010                                                         |                                  | 17                      | 17                                      |                         |                                         |
| CBW = Convert Byte to Word                                                                 | 10011000                                             |                                                                  |                                  | 3                       | 3                                       |                         |                                         |
| CWD ≖ Convert Word to<br>Double Word                                                       | 10011001                                             | ]                                                                |                                  | 2                       | 2                                       |                         |                                         |
| LOGIC                                                                                      |                                                      |                                                                  |                                  |                         |                                         |                         |                                         |
| Shift/Rotate Instructions<br>Not Through Carry (ROL, ROR, SAL,                             | SAR, SHL, and SI                                     | łR)                                                              |                                  |                         |                                         |                         |                                         |
| Register/Memory by 1                                                                       | 1101000w                                             | mod TTT r/m                                                      |                                  | 3/7                     | 3/7                                     | ь                       | h                                       |
| Register/Memory by CL                                                                      | 1101001w                                             | mod TTT r/m                                                      |                                  | 3/7                     | 3/7                                     | ь                       | h                                       |
| Register Memory by Immediate Count                                                         | 1100000w                                             | mod TTT r/m                                                      | immediate 8-bit data             | 3/7                     | 3/7                                     | ь                       | h                                       |
| Through Carry (RCL and RCR)                                                                |                                                      | <b>.</b>                                                         |                                  |                         |                                         |                         |                                         |
| Register/Memory by 1                                                                       | 1101000w                                             | mod TTT r/m                                                      |                                  | 9/10                    | 9/10                                    | ь                       | h                                       |
| Register/Memory by CL                                                                      | 1101001w                                             | mod TTT r/m                                                      |                                  | 9/10                    | 9/10                                    | ь                       | h                                       |
| Register/Memory by Immediate Count                                                         | 1100000w                                             | mod TTT r/m                                                      | immediate 8-bit data             | 9/10                    | 9/10                                    | ь                       | h                                       |
|                                                                                            | TTT<br>000<br>001<br>010<br>011<br>100<br>101<br>111 | Instruction<br>ROL<br>ROR<br>RCL<br>RCR<br>SHL/SAL<br>SHR<br>SAR |                                  |                         |                                         |                         |                                         |
| SHLD = Shift Left Double                                                                   | ····                                                 |                                                                  |                                  |                         |                                         |                         |                                         |
| Register/Memory by Immediate                                                               | 00001111                                             | 10100100                                                         | mod reg r/m inmediate 8-bit data | 3/7                     | 3/7                                     |                         |                                         |
| Register/Memory by CL                                                                      | 00001111                                             | 10100101                                                         | mod reg r/m                      | 3/7                     | 3/7                                     |                         |                                         |
| SHRD=Shift Right Double                                                                    |                                                      |                                                                  |                                  |                         |                                         |                         |                                         |
| Register/Memory by Immediate                                                               | 00001111                                             | 10101100                                                         | mod reg r/m immediate 8-bit data | 3/7                     | 3/7                                     |                         |                                         |
| Register/Memory by CL                                                                      | 00001111                                             | 10101101                                                         | mod reg r/m                      | 3/7                     | 3/7                                     |                         |                                         |
| AND = And                                                                                  |                                                      |                                                                  | 1                                |                         |                                         |                         |                                         |
| Register to Register                                                                       | 001000dw                                             | mod reg r/m                                                      |                                  | 2                       | 2                                       |                         |                                         |
| Register to Memory                                                                         | 0010000w                                             | mod reg r/m                                                      |                                  | 7                       | 7                                       | ь                       | h                                       |
| Memory to Register                                                                         | 0010001w                                             | mod reg r/m                                                      |                                  | 6                       | 6                                       | b                       | h                                       |
| Immediate to Register/Memory                                                               | 1000000w                                             | modi110 r/m                                                      | immediate data                   | 2/7                     | 2/7                                     | ь                       | h                                       |
| Immediate to Accumulator (short form)                                                      | 0010010w                                             | immediate data                                                   |                                  | 2                       | 2                                       |                         |                                         |
| TEST = And Function to Flags, no Re                                                        | sult                                                 |                                                                  |                                  | 1                       |                                         |                         |                                         |
| Register/Memory and Register                                                               | 1000010w                                             | mod reg r/m                                                      |                                  | 2/5                     | 2/5                                     | b                       | h                                       |
| Immediate Data and Register/Memory                                                         | 1111011w                                             | mod 0 0 0 r/m                                                    | immediate data                   | 2/5                     | 2/5                                     | b                       | h                                       |
| Immediate Data and Accumulator<br>(short form)                                             | 1010100w                                             | immediate data                                                   |                                  | 2                       | 2                                       |                         |                                         |

# Table 23. Am386DXL Microprocessor Instruction Set Summary (continued)

|                                                                     |               |                              |                |                             | Clock           | Count                           | Co              | mments                          |
|---------------------------------------------------------------------|---------------|------------------------------|----------------|-----------------------------|-----------------|---------------------------------|-----------------|---------------------------------|
|                                                                     |               |                              |                |                             | Real<br>Address | Protected<br>Virtual<br>Address | Real<br>Address | Protected<br>Virtual<br>Address |
|                                                                     | Format        |                              |                |                             | Mode            | Mode                            | Mode            | Mode                            |
| LOGIC (continued)                                                   |               |                              |                |                             |                 |                                 |                 |                                 |
| OR = Or<br>Bogistor to Bogistor                                     | 000010dw      | mod coo r/m                  |                |                             | 2               | 2                               |                 |                                 |
| Register to Register                                                | 0000100w      | mod reg r/m                  |                |                             | 7               | 7                               | ь               | h                               |
| Register to Memory<br>Memory to Register                            | 0000101w      | mod reg r/m                  |                |                             | 6               | 6                               | ь               | h                               |
|                                                                     | 1000000w      | mod reg r/m<br>mod 0 0 1 r/m | immediate data |                             | 2/7             | 2/7                             | ь               | h ii                            |
| Immediate and Register/Memory Immediate to Accumulator (short form) | 0000110w      | immediate data               | immetiale data |                             | 2               | 2                               | L D             |                                 |
|                                                                     | 0000110₩      | inimediate data              |                |                             | 2               | 2                               |                 |                                 |
| XOR = Exclusive or                                                  |               |                              |                |                             |                 |                                 |                 |                                 |
| Register to Register                                                | 001100dw      | mod reg r/m                  |                | :                           | 2               | 2                               |                 |                                 |
| Register to Memory                                                  | 0011000w      | mod reg r/m                  |                |                             | 7               | 7                               | b               | h                               |
| Memory to Register                                                  | 0011001w      | mod reg r/m                  |                |                             | 6               | 6                               | b               | h                               |
| Immediate to Register/Memory                                        | 1000000w      | mod 1 1 0 r/m                | immediate data |                             | 2/7             | 2/7                             | Ь               | h                               |
| Immediate to Accumulator (short form)                               | 0011010w      | immediate data               |                |                             | 2               | 2                               |                 |                                 |
| NOT = Invert Register/Memory                                        | 1111011w      | mod 0 1 0 r/m                |                |                             | 2/6             | 2/6                             | Ь               | h                               |
| STRING MANIPULATION                                                 |               | 1                            |                | Clock Count                 |                 |                                 |                 |                                 |
| CMPS = Compare Byte/Word                                            | 1010011w      |                              |                | Virtual 8086<br>Mode        | 10              | 10                              | b               | h                               |
| INS = Input Byte/Wd from DX Port                                    | 0110110w      |                              |                | 290                         | 15              | 9*/29**                         | ь               | h, m                            |
| LODS = Load Byte/Wd to AL/AX                                        | 1010110w      |                              |                |                             | 5               | 5                               | ь               | h                               |
| MOVS = Move Byte/Word                                               | 1010010w      |                              |                |                             | 8               | 8                               | ь               | h                               |
| OUTS = Output Byte/Wd to DX Port                                    | 0110111w      |                              |                | 280                         | 14              | 8*/28**                         | ь               | h, m                            |
| SCAS = Scan Byte/Word                                               | 1010111w      |                              |                | L                           | 8               | 8                               | b               | h                               |
| STOS = Store Byte/Word from AL/AX/EX                                | 1010101w      |                              |                |                             | 5               | 5                               | ь               | h                               |
| XLAT = Translate String                                             | 11010111      |                              |                |                             | 5               | 5                               |                 | h                               |
| REPEATED STRING MANIPULA                                            | TION Repeated | by Count in CX               | or ECX         |                             |                 |                                 |                 |                                 |
| REPE CMPS = Compare string                                          | 11110011      | 1010011w                     | l              |                             | 5+9n            | 5+9n                            | ь               | h                               |
| (Find Non-Match)<br>REPNE CMPS = Compare String                     |               |                              |                | Clock Count<br>Virtual 8086 | 5+90            | 5+91                            | D               | n                               |
| (Find Match)                                                        | 11110010      | 1010011w                     |                | Mode                        | 5+9n            | 5+9n                            | b               | h                               |
| REP INS = Input String                                              | 11110010      | 0110110w                     |                | 28 + 6n◊                    | 14+6n           | 8+6n*/<br>28+6n**               | b               | h, m                            |
| REP LODS = Load String                                              | 11110010      | 1010110w                     |                |                             | 5+6n            | 5+6n                            | ь               | h                               |
| REP MOVS = Move String                                              | 11110010      | 1010010w                     |                |                             | 8 + 4n          | 8 + 4n                          | ь               | h                               |
| REP OUTS = Output String                                            | 11110010      | 0110111w                     |                | 26 + 5n◊                    | 12+5n           | 6+5n*/<br>26+5n**               | ь               | h, m                            |
| REPE SCAS = Scan String<br>(Find Non-AL/AX/EAX)                     | 11110011      | 1010111w                     |                |                             | 5+8n            | 5+8n                            | ь               | h                               |
| REPNE SCAS = Store String                                           |               | 1010111                      |                |                             | 5.0-            |                                 |                 |                                 |
| (Find AL/AX/EAX)                                                    | 11110010      | 1010111w                     |                |                             | 5+8n            | 5+9n                            | Ь               | h L                             |
| REP STOS = Store String                                             | 11110010      | 1010101w                     | ]              |                             | 5+5n            | 5+5n                            | ь               | h                               |
| BIT MANIPULATION<br>BSF=Scan Bit Forward                            | 00001111      | 10111100                     | mod reg r/m    |                             | 11+3n           | 11+3n                           | ь               | h                               |
| BSR=Scan Bit Reverse                                                | 00001111      | 10111101                     | mod reg r/m    |                             | 9+3n            | 9+3n                            | Ь               | h                               |
|                                                                     |               |                              | mou reg min    |                             | 1 3701          | 1 3 T UI                        | 1 5             | I "                             |

• If CPL≤IOPL

Clock count shown applies if I/O permission allows I/O to the port in Virtual 8086 Mode. If I/O bit map denies permission, Exception 13 fault occurs; refer to clock counts for INT 3 instruction.

\*\* If CPL > IOPL



#### **Clock Count** Comments Protecte Virtual rotected Real Real Virtual Address Addres Address dela Instruction Format Mode Mode Mode Mode **BIT MANIPULATION (continued)** BT = Test Bit 00001111 Register/Memory, Immediate 10111010 mod 1 0 0 r/m immediate 8-bit data 3/6 3/6 h h Register/Memory, Register 00001111 10100011 mod reg 3/12 3/12 r/m b h BTC = Test Bit and Complement Register/Memory, Immediate 00001111 10111010 mod 1 1 1 immediate 8-bit data 6/8 6/8 b r/m h Register/Memory, Register 00001111 10111011 mod reg r/m 6/13 6/13 b h BTR = Test Bit and Reset Register/Memory, Immediate 00001111 10111010 mod 1 1 0 immediate 8-bit data 6/8 6/8 r/m h h 00001111 10110011 Register/Memory, Register mod rea r/m 6/13 6/13 h h BTS = Test Bit and Set Register/Memory, Immediate 00001111 10111010 mod 1 0 1 r/m immediate 8-bit data 6/8 6/8 b h 00001111 10101011 Register/Memory, Register 6/13 6/13 mod rea r/m h h CONTROL TRANSFER CALL = Call **Direct Within Segment** 11101000 full displacement b 7+m 7 + m Register/Memory 11111111 mod 0 1 0 r/m 7 + m 7 + m b h.r Indirect Within Segment 10 + m 10 + m Direct Intersegment 10011010 unsigned full offset, selector 17 ± m 34 + m h j, k, r Protected Mode Only (Direct Intersegment) Via Call Gate to Same Privilege Level 52 + m h, j, k, r Via Call Gate to Different Privilege Level, (No Parameters) 86 + m h, j, k, r Via Call Gate to Different Privilege Level, (x Parameters) 94+4x+m h, j, k, r From 80286 Task to 80286 TSS 273 h, j, k, r From 80286 Task to Am386DXL CPU TSS 298 h, j, k, r From 80286 Task to Virtual 8086 Task (Am386DXL CPU TSS) 218 h, j, k, r From Am386DXL CPU Task to 80286 TSS 273 h, j, k, r From Am386DXL CPU Task to Am386DXL CPU TSS 300 h, j, k, r From Am386DXL CPU Task to Virtual 8086 Task (Am386DXL CPU TSS) 218 h, j, k, r Indirect Interseament 11111111 mod 0 1 1 r/m 22 + m 38 + m h h, j, k, r Protected Mode Only (Indirect Intersegment) Via Call Gate to Same Privilege Level 56 + m h, j, k, r Via Call Gate to Different Privilege Level (No Parameters) 90 + m h, j, k, r Via Call Gate to Different Privilege Level (x Parameters) 98+4x+m h, j, k, r From 80286 Task to 80286 TSS 278 h, j, k, r From 80286 Task to Am386DXL CPU TSS 303 h, j, k, r From 80286 Task to Virtual 8086 Task (Am386DXL CPU TSS) 222 h, j, k, r From Am386DXL CPU Task to 80286 TSS 278 h, j, k, r From Am386DXL CPU Task to Am386DXL CPU TSS 305 h, j, k, r From Am386DXL CPU Task to Virtual 8086 Task (Am386DXL CPU TSS) 222 h, j, k, i JMP = Unconditional Jump Short 11101011 8-bit displacement 7 + m 7 + m r 11101001 **Direct within Segment** full displacement 7+m 7+m Register/Memory Indirect within Segment 11111111 mod 1 0 0 r/m 7 + m 7 + mh h.r $10 \pm m$ 10 + m**Direct Intersegment** 11101010 unsigned full offset, selector 12 + m 27 + m i, k, r

|                                                                                                                                                                                           |                                                                                        |                     |                   | Clock                   | Clock Count                             |                          | mments                                                             |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|---------------------|-------------------|-------------------------|-----------------------------------------|--------------------------|--------------------------------------------------------------------|
| Instruction                                                                                                                                                                               | Format                                                                                 |                     |                   | Real<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode  | Protected<br>Virtual<br>Address<br>Mode                            |
| CONTROL TRANSFER                                                                                                                                                                          | (continued)                                                                            |                     |                   |                         |                                         |                          |                                                                    |
| Protected Mode Only (Direc<br>Via Call Gate to Same Pri<br>From 80286 Task to 8028<br>From 80286 Task to Am3<br>From 80286 Task to Virtua<br>From Am386DXL CPU Ta<br>From Am386DXL CPU Ta | t Intersegment)<br>vilege Level<br>6 TSS<br>S6DXL CPU TSS<br>al 8086 Task (Am386DXL CP | ·                   |                   | 303<br>221              | 45 + m<br>274<br>301<br>219<br>270      | h, j, k, r<br>h, j, k, r | h, j, k, r<br>h, j, k, r<br>h, j, k, r<br>h, j, k, r<br>h, j, k, r |
| Indirect Intersegment                                                                                                                                                                     | 11111111                                                                               | rnod 101 r/m        |                   | 17+m                    | 31 + m                                  | b                        | h, j, k, r                                                         |
| Protected Mode Only (Indire                                                                                                                                                               | ct Intersegment)                                                                       |                     |                   |                         |                                         |                          |                                                                    |
| From Am386DXL CPU Ta<br>From Am386DXL CPU Ta                                                                                                                                              | 6 TŠS<br>86DXL CPU TSS<br>al 8086 Task (Am386DXL CP                                    |                     |                   | 308<br>225              | 49 + m<br>279<br>306<br>223<br>275      | h, j, k, r<br>h, j, k, r | h, j, k, r<br>h, j, k, r<br>h, j, k, r<br>h, j, k, r<br>h, j, k, r |
| RET = Return from CALL                                                                                                                                                                    |                                                                                        |                     |                   |                         |                                         |                          |                                                                    |
| Within Segment                                                                                                                                                                            | 11000011                                                                               | ]                   |                   | 10+m                    | 10+m                                    | ь                        | g, h, r                                                            |
| Within Seg. Adding Immedia                                                                                                                                                                |                                                                                        | 16-bit displacement |                   | 10+m                    | 10+m                                    | ь                        | g, h, r                                                            |
| Intersegment                                                                                                                                                                              | 11001011                                                                               | 1                   |                   | 18+m                    | 32+m                                    | ь                        | g, h, j, k,                                                        |
| Intersegment Adding Immed                                                                                                                                                                 | liate to SP 11001010                                                                   | 16-bit displacement |                   | 18+m                    | 32+m                                    | ь                        | g,h,j,k,                                                           |
|                                                                                                                                                                                           | -                                                                                      | 'Taken or Not Tal   | (en")             |                         | 69<br>69                                |                          | h, j, k, ı<br>h, j, k, ı                                           |
| JO = Jump on Overflow                                                                                                                                                                     |                                                                                        | T                   | 1                 |                         |                                         |                          |                                                                    |
| 8-bit Displacement                                                                                                                                                                        | 01110000                                                                               | 8-bit displacement  |                   | 7+m or 3                | 7+m or 3                                |                          | r                                                                  |
| Full Displacement                                                                                                                                                                         | 00001111                                                                               | 10000000            | full displacement | 7+m or 3                | 7+m or 3                                |                          | r                                                                  |
| JNO = Jump on Not Overfic                                                                                                                                                                 |                                                                                        | Т                   | 1                 |                         |                                         |                          |                                                                    |
| 8-bit Displacement                                                                                                                                                                        | 01110001                                                                               | 8-bit displacement  |                   | 7+m or 3                | 7+m or 3                                |                          | r                                                                  |
| Full Displacement                                                                                                                                                                         | 00001111                                                                               | 10000001            | full displacement | 7+m or 3                | 7+m or 3                                |                          | r                                                                  |
| JB/JNAE = Jump on Below                                                                                                                                                                   | <b></b>                                                                                |                     | l                 |                         |                                         |                          |                                                                    |
| 8-bit Displacement                                                                                                                                                                        | 01110010                                                                               | 8-bit displacement  |                   | 7+m or 3                | 7+m or 3                                |                          | ſ                                                                  |
| Full Displacement                                                                                                                                                                         | 00001111                                                                               | 10000010            | full displacement | 7+m or 3                | 7+m or 3                                |                          | r                                                                  |
| JNB/JAE = Jump on Not B                                                                                                                                                                   | r                                                                                      | 1                   | 1                 |                         |                                         |                          |                                                                    |
| 8-bit Displacement                                                                                                                                                                        | 01110011                                                                               | 8-bit displacement  |                   | 7+m or 3                | 7+m or 3                                |                          | l '                                                                |
| Full Displacement                                                                                                                                                                         | 00001111                                                                               | 10000011            | full displacement | 7+m or 3                | 7+m or 3                                |                          | ſ                                                                  |
| JE/JZ=Jumpon Equal/Z                                                                                                                                                                      |                                                                                        | 1                   | 1                 |                         |                                         |                          |                                                                    |
| 3-bit Displacement                                                                                                                                                                        | 01110100                                                                               | 8-bit displacement  |                   | 7+m or 3                | 7+m or 3                                |                          | ſ                                                                  |
| Full Displacement                                                                                                                                                                         | 00001111                                                                               | 10000100            | full displacement | 7+m or 3                | 7+m or 3                                | 1                        | r                                                                  |
| JNE/JNZ = Jump on Not Ed                                                                                                                                                                  |                                                                                        | T                   | 1                 |                         |                                         |                          |                                                                    |
| 8-bit Displacement                                                                                                                                                                        | 01110 101                                                                              | 8-bit displacement  |                   | 7+m or 3                | 7+m or 3                                |                          | r                                                                  |
| Full Displacement                                                                                                                                                                         | 00001111                                                                               | 10000101            | full displacement | 7+m or 3                | 7+m or 3                                | 1                        | ľ                                                                  |
|                                                                                                                                                                                           | or Equal/Not Above                                                                     |                     |                   |                         | 1                                       | 1                        | 1                                                                  |
| JBE/JNA = Jump on Below                                                                                                                                                                   |                                                                                        |                     | 1                 |                         |                                         | 1                        |                                                                    |
| JBE/JNA = Jump on Below<br>8 -bit Displacement                                                                                                                                            | 01110110                                                                               | 8-bit displacement  |                   | 7+m or 3                | 7+m or 3                                |                          | r                                                                  |



|                                     |            |                      |                   | <br>Clock Count         |                                         | Con                     | nments                                  |
|-------------------------------------|------------|----------------------|-------------------|-------------------------|-----------------------------------------|-------------------------|-----------------------------------------|
| Instruction                         | Format     |                      |                   | Reai<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode |
| CONDITIONAL JUMPS (continue         |            |                      |                   | <br>mout                |                                         | moue                    |                                         |
| JNBE/JA = Jump on Not Below or Eq   | -          |                      |                   |                         |                                         |                         |                                         |
| 8-bit Displacement                  | 01110111   | 8 - bit displacement | 1                 | 7+m or 3                | 7+m or 3                                |                         | r                                       |
| Full Displacement                   | 00001111   | 10000111             | full displacement | 7+m or 3                | 7+m or 3                                |                         | r                                       |
| JS = Jump on Sign                   | L          | 1                    | ]                 |                         |                                         |                         |                                         |
| 8-bit Displacement                  | 01111000   | 8-bit displacement   | 1                 | 7+m or 3                | 7+m or 3                                |                         | r                                       |
| Full Displacement                   | 00001111   | 10001000             | full displacement | 7+m or 3                | 7+m or 3                                |                         | r                                       |
| JNS = Jump on Not Sign              |            | L                    |                   |                         |                                         |                         |                                         |
| 8-bit Displacement                  | 01111001   | 8 - bit displacement |                   | 7+m or 3                | 7+m or 3                                |                         | r                                       |
| Full Displacement                   | 00001111   | 10001001             | full displacement | 7+m or 3                | 7+m or 3                                |                         | r                                       |
| JP/JPE = Jump on Parity/Parity Even | L          | 1                    |                   |                         |                                         |                         |                                         |
| 8-bit Displacement                  | 01111010   | 8 - bit displacement |                   | 7+m or 3                | 7+m or 3                                |                         | r                                       |
| Full Displacement                   | 00001111   | 10001010             | full displacement | 7+m or 3                | 7+m or 3                                |                         | r                                       |
| JNP/JPO = Jump on Not Parity/Parity |            | 1                    |                   |                         |                                         |                         |                                         |
| 8-bit Displacement                  | 01111011   | 8 -bit displacement  | 1                 | 7+m or 3                | 7+m or 3                                |                         | l r                                     |
| Full Displacement                   | 00001111   | 10001011             | full displacement | 7+m or 3                | 7+m or 3                                |                         | r                                       |
| JL/JNGE = Jump on Less/Not Greate   | L          | 1                    |                   |                         |                                         |                         |                                         |
| 8-bit Displacement                  | 01111100   | 8 -bit displacement  | ]                 | 7+m or 3                | 7+m or 3                                |                         | l r                                     |
| Full Displacement                   | 00001111   | 10001100             | full displacement | 7+m or 3                | 7+m or 3                                |                         | l r                                     |
| JNL/JGE = Jump on Not Less/Greate   | L          | 1                    |                   |                         |                                         |                         |                                         |
| 8-bit Displacement                  | 01111101   | 8 -bit displacement  | 1                 | 7+m or 3                | 7+m or 3                                | í                       | r                                       |
| Full Displacement                   | 00001111   | 10001101             | full displacement | 7+m or 3                | 7+m or 3                                | l                       | r                                       |
| JLE/JNG = Jump on Less or Equal/N   | ot Greater | .i                   | 1                 |                         |                                         |                         |                                         |
| 8-bit Displacement                  | 01111110   | 8 -bit displacement  | }                 | 7+m or 3                | 7+m or 3                                |                         | r                                       |
| Full Displacement                   | 00001111   | 10001110             | full displacement | 7+m or 3                | 7+m or 3                                |                         | r                                       |
| JNLE/JG = Jump on Not Less or Equ   | al/Greater | 1                    | ]                 | 2                       |                                         |                         |                                         |
| 8-bit Displacement                  | 01111111   | 8 -bit displacement  | ]                 | 7+m or 3                | 7+m or 3                                | [                       | l r                                     |
| Full Displacement                   | 00001111   | 10001111             | full displacement | 7+m or 3                | 7+m or 3                                |                         | r                                       |
| JCXZ = Jump on CX Zero *            | 11100011   | 8-bit displacement   |                   | 9+m or 5                | 9+m or 5                                |                         | r                                       |
| JECXZ = Jump on ECX Zero *          | 11100011   | 8-bit displacement   |                   | 9+m or 5                | 9+m or 5                                |                         | r                                       |
| LOOP = Loop CX Times                | 11100010   | 8 - bit displacement |                   | 11 + m                  | 11+m                                    |                         | l r                                     |
| LOOPZ/LOOPE = Loop with Zero/Equal  |            | 8-bit displacement   |                   | 11 + m                  | 11+m                                    |                         | r                                       |
| LOOPNZ/LOOPNE=Loop while Not Zero   |            | 8-bit displacement   |                   | 11 + m                  | 11+m                                    | 1                       | r                                       |
| CONDITIONAL BYTE SET (Note          | L          |                      | 1                 |                         |                                         |                         |                                         |
| SETO = Set Byte on Overflow         |            |                      |                   |                         |                                         |                         |                                         |
| To Register/Memory                  | 00001111   | 10010000             | mod 0 0 0 r/m     | 4/5                     | 4/5                                     |                         | h                                       |
| SETNO=Set Byte on Not Overflow      | L          | L                    | I                 |                         |                                         |                         |                                         |
| To Register/Memory                  | 00001111   | 10010001             | mod 0 0 0 r/m     | 4/5                     | 4/5                                     |                         | h                                       |
| SETB/SETNAE = Set Byte on Below/    | L          |                      | I                 |                         |                                         |                         |                                         |
| To Register/Memory                  | 00001111   | 10010010             | mod 0 0 0 r/m     | 4/5                     | 4/5                                     |                         | h                                       |
| g;                                  | L          | 1                    | 1                 |                         | I "Ŭ                                    | I                       | 1                                       |

\* Address Size Prefix Differentiates JCXZ from JECXZ.

| Instruction         Period         Nature<br>Autom         Period<br>Autom         Nature<br>Autom         Period<br>Autom         Nature<br>Autom                                                                                                                                                                                                                                                                                                                                                                                                                    |                                    |                                                  | Clock Count |                    |            |                                       |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|--------------------------------------------------|-------------|--------------------|------------|---------------------------------------|
| CONDITIONAL BYTE SET (continued)         45         45           SETME 3set Byte on Not Below/Above or Equal         45         45         45           To Register/Memory         0 0 0 0 1 1 1 1 0 0 1 0 0 0 1 m         45         45         45           SETME 3set Byte on Not Equal/Not Zeroo         45         45         45         45           To Register/Memory         0 0 0 0 1 1 1 1 0 0 1 0 1 0 1 mod 0 0 0 m         45         45         45           SETMESETN2 = Set Byte on Not Equal/Not Zeroo         45         45         45         45           To Register/Memory         0 0 0 0 1 1 1 1 0 0 1 0 1 0 1 1 mod 0 0 0 m         45         45         45           SETMESETNA = Set Byte on Not Equal/Not Above         45         45         45         h           To Register/Memory         0 0 0 0 1 1 1 1 0 0 1 1 0 1 mod 0 0 0 m         45         45         h           SETNESETNA = Set Byte on Not Biow or Equal/Rove         45         45         h           To Register/Memory         0 0 0 0 1 1 1 1 0 0 1 1 0 0 1 mod 0 0 0 m         45         45         h           SETNESETO = Set Byte on Not Sign         45         45         h         5           To Register/Memory         0 0 0 0 1 1 1 1 0 0 1 1 0 0 1 mod 0 0 0 m         45         45         h <th>Instruction</th> <th>Format</th> <th>Address</th> <th>Virtual<br/>Address</th> <th>Address</th> <th>Protecte<br/>Virtual<br/>Addres<br/>Mode</th>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Instruction                        | Format                                           | Address     | Virtual<br>Address | Address    | Protecte<br>Virtual<br>Addres<br>Mode |
| SETNB = Set Byte on Not Below/Above or Equal         4/5         4/5         4/5         h           To Register/Memory         0.0001111         1.001001         mod 0.00 //m         4/5         4/5         h           SETE/SETZ = Set Byte on Net Equal/Not Zero         0.0001111         1.001001         mod 0.00 //m         4/5         4/5         h           To Register/Memory         0.0001111         1.001001         mod 0.00 //m         4/5         4/5         h           SETE/SETXA = Set Byte on Net Equal/Not Zero         0.0001111         1.001001         mod 0.00 //m         4/5         4/5         h           SETE/SETXA = Set Byte on Not Below or Equal/Above         0.0001111         1.001010         mod 0.00 //m         4/5         4/5         h           SETNE/SETVA = Set Byte on Not Below or Equal/Above         0.0001111         1.001100         mod 0.00 //m         4/5         4/5         h           SETNE/SETVA = Set Byte on Not Below         0.0001111         1.001100         mod 0.00 //m         4/5         4/5         h           SETNE/SETVA = Set Byte on Net Hyte/Party Even         1.00110.01         mod 0.00 //m         4/5         4/5         h           SETNE/SETVA = Set Byte on Net Hyte/Party Even         1.00110.01         mod 0.00 //m         4/5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                    |                                                  | mode        | Mode               | mode       | mode                                  |
| To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 0 0 1 1       mod 0 0 0       mm       45       45       h         SETESET72 = Set Byte on Equal/Zero       0 0 0 0 1 1 1 1       1 0 0 1 0 0 0       mod 0 0 0       md       45       45       h         SETESET72 = Set Byte on Net Equal/Not Zero       0 0 0 0 1 1 1 1       1 0 0 1 0 0 1       mod 0 0 0       md       45       45       h         SETESESTA = Set Byte on Net Equal/Not Zero       0 0 0 0 1 1 1 1       1 0 0 1 0 1 1       mod 0 0 0       md       45       45       h         SETNESESTA = Set Byte on Not Betwore Equal/Mobove       0 0 0 0 1 1 1 1       1 0 0 1 0 1 1       mod 0 0 0       md       45       45       h         SETNESESTA = Set Byte on Not Betwore Equal/Mobove       0 0 0 0 1 1 1 1       1 0 0 1 1 0 0       mod 0 0 0       md       45       45       h         SETNESESTA = Set Byte on Not Betwore Equal/Mobove       0 0 0 0 1 1 1 1       1 0 0 1 1 0 0       mod 0 0 0       md       45       45       h         SETNESETD = Set Byte on Not Sign       1 0 0 0 1 1 1 1       1 0 0 1 1 0 1       mod 0 0 0       md       45       45       h         SETN/SETD = Set Byte on Not Partiv/Partify Codd       1 0 0 0 1 1 1 1       1 0 0 1 1 1 1       n 0 0 0 0       md 0 0 0 <t< td=""><td></td><td></td><td></td><td></td><td></td><td></td></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                    |                                                  |             |                    |            |                                       |
| SETE/SET2 = Set Byte on Equal/Zero       4/5       4/5         To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 0 1 0 1       mod 0 0 0 1/m         SETE/SETVA = Set Byte on Not Equal/Not Above       4/5       4/5       4/5         To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 0 1 0 1       mod 0 0 0 1/m         SETE/SETVA = Set Byte on Not Equal/Not Above       4/5       4/5       4/5         To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 0 1 1 0       mod 0 0 0 1/m         SETS Set Byte on Not Educer or Equal/Above       4/5       4/5       4/5         To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 0 0 0 1/m       4/5       4/5       h         SETS Set Byte on Not Educer or Equal/Above       4/5       4/5       h       h         SETNES/Set Byte on Not Sign       4/5       4/5       h       h         To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 0 0 1       mod 0 0 0 1/m       4/5       4/5       h         SETNES/Set Byte on Not Sign       1       0 0 0 0 1 1 1 1       1 0 0 1 1 0 1       mod 0 0 0 1/m       4/5       4/5       h         SETNES/Set Byte on Net Sign       1       0 0 0 0 1 1 1 1       1 0 0 1 1 0 1       mod 0 0 0 1/m       4/5       4/5       h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | -                                  |                                                  | 4/5         | 4/5                |            | h                                     |
| To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 0 1 0 0       mod 0 0 0       r/m       4/5       4/5       h         SETNESETNZ = Set Byte on Not Equal/Not Zero       0 0 0 0 1 1 1 1       1 0 0 1 0 1 0 1       mod 0 0 0       r/m       4/5       4/5       h         SETBESETNA = Set Byte on Not Balow or Equal/Not Above       0 0 0 0 1 1 1 1       1 0 0 1 0 1 0 1 1       mod 0 0 0       r/m       4/5       4/5       h         SETBESETNA = Set Byte on Not Balow or Equal/Not Above       0 0 0 0 1 1 1 1       1 0 0 1 0 1 1 1       mod 0 0 0       r/m       4/5       4/5       h         SETNESETNA = Set Byte on Not Balow or Equal/Above       0 0 0 0 1 1 1 1       1 0 0 1 0 1 0 1       mod 0 0 0       r/m       4/5       4/5       h         SETNESETNA = Set Byte on Not Balow       0 0 0 0 1 1 1 1       1 0 0 1 1 0 0 1       mod 0 0 0       r/m       4/5       4/5       h         SETNESETNAE = Set Byte on Not Sign       0 0 0 0 1 1 1 1       1 0 0 1 1 0 0 1       mod 0 0 0       r/m       4/5       4/5       h         SETNSETCES = Set Byte on Not Parity/Parity Even       To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 0 0       r/m 0 0 0 0       r/m       4/5       4/5       h         SETN/SETOS = Set Byte on Not Lese/Creater or Equal       To Register/Me                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                    |                                                  |             |                    |            |                                       |
| SETNE/SETNZ=Set Byte on Not Equal/Not Zero       4/5       4/5       4/5         To Register/Memory       0 0 0 0 1 11 1       1 0 0 1 0 1 0 1       mod 0 0 0 r/m       4/5       4/5       h         SETNE/SETNA=Set Byte on Not Below or Equal/Not Above       4/5       4/5       4/5       h         To Register/Memory       0 0 0 0 1 11 1       1 0 0 1 0 1 1 1       mod 0 0 0 r/m       4/5       4/5       h         SETNE/SETA=Set Byte on Not Below or Equal/Above       4/5       4/5       h       h       h         To Register/Memory       0 0 0 0 1 11 1       1 0 0 1 0 10 1       mod 0 0 0 r/m       4/5       4/5       h         SETNE set Byte on Not Sign                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                    |                                                  | 4/5         | 4/5                |            | h                                     |
| To Register/Memory       0 0 0 0 1 11 1       1 0 0 1 0 1 0 1       mod 0 0 0 r/m       445       445       h         SETBLESETNA_Set Byde on Balow or Equal/Not Above                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                    |                                                  |             |                    |            |                                       |
| SETBE/SETNA = Set Byte on Below or Equal/Not Above         4/5         4/5         h           To Register/Memory         0 0 0 0 1 1 1 1         1 0 0 1 0 1 1 0         mod 0 0 0 r/m         4/5         4/5         h           SETMBE/SETA = Set Byte on Not Below or Equal/Above         0 0 0 0 1 1 1 1         1 0 0 1 0 1 1 1         mod 0 0 0 r/m         4/5         4/5         h           SETS = Set Byte on Not Sign         0 0 0 0 1 1 1 1         1 0 0 1 1 0 0 1         mod 0 0 0 r/m         4/5         4/5         h           SETN = Set Byte on Not Sign         0 0 0 0 1 1 1 1         1 0 0 1 1 0 0 1         mod 0 0 0 r/m         4/5         4/5         h           SETNS = Set Byte on Not Sign         0 0 0 0 1 1 1 1         1 0 0 1 1 0 0 1         mod 0 0 0 r/m         4/5         4/5         h           SETNS = Set Byte on Not Parity/Parity Even         1 0 0 1 1 0 1 1         mod 0 0 0 r/m         4/5         4/5         h           SETN/SETPO= Set Byte on Not Parity/Parity Odd         1 0 0 0 0 0 1 1 1 1         1 0 0 1 1 0 0 1         mod 0 0 0 r/m         4/5         4/5         h           SETL/SETIGE = Set Byte on Not Less/For Equal         0 0 0 0 1 1 1 1         1 0 0 1 1 1 0 0 1         mod 0 0 0 r/m         4/5         4/5         h           SETL/SETIGE = Set Byte on Not Less or Equal/Creater                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                    |                                                  | 4/5         | 4/5                |            | h                                     |
| To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 0 1 1 0       mod 0 0 0       r/m       4/5       4/5       h         SETNBE/SETA = Set Byte on Not Below or Equal/Above       0 0 0 0 1 1 1 1       1 0 0 1 0 1 1 1       mod 0 0 0       r/m       4/5       4/5       h         SETS = Set Byte on Not Below or Equal/Above       0 0 0 0 1 1 1 1       1 0 0 1 0 0 0       r/m       4/5       4/5       h         SETNS = Set Byte on Not Sign       0 0 0 0 1 1 1 1       1 0 0 1 1 0 0 1       mod 0 0 0       r/m       4/5       4/5       h         SETNS = Set Byte on Not Sign       0 0 0 0 1 1 1 1       1 0 0 1 1 0 0 1       mod 0 0 0       r/m       4/5       4/5       h         SETNS = Set Byte on Not Parity/Parity Even       4/5       4/5       h       h       Set Dyte on Not Parity/Parity Odd       4/5       4/5       h         To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 0 0 1       mod 0 0 0       r/m       4/5       4/5       h         SETUSETGE = Set Byte on Not Less/For Equal       mod 0 0 0       r/m       4/5       4/5       h         SETUSETGE = Set Byte on Not Less/For Equal/Creater       mod 0 0 0       r/m       4/5       4/5       h         SETUSETMSETGE = Set Byte on Not Less or Equal/Creater <td< td=""><td></td><td></td><td></td><td></td><td></td><td></td></td<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                    |                                                  |             |                    |            |                                       |
| SETNBE/SETA = Set Byte on Not Below or Equal/Above       4/5       4/5       h         To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 0 0 0 mod 0                                                                       |                                    |                                                  | 4/5         | 4/5                |            | h                                     |
| To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 0 0 1 1 1 1       mod 0 0 0 r/m       4/5       4/5       h         SETS = Set Byte on Not Sign       0 0 0 0 1 1 1 1       1 0 0 1 1 0 0 1       mod 0 0 0 r/m       4/5       4/5       h         SETN = Set Byte on Not Sign       0 0 0 0 1 1 1 1       1 0 0 1 1 0 0 1       mod 0 0 0 r/m       4/5       4/5       h         SETNS = Set Byte on Not Sign       0 0 0 0 1 1 1 1       1 0 0 1 1 0 0 1       mod 0 0 0 r/m       4/5       4/5       h         SETP/SETPE = Set Byte on Not Parity/Parity Even       0 0 0 0 1 1 1 1       1 0 0 1 1 0 1       mod 0 0 0 r/m       4/5       4/5       h         SETN/SETPC = Set Byte on Not Parity/Parity Odd       0 0 0 0 1 1 1 1       1 0 0 1 1 0 0 1 mod 0 0 0 r/m       4/5       4/5       h         SETL/SETROE = Set Byte on Less/Not Greater or Equal       0 0 0 0 1 1 1 1       0 0 1 1 1 1 0 0 1 1 1 0 0       mod 0 0 0 r/m       4/5       4/5       h         SETL/SETGE = Set Byte on Not Less or Equal/Not Greater       1 0 0 1 1 1 1 0 0 1 1 1 1 0       mod 0 0 0 r/m       4/5       4/5       h         SETLE/SETG = Set Byte on Not Less or Equal/Not Greater       1 0 0 1 1 1 1 0 0 1 1 1 1 0       mod 0 0 0 r/m       4/5       4/5       h         SETLE/SETG = Set Byte on Not Less or Equal/Greater       1 0 0 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                    |                                                  |             |                    |            |                                       |
| SETS = Set Byte on Sign       4/5       4/5       4/5       h         To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 0 0 1       mod 0 0 0       r/m       4/5       4/5       h         SETN S = Set Byte on Not Sign       4/5       4/5       4/5       h       h         To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 0 0 1       mod 0 0 0       r/m       4/5       4/5       h         SETN/SETPC = Set Byte on Not Parity/Parity Even       0 0 0 0 1 1 1 1       1 0 0 1 1 0 1 1       mod 0 0 0       r/m       4/5       4/5       h         SETN/SETPC = Set Byte on Not Parity/Parity Odd       0 0 0 0 1 1 1 1       1 0 0 1 1 0 1 1       mod 0 0 0       r/m       4/5       4/5       h         SETN/SETOE = Set Byte on Not Less/Roreater or Equal       4/5       4/5       h       h       SETN/SETOE = Set Byte on Not Less/Roreater or Equal       4/5       4/5       h         To Register/Memory       0 0 0 0 1 1 1 1       0 1 1 1 1 1 0 1 1 1 1 0 1       mod 0 0 0       r/m       4/5       4/5       h         SETL/SETOE = Set Byte on Not Less or Equal/Not Greater       To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 1 1       mod 0 0 0       r/m       4/5       4/5       h         SETNLE/SETOE = Set Byte on No                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | -                                  |                                                  | 4/5         | 4/5                |            | h                                     |
| To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 0 0 1       mod 0 0 0t/m       4/5       4/5       h         SETNS = Set Byte on Not Sign                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                    |                                                  |             |                    |            |                                       |
| To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 0 0 1       mod 0 0 0       r/m         SETP/SETPE = Set Byte on Parity/Parity Even       4/5       4/5       4/5       h         To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 0 1 0       mod 0 0 0       r/m       4/5       4/5       h         SETP/SETPO = Set Byte on Not Parity/Parity Odd       To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 0 1 1       mod 0 0 0       r/m         SETL/SETNGE = Set Byte on Less/Not Greater or Equal       To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 1 0 1       mod 0 0 0       r/m         SETNL/SETGE = Set Byte on Not Less/Greater or Equal       To Register/Memory       0 0 0 0 1 1 1 1       0 1 1 1 1 1 0 0 1 1 1 0 1       mod 0 0 0       r/m         SETNL/SETGE = Set Byte on Not Less/Greater or Equal       To Register/Memory       0 0 0 0 1 1 1 1       0 1 1 1 1 1 0 0 1 1 1 1 0       mod 0 0 0       r/m         SETNLE/SETG = Set Byte on Not Less or Equal/Greater       To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 1 1 1       mod 0 0 0       r/m         SETNLE/SETG = Set Byte on Not Less or Equal/Greater       To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 1 1 1       mod 0 0 0       r/m         L=0       L=0       1 1 0 0 1 0 0 1       1 1 0 0 1 1 0 1       To H <td< td=""><td></td><td>00001111 10011000 mod 000 r/m</td><td>4/5</td><td>4/5</td><td></td><td>h</td></td<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                    | 00001111 10011000 mod 000 r/m                    | 4/5         | 4/5                |            | h                                     |
| SETP/SETPE = Set Byte on Parity/Parity Even       4/5       4/5       h         To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 0 1 0       mod 0 0 0 "/m       4/5       4/5       h         SETP/SETPO = Set Byte on Not Parity/Parity Odd       0 0 0 0 1 1 1 1       1 0 0 1 1 0 1 1       mod 0 0 0 "/m       4/5       4/5       h         SET/SETPG = Set Byte on Less/Not Greater or Equal       mod 0 0 0 "/m       4/5       4/5       h         SETNL/SETIGE = Set Byte on Not Less/Greater or Equal       mod 0 0 0 "/m       4/5       4/5       h         SETNL/SETIGE = Set Byte on Not Less/Greater or Equal       mod 0 0 0 "/m       4/5       4/5       h         SETNL/SETIGE = Set Byte on Not Less/Greater or Equal/Not Greater       mod 0 0 0 "/m       4/5       4/5       h         SETNLE/SETG = Set Byte on Not Less or Equal/Not Greater       mod 0 0 0 "/m       4/5       4/5       h         SETNLE/SETG = Set Byte on Not Less or Equal/Greater       mod 0 0 0 "/m       4/5       4/5       h         L = 0       1 1 0 0 1 1 0 1       1 1 0 0 1 1 1 1       mod 0 0 0 "/m       4/5       4/5       h         L = 0       1 1 0 0 1 0 0 1       1 1 0 0 1 1 0 1       mod 0 0 0 "/m       4/5       h       h         L = 0       1 1 0 0 1 0 0 1       <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | SETNS = Set Byte on Not Sign       |                                                  |             |                    |            |                                       |
| To Register/Memory       00001111       1001101       mod 000 r/m       4/5       4/5       h         SETNP/SETPO=Set Byte on Not Parity/Parity Odd       00001111       1001101       mod 000 r/m       4/5       4/5       h         SETNP/SETROE_Set Byte on Not Parity/Parity Odd       00001111       1001101       mod 000 r/m       4/5       4/5       h         SETL/SETNGE_Set Byte on Not Less/Not Greater or Equal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | To Register/Memory                 | 00001111 10011001 mod 000 r/m                    | 4/5         | 4/5                |            | h                                     |
| SETNP/SETPO= Set Byte on Not Parity/Parity Odd <ul> <li>To Register/Memory</li> <li>0 0 0 0 1 1 1 1</li> <li>1 0 0 1 1 0 1 1</li> <li>1 0 0 1 1 0 1</li> <li>1 0 0 1 1 1 1</li> <li>0 0 0 0 0 1 1 1</li> <li>0 0 0 0 0 1 1 1 1</li> <li>0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | SETP/SETPE = Set Byte on Parity/Pa | rity Even                                        |             |                    |            |                                       |
| To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 0 1 1       mod 0 0 0       r/m         SETL/SETNGE = Set Byte on Less/Not Greater or Equal       4/5       4/5       4/5       h         To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 0 0       mod 0 0 0       r/m       4/5       4/5       h         SETL/SETNGE = Set Byte on Less/Reater or Equal       mod 0 0 0       r/m       4/5       4/5       h         To Register/Memory       0 0 0 0 1 1 1 1       0 1 1 1 1 1 0       mod 0 0 0       r/m       4/5       4/5       h         SETL/SETNG = Set Byte on Not Less/Greater or Equal/Not Greater       10 0 1 1 1 1       0 0 0 0 1 1 1 1       mod 0 0 0       r/m         SETNLE/SETG = Set Byte on Not Less or Equal/Greater       10 0 0 0 1 1 1 1       10 0 1 1 1 1       mod 0 0 0       r/m         SETNLE/SETG = Set Byte on Not Less or Equal/Greater       10 0 1 0 0 16-bit displacement, 8-bit level       10       10       b         L=0       12       12       12       b       h         L=1       1       10 0 1 0 0 1       1       h       h         LEAVE = Leave Procedure       1 1 0 0 1 1 0 1       type       37       b         Type 3       1 1 0 0 1 1 0 1       type       33       b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | To Register/Memory                 | 00001111 10011010 mod 000 r/m                    | 4/5         | 4/5                |            | h                                     |
| SETL/SETNGE = Set Byte on Less/Not Greater or Equal       4/5       4/5       h         Fo Register/Memory       0 0 0 0 1 1 1 1       0 0 1 1 1 0 0       mod 0 0 0       r/m       4/5       4/5       h         SETNUSETGE = Set Byte on Not Less/Greater or Equal       0 0 0 0 1 1 1 1       0 1 1 1 1 1 0 1       mod 0 0 0       r/m       4/5       4/5       h         SETNUSETGE = Set Byte on Not Less/Greater or Equal/Not Greater       mod 0 0 0       r/m       4/5       4/5       h         SETNLE/SETNG = Set Byte on Not Less or Equal/Greater       mod 0 0 0       r/m       4/5       4/5       h         SETNLE/SETG = Set Byte on Not Less or Equal/Greater       mod 0 0 0       r/m       4/5       4/5       h         SETNER = Enter Procedure       1 1 0 0 1 1 1 1       1 0 0 1 1 1 1       mod 0 0 0       r/m       4/5       4/5       h         L=0       L=0       10       10       b       h       h       h       h         L=AVE = Leave Procedure       1 1 0 0 1 1 0 1       10       4/4       b       h       h         NTERRUPT INSTRUCTIONS       11 0 0 1 1 0 1       type       33       b       h       h         NT0 = Interrupt 4 if Overflow Flag Set       1 1 0 0 1 1 1 0       10 0 1 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | SETNP/SETPO=Set Byte on Not Pa     | rity/Parity Odd                                  |             |                    |            |                                       |
| To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 1 0 0       mod 0 0 0       r/m         SETNL/SETGE = Set Byte on Not Less/Greater or Equal       4/5       4/5       4/5       h         To Register/Memory       0 0 0 0 1 1 1 1       0 1 1 1 1 0 1       mod 0 0 0       r/m       4/5       4/5       h         SETNL/SETGE = Set Byte on Not Less or Equal/Not Greater       mod 0 0 0       r/m       4/5       4/5       h         To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 1 0       mod 0 0 0       r/m       4/5       4/5       h         SETNLE/SETGE = Set Byte on Not Less or Equal/Greater       10 0 1 0 1 1 1       mod 0 0 0       r/m       4/5       4/5       h         To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 1 1       mod 0 0 0       r/m       4/5       4/5       h         SETNLE/SETG = Set Byte on Not Less or Equal/Greater       1 1 0 0 1 1 0 0       16-bit displacement, 8-bit level       10       10       b       h         L = 0       1 1 0 0 1 0 0 0       16-bit displacement, 8-bit level       10       12       12       b       h         LEAVE = Leave Procedure       1 1 0 0 1 0 0 1       type       37       b       h         INTERRUPT INSTRUCTIONS       11 0 0 1 1 0 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | To Register/Memory                 | 00001111 10011011 mod 000 r/m                    | 4/5         | 4/5                |            | h                                     |
| SETNL/SETGE = Set Byte on Not Less/Greater or Equal       mod 0 0 0 r/m       4/5       4/5       h         Fo Register/Memory       0 0 0 0 1 1 1 1       0 1 1 1 1 1 0 0 1 1 1 1 0       mod 0 0 0 r/m       4/5       4/5       h         SETNLE/SETGE = Set Byte on Less or Equal/Not Greater       0 0 0 0 1 1 1 1       1 0 0 1 1 1 1 0       mod 0 0 0 r/m       4/5       4/5       h         Fo Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 1 1 1       mod 0 0 0 r/m       4/5       4/5       h         SETNLE/SETGE = Set Byte on Not Less or Equal/Greater       1 0 0 1 1 1 1       mod 0 0 0 r/m       4/5       4/5       h         SETNLE/SETGE = Set Byte on Not Less or Equal/Greater       1 0 0 1 1 1 1       mod 0 0 0 r/m       4/5       4/5       h         SETNLE/SETGE = Set Byte on Not Less or Equal/Greater       1 1 0 0 1 0 0       16-bit displacement, 8-bit level       10       10       b       h         L = 0       1 1 0 0 1 0 0       16-bit displacement, 8-bit level       10       10       10       b       h         L= 1       1 1 0 0 1 0 0       1       15+4(n-1)       b       h       h         LEAVE = Leave Procedure       1 1 0 0 1 1 0 1       type       37       b       h         Type Specified       1 1 0 0 1 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | SETL/SETNGE = Set Byte on Less/N   | bt Greater or Equal                              |             |                    |            |                                       |
| To Register/Memory       0 0 0 0 1 1 1 1       0 1 1 1 1 1 0 1       mod 0 0 0       r/m         SETLE/SETNG=Set Byte on Less or Equal/Not Greater       0 0 0 0 1 1 1 1       1 0 0 1 1 1 1 0       mod 0 0 0       r/m         Fo Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 1 1 0       mod 0 0 0       r/m       4/5       4/5       h         SETNLE/SETG=Set Byte on Not Less or Equal/Greater       mod 0 0 0       r/m       4/5       4/5       h         To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 1 1 1       mod 0 0 0       r/m       4/5       4/5       h         SETNLE/SETG=Set Byte on Not Less or Equal/Greater       1 1 0 0 1 0 0 1       mod 0 0 0       r/m       4/5       4/5       h         SETNERSETG=Set Byte on Not Less or Equal/Greater       1 1 0 0 1 0 0 1       16-bit displacement, 8-bit level       10       10       b       h         L=0       L=1       1 1 0 0 1 0 0 1       16-bit displacement, 8-bit level       12       12       b       h         L=1       L=1       1 1 0 0 1 0 0 1       15-bit displacement, 8-bit level       12       15+4(n=1)       b       h         INTERRUPT INSTRUCTIONS       33       4       4       b       h         Type 3       1 1 0 0 1 1 0 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | To Register/Memory                 | 00001111 10011100 mod 000 r/m                    | 4/5         | 4/5                |            | h                                     |
| SETLE/SETNG = Set Byte on Less or Equal/Not Greater       4/5       4/5       h         To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 1 1 0       mod 0 0 0       r/m       4/5       4/5       h         SETNLE/SETG = Set Byte on Not Less or Equal/Greater       0 0 0 0 1 1 1 1       1 0 0 1 1 1 1 1       mod 0 0 0       r/m       4/5       4/5       h         To Register/Memory       0 0 0 0 1 1 1 1       1 0 0 1 1 1 1 1       mod 0 0 0       r/m       4/5       4/5       h         ENTER = Enter Procedure       1 1 0 0 1 0 0 0       16-bit displacement, 8-bit level       10       10       b       h         L=0       L=1       1       10 0 1 0 0 1       15+4(n-1)       b       h         LEAVE = Leave Procedure       1 1 0 0 1 0 0 1       4       4       b       h         INTERRUPT INSTRUCTIONS       4       4       b       h         NT = Interrupt:       7       b       5       b       b         Type 3       1 1 0 0 1 1 0 1       10       33       b       b         If OF = 1       35       b, e       b, e       b       b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | SETNL/SETGE = Set Byte on Not Let  | s/Greater or Equal                               |             |                    |            |                                       |
| To Register/Memory       0 0 0 0 1 1 1 1 1 0 0 1 1 1 1 0 mod 0 0 0 r/m       4/5       4/5       h         SETNLE/SETG = Set Byte on Not Less or Equal/Greater       0 0 0 0 1 1 1 1 1 0 0 1 1 1 1 1 mod 0 0 0 r/m       4/5       4/5       h         To Register/Memory       0 0 0 0 1 1 1 1 1 0 0 1 1 1 1 1 mod 0 0 0 r/m       4/5       4/5       h         To Register/Memory       0 0 0 0 1 1 1 1 1 0 0 1 1 1 1 1 mod 0 0 0 r/m       4/5       4/5       h         ENTER = Enter Procedure       1 1 0 0 1 0 0 0 16-bit displacement, 8-bit level       10       10       b       h         L=0       12       12       b       h       h       h       h       h         L=1       1       1 0 0 1 0 0 1       16-bit displacement, 8-bit level       10       10       b       h         LEAVE = Leave Procedure       1 1 0 0 1 0 0 1       4       4       b       h         INTERRUPT INSTRUCTIONS       4       4       b       h         Type Specified       1 1 0 0 1 1 0 1 type       33       b       h         If OF = 1       35       b, e       b, e       b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | To Register/Memory                 | 00001111 0111101 mod 000 r/m                     | 4/5         | 4/5                |            | h                                     |
| SETNLE/SETG = Set Byte on Not Less or Equal/Greater         To Register/Memory       0 0 0 0 1 1 1 1 1 0 0 1 1 1 1 1 mod 0 0 0 r/m         ENTER = Enter Procedure       1 1 0 0 1 0 0 0 16-bit displacement, 8-bit level         L = 0       10 10 b         L = 1       12 12 b         L > 1       15+4(n-1)         L = 1       15+4(n-1)         L > 1       10 0 1 0 0 1         L = 1       10 1 0 b         L > 1       11 0 0 1 0 0 1         INTERRUPT INSTRUCTIONS       4         NT = Interrupt:       7         Type 3       11 0 0 1 1 0 1         If OF = 1       35                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | SETLE/SETNG = Set Byte on Less o   | Equal/Not Greater                                |             |                    |            |                                       |
| To Register/Memory       0 0 0 0 1 1 1 1 1 0 0 1 1 1 1 1 mod 0 0 0 r/m       4/5       4/5       h         ENTER = Enter Procedure       1 1 0 0 1 0 0 0 16-bit displacement, 8-bit level       10       10       b       h         L=0       12       12       b       h       h       h       h         L=1       10 1 0 0 0       16-bit displacement, 8-bit level       10       10       b       h         L=1       1       10 0 1 0 0 1       16-bit displacement, 8-bit level       11       12       b       h         L=1       1       10 0 1 0 0 1       12       15+4(n=1)       b       h         LEAVE = Leave Procedure       1 1 0 0 1 0 0 1       4       4       b       h         INTERRUPT INSTRUCTIONS       4       4       b       h         INT = Interrupt:       7       5       b       b         Type 3       1 1 0 0 1 1 0 1       10       33       b       b         If OF = 1       35       b, e       b, e       b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | To Register/Memory                 | 00001111 10011110 mod 000 r/m                    | 4/5         | 4/5                |            | h                                     |
| ENTER = Enter Procedure         1 1 0 0 1 0 0 0         16-bit displacement, 8-bit level         10         10         b         h           L=0         12         12         b         h         12         12         b         h           L=1         10 0 1 0 0 1         10 0 1 0 0         16-bit displacement, 8-bit level         10         10         b         h           LEAVE = Leave Procedure         11 0 0 1 0 0 1         4         4         b         h           INTERRUPT INSTRUCTIONS         4         4         b         h           INT = Interrupt:         7         b         5         b           Type 3         11 0 0 1 1 0 1         type         33         b           INTO = Interrupt 4 if Overfiow Flag Set         11 0 0 1 1 1 0         5         b, e                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | SETNLE/SETG = Set Byte on Not Les  | s or Equal/Greater                               |             |                    |            |                                       |
| L=0       10       10       10       10       12       12       12       12       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15       15 <t< td=""><td>To Register/Memory</td><td>00001111 10011111 mod 000 r/m</td><td>4/5</td><td>4/5</td><td></td><td>h</td></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | To Register/Memory                 | 00001111 10011111 mod 000 r/m                    | 4/5         | 4/5                |            | h                                     |
| L=1       12       12       b       h         L=1       15+4(n-1)       12       b       h         LEAVE=Leave Procedure       11001001       4       4       b       h         INTERRUPT INSTRUCTIONS       4       4       b       h         INT=Interrupt:       7       5       b       b         Type 3       11001100       33       b       b         INTO=Interrupt 4 if Overflow Flag Set       11001110       b, e       b, e                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ENTER = Enter Procedure            | 1 1 0 0 1 0 0 0 16-bit displacement, 8-bit level |             |                    |            |                                       |
| L>1       15+4(n-1)       15+4(n-1)       b       h         LEAVE = Leave Procedure       11001001       4       4       b       h         INTERRUPT INSTRUCTIONS       4       4       b       h         INT = Interrupt:       37       b       b         Type Specified       11001100       33       b         INTO=Interrupt 4 if Overflow Flag Set       11001110       b, e                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                    |                                                  |             |                    |            | h                                     |
| INTERRUPT INSTRUCTIONS         Image: Construction of the second of |                                    |                                                  |             |                    |            | h                                     |
| NT = Interrupt:     I     1     0     1     1     type       Type Specified     1     1     0     1     0       Type 3     1     1     0     1     0       INTO = Interrupt 4 if Overflow Flag Set     1     1     0     1       If OF = 1     35     b, e                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | LEAVE = Leave Procedure            | 11001001                                         | 4           | 4                  | ь          | h                                     |
| Type Specified         1 1 0 0 1 1 0 1         type         37         b           Type 3         1 1 0 0 1 1 0 0         33         b           INTO = Interrupt 4 if Overflow Flag Set         1 1 0 0 1 1 1 0         b         b           If OF = 1         35         b, e         b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | INTERRUPT INSTRUCTIONS             |                                                  |             |                    |            |                                       |
| Type 3         11001100         33         b           NTO=Interrupt 4 if Overflow Flag Set         11001110         b         b           If OF = 1         35         b, e         b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | NT = Interrupt:                    |                                                  |             |                    |            |                                       |
| NTO=Interrupt 4 if Overflow Flag Set         1 1 0 0 1 1 1 0           if OF = 1         35         b, e                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Type Specified                     | 11001101 type                                    | 37          |                    | ь          |                                       |
| If OF = 1 35 b, e                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Туре З                             | 11001100                                         | 33          |                    | b          |                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                    | 11001110                                         | 35          | 3                  | b,e<br>b,e |                                       |



|                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                           | Clock                   |                                                                         |                          |                                                                                                                                          |  | mments |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------------------------------------------------------------------------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--|--------|
| Instruction                                                                                                                                                                                                                                                                                                                      | Format                                                                                                                                                                                                    | Real<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode                                 | Real<br>Address<br>Mode  | Protected<br>Virtual<br>Address<br>Mode                                                                                                  |  |        |
| NTERRUPT INSTRUCTIONS                                                                                                                                                                                                                                                                                                            | (continued)                                                                                                                                                                                               |                         |                                                                         |                          |                                                                                                                                          |  |        |
| Bound = Interrupt 5 if Detect<br>Value Out of Range                                                                                                                                                                                                                                                                              | 0 1 1 0 0 0 1 0 mod reg r/m                                                                                                                                                                               |                         |                                                                         |                          |                                                                                                                                          |  |        |
| If Out of Range<br>If in Range                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                           | 44<br>10                | 10                                                                      | b, e<br>b, e             | e,g,h,j,k,<br>e,g,h,j,k,                                                                                                                 |  |        |
| Protected Mode Only (INT)<br>INT: Type Specified<br>Via Interrupt or Trap Gate to San<br>Via Interrupt or Trap Gate to Diffe<br>From 80286 Task to 80286 TSS<br>From 80286 Task to Nirtual 8086<br>From Am386DXL CPU Task to 8<br>From Am386DXL CPU Task to A<br>From Am386DXL CPU Task to A                                     | arent Privilege Level<br>via Task Gate<br>CPU TSS via Task Gate<br>Mode via Task Gate<br>0286 TSS via Task Gate<br>m386DXL CPU TSS via Task Gate                                                          |                         | 59<br>99<br>282<br>309<br>226<br>284<br>311<br>228                      |                          | g, j, k, r<br>g, j, k, r                             |  |        |
| From Virtual 8086 Mode to 80280<br>From Virtual 8086 Mode to Am38<br>From Virtual 8086 Mode to Privile                                                                                                                                                                                                                           |                                                                                                                                                                                                           |                         | 289<br>316<br>119                                                       |                          | g, j, k, r<br>g, j, k, r<br>g, j, k, r                                                                                                   |  |        |
| From Am386DXL CPU Task to V<br>From Virtual 8086 Mode to 8028<br>From Virtual 8086 Mode to Am38<br>From Virtual 8086 Mode to Privile                                                                                                                                                                                             | erent Privilege Level<br>via Task Gate<br>CPU TSS via Task Gate<br>Mode via Task Gate<br>0286 TSS via Task Gate<br>m386DXL CPU TSS via Task Gate<br>irrual 8086 Mode via Task Gate<br>5 TSS via Task Gate |                         | 59<br>99<br>278<br>305<br>222<br>280<br>307<br>224<br>285<br>312<br>119 |                          | 9, j, k, r<br>9, j, k, r |  |        |
| From Am386DXL CPU Task to V<br>From Virtual 8086 Mode to 80286<br>From Virtual 8086 Mode to Am38                                                                                                                                                                                                                                 | orent Privilege Level<br>via Task Gate<br>CPU TSS via Task Gate<br>Mode via Task Gate<br>0286 TSS via Task Gate<br>m386DXL CPU TSS via Task Gate<br>inual 8086 Mode via Task Gate<br>5 TSS via Task Gate  |                         | 59<br>99<br>280<br>307<br>224<br>282<br>309<br>225<br>287<br>314<br>119 |                          | g, j, k, r<br>g, j, k, r               |  |        |
| From Am386DXL CPU Task to V<br>From Virtual 8086 Mode to 80286<br>From Virtual 8086 Mode to Am38                                                                                                                                                                                                                                 | orent Privilege Level<br>via Task Gate<br>CPU TSS via Task Gate<br>Mode via Task Gate<br>0286 TSS via Task Gate<br>m386DXL CPU TSS via Task Gate<br>irtual 8086 Mode via Task Gate<br>5 TSS via Task Gate |                         | 59<br>99<br>254<br>284<br>231<br>264<br>294<br>243<br>264<br>294<br>119 |                          | 9, j, k, r<br>9, j, k, r |  |        |
| NTERRUPT RETURN                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                           |                         |                                                                         |                          |                                                                                                                                          |  |        |
| IRET = Interrupt Return<br>Protected Mode Only (IRET)<br>To the Same Privilege Level (with<br>To Different Privilege Level (with<br>From 80286 Task to 80286 TSS<br>From 80286 Task to 80286 TSS<br>From 80286 Task to Virtual 8086<br>From Am386DXL CPU Task to 8<br>From Am386DXL CPU Task to A<br>From Am386DXL CPU Task to A | n Task)<br>CPU TSS<br>Task<br>Mode (within Task)<br>0286 TSS<br>m386DXL CPU TSS                                                                                                                           | 22<br>275<br>223        | 38<br>82<br>232<br>265<br>213<br>60<br>271                              | h, j, k, r<br>h, j, k, r | g, h, j, k, i<br>g, h, j, k, i<br>g, h, j, k, r<br>h, j, k, r<br>h, j, k, r<br>h, j, k, r                                                |  |        |
|                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                           |                         |                                                                         |                          |                                                                                                                                          |  |        |

|                                                  |                  |                    |                      |    | Clock Count     |                                 | Cor             | nments                          |
|--------------------------------------------------|------------------|--------------------|----------------------|----|-----------------|---------------------------------|-----------------|---------------------------------|
|                                                  | _                |                    |                      |    | Real<br>Address | Protected<br>Virtual<br>Address | Real<br>Address | Protected<br>Virtual<br>Address |
|                                                  | Format           |                    |                      |    | Mode            | Mode                            | Mode            | Mode                            |
|                                                  | 11110100         | 1                  |                      |    | 5               | 5                               |                 |                                 |
| HLT=HALT                                         |                  | 1                  |                      |    | 3               | 5                               |                 |                                 |
| MOV = Move to and From Control/De                | 00001111         | 00100010           |                      |    | 1 1/4/5         | 11/4/5                          |                 |                                 |
| CR0/CR2/CR3 from register<br>Register From CR3–0 | 00001111         | 00100000           | 1 1 eee reg          |    | 6               | 6                               |                 |                                 |
| •                                                | 00001111         | 00100011           | 1 1 eee reg          |    | 22              | 22                              |                 |                                 |
| DR3–0 From Register<br>DR7–6 From Register       | 00001111         | 00100011           | 1 1 eee reg          |    | 16              | 16                              |                 |                                 |
| Register from DR7–6                              | 00001111         | 00100001           | 1 1 eee reg          |    | 14              | 14                              |                 |                                 |
| Register from DR3-0                              | 00001111         | 00100001           | 1 1 eee reg          |    | 22              | 22                              |                 |                                 |
| R7-6 from Register                               | 00001111         | 00100110           | 1 1 eee reg          |    | 12              | 12                              |                 |                                 |
| Register from TR7-6                              | 00001111         | 00100100           | 1 1 eee reg          |    | 12              | 12                              |                 |                                 |
| NOP = No Operation                               | 10010000         | 00100100           | 11000109             |    | 3               | 3                               |                 |                                 |
| VAIT = Wait until $\overline{BUSY}$              | 10011011         |                    |                      |    | 7               | 7                               |                 |                                 |
| pin is negated                                   |                  |                    |                      |    | '               | ,                               |                 |                                 |
| NOP = No Operation                               | 10010000         |                    |                      |    | 3               | 3                               |                 |                                 |
| PROCESSOR EXTENSION INST                         | RUCTIONS-Se      | e coprocessor d    | atasheets            |    |                 |                                 |                 |                                 |
| Processor Extension Escape                       | 11011TTT         | modLLL r/m         |                      |    |                 |                                 |                 | h                               |
|                                                  | TTT and LLL bits | are op-code inform | ation for coprocesso | or |                 |                                 |                 |                                 |
| PREFIX BYTES                                     |                  |                    |                      |    |                 |                                 |                 |                                 |
| ddress Size Prefix                               | 01100111         |                    |                      |    | 0               | 0                               |                 |                                 |
| OCK = Bus Lock Prefix                            | 11110000         |                    |                      |    | 0               | 0                               |                 | m                               |
| perand Size Prefix                               | 01100110         |                    |                      |    | 0               | 0                               |                 |                                 |
| egment Override Prefix                           | ·····            | 1                  |                      |    |                 |                                 |                 |                                 |
| CS:                                              | 00101110         |                    |                      |    | 0               | 0                               |                 |                                 |
| DS:                                              | 00111110         |                    |                      |    | 0               | 0                               |                 |                                 |
| ES:                                              | 00100110         |                    |                      |    | 0               | 0                               |                 |                                 |
| FS:                                              | 01100100         |                    |                      |    | 0               | 0                               |                 |                                 |
| GS:                                              | 01100101         |                    |                      |    | 0               | 0                               |                 |                                 |
| SS:                                              | 00110110         |                    |                      |    | 0               | 0                               |                 |                                 |
| PROTECTION CONTROL                               |                  |                    |                      |    |                 |                                 |                 |                                 |
| ARPL = Adjust Requested Privilege                | Level            |                    |                      |    |                 |                                 |                 |                                 |
| From Register/Memory                             | 01100011         | mod reg r/m        |                      |    | N/A             | 20/21                           | a               | h                               |
| LAR = Load Access Rights                         |                  |                    |                      |    |                 |                                 |                 |                                 |
| From Register/Memory                             | 00001111         | 00000010           | mod reg r/m          |    | N/A             | 15/16                           | a               | g, h, j, p                      |
| LGDT = Load Global Descriptor                    |                  |                    |                      |    |                 |                                 |                 |                                 |
| Table Register                                   | 00001111         | 00000001           | modi010 r/m          |    | 11              | 11                              | b,c             | h,i                             |
| LIDT = Load Interrupt Descriptor                 |                  |                    |                      |    |                 |                                 |                 |                                 |
| Table Register                                   | 00001111         | 00000001           | mod 0 1 1 r/m        |    | 11              | 11                              | b, c            | h, I                            |
| LLDT = Load Local Descriptor                     |                  |                    |                      |    |                 |                                 |                 |                                 |
| Table Register to Register/Memory                | 00001111         | 00000000           | mod 0 1 0 r/m        |    | N/A             | 20/24                           | a               | g, h, j, l                      |
| LMSW = Load Machine Status Word                  |                  |                    |                      |    |                 |                                 |                 |                                 |
| From Register/Memory                             | 00001111         | 00000001           | mod 1 1 0 r/m        | ]  | 11/14           | 11/14                           | b.c             | h, i                            |



|                                                                               |          |           |               |   |                         | Clock Count                             |                         | ments                                   |  |
|-------------------------------------------------------------------------------|----------|-----------|---------------|---|-------------------------|-----------------------------------------|-------------------------|-----------------------------------------|--|
| Instruction                                                                   | Format   |           |               |   | Real<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode | Protected<br>Virtual<br>Address<br>Mode |  |
| PROTECTION CONTROL (continu                                                   | ued)     |           |               |   |                         |                                         |                         |                                         |  |
| LSL = Load Segment Limit                                                      |          |           |               |   |                         |                                         |                         |                                         |  |
| From Register/Memory                                                          | 00001111 | 00000011  | mod reg r/m   |   |                         |                                         |                         | l                                       |  |
| Byte-Granular Limit<br>Page-Granular Limit<br>LTR <b>= Load Task Register</b> |          |           |               |   | N/A<br>N/A              | 21/22<br>25/26                          | a<br>a                  | g, h, j, p<br>g, h, j, p                |  |
| From Register/Memory                                                          | 00001111 | 00000000  | mod 0 0 1 r/m |   | N/A                     | 23/27                                   | а                       | g, h, j, l                              |  |
| SGDT = Store Global Descriptor                                                |          | L         |               |   |                         |                                         |                         |                                         |  |
| Table Register                                                                | 00001111 | 00000001  | mod 0 0 0 r/m |   | 9                       | 9                                       | b, c                    | h                                       |  |
| SIDT = Store Interrupt Descriptor                                             |          | •         |               |   |                         |                                         |                         |                                         |  |
| Table Register                                                                | 00001111 | 00000001  | mod 0 0 1 r/m |   | 9                       | 9                                       | b, c                    | h                                       |  |
| SLDT = Store Local Descriptor Table                                           | Register | - <u></u> | A             | 1 |                         |                                         |                         | 1                                       |  |
| To Register/Memory                                                            | 00001111 | 00000000  | mod 0 0 0 r/m |   | N/A                     | 2/2                                     | a                       | h                                       |  |
| SMSW = Store Machine Status Word                                              | 00001111 | 00000001  | mod 1 0 0 r/m |   | 2/2                     | 2/2                                     | b, c                    | h, I                                    |  |
| STR = Store Task Register                                                     |          |           | <b>.</b>      |   |                         |                                         |                         | 1                                       |  |
| To Register/Memory                                                            | 00001111 | 00000000  | mod 0 0 1 r/m | 1 | N/A                     | 2/2                                     | a                       | h                                       |  |
| VERR = Verify Read Access                                                     |          | L         | L             | , |                         |                                         |                         |                                         |  |
| Register/Memory                                                               | 00001111 | 00000000  | mod 1 0 0 r/m |   | N/A                     | 10/11                                   | а                       | g, h, j, p                              |  |
| VERW = Verify Write Access                                                    | 00001111 | 00000000  | mod 1 0 1 r/m |   | N/A                     | 15/16                                   | a                       | g, h, j, p                              |  |

Instruction Notes for Table 23.

Notes a through c apply to Am386DXL CPU Real Address Mode only.

- a. This is a Protected Mode instruction. Attempted execution in Real Mode will result in Exception 6 (Invalid op-code).
- b. Exception 13 fault (General Protection) will occur in Real Mode if an operand reference is made that partially or fully extends beyond the maximum CS, DS, ES, FS, or GS limit, FFFFH. Exception 12 (fault stack segment limit violation or not present) will occur in Real Mode if an operand reference is made that partially or fully extends beyond the maximum SS limit.
- c. This instruction may be executed in Real Mode. In Real Mode, its purpose is primarily to initialize the CPU for Protected Mode.

#### Notes d through g apply to Am386DXL CPU Real Address Mode and Am386DXL CPU Protected Virtual Address Mode.

d. The Am386DXL CPU uses an early-out multiply algorithm. The actual number of clocks depends on the position of the most significant bit in the operand (multiplier).

Clock counts given are minimum to maximum. To calculate actual clocks use the following formula:

Actual Clock = if m < > 0 then max ([log<sub>2</sub> |m]], 3) + b clocks: if m = 0 then 3 + b clocks

In this formula, m is the multiplier, and

- b = 9 for register to register,
- b = 12 for memory to register,
- b = 10 for register with immediate to register,
- b = 11 for memory with immediate to register.
- e. An Exception may occur, depending on the value of the operand.
- f. LOCK is automatically asserted, regardless of the presence or absence of the LOCK prefix.
- g. LOCK is asserted during descriptor table accesses.

### Notes h through r apply to Am386DXL CPU Protected Virtual Address Mode only.

- h. Exception 13 fault (General Protection Violation) will occur if the memory operand in CS, DS, ES, FS, or GS cannot be used due to either a segment limit violation or access rights violation. If a stack limit is violated, an Exception 12 (Stack Segment Limit Violation or Not Present) occurs.
- For segment load operations, the CPL, RPL, and DPL must agree with the privilege rules to avoid an Exception 13 fault (General Protection Violation). The segment's descriptor must indicate present or Exception 11 (CS, DS, ES, FS, GS Not Present). If the SS register is loaded and a stack segment not present is detected, an Exception 12 (Stack Segment Limit Violation or Not Present) occurs.
- All segment descriptor accesses in the GDT or LDT made by this instruction will automatically assert LOCK to maintain descriptor integrity in multiprocessor systems.
- k. JMP, CALL, INT, RET, and IRET instructions referring to another code segment will cause an Exception 13 (General Protection Violation) is an applicable privilege rule is violated.
- I. An Exception 13 fault occurs if CPL is greater than 0 (0 is the most privileged level).
- m. An Exception 13 fault occurs if CPL is greater than IOPL.
- The IF bit of the flag register is not updated if CPL is greater than IOPL. The IOPL and VM fields of the flag register are updated only if CPL = 0.
- The PE bit of the MSW (CR0) cannot be reset by this instruction. Use MOV into CR0 if desiring to reset the PE bit.
- p. Any violation of privilege rules as applied to the selector operand does not cause a protection Exception; rather, the zero flag is cleared.

- q. If the coprocessor's memory operand violates a segment limit or segment access rights, an Exception 13 fault (General Protection Exception) will occur before the ESC instruction is executed. An Exception 12 fault (Stack Segment Limit Violation or Not Present) will occur if the stack limit is violated by the operand's starting address.
- r. The destination of a JMP, CALL, INT, RET, or IRET must be in the defined limit of a code segment or an Exception 13 fault (General Protection Violation) will occur.

### Instruction Encoding

#### Overview

All instruction encodings are subsets of the general instruction format shown in Figure 83. Instructions consist of one or two primary op-code bytes, possibly an address specifier consisting of the mod r/m byte and scaled index byte, a displacement if required, and an immediate data field if required.

Within the primary op-code or op-codes, smaller encoding fields may be defined. These fields vary according to the class of operation. The fields define such information as direction of the operation, size of the displacements, register encoding, or sign extension.

Almost all instructions referring to an operand in memory have an addressing mode byte following the primary op-code byte(s). This byte, the mod r/m byte, specifies the address mode to be used. Certain encodings of the mod r/m byte indicate a second addressing byte, the scale-index-base byte, follows the mod r/m byte to fully specify the addressing mode.

Addressing modes can include a displacement immediately following the mod r/m byte, or scaled index byte. If a displacement is present, the possible sizes are 8, 16, or 32 bits.

If the instruction specifies an immediate operand, the immediate operand follows any displacement bytes. The immediate operand, if specified, is always the last field of instruction.

Figure 83 illustrates several of the fields that can appear in an instruction, such as the mod field and the r/m field, but the Figure does not show all fields. Several smaller fields also appear in certain instructions, sometimes within the op-code bytes themselves. Table 24 is a complete list of all fields appearing in the Am386DXL microprocessor instruction set. Further ahead, following Table 24, are detailed tables for each field.

#### 32-Bit Extensions of the Instruction Set

With the Am386DXL microprocessor, the 8086/80186/ 80286 instruction set is extended in two orthogonal directions: 32-bit forms of all 16-bit instructions are added to support the 32-bit data types, and 32-bit addressing modes are made available for all instructions referencing memory. This orthogonal instruction set extension is accomplished having a Default (D) bit in the code segment descriptor, and by having 2 prefixes to the instruction set.

Whether the instruction defaults to operations of 16 or 32 bits depends on the setting of the D bit in the code segment descriptor, which gives the default length (either 32 or 16 bits) for both operands and effective addresses when executing that code segment. In the Real Address Mode or Virtual 8086 Mode, no code segment descriptors are used, but a D value of 0 is assumed internally by the Am386DXL microprocessor when operating in those modes (for 16-bit default sizes compatible with the 8086/80C186/80286).

Two prefixes, the Operand Size Prefix and the Effective Address Size Prefix, allow overriding individually the Default selection of operand size and effective address size. These prefixes may precede any op-code bytes and affect only the instruction they precede. If necessary, one or both of the prefixes may be placed before the op-code bytes. The presence of the Operand Size Prefix and the Effective Address Prefix will toggle the operand size or the effective address size, respectively, to the value opposite from the Default setting. For example, if the default operand size is for 32-bit data operations, then presence of the Operand Size Prefix toggles the instruction to 16-bit data operation. As another example, if the default effective address size is 16 bits. presence of the Effective Address Size prefix togales the instruction to use 32-bit effective address computations.



Figure 83. General Instruction Format

| Field Name | Description                                                                       | Number of Bits          |
|------------|-----------------------------------------------------------------------------------|-------------------------|
| w          | Specifies if Data is Byte or Full Size (Full Size is either 16 or 32 bits)        | 1                       |
| d          | Specifies Direction of Data Operation                                             | 1                       |
| S          | Specifies if an Immediate Data Field must be Sign-Extended                        | 1                       |
| reg        | General Register Specifier                                                        | 3                       |
| mod r/m    | Address Mode Specifier (Effective Address can be a General Register)              | 2 for mod;<br>3 for r/m |
| SS         | Scale Factor for Scaled Index Address Mode                                        | 2                       |
| index      | General Register to be used as Index Register                                     | 3                       |
| base       | General Register to be used as Base Register                                      | 3                       |
| sreg2      | Segment Register Specifier for CS, SS, DS, ES                                     | 2                       |
| sreg3      | Segment Register Specifier for CS, SS, DS, ES, FS, GS                             | 3                       |
| tttn       | For Condition Instructions, specifies a Condition Asserted or a Condition Negated | 4                       |

Note: Table 23 shows encoding of individual instructions.

These 32-bit extensions are available in all Am386DXL microprocessor modes, including the Real Address Mode or the Virtual 8086 Mode. In these modes the default is always 16 bits, so prefixes are needed to specify 32-bit operands or addresses. For instructions with more than one prefix, the order of prefixes is unimportant.

Unless specified otherwise, instructions with 8- and 16-bit operands do not affect the contents of the highorder bits of the extended registers.

#### **Encoding of Instruction Fields**

Within the instruction are several fields indicating register selection, addressing mode and so on. The exact encodings of these fields are defined immediately ahead.

#### Encoding of Operand Length (w) Field

For any given instruction performing a data operation, the instruction is executing as a 32- or 16-bit operation. Within the constraints of the operation size, the w field encodes the operand size as either one byte or the full operation size, as shown in the table below.

| w Field | Operand Size<br>During 16-Bit<br>Data Operations | Operand Size<br>During 32-Bit<br>Data Operations |
|---------|--------------------------------------------------|--------------------------------------------------|
| 0       | 8 Bits                                           | 8 Bits                                           |
| 1       | 16 Bits                                          | 32 Bits                                          |

### Encoding of The General Register (reg) Field

The general register is specified by the reg field, which may appear in the primary op-code bytes, or as the reg field of the mod r/m byte, or as the r/m field of the mod r/m byte.

Encoding of reg Field When w Field is not Present in Instruction

| reg Field | Register Selected<br>During 16-Bit<br>Data Operations | Register Selected<br>During 32-Bit<br>Data Operations |
|-----------|-------------------------------------------------------|-------------------------------------------------------|
| 000       | AX                                                    | EAX                                                   |
| 001       | СХ                                                    | ECX                                                   |
| 010       | DX                                                    | EDX                                                   |
| 011       | BX                                                    | EBX                                                   |
| 100       | SP                                                    | ESP                                                   |
| 101       | BP                                                    | EBP                                                   |
| 110       | SI                                                    | ESI                                                   |
| 111       | DI                                                    | EDI                                                   |

#### Encoding of reg Field When w Field is Present in Instruction

|     | Register Specified by reg Field<br>During 16-Bit Data Operations |              |  |  |  |  |
|-----|------------------------------------------------------------------|--------------|--|--|--|--|
|     | Function                                                         | of w Field   |  |  |  |  |
| reg | (when w = 0)                                                     | (when w = 1) |  |  |  |  |
| 000 | AL                                                               | AX           |  |  |  |  |
| 001 | CL                                                               | сх           |  |  |  |  |
| 010 | DL                                                               | DX           |  |  |  |  |
| 011 | BL                                                               | BX           |  |  |  |  |
| 100 | AH                                                               | SP           |  |  |  |  |
| 101 | СН                                                               | BP           |  |  |  |  |
| 110 | DH                                                               | SI           |  |  |  |  |
| 111 | вн                                                               | DI           |  |  |  |  |

|     | Register Specified by reg Field<br>During 32-Bit Data Operations |     |
|-----|------------------------------------------------------------------|-----|
|     | Function of w Field       reg     (when w = 0)     (when w = 1)  |     |
| reg |                                                                  |     |
| 000 | AL                                                               | EAX |
| 001 | CL                                                               | ECX |
| 010 | DL                                                               | EDX |
| 011 | BL                                                               | EBX |
| 100 | AH                                                               | ESP |
| 101 | СН                                                               | EBP |
| 110 | DH                                                               | ESI |
| 111 | ВН                                                               | EDI |

### Encoding of The Segment Register (sreg) Field

The sreg field in certain instructions is a 2-bit field allowing one of the four 80286 segment registers to be specified. The sreg field in other instructions is a 3-bit field, allowing the Am386DXL microprocessor FS and GS segment registers to be specified.

#### 2-Bit sreg2 Field

| 2-Bit sreg2 Field | Segment Register Selected |
|-------------------|---------------------------|
| 00                | ES                        |
| 01                | CS                        |
| 10                | SS                        |
| 11                | DS                        |

### 3-Bit sreg3 Field

| 3-Bit sreg3 Field | Segment Register Selected |
|-------------------|---------------------------|
|                   | +                         |
| 000               | ES                        |
| 001               | CS                        |
| 010               | SS                        |
| 011               | DS                        |
| 100               | FS                        |
| 101               | GS                        |
| 110               | do not use                |
| 111               | do not use                |

### Encoding of Address Mode

Except for special instructions, such as PUSH or POP, where the addressing mode is pre-determined, the addressing mode for the current instruction is specified by addressing bytes following the primary op-code. The primary addressing byte is the mod r/m byte, and a second byte of addressing information, the s-i-b (scale-index-base) byte, can be specified.

The s-i-b byte (scale-index-base byte) is specified when using 32-bit addressing mode and the mod r/m byte has r/m = 100 and mod = 00, 01, or 10. When the sib byte is present, the 32-bit addressing mode is a function of the mod, ss, index, and base fields.

The primary addressing byte, the mod r/m byte, also contains three bits (shown as TTT in Figure 83) sometimes used as an extension of the primary op-code. The three bits, however, may also be used as a register field (reg).

When calculating an effective address, either 16-bit addressing or 32-bit addressing is used. 16-bit addressing uses 16-bit address components to calculate the effective address while 32-bit addressing uses 32-bit address components to calculate the effective address. When 16-bit addressing is used, the mod r/m byte is interpreted as a 16-bit addressing mode specifier. When 32-bit addressing is used, the mod r/m byte is interpreted as a 32-bit addressing mode specifier.

 Tables on the following pages define all encodings of all

 16- and 32-bit addressing modes.

| mod r/m | Effective Address |
|---------|-------------------|
| 00 000  | DS:[BX + SI]      |
| 00 001  | DS:[BX + DI]      |
| 00 010  | SS:[BP + SI]      |
| 00 011  | DS:[BP + DI]      |
| 00 100  | DS:[SI]           |
| 00 101  | DS:[DI]           |
| 00 110  | DS:d16            |
| 00 111  | DS:[BX]           |
|         |                   |
| 01 000  | DS:[BX + SI + d8] |
| 01 001  | DS:[BX + DI + d8] |
| 01 010  | SS:[BP + SI + d8] |
| 01 011  | SS:[BP + DI + d8] |
| 01 100  | DS:[SI + d8]      |
| 01 101  | DS:[DI + d8]      |
| 01 110  | SS:[BP + d8]      |
| 01 111  | DS:[BX + d8]      |

### Encoding of 16-Bit Address Mode with mod r/m Byte

| mod r/m | Effective Address  |
|---------|--------------------|
| 10 000  | DS:[BX + SI + d16] |
| 10 001  | DS:[BX + DI + d16] |
| 10 010  | SS:[BP + SI + d16] |
| 10 011  | SS:[BP + DI + d16] |
| 10 100  | DS:[SI + d16]      |
| 10 101  | DS:[DI + d16]      |
| 10 110  | SS:[BP + d16]      |
| 10 111  | DS:[BX + d16]      |
|         |                    |
| 11 000  | Register—See Below |
| 11 001  | Register—See Below |
| 11 010  | Register—See Below |
| 11 011  | Register—See Below |
| 11 100  | Register—See Below |
| 11 101  | Register—See Below |
| 11 110  | Register—See Below |
| 11 111  | Register—See Below |

| I       | Register Specified by r/m<br>During 16-Bit Data Operations |              |
|---------|------------------------------------------------------------|--------------|
|         | Function                                                   | of w Field   |
| mod r/m | (when w = 0)                                               | (when w = 1) |
| 11 000  | AL                                                         | AX           |
| 11 001  | CL                                                         | СХ           |
| 11 010  | DL                                                         | DX           |
| 11 011  | BL                                                         | BX           |
| 11 100  | AH                                                         | SP           |
| 11 101  | СН                                                         | BP           |
| 11 110  | DH                                                         | SI           |
| 11 111  | BH                                                         | DI           |

| Register Specified by r/m<br>During 32-Bit Data Operations |                                   |            |  |
|------------------------------------------------------------|-----------------------------------|------------|--|
|                                                            | Function                          | of w Field |  |
| mod r/m                                                    | mod r/m (when w = 0) (when w = 1) |            |  |
| 11 000                                                     | AL                                | EAX        |  |
| 11 001                                                     | CL                                | ECX        |  |
| 11 010                                                     | DL                                | EDX        |  |
| 11 011                                                     | BL                                | EBX        |  |
| 11 100                                                     | AH                                | ESP        |  |
| 11 101                                                     | СН                                | EBP        |  |
| 11 110                                                     | DH                                | ESI        |  |
| 11 111                                                     | BH                                | EDI        |  |

| mo | d r/m | Effective Address |
|----|-------|-------------------|
| 00 | 000   | DS:[EAX]          |
| 00 | 001   | DS:[ECX]          |
| 00 | 010   | DS:[EDX]          |
| 00 | 011   | DS:[EBX]          |
| 00 | 100   | s-i-b is present  |
| 00 | 101   | DS:d32            |
| 00 | 110   | DS:[ESI]          |
| 00 | 111   | DS:[EDI]          |
| 01 | 000   | DS:[EAX + d8]     |
| 01 | 001   | DS:[ECX + d8]     |
| 01 | 010   | DS:[EDX + d8]     |
| 01 | 011   | DS:[EBX + d8]     |
| 01 | 100   | s-i-b is present  |
| 01 | 101   | SS:[EBP + d8]     |
| 01 | 110   | DS:[ESI + d8]     |
| 01 | 111   | DS:[EDI + d8]     |

### Encoding of 32-Bit Address Mode with mod r/m byte (No s-i-b Byte Present)

| moo | l r/m | Effective Address   |
|-----|-------|---------------------|
| 10  | 000   | DS:[EAX + d32]      |
| 10  | 001   | DS:[ECX + d32]      |
| 10  | 010   | DS:[EDX + d32]      |
| 10  | 011   | DS:[EBX + d32]      |
| 10  | 100   | s-i-b is present    |
| 10  | 101   | SS:[EBP + d32]      |
| 10  | 110   | DS:[ESI + d32]      |
| 10  | 111   | DS:[EDI + d32]      |
| 11  | 000   | Register—See Below  |
| 11  | 001   | Register—See Below  |
| 11  | 010   | Register—See Below  |
| 11  | 011   | Register—See Below  |
| 11  | 100   | Register—See Below  |
| 11  | 101   | Register— See Below |
| 11  | 110   | Register—See Below  |
| 11  | 111   | Register—See Below  |

| Register Specified by reg or r/m<br>During 16-Bit Data Operations |                                   |            |  |
|-------------------------------------------------------------------|-----------------------------------|------------|--|
|                                                                   | Function                          | of w Field |  |
| mod r/m                                                           | mod r/m (when w = 0) (when w = 1) |            |  |
| 11 000                                                            | AL                                | AX         |  |
| 11 001                                                            | CL                                | СХ         |  |
| 11 010                                                            | DL                                | DX         |  |
| 11 011                                                            | BL                                | BX         |  |
| 11 100                                                            | AH                                | SP         |  |
| 11 101                                                            | СН                                | BP         |  |
| 11 110                                                            | DH                                | SI         |  |
| 11 111                                                            | BH                                | DI         |  |

| Register Specified by reg or r/m<br>During 32-Bit Data Operations |              |              |
|-------------------------------------------------------------------|--------------|--------------|
|                                                                   | Function     | of w Field   |
| mod r/m                                                           | (when w = 0) | (when w = 1) |
| 11 000                                                            | AL           | EAX          |
| 11 001                                                            | CL           | ECX          |
| 11 010                                                            | DL           | EDX          |
| 11 011                                                            | BL           | EBX          |
| 11 100                                                            | AH           | ESP          |
| 11 101                                                            | СН           | EBP          |
| 11 110                                                            | DH           | ESI          |
| 11 111                                                            | BH           | EDI          |

| mod base | Effective Address               |
|----------|---------------------------------|
| 00 000   | DS:[EAX + (scaled index)]       |
| 00 001   | DS:[ECX + (scaled index)]       |
| 00 010   | DS:[EDX + (scaled index)]       |
| 00 011   | DS:[EBX + (scaled index)]       |
| 00 100   | SS:[ESP + (scaled index)]       |
| 00 101   | DS:[d32 + (scaled index)]       |
| 00 110   | DS:[ESI + (scaled index)]       |
| 00 111   | DS:[EDI + (scaled index)]       |
|          |                                 |
| 01 000   | DS:[EAX + (scaled index) + d8]  |
| 01 001   | DS:[ECX + (scaled index) + d8]  |
| 01 010   | DS:[EDX + (scaled index) + d8]  |
| 01 011   | DS:[EBX + (scaled index) + d8]  |
| 01 100   | SS:[ESP + (scaled index) + d8]  |
| 01 101   | SS:[EBP + (scaled index) + d8]  |
| 01 110   | DS:[ESI + (scaled index) + d8]  |
| 01 111   | DS:[EDI + (scaled index) + d8]  |
|          |                                 |
| 10 000   | DS:[EAX + (scaled index) + d32] |
| 10 001   | DS:[ECX + (scaled index) + d32] |
| 10 010   | DS:[EDX + (scaled index) + d32] |
| 10 011   | DS:[EBX + (scaled index) + d32] |
| 10 100   | SS:[ESP + (scaled index) + d32] |
| 10 101   | SS:[EBP + (scaled index) + d32] |
| 10 110   | DS:[ESI + (scaled index) + d32] |
| 10 111   | DS:[EDI + (scaled index) + d32] |

#### Encoding of 32-Bit Address Mode (mod r/m Byte and s-i-b present)

Note: Mod field in mod r/m byte; ss, index, base fields in s-i-b byte.

#### Encoding of Operation Direction (d) Field

In many two-operand instructions the d field is present to indicate which operand is considered the source and which is the destination.

| d | Direction of Operation                                                                                                              |
|---|-------------------------------------------------------------------------------------------------------------------------------------|
| 0 | Register/Memory ← Register<br>reg Field indicates Source Operand;<br>mod r/m or mod ss index base indicates<br>Destination Operand. |
| 1 | Register                                                                                                                            |

| <b>SS</b> | Scale Factor |
|-----------|--------------|
| 00        | x1           |
| 01        | x2           |
| 10        | x4           |
| 11        | x8           |

| index | Index Register          |
|-------|-------------------------|
| 000   | EAX                     |
| 001   | ECX                     |
| 010   | EDX                     |
| 011   | EBX                     |
| 100   | no index reg (see note) |
| 101   | EBP                     |
| 110   | ESI                     |
| 111   | EDI                     |

Note: When index field is 100, indicating no index register, then ss field must equal 00. If index is 100 and ss does not equal 00, the effective address is undefined.

#### Encoding of Sign-Extend (s) Field

The *s* field occurs primarily to instructions with immediate data fields. The s field has an effect only if the size of the immediate data is 8 bits and is being placed in a 16or 32-bit destination.

| 8 | Effect on<br>Immediate Data 8                                | Effect on<br>Immediate Data 16 32 |  |  |  |
|---|--------------------------------------------------------------|-----------------------------------|--|--|--|
| 0 | None                                                         | None                              |  |  |  |
| 1 | Sign-Extended Data 8 to fill<br>16-Bit or 32-Bit Destination | None                              |  |  |  |

# 

### Encoding of Conditional Test (tttn) Field

For the conditional instructions (conditional jumps and set on condition), tttn is encoded with n indicating to use the condition (n=0) or its negation (n=1), and ttt giving the condition to test.

| Mnemonic | Condition                           | tttn |
|----------|-------------------------------------|------|
| 0        | Overflow                            | 0000 |
| NO       | No Overflow                         | 0001 |
| B/NAE    | Below/Not Above or Equal            | 0010 |
| NB/AE    | Not Below/Above or Equal            | 0011 |
| E/Z      | Equal/Zero                          | 0100 |
| NE/NZ    | Not Equal/Not Zero                  | 0101 |
| BE/NA    | Below or Equal/Not Above            | 0110 |
| NBE/A    | Not Below or Equal/Above            | 0111 |
| S        | Sign                                | 1000 |
| NS       | Not Sign                            | 1001 |
| P/PE     | Parity/Parity Even                  | 1010 |
| NP/PO    | Not Parity/Parity Odd               | 1011 |
| L/NGE    | Less Than/Not Greater or Equal      | 1100 |
| NL/GE    | Not Less Than/Greater or Equal      | 1101 |
| LE/NG    | Less Than or Equal/Not Greater Than | 1110 |
| NLE/G    | Not Less Than or Equal/Greater Than | 1111 |

# Encoding of Control or Debug or Test Register (eee) Field

For the loading and storing of the Control, Debug and Test registers.

#### When Interpreted as Control Register Field

| eee Code                       | Reg Name |  |  |  |
|--------------------------------|----------|--|--|--|
| 000                            | CR0      |  |  |  |
| 010                            | CR2      |  |  |  |
| 011                            | CR3      |  |  |  |
| Do not use any other encoding. |          |  |  |  |

#### When Interpreted as Debug Register Field

| eee Code                      | Reg Name |  |  |  |
|-------------------------------|----------|--|--|--|
| 000                           | DRO      |  |  |  |
| 001                           | DR1      |  |  |  |
| 010                           | DR2      |  |  |  |
| 011                           | DR3      |  |  |  |
| 110                           | DR6      |  |  |  |
| 111                           | DR7      |  |  |  |
| Do not use any other encoding |          |  |  |  |

Do not use any other encoding.

### When Interpreted as Test Register Field

| eee Code                       | Reg Name |  |  |  |  |
|--------------------------------|----------|--|--|--|--|
| 110                            | TR6      |  |  |  |  |
| 111                            | TR7      |  |  |  |  |
| Do not use any other encoding. |          |  |  |  |  |

### **MECHANICAL DATA**

### Introduction

In this section, the physical packaging and its connections are described in detail.

### Package Dimensions and Mounting

The initial Am386DXL microprocessor package is a 132-pin ceramic pin grid array (PGA). Pins of this package are arranged 0.100 inch (2.54 mm) center-to-center, in a  $14 \times 14$  matrix, three rows around.

A wide variety of available sockets allow low insertion force or zero insertion force mountings, and a choice of terminals such as soldertail, surface mount, or wire wrap.

### Package Thermal Specification

The Am386DXL microprocessor is specified for operation when ambient temperature is within the range of 0°C-100°C. The ambient temperature may be measured in any environment, to determine whether the Am386DXL microprocessor is within specified operating range.

The PGA ambient temperature should be measured at the center of the top surface opposite the pins.

### **ELECTRICAL DATA**

### Introduction

The following sections describe recommended electrical connections for the Am386DXL microprocessor and its electrical specifications.

### **Power and Grounding**

#### **Power Connections**

The Am386DXL CPU is implemented in CS21S technology and has modest power requirements. However, its high clock frequency and 72 output buffers (address, data, control, and HLDA) can cause power surges as multiple output buffers drive new signal levels simultaneously. For clean on-chip power distribution at high frequency, 20 Vcc and 21 Vss pins separately feed functional units of the Am386DXL CPU.

Power and ground connections must be made to all external V $\infty$  and GND pins of the Am386DXL CPU. On the circuit board, all V $\infty$  pins must be connected on a V $\infty$  plane. All Vss pins must be likewise connected on a GND plane.

#### **Power Decoupling Recommendations**

Liberal decoupling capacitance should be placed near the Am386DXL CPU. The Am386DXL microprocessor driving its 32-bit parallel address and data buses at high frequencies can cause transient power surges, particularly when driving large capacitive loads.

Low inductance capacitors and interconnects are recommended for best high frequency electrical performance. Inductance can be reduced by shortening circuit board traces between the Am386DXL microprocessor and decoupling capacitors as much as possible. Capacitors specifically for PGA packages are also commercially available, for the lowest possible inductance.

### **Resistor Recommendations**

The ERROR, FLT, and BUSY inputs have resistor pullups of approximately 20 Kohms built into the Am386DXL CPU to keep these signals negated when no 387DX math coprocessor is present in the system (or temporarily removed from its socket). The BS16 input also has an internal pullup resistor of approximately 20 Kohms, and the PEREQ input has an internal pulldown resistor of approximately 20 Kohms.

In typical designs, the external pullup resistors are recommended. However, a particular design may have reason to adjust the resistor values recommended here, or alter the use of pullup resistors in other ways.

#### **Other Connection Recommendations**

For reliable operation, always connect unused inputs to an appropriate signal level. NC pins should always remain unconnected.

Particularly when not using interrupts or bus hold, (as when first prototyping, perhaps) prevent any chance of spurious activity by connecting these associated inputs to GND.

| Pin | Signal |
|-----|--------|
| B7  | INTR   |
| B8  | NMI    |
| D14 | HOLD   |

If not using address pipelining, pullup D13 NA to Vcc.

If not using 16-bit size, pullup C14 BS16 to Vcc.

Pullups in the range of 20 Kohms are recommended.

# Am386™SXL

High-Performance, 32-Bit Microprocessor with 16-Bit Data Bus

### DISTINCTIVE CHARACTERISTICS

- 25- and 20-MHz operating speeds
- True static design for long battery life in portable PCs
  - -0 MHz (DC) minimum frequency
  - -Typical standby (DC) current < 0.02 mA
  - -Typical operating current < 165 mA at 20 MHz
  - ---Wide range of chip set and BIOS support take advantage of standby mode capabilities
- Lower heat dissipation facilitates elimination of cooling fan in desktop PCs

### **GENERAL DESCRIPTION**

The Am386SXL microprocessor is a high-speed, true static implementation of the Intel i386SX. It is ideal for both desktop and battery-powered notebook personal computers. For notebooks, the Am386SXL microprocessor's true static design offers longer battery life with low operating power consumption and standby mode. At 20 MHz, this device offers a current which is 22% lower than the Intel i386SX. Standby mode allows the Am386SXL CPU to be clocked down to 0 MHz (DC) and retain full register contents. Typical current in standby mode is reduced to less than 0.02 mA—nearly a 1000× reduction in power consumption versus the Intel i386SX.

Worse

power

higher 1

ower power

Better

mA

50

Min. Freq.

Compatible with 386SX systems and software

Advanced Micro

Devices

- Pin-for-pin replacement of the Intel i386SX
- Supports 387SX-compatible math coprocessors
- 100-pin PQFP package with optional protective ring for better lead coplanarity
- Advanced 0.8 micron CMOS technology

For desktop PCs, the Am386SXL microprocessor offers a 25% increase in the maximum operating speed, from 20 to 25 MHz. Also, this device offers lower heat dissipation, allowing system designers to remove or reduce the size and cost of the cooling fan.

This device will be available in a standard 100-pin plastic quad flat pack (PQFP). This package may be shipped in an optional protective ring for better lead protection during manufacturing.

NA

25 MHz



20 MHz



## BLOCK DIAGRAM

AMD







15022B-003

### **FUNCTIONAL DESCRIPTION**

### **True Static Operation**

The Am386SXL microprocessor incorporates a true static design. Unlike dynamic circuit design, the Am386SXL CPU eliminates the minimum operating frequency restriction. It may be clocked from its maximum speed of 25 MHz all the way down to 0 MHz (DC). System designers can use this feature to design battery-powered notebook PCs with long battery life.

### Standby Mode

This true static design allows for a standby mode. At any operating speed (25 to 0 MHz), the Am386SXL microprocessor will retain its state (i.e., the contents of all its registers). By shutting off the clock completely, the device enters standby mode. Since power consumption is proportional to clock frequency, operating power consumption is reduced as the frequency is lowered. In standby mode, typical current draw is reduced to less than 0.02 mA at DC.

Not only does this feature improve battery life, but it also simplifies the design of power-conscious notebook computers in the following ways:

- 1. Eliminates the need for software in the BIOS to save and restore the contents of registers.
- Allows simpler circuitry to control stopping of the clock since the system does not need to know what state the processor is in.

### Lower Operating Icc

True static design also allows lower operating lcc when operating at any speed. See the following graph for typical current at operating speeds.



### **Performance On Demand**

The Am386SXL microprocessor retains its state at any speed from 0 MHz (DC) to its maximum operating speed. With this feature, system designers may vary the operating speed of the system to extend the battery life in portable systems.

For example, the system could operate at low speeds during inactivity or polling operations. However, upon interrupt, the system clock can be increased up to its maximum speed. After a user-defined time-out period, the system can be returned to a low (or 0 MHz) operating speed without losing its state. This design maximizes battery life while achieving optimal performance.



### **CONNECTION DIAGRAM**

**Top View** 



Notes: NC = No Connect. Pin 1 is marked for orientation. 15022B--002

| Add                                                                                                                                                  | ress                                                                                         | Da                                                                                                 | ita                                                                                          | Cor                                                                                                                                     | itrol                                                                                                      | NC                                                       | V <sub>cc</sub>                                                                | V <sub>ss</sub>                                                                                        |
|------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|--------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|
| Pin Name                                                                                                                                             | Pin No.                                                                                      | Pin Name                                                                                           | Pin No.                                                                                      | Pin Name                                                                                                                                | Pin No.                                                                                                    | Pin No.                                                  | Pin No.                                                                        | Pin No.                                                                                                |
| A1<br>A2<br>A3<br>A4<br>A5<br>A6<br>A7<br>A8<br>A9<br>A10<br>A11<br>A12<br>A13<br>A14<br>A15<br>A16<br>A17<br>A18<br>A19<br>A20<br>A21<br>A22<br>A23 | 18<br>51<br>52<br>53<br>55<br>55<br>55<br>55<br>55<br>55<br>55<br>55<br>55<br>55<br>55<br>55 | D0<br>D1<br>D2<br>D3<br>D4<br>D5<br>D6<br>D7<br>D8<br>D9<br>D10<br>D11<br>D12<br>D13<br>D14<br>D15 | 1<br>100<br>99<br>96<br>95<br>94<br>93<br>92<br>90<br>89<br>88<br>87<br>86<br>83<br>82<br>81 | ADS<br>BHE<br>BLE<br>BUSY<br>CLK2<br>D/C<br>ERROR<br>FLT<br>HLDA<br>HOLD<br>INTR<br>LOCK<br>MA<br>NMI<br>PEREQ<br>READY<br>RESET<br>W/R | 16<br>19<br>17<br>34<br>15<br>24<br>36<br>28<br>3<br>4<br>40<br>26<br>23<br>6<br>38<br>37<br>7<br>33<br>25 | 20<br>27<br>29<br>30<br>31<br>43<br>44<br>45<br>46<br>47 | 8<br>9<br>10<br>21<br>32<br>39<br>42<br>48<br>57<br>69<br>71<br>84<br>91<br>97 | 2<br>5<br>11<br>12<br>13<br>14<br>22<br>35<br>41<br>49<br>50<br>63<br>67<br>68<br>77<br>78<br>85<br>98 |

### PIN DESIGNATION TABLES (Sorted by Pin Name)

### PIN DESIGNATION TABLES (Sorted by Pin Number)

| Pin No. | Pin Name        |
|---------|-----------------|---------|-----------------|---------|-----------------|---------|-----------------|---------|-----------------|
| 1       | D0              | 21      | V <sub>cc</sub> | 41      | V <sub>ss</sub> | 61      | A11             | 81      | D15             |
| 2       | V <sub>ss</sub> | 22      | V <sub>ss</sub> | 42      | V <sub>cc</sub> | 62      | A12             | 82      | D14             |
| 3       | HLDA            | 23      | M/ĪŌ            | 43      | NC              | 63      | V <sub>ss</sub> | 83      | D13             |
| 4       | HOLD            | 24      | D/C             | 44      | NC              | 64      | A13             | 84      | V <sub>cc</sub> |
| 5       | V <sub>ss</sub> | 25      | ₩/R             | 45      | NC              | 65      | A14             | 85      | V <sub>ss</sub> |
| 6       | NA              | 26      | LOCK            | 46      | NC              | 66      | A15             | 86      | D12             |
| 7       | READY           | 27      | NC              | 47      | NC              | 67      | V <sub>ss</sub> | 87      | D11             |
| 8       | V <sub>cc</sub> | 28      | FLT             | 48      | V <sub>cc</sub> | 68      | V <sub>ss</sub> | 88      | D10             |
| 9       | V <sub>cc</sub> | 29      | NC              | 49      | V <sub>ss</sub> | 69      | V <sub>cc</sub> | 89      | D9              |
| 10      | V <sub>cc</sub> | 30      | NC              | 50      | V <sub>ss</sub> | 70      | A16             | 90      | D8              |
| 11      | V <sub>ss</sub> | 31      | NC              | 51      | A2              | 71      | V <sub>cc</sub> | 91      | V <sub>cc</sub> |
| 12      | V <sub>ss</sub> | 32      | V <sub>cc</sub> | 52      | A3              | 72      | A17             | 92      | D7              |
| 13      | V <sub>ss</sub> | 33      | RESET           | 53      | A4              | 73      | A18             | 93      | D6              |
| 14      | V <sub>ss</sub> | 34      | BUSY            | 54      | A5              | 74      | A19             | 94      | D5              |
| 15      | CLK2            | 35      | V <sub>ss</sub> | 55      | A6              | 75      | A20             | 95      | D4              |
| 16      | ADS             | 36      | ERROR           | 56      | A7              | 76      | A21             | 96      | D3              |
| 17      | BLE             | 37      | PEREQ           | 57      | V <sub>cc</sub> | 77      | V <sub>ss</sub> | 97      | V <sub>cc</sub> |
| 18      | A1              | 38      | NMI             | 58      | A8              | 78      | V <sub>ss</sub> | 98      | V <sub>ss</sub> |
| 19      | BHE             | 39      | V <sub>cc</sub> | 59      | A9              | 79      | A22             | 99      | D2              |
| 20      | NC              | 40      | INTR            | 60      | A10             | 80      | A23             | 100     | D1              |

### ORDERING INFORMATION

### **Standard Products**

AMD standard products are available in several packages and operating ranges. The order number (Valid Combination) is formed by a combination of the elements below.



NG = 100-Pin Plastic Quad Flat Pack (PQ100, PQB100)

| Valid Combinations |          |                       |  |  |  |
|--------------------|----------|-----------------------|--|--|--|
|                    |          | 25<br>20<br>16*       |  |  |  |
| NG                 | 80386SXL | 25F<br>20F<br>16F*    |  |  |  |
|                    |          | -25S<br>-20S<br>-16S* |  |  |  |

\*Contact AMD for 16-MHz availability.

#### Valid Combinations

Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations and to check on newly released combinations.

### **PIN DESCRIPTIONS**

## A23-A1

### Address Bus (Outputs)

Outputs physical memory or port I/O addresses.

### ADS

### Address Status (Active Low; Output)

Indicates that a valid bus cycle definition and address  $(W/\overline{R}, D/\overline{C}, M/\overline{IO}, \overline{BHE}, \overline{BLE}, and A23-A1)$  are being driven at the Am386SXL microprocessor pins.

### BHE, BLE

### Byte Enables (Active Low; Outputs)

Indicate which data bytes of the data bus take part in a bus cycle.

### BUSY

#### Busy (Active Low; Input)

Signals a busy condition from a processor extension.

### CLK2

#### CLK2 (Input)

Provides the fundamental timing for the Am386SXL microprocessor.

### D15–D0

#### Data Bus (Inputs/Outputs)

Inputs data during memory, I/O, and interrupt acknowledge read cycles; outputs data during memory and I/O write cycles.

### D/C

### Data/Control (Output)

A bus cycle definition pin that distinguishes data cycles, either memory or I/O, from control cycles which are: interrupt acknowledge, halt, and code fetch.

### ERROR

### Error (Active Low; Input)

Signals an error condition from a processor extension.

### FLT

### Float (Active Low; Input)

An input which forces all bi-directional and output signals, including HLDA, to the three-state condition.

### HLDA

### Bus Hold Acknowledge (Active High; Output)

Output indicates that the Am386SXL microprocessor has surrendered control of its logical bus to another bus master.

### HOLD

### **Bus Hold Request (Active High; Input)**

Input allows another bus master to request control of the local bus.

### INTR

#### Interrupt Request (Active High; Input)

A maskable input that signals the Am386SXL microprocessor to suspend execution of the current program and execute an interrupt acknowledge function.

### LOCK

### Bus Lock (Active Low; Output)

A bus cycle definition pin that indicates that other system bus masters are not to gain control of the system bus while it is active.

### M/IO

### Memory/IO (Output)

A bus cycle definition pin that distinguishes memory cycles from input/output cycles.

### NA

### Next Address (Active Low; Input)

Used to request address pipelining.

### NC

### No Connect

Should always be left unconnected. Connection of a NC pin may cause the processor to malfunction or be incompatible with future steppings of the Am386SXL microprocessor.

### NMI

# Non-Maskable Interrupt Request (Active High; Input)

A non-maskable input that signals the Am386SXL microprocessor to suspend execution of the current program and execute an interrupt acknowledge function.

### PEREQ

### Processor Extension Request (Active High; Input)

Indicates that the processor has data to be transferred by the Am386SXL microprocessor.

### READY

#### Bus Ready (Active Low; Input)

Terminates the bus cycle.

### RESET Reset (Active High; Input)

Suspends any operation in progress and places the Am386SXL microprocessor in a known reset state.

### $V_{cc}$

System Power (Active High; Input)

Provides the +5 V nominal DC supply input.

### V<sub>ss</sub> System Ground (Input)

Provides the 0 V connection from which all inputs and outputs are measured.

### W/R

### Write/Read (Output)

A bus cycle definition pin that distinguishes write cycles from read cycles.

### INTRODUCTION

The Am386SXL microprocessor is 100% object-code compatible with the Am386DX, 286, and 8086 microprocessors. System manufacturers can provide Am386DX CPU based systems optimized for performance and Am386SXL CPU based systems optimized for cost, both sharing the same operating systems and application software. Systems based on the Am386SXL microprocessor can access the world's largest existing microcomputer software base. Only the Am386DX CPU architecture can run UNIX, OS/2, and MS-DOS.

Instruction pipelining, high-bus bandwidth, and a very high-performance ALU ensure short average instruction execution times and high system throughput. The Am386SXL CPU is capable of execution at sustained rates of 2.5–3.0 million instructions per second.

The integrated Memory Management Unit (MMU) includes an address translation cache, advanced multitasking hardware, and a four-level hardware-enforced protection mechanism to support operating systems. The virtual machine capability of the Am386SXL CPU allows simultaneous execution of applications from multiple operating systems such as MS-DOS and UNIX.

The Am386SXL CPU offers on-chip testability and debugging features. Four breakpoint registers allow conditional or unconditional breakpoint traps on code execution or data accesses for powerful debugging of even ROM-based systems. Other testability features include self-test, three-state of output buffers, and direct access to the page translation cache.

### **BASE ARCHITECTURE**

The Am386SXL microprocessor consists of a central processing unit, a memory management unit, and a bus interface.

The central processing unit consists of the execution unit and the instruction unit. The execution unit contains the eight 32-bit general purpose registers which are used for both address calculation and data operations and a 64-bit barrel shifter used to speed shift, rotate, multiply, and divide operations. The instruction unit decodes the instruction op-codes and stores them in the decoded instruction queue for immediate use by the execution unit.

The MMU consists of a segmentation unit and a paging unit. Segmentation allows the managing of the logical address space by providing an extra addressing component, one that allows easy code and data relocatability, and efficient sharing. The paging mechanism operates beneath and is transparent to the segmentation process, to allow management of the physical address space.

The segmentation unit provides four levels of protection for isolating and protecting applications and the operating system from each other. The hardware enforced protection allows the design of systems with a high degree of integrity.

The Am386SXL microprocessor has two modes of operation: Real Address Mode (Real Mode) and Protected Virtual Address Mode (Protected Mode). In Real Mode the Am386SXL CPU operates as a very fast 8086, but with 32-bit extensions, if desired. Real Mode is required primarily to set up the processor for Protected Mode operation.

Within Protected Mode, software can perform a task switch to enter into tasks designated as Virtual 8086 Mode tasks. Each such task behaves with 8086 semantics, thus allowing 8086 software (an application program or an entire operating system) to execute. The Virtual 8086 tasks can be isolated and protected from one another and the host Am386SXL microprocessor operating system by use of paging.

Finally, to facilitate high-performance system hardware designs, the Am386SXL microprocessor bus interface offers address pipelining and direct Byte Enable signals for each byte of the data bus.

### **Register Set**

The Am386SXL microprocessor has 34 registers as shown in Figure 1. These registers are grouped into the following seven categories:

**General Purpose Registers**: The eight 32-bit general purpose registers are used to contain arithmetic and logical operands. Four of these (EAX, EBX, ECX, and EDX) can be used either in their entirety as 32-bit registers, as 16-bit registers, or split into pairs of separate 8-bit registers.

Segment Registers: Six 16-bit special purpose registers select, at any given time, the segments of memory that are immediately addressable for code, stack, and data.

Flags and Instruction Pointer Registers: The two 32-bit special purpose registers in Figure 1 record or control certain aspects of the Am386SXL microprocessor state. The EFLAGS register includes status and control bits that are used to reflect the outcome of many instructions and modify the semantics of some instructions. The Instruction Pointer (EIP) is 32-bits wide. The EIP controls instruction fetching, and the processor automatically increments it after executing an instruction.

**Control Registers**: The four 32-bit control registers are used to control the global nature of the Am386SXL microprocessor. The CR0 register contains bits that set the different processor modes (Protected, Real, Paging, and Coprocessor Emulation). CR2 and CR3 registers are used in the paging operation.





Reserved for future use---do not use.

15022B--004

#### Figure 1. Am386SXL Microprocessor Registers

System Address Registers: These four special registers reference the tables or segments supported by the 80286/Am386SXL/Am386DX CPU's protection model. These tables or segments are:

GDTR (Global Descriptor Table Register), IDTR (Interrupt Descriptor Table Register), LDTR (Local Descriptor Table Register), TR (Task State Segment Register).

**Debug Registers**: The six programmer accessible debug registers provide on-chip support for debugging. The use of the debug registers is described in the section Debugging Support.

**Test Registers**: Two registers are used to control the testing of the RAM/CAM (Content Addressable Memories) in the Translation Look-Aside Buffer portion of the Am386SXL microprocessor. Their use is discussed in the section Testability.

#### **EFLAGS Register**

The flag register is a 32-bit register named EFLAGS. The defined bits and bit fields within EFLAGS, shown in Figure 2, control certain operations and indicate the status of the Am386SXL microprocessor. The lower 16 bits (bits 15–0) of EFLAGS contain the 16-bit flag register named FLAGS. This is the default flag register used when executing 8086, 80286, or real mode code. The functions of the flag bits are given in Table 1.

#### **Control Registers**

The Am386SXL microprocessor has three control registers of 32 bits, CR3–CR0, to hold the machine state of a global nature. These registers are shown in Figures 1 and 2. The defined CR0 bits are described in Table 2.

### **Instruction Set**

The instruction set is divided into nine categories of operations:

Data Transfer Arithmetic Shift/Rotate String Manipulation Bit Manipulation Control Transfer High-Level Language Support Operating System Support Processor Control

These instructions are listed in the Instruction Set Clock Count Summary (pages 1-406 through 1-420).



Figure 2. Status and Control Register Bit Functions

| Bit Position | Name | Function                                                                                                                                                                                                                                                                                       |  |
|--------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0            | CF   | Carry Flag—Set on high-order bit carry or borrow; cleared otherwise.                                                                                                                                                                                                                           |  |
| 2            | PF   | Parity Flag—Set if low-order 8 bits of result contain an even number of 1 bits;<br>cleared otherwise.                                                                                                                                                                                          |  |
| 4            | AF   | Auxiliary Carry Flag—Set on carry from or borrow to the low-order 4 bits of AL; cleared otherwise.                                                                                                                                                                                             |  |
| 6            | ZF   | Zero Flag—Set if result is zero; cleared otherwise.                                                                                                                                                                                                                                            |  |
| 7            | SF   | Sign Flag—Set equal to high-order bit of result (0 if positive, 1 if negative).                                                                                                                                                                                                                |  |
| 8            | TF   | Single-Step Flag—Once set, a single-step interrupt occurs after the next<br>instruction executes. TF is cleared by the single-step interrupt.                                                                                                                                                  |  |
| 9            | IF   | Interrupt-Enable Flag—When set, maskable interrupts will cause the CPU to<br>transfer control to an interrupt vector specified location.                                                                                                                                                       |  |
| 10           | DF   | Direction Flag—Causes string instructions to auto-increment (default) the<br>appropriate index registers when cleared. Setting DF causes auto-decrement.                                                                                                                                       |  |
| 11           | OF   | Overflow Flag—Set if the operation resulted in a carry/borrow into the sign bit<br>(high-order bit) of the result but did not result in a carry/borrow out of the high<br>order bit or vice-versa.                                                                                             |  |
| 12, 13       | IOPL | I/O Privilege Level—Indicates the maximum CPL permitted to execute I/O instructions without generating an Exception 13 fault or consulting the I/O permission bit map while executing in protected mode. For virtual 8086 mode it indicates the maximum CPL allowing alteration of the IF bit. |  |
| 14           | NT   | Nested Task—Indicates that the execution of the current task is nested within<br>another task.                                                                                                                                                                                                 |  |
| 16           | RF   | Resume Flag—Used in conjunction with debug register breakpoints. It is checked at instruction boundaries before breakpoint processing. If set, any debug fault is ignored on the next instruction.                                                                                             |  |
| 17           | VM   | Virtual 8086 Mode—If set while in protected mode, the Am386SXL micro-<br>processor will switch to virtual 8086 operation, handling segment loads as<br>8086 does, but generating Exception 13 faults on privileged op-codes.                                                                   |  |

### Table 2. CR0 Definitions

| Bit Position | Name | Function                                                                                                                                                                                                                                                                   |  |
|--------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0            | PE   | Protection Mode Enable—Places the Am386SXL microprocessor into pro-<br>tected mode. If PE is reset, the processor operates again in Real Mode. PE<br>may be set by loading MSW or CR0. PE can be reset only by loading CR0;<br>it cannot be reset by the LMSW instruction. |  |
| 1            | MP   | Monitor Coprocessor Extension—Allows WAIT instructions to cause a processor extension Not Present exception (number 7).                                                                                                                                                    |  |
| 2            | ЕМ   | Emulate Processor Extension—Causes a processor extension Not Present<br>exception (number 7) on ESC instructions to allow emulating a processor<br>extension.                                                                                                              |  |
| 3            | TS   | Task Switched—Indicates the next instruction using a processor extension will<br>cause Exception 7, allowing software to test whether the current processor<br>extension context belongs to the current task.                                                              |  |
| 31           | PG   | Paging Enable Bit—Is set to enable the on-chip paging unit. It is reset to<br>disable the on-chip paging unit.                                                                                                                                                             |  |

All Am386SXL microprocessor instructions operate on either 0, 1, 2, or 3 operands; an operand resides in a register, in the instruction itself, or in memory. Most zero operand instructions (e.g., CLI, STI) take only one byte. One operand instructions generally are two bytes long. The average instruction is 3.2 bytes long. Since the Am386SXL CPU has a 16-byte prefetch instruction queue, an average of 5 instructions will be prefetched. The use of two operands permits the following types of common instructions:

Register to Register Memory to Register Immediate to Register Memory to Memory Register to Memory Immediate to Memory

The operands can be either 8, 16, or 32 bits long. As a general rule, when executing code written for the Am386SXL microprocessor (32-bit code), operands are 8 or 32 bits; when executing existing 8086 or 80286 code (16-bit code), operands are 8 or 16 bits. Prefixes can be added to all instructions which override the default length of the operands (i.e., use 32-bit operands for 16-bit code), or 16-bit operands for 32-bit code).

### Memory Organization

Memory on the Am386SXL microprocessor is divided into 8-bit quantities (Bytes), 16-bit quantities (Words), and 32-bit quantities (Dwords). Words are stored in two consecutive bytes in memory with the low-order byte at the lowest address. Dwords are stored in four consecutive bytes in memory with the low-order byte at the lowest address. The address of a Word or Dword is the byte address of the low-order byte.

In addition to these basic data types, the Am386SXL microprocessor supports two larger units of memory: pages and segments. Memory can be divided up into one or more variable length segments, which can be swapped to disk or shared between programs. Memory can also be organized into one or more 4-Kb pages. Finally, both segmentation and paging can be combined, gaining the advantages of both systems. The Am386SXL CPU supports both pages and segmentation in order to provide maximum flexibility to the system designer. Segmentation and paging are complementary. Segmentation is useful for organizing memory in logical modules, and, as such, is a tool for the application programmer, while pages are useful to the system programmer for managing the physical memory of a system.



15021B--011

Figure 3. Address Translation

# 

### Address Spaces

The Am386SXL microprocessor has three types of address spaces: logical, linear, and physical. A logical address (also known as a virtual address) consists of a selector and an offset. A selector is the contents of a segment register. An offset is formed by summing all of the addressing components (Base, Index, Displacement), discussed in the section Addressing Modes, into an effective address. This effective address, along with the selector, is known as the logical address. Since each task on the Am386SXL CPU has a maximum of 16K (2<sup>14</sup>-1) selectors, and offsets can be 4 Gb (with paging enabled), this gives a total of 2<sup>46</sup> bits, or 64 tb, of logical address space.

The segmentation unit translates the logical address space into a 32-bit linear address space. If the paging unit is not enabled then the 32-bit linear address is truncated into a 24-bit physical address. The physical address is what appears on the address pins.

The primary differences between Real Mode and Protected Mode are how the segmentation unit performs the translation of the logical address into the linear address, size of the address space, and paging capability. In Real Mode, the segmentation unit shifts the selector left four bits and adds the result to the effective address to form the linear address. This linear address is limited to 1 Mb. In addition, Real Mode has no paging capability.

Protected Mode will see one of two different address spaces, depending on whether or not paging is enabled. Every selector has a logical base address associated with it that can be up to 32 bits in length. This 32-bit logical base address is added to the effective address to form a final 32-bit linear address. If paging is disabled, this final linear address reflects physical memory and is truncated so that only the lower 24 bits of this address are used to address the 16-Mb memory address space. If paging is enabled, this final linear address reflects a 32-bit address that is translated through the paging unit to form a 16-Mb physical address. The logical base address is stored in one of two operating system tables (i.e., the Local Descriptor Table or Global Descriptor Table).

Figure 3 shows the relationship between the various address spaces.

#### Segment Register Usage

The main data structure used to organize memory is the segment. On the Am386SXL CPU, segments are variable sized blocks of linear addresses which have certain attributes associated with them. There are two main types of segments, code and data. The segments are of variable size and can be as small as 1 byte or as large as 4 Gb (2<sup>32</sup> bits).

In order to provide compact instruction encoding and increase processor performance, instructions do not

need to explicitly specify which segment register is used. The segment register is automatically chosen according to the rules of Table 3 (Segment Register Selection Rules). In general, data references use the selector contained in the DS register; stack references use the SS register; and, instruction fetches use the CS register. The contents of the Instruction Pointer provide the offset. Special segment override prefixes allow the explicit use of a given segment register, and override the implicit rules listed in Table 3. The override prefixes also allow the use of the ES, FS, and GS segment registers.

There are no restrictions regarding the overlapping of the base addresses of any segments. Thus, all six segments could have the base address set to zero and create a system with 4-Gb linear address space. This creates a system where the virtual address space is the same as the linear address space. Further details of segmentation are discussed in the section Protected Mode Architecture.

### Addressing Modes

The Am386SXL microprocessor provides a total of eight addressing modes for instructions to specify operands. The addressing modes are optimized to allow the efficient execution of high-level languages such as C and FORTRAN, and they cover the vast majority of data references needed by high-level languages.

#### **Register and Immediate Modes**

Two of the addressing modes provide for instructions that operate on register or immediate operands.

**Register Operand Mode**: The operand is located in one of the 8-, 16-, or 32-bit general registers.

**Immediate Operand Mode**: The operand is included in the instruction as part of the op-code.

### 32-Bit Memory Addressing Modes

The remaining six modes provide a mechanism for specifying the effective address of an operand. The linear address consists of two components: the segment base address and an effective address. The effective address is calculated by summing any combination of the following three address elements (see Figure 3).

**Displacement:** an 8-,16-, or 32-bit immediate value, following the instruction.

**Base**: The contents of any general purpose register. The base registers are generally used by compilers to point to the start of the local variable area.

Index: The contents of any general purpose register except for ESP. The index registers are used to access the elements of an array or a string of characters. The index register's value can be multiplied by a scale factor, either 1, 2, 4, or 8. The scaled index is especially useful for accessing arrays or structures.

| Type of Memory Reference                                                    | Implied (Default) Segment Use | Segment Override Prefixes Possible |
|-----------------------------------------------------------------------------|-------------------------------|------------------------------------|
| Code Fetch                                                                  | CS                            | None                               |
| Destination of PUSH, PUSHF, INT,<br>CALL, PUSHA Instructions                | SS                            | None                               |
| Source of POP, POPA, POPF,<br>IRET, RET Instructions                        | SS                            | None                               |
| Destination of STOS, MOVE, REP<br>STOS, REP MOVS Instructions               | ES                            | None                               |
| Other Data References, with<br>Effective Address Using Base<br>Register of: |                               |                                    |
| [EAX]                                                                       | DS                            | CS, SS, ES, FS, GS                 |
| [EBX]                                                                       | DS                            | CS, SS, ES, FS, GS                 |
| [ECX]                                                                       | DS                            | CS, SS, ES, FS, GS                 |
| [EDX]                                                                       | DS                            | CS, SS, ES, FS, GS                 |
| [ESI]                                                                       | DS                            | CS, SS, ES, FS, GS                 |
| [EDI]                                                                       | DS                            | CS, SS, ES, FS, GS                 |
| [EBP]                                                                       | SS                            | CS, DS, ES, FS, GS                 |
| [ESP]                                                                       | SS                            | CS, DS, ES, FS, GS                 |

**Table 3. Segment Register Selection Rules** 

Combinations of these three components make up the six additional addressing modes. There is no performance penalty for using any of these addressing combinations, since the effective address calculation is pipelined with the execution of other instructions. The one exception is the simultaneous use of Base and Index components which requires one additional clock.

As shown in Figure 4, the Effective Address (EA) of an operand is calculated according to the following formula:

 $EA = Base_{Register} + (Index_{Register} \times Scaling) + Displacement$ 

- 1. **Direct Mode**: The operand's offset is contained as part of the instruction as an 8-, 16-, or 32-bit displacement.
- 2. **Register Indirect Mode**: A Base register contains the address of the operand.
- 3. **Based Mode:** A Base register's contents are added to a Displacement to form the operand's offset.
- Scaled Index Mode: An Index register's contents are multiplied by a Scaling factor, and the result is added to a Displacement to form the operand's offset.
- Based Scaled Index Mode: The contents of an Index register are multiplied by a Scaling factor, and the result is added to the contents of a Base register to obtain the operand's offset.
- 6. Based Scaled Index Mode with Displacement: The contents of an Index register are multiplied by a Scaling factor, and the result is added to the contents of a Base register and a Displacement to form the operand's offset.

#### Differences Between 16- and 32-Bit Addresses

In order to provide software compatibility with the 8086 and the 80286, the Am386SXL microprocessor can execute 16-bit instructions in Real and Protected Modes. The processor determines the size of the instructions it is executing by examining the D bit in a Segment Descriptor. If the D bit is 0, then all operand lengths and effective addresses are assumed to be 16-bits long. If the D bit is 1, then the default length for operands and addresses is 32 bits. In Real Mode the default size for operands and addresses is 16 bits.

Regardless of the default precision of the operands or addresses, the Am386SXL microprocessor is able to execute either 16- or 32-bit instructions. This is specified through the use of override prefixes. Two prefixes, the Operand Length Prefix and the Address Length Prefix, override the value of the D bit on an individual instruction basis. These prefixes are automatically added by assemblers.

The Operand Length and Address Length Prefixes can be applied separately or in combination to any instruction. The Address Length Prefix does not allow addresses over 64 Kb to be accessed in Real Mode. A memory address which exceeds 0FFFFH will result in a General Protection Fault. An Address Length Prefix only allows the use of the additional Am386SXL CPU addressing modes.

When executing 32-bit code, the Am386SXL CPU uses either 8- or 32-bit displacements, and any register can be used as Base or Index registers. When executing 16-bit code, the displacements are either 8- or 16-bits, and the Base and Index registers conform to the 80286 model. Table 4 illustrates the differences.



15021B-012

Figure 4. Addressing Mode Calculations

### **Data Types**

The Am386SXL microprocessor supports all of the data types commonly used in high-level languages.

Bit: A single bit quantity.

**Bit Field**: A group of up to 32 contiguous bits, which spans a maximum of four bytes.

**Bit String**: A set of contiguous bits; on the Am386SXL microprocessor, bit strings can be up to 4 Gbits long.

Byte: A signed 8-bit quantity.

Unsigned Byte: An unsigned 8-bit quantity.

Integer (Word): A signed 16-bit quantity.

Long Integer (Dword): A signed 32-bit quantity. All operations assume a 2's complement representation.

Unsigned Integer (Word): An unsigned 16-bit quantity.

Unsigned Long Integer (Dword): An unsigned 32-bit quantity.

Signed Quad Word: A signed 64-bit quantity.

Unsigned Quad Word: An unsigned 64-bit quantity.

**Pointer:** A 16- or 32-bit offset-only quantity which indirectly references another memory location.

Long Pointer: A full pointer which consists of a 16-bit segment selector and either a 16- or 32-bit offset.

**Char**: A byte representation of an ASCII alphanumeric or control character.

String: A contiguous sequence of bytes, Words, or Dwords. A string may contain between 1 byte and 4 Gb.

BCD: A byte (unpacked) representation of decimal digits 0–9.

**Packed BCD**: A byte (packed) representation of two decimal digits 0–9 storing one digit in each nibble.

When the Am386SXL microprocessor is coupled with a 387SX math coprocessor, the following common floating point types are supported.

Floating Point: A signed 32-, 64-, or 80-bit real number representation. Floating point numbers are supported by 387SX-compatible math coprocessors.

| Table 4.         | Base and Index Registers for 16- and |  |
|------------------|--------------------------------------|--|
| 32-Bit Addresses |                                      |  |

|                                 | 16-Bit<br>Addressing  | 32-Bit<br>Addressing                                           |
|---------------------------------|-----------------------|----------------------------------------------------------------|
| Base Register<br>Index Register | BX, BP<br>SI, DI      | Any 32-bit GP Register<br>Any 32-bit GP Register<br>Except ESP |
| Scale Factor<br>Displacement    | None<br>0, 8, 16 bits | 1, 2, 4, 8<br>0, 8, 32 bits                                    |

Figure 5 illustrates the data types supported by the Am386SXL microprocessor and a 387SX-compatible math coprocessor.

### I/O Space

The Am386SXL CPU has two distinct physical address spaces: physical memory and I/O. Generally, peripherals are placed in I/O space, although the Am386SXL CPU also supports memory-mapped peripherals. The I/O space consists of 64 Kb which can be divided into 64K 8-bit ports or 32K 16-bit ports, or any combination of ports which add up to no more than 64 Kb. The 64K I/O address space refers to physical addresses rather than linear addresses since I/O instructions do not go through the segmentation or paging hardware. The M/IO pin acts as an additional address line, thus allowing the system designer to easily determine which address space the processor is accessing.

The I/O ports are accessed by the In and Out instructions, with the port address supplied as an immediate 8-bit constant in the instruction or in the DX register. All 8-bit and 16-bit port addresses are zero extended on the upper address lines. The I/O instructions cause the M/IO pin to be driven Low. I/O port addresses 00F8H through 00FFH are reserved for future use.

### Interrupts and Exceptions

Interrupts and exceptions alter the normal program flow in order to handle external events, report errors, or report exceptional conditions. The difference between interrupts and exceptions is that interrupts are used to handle asynchronous external events while exceptions handle instruction faults. Although a program can generate a software interrupt via an INT n instruction, the processor treats software interrupts as exceptions.

Hardware interrupts occur as the result of an external event and are classified into two types: maskable or non-maskable. Interrupts are serviced after the execution of the current instruction. After the interrupt handler is finished servicing the interrupt, execution proceeds with the instruction immediately after the interrupted instruction.

Exceptions are classified as faults, traps, or aborts, depending on the way they are reported and whether or

not restart of the instruction causing the exception is supported. Faults are exceptions that are detected and serviced *before* the execution of the faulting instruction. Traps are exceptions that are reported immediately *after* the execution of the instruction which caused the problem. Aborts are exceptions that do not permit the precise location of the instruction causing the exception to be determined.

Thus, when an interrupt service routine has been completed, execution proceeds from the instruction immediately following the interrupted instruction. On the other hand, the return address from an exception fault routine will always point to the instruction causing the exception and will include any leading instruction prefixes. Table 5 summarizes the possible interrupts for the Am386SXL microprocessor and shows where the return address points to.

The Am386SXL CPU has the ability to handle up to 256 different interrupts/exceptions. In order to service the interrupts, a table with up to 256 interrupt vectors must be defined. The interrupt vectors are simply pointers to the appropriate interrupt service routine. In Real Mode, the vectors are 4-byte quantities, a Code Segment plus a 16-bit offset; in Protected Mode, the interrupt vectors are 8-byte quantities which are put in an Interrupt Descriptor Table. Of the 256 possible interrupts, 32 are reserved for future use and the remaining 224 are free to be used by the system designer.

### Interrupt Processing

When an interrupt occurs, the following actions happen. First, the current program address and Flags are saved on the stack to allow resumption of the interrupted program. Next, an 8-bit vector is supplied to the Am386SXL microprocessor which identifies the appropriate entry in the interrupt table. The table contains the starting address of the interrupt service routine. Then, the user supplied interrupt service routine is executed. Finally, when an IRET instruction is executed the old processor state is restored and program execution resumes at the appropriate instruction.

The 8-bit interrupt vector is supplied to the Am386SXL microprocessor in several different ways: exceptions supply the interrupt vector internally; software INT instructions contain or imply the vector; maskable hardware interrupts supply the 8-bit vector via the interrupt acknowledge bus sequence. Non-Maskable hardware interrupts are assigned to interrupt vector 2.

### Maskable Interrupt

Maskable interrupts are the most common way to respond to asynchronous external hardware events. A hardware interrupt occurs when the INTR is pulled High and the Interrupt Flag bit (IF) is enabled. The processor only responds to interrupts between instructions (string instructions have an interrupt window between memory moves that allows interrupts during long string





| Function                    | Interrupt<br>Number | Instruction Which<br>Can Cause Exception       | Return Address Points to Faulting Instruction | Туре  |
|-----------------------------|---------------------|------------------------------------------------|-----------------------------------------------|-------|
| Divide Error                | 0                   | DIV, IDIV                                      | Yes                                           | FAULT |
| Debug Exception             | 1                   | Any Instruction                                | Yes                                           | TRAP* |
| NMI Interrupt               | 2                   | INT2 or NMI                                    | No                                            | NMI   |
| One Byte Interrupt          | 3                   | INT                                            | No                                            | TRAP  |
| Interrupt on Overflow       | 4                   | INTO                                           | No                                            | TRAP  |
| Array Bounds Check          | 5                   | BOUND                                          | Yes                                           | FAULT |
| Invalid Op-code             | 6                   | Any Illegal Instruction                        | Yes                                           | FAULT |
| Device Not Available        | 7                   | ESC, WAIT                                      | Yes                                           | FAULT |
| Double Fault                | 8                   | Any instruction that can generate an exception |                                               | ABORT |
| Coprocessor Segment Overrun | 9                   | ESC                                            | No                                            | ABORT |
| Invalid TSS                 | 10                  | JMP, CALL, IRET, INT                           | Yes                                           | FAULT |
| Segment Not Present         | 11                  | Segment Register Instructions                  | Yes                                           | FAULT |
| Stack Fault                 | 12                  | Stack References                               | Yes                                           | FAULT |
| General Protection Fault    | 13                  | Any Memory Reference                           | Yes                                           | FAULT |
| Page Fault                  | 14                  | Any Memory Access or Code Fetch                | Yes                                           | FAULT |
| Coprocessor Error           | 16                  | ESC, WAIT                                      | Yes                                           | FAULT |
| Reserved for Future Use     | 17–32               |                                                |                                               |       |
| Two Byte Interrupt          | 0255                | INT n                                          | No                                            | TRAP  |

**Table 5. Interrupt Vector Assignments** 

Note: Some debug exceptions may report both traps on the previous instruction and faults on the next instruction.

moves). When an interrupt occurs the processor reads an 8-bit vector supplied by the hardware which identifies the source of the interrupt (one of 224 user defined interrupts).

Interrupts through interrupt gates automatically reset IF bit, disabling INTR requests. Interrupts through Trap Gates leave the state of the IF bit unchanged. Interrupts through a Task Gate change the IF bit according to the image of the EFLAGs register in the task's Task State Segment (TSS). When an IRET instruction is executed, the original state of the IF bit is restored.

#### Non-Maskable Interrupt

Non-maskable interrupts provide a method of servicing very high priority interrupts. When the NMI input is pulled High it causes an interrupt with an internally supplied vector value of 2. Unlike a normal hardware interrupt, no interrupt acknowledgment sequence is performed for an NMI.

While executing the NMI servicing procedure, the Am386SXL microprocessor will not service any further NMI request or INT requests until an Interrupt Return (IRET) instruction is executed or the processor is reset. If NMI occurs while currently servicing an NMI, its presence will be saved for servicing after executing the first IRET instruction. The IF bit is cleared at the beginning of an NMI interrupt to inhibit further INTR interrupts.

### Software Interrupts

A third type of interrupt/exception for the Am386SXL CPU is the software interrupt. An INT n instruction causes the processor to execute the interrupt service routine pointed to by the nth vector in the interrupt table.

A special case of the two byte software interrupt INT n is the one byte INT 3, or breakpoint interrupt. By inserting this one byte instruction in a program, the user can set breakpoints in his program as a debugging tool.

A final type of software interrupt is the single-step interrupt. It is discussed in section Single-Step Trap.

#### Interrupt and Exception Priorities

Interrupts are externally generated events. Maskable Interrupts (on the INTR input) and Non-Maskable Interrupts (on the NMI input) are recognized at instruction boundaries. When NMI and maskable INTR are both recognized at the same instruction boundary, the Am386SXL microprocessor invokes the NMI service routine first. If maskable interrupts are still enabled after the NMI service routine has been invoked, then the Am386SXL CPU will invoke the appropriate interrupt service routine.

As the Am386SXL microprocessor executes instructions, it follows a consistent cycle in checking for exceptions, as shown in Table 6. This cycle is repeated as each instruction is executed, and occurs in parallel with instruction decoding and execution.

#### Instruction Restart

The Am386SXL microprocessor fully supports restarting all instructions after Faults. If an exception is detected in the instruction to be executed (exception categories 4 through 10 in Table 6), the Am386SXL microprocessor invokes the appropriate exception service routine. The Am386SXL microprocessor is in a state that permits restart of the instruction, for all cases by those given in Table 7. Note that all such cases will be avoided by a properly designed operating system.

#### **Double Fault**

A Double Fault (Exception 8) results when the processor attempts to invoke an exception service routine for the segment exceptions (10, 11, 12, or 13), but in the process of doing so detects an exception other than a Page Fault (Exception 14).

One other cause of generating a Double Fault is the Am386SXL CPU detecting any other exception when it is attempting to invoke the Page Fault (Exception 14) service routine (e.g., if a Page Fault is detected when the Am386SXL microprocessor attempts to invoke the Page Fault service routine). Of course, in any functional system, not only the Am386SXL CPU-based systems, the entire Page Fault service must remain present in memory.

# **Reset and Initialization**

When the processor is initialized or Reset, the registers have the values shown in Table 8. The Am386SXL CPU will then start executing instructions near the top of physical memory, at location 0FFFF0H. When the first intersegment Jump or Call is executed, address lines A23–A20 will drop Low for CS-relative memory cycles, and the Am386SXL CPU will only execute instructions in the lower 1 Mb of physical memory. This allows the system designer to use a shadow ROM at the top of physical memory to initialize the system and take care of Resets.

Reset forces the Am386SXL microprocessor to terminate all execution and local bus activity. No instruction execution or bus activity will occur as long as Reset is active. Between 350- and 450-CLK2 periods after Reset becomes inactive, the Am386SXL microprocessor will start executing instructions at the top of physical memory.

#### Table 6. Sequence of Exception Checking

Consider the case of the 386SXL microprocessor having just completed an instruction. It then performs the following checks before reaching the point where the next instruction is completed.

- 1. Check for Exception 1 Traps from the instruction just completed (single-step via Trap Flag, or Data Breakpoints set in the Debug Registers).
- 2. Check for external NMI and INTR.
- 3. Check for Exception 1 Faults in the next instruction (Instruction Execution Breakpoint set in the Debug Registers for the next instruction).
- 4. Check for Segmentation Faults that prevented fetching the entire next instruction (Exceptions 11 and 13).
- 5. Check for Page Faults that prevented fetching the entire next instruction (Exception 14).
- Check for Faults decoding the next instruction (Exception 6 if illegal op-code; Exception 6 if in Real Mode or in Virtual 8086 Mode and attempting to execute an instruction for Protected Mode only; or Exception 13 if instruction is longer than 15 bytes, or privilege violation in Protected Mode (i.e., not at IOPL or at CPL = 0)).
- 7. If WAIT op-code, check if TS = 1 and MP = 1 (Exception 7 if both are 1).
- 8. If ESCape op-code for math coprocessor, check if EM = 1 or TS = 1 (Exception 7 if either are 1).
- If WAIT op-code or ESCape op-code for math coprocessor, check ERROR input signal (Exception 16 if ERROR input is asserted).
- 10. Check in the following order for each memory reference required by the instruction.
  - a. Check for Segmentation Faults that prevent transferring the entire memory quantity (Exceptions 11, 12, and 13).
  - b. Check for Page Faults that prevent transferring the entire memory quantity (Exception 14).

Note: Segmentation exceptions are generated before paging exceptions.

#### **Table 7. Conditions Preventing Instruction Restart**

- An instruction causes a task switch to a task whose Task State Segment (TSS) is partially not present (an entire not present TSS is restartable). Partially present TSSs can be avoided either by keeping the TSSs of such tasks present in memory, or by aligning TSS segments to reside entirely within a single 4K page (for TSS segments of 4 Kb or less).
- 2. A coprocessor operand wraps around the top of a 64-Kb segment or a 4-Gb segment and spans three pages, and the page holding the middle portion of the operand is not present. This condition can be avoided by starting at a page boundary any segments containing coprocessor operands, if the segments are approximately 64K-200K bytes or larger (i.e., large enough for wraparound of the coprocessor operand to possibly occur).

Note: These conditions are avoided by using the operating system designs mentioned in this table.

#### **Table 8. Register Values after Reset**

| Flag Word (EFLAGS)        | uuuu0002H                 | Note 1 |
|---------------------------|---------------------------|--------|
| Machine Status Word (CR0) | uuuuuu10H                 |        |
| Instruction Pointer (EIP) | 0000FFF0H                 |        |
| Code Segment (CS)         | F000H                     | Note 2 |
| Data Segment (DS)         | 0000H                     | Note 3 |
| Stack Segment (SS)        | 0000H                     |        |
| Extra Segment (ES)        | 0000H                     | Note 3 |
| Extra Segment (FS)        | 0000H                     |        |
| Extra Segment (GS)        | 0000H                     |        |
| EAX Register              | 0000H                     | Note 4 |
| EDX Register              | Component and Stepping ID | Note 5 |
| All Other Registers       | Undefined                 | Note 6 |

Notes: 1. EFLAGS Register. The upper 14 bits of the EFLAGS register are undefined; all defined flag bits are zero.

2. The Code Segment register (CS) will have its Base Address set to 0FFFF0000H and Limit set to 0FFFFH.

3. The Data and Extra Segment registers (DS and ES) will have their Base Address set to 000000000H and Limit set to 0FFFFH.

4. If self-test is selected, the EAX register should contain a 0 value. If a value of 0 is not found, the self-test has detected a flaw in

the part.

5. EDX register always holds a component and stepping identifier.

6. All undefined bits are reserved for future use and should not be used.

# Testability

The Am386SXL microprocessor, like the Am386DX microprocessor, offers testability features that include a self-test and direct access to the page translation cache.

#### Self-Test

The Am386SXL microprocessor has the capability to perform a self-test. The self-test checks the function of all of the Control ROM and most of the non-random logic of the part. Approximately one-half of the Am386SXL CPU can be tested during self-test.

Self-Test is initiated on the Am386SXL microprocessor when the Reset pin transitions from High to Low, and the BUSY pin is Low. The self-test takes about 2<sup>20</sup> clocks, or approximately 33 ms with a 16-MHz Am386SXL CPU. At the completion of self-test the processor performs reset and begins normal operation. The part has successfully passed self-test if the contents of the EAX are zero. If the results of the EAX are not zero, then the self-test has detected a flaw in the part.

# **TLB Testing**

The Am386SXL microprocessor also provides a mechanism for testing the Translation Look-Aside Buffer (TLB), if desired. This particular mechanism may not be continued in the same way in future processors.

There are two TLB testing operations: 1) writing entries into the TLB; and, 2) performing TLB lookups. Two test registers, shown in Figure 6 are provided for the purpose of testing. TR6 is the test command register, and TR7 is the test data register.

# **Debugging Support**

The Am386SXL microprocessor provides several features which simplify the debugging process. The three categories of on-chip debugging aids are:

- 1. The code execution breakpoint op-code (0CCH).
- 2. The single-step capability provided by the TF bit in the flag register.
- 3. The code and data breakpoint capability provided by the Debug Registers DR3-DR0, DR6, and DR7.

#### **Breakpoint Instruction**

A single-byte software interrupt (INT 3) breakpoint instruction is available for use by software debuggers. The breakpoint op-code is 0CCH, and generates an Exception 3 trap when executed.

#### Single-Step Trap

If the single-step flag (TF, bit 8) in the EFLAGS register is found to be set at the end of an instruction, a single-step exception occurs. The single-step exception is auto-vectored to Exception 1.

#### **Debug Registers**

The Debug Registers are an advanced debugging feature of the Am386SXL microprocessor. They allow data access breakpoints as well as code execution breakpoints. Since the breakpoints are indicated by on-chip registers, an instruction execution breakpoint can be placed in ROM code or in code shared by several tasks, neither of which can be supported by the INT 3 breakpoint op-code.

The Am386SXL microprocessor contains six Debug Registers, consisting of four breakpoint address

#### Table 9. Exceptions in Real Mode

| Function                                        | Interrupt<br>Number | Related<br>Instructions                                                                             | Return<br>Address Location |
|-------------------------------------------------|---------------------|-----------------------------------------------------------------------------------------------------|----------------------------|
| Interrupt table limit too small                 | 8                   | INT vector is not within table limit                                                                | Before<br>Instruction      |
| CS, DS, ES, FS, GS<br>Segment Overrun exception | 13                  | Word memory reference with<br>offset = 0FFFFH. An attempt to<br>execute past the end of CS segment. | Before<br>Instruction      |
| SS Segment Overrun exception                    | 12                  | Stack Reference<br>beyond offset = 0FFFFH.                                                          | Before<br>Instruction      |



Figure 6. Test Registers

registers and two breakpoint control registers. Initially after reset, breakpoints are in the disabled state; therefore, no breakpoints will occur unless the Debug Registers are programmed. Breakpoints set up in the Debug Registers are auto-vectored to Exception 1. Figure 7 shows the breakpoint status and control registers.

# **REAL MODE ARCHITECTURE**

When the processor is reset or powered up it is initialized in Real Mode. Real Mode has the same base architecture as the 8086, but allows access to the 32-bit register set of the Am386SXL microprocessor. The addressing mechanism, memory size, and interrupt handling are all identical to the Real Mode on the 80286.

The default operand size in Real Mode is 16 bits, as in the 8086. In order to use the 32-bit registers and addressing modes, override prefixes must be used. In addition, the segment size on the Am386SXL microprocessor in Real Mode is 64 Kb, so 32-bit addresses must have a value less than 0000FFFFH. The primary purpose of Real Mode is to set up the processor for Protected Mode operation.

# Memory Addressing

In Real Mode the linear addresses are the same as physical addresses (paging is not allowed). Physical addresses are formed in Real Mode by adding the contents of the appropriate segment register which is shifted left by four bits to an effective address. This addition results in a 20-bit physical address or a 1-Mb address space. Since segment registers are shifted left by 4 bits, Real Mode segments always start on 16-byte boundaries.

All segments in Real Mode are exactly 64-Kb long, and may be read, written, or executed. The Am386SXL microprocessor will generate an Exception 13 if a data operand or instruction fetch occurs past the end of a segment.

# **Reserved Locations**

There are two fixed areas in memory that are reserved in Real Address Mode: the system initialization area and the interrupt table area. Locations 00000H through 003FFH are reserved for interrupt vectors. Each one of the 256 possible interrupts has a 4-byte jump vector reserved for it. Locations 0FFFFF0H through 0FFFFFFH are reserved for system initialization.

## Interrupts

Many of the exceptions discussed in section Interrupts and Exceptions are not applicable to Real Mode operation; in particular, Exceptions 10, 11, and 14 do not occur in Real Mode. Other exceptions have slightly different meanings in Real Mode; Table 9 identifies these exceptions.

## Shutdown and Halt

The HLT instruction stops program execution and prevents the processor from using the local bus until restarted. Either NMI, FLT, INTR with interrupts enabled (IF=1), or Reset will force the Am386SXL microprocessor out of halt. If interrupted, the saved CS:IP will point to the next instruction after the HLT.

Shutdown will occur when a severe error is detected that prevents further processing. In Real Mode, shutdown can occur under two conditions:

- An interrupt or an exception occurs (Exceptions 8 or 13) and the interrupt vector is larger than the Interrupt Descriptor Table.
- 2. A Call, INT, or Push instruction attempts to wrap around the stack segment when SP is not even.

An NMI input can bring the processor out of shutdown if the Interrupt Descriptor Table limit is large enough to contain the NMI interrupt vector (at least 000FH) and the stack has enough room to contain the vector and flag information (i.e., SP is greater than 0005H). Otherwise, shutdown can only be exited by a processor reset.

# **LOCK Operation**

The LOCK prefix on the Am386SXL microprocessor, even in Real Mode, is more restrictive than on the 80286. This is due to the addition of paging on the Am386SXL CPU in Protected Mode and Virtual 8086 Mode. The LOCK prefix is not supported during repeat string instructions.

The only instruction forms where the LOCK prefix is legal on the Am386SXL microprocessor are shown in Table 10.

| Table 10 | . Legal | Instructions | for the | LOCK Prefix |
|----------|---------|--------------|---------|-------------|
|----------|---------|--------------|---------|-------------|

| Op-Code                              | Operands<br>(Dest, Source) |
|--------------------------------------|----------------------------|
| BIT Test and<br>SET/RESET/COMPLEMENT | Mem, Reg/Immed             |
| XCHG<br>XCHG                         | Reg, Mem<br>Mem, Reg       |
| ADD, OR, ADC, SBB<br>AND, SUB, XOR   | Mem, Reg/Immed             |
| NOT, NEG, INC, DEC                   | Mem                        |

An Exception 6 will be generated if a LOCK prefix is placed before any instruction form or op-code not listed above. The LOCK prefix allows indivisible read/modify/ write operations on memory operands using the instructions above.

The LOCK prefix is not IOPL-sensitive on the Am386SXL microprocessor. The LOCK prefix can be used at any privilege level, but only on the instruction forms listed in Table 10.

# PROTECTED MODE ARCHITECTURE

The complete capabilities of the Am386SXL microprocessor are unlocked when the processor operates in Protected Virtual Address Mode (Protected Mode). Protected Mode vastly increases the linear address space to 4 Gb (2<sup>32</sup> bytes), and allows the running of virtual memory programs of almost unlimited size (64 tb (2<sup>46</sup> bytes)). In addition, Protected Mode allows the Am386SXL CPU to run all of the existing Am386DX CPU (using only 16 Mb of physical memory), 80286, and 8086 CPU's software, while providing a sophisticated memory management and a hardware-assisted protection mechanism. Protected Mode allows the use of additional instructions specially optimized for supporting multitasking operating systems. The base architecture of the Am386SXL microprocessor remains the same; the registers, instructions, and addressing modes described in the previous sections are retained. The main difference between Protected Mode and Real Mode from a programmer's viewpoint is the increased address space and a different addressing mechanism.

# Addressing Mechanism

Like Real Mode, Protected Mode uses two components to form the logical address: a 16-bit selector is used to determine the linear base address of a segment, the base address is added to a 32-bit effective address to form a 32-bit linear address. The linear address is then either used as a 24-bit physical address, or if paging is enabled, the paging mechanism maps the 32-bit linear address into a 24-bit physical address.

The difference between the two modes lies in calculating the base address. In Protected Mode, the selector is used to specify an index into an operating system defined table (see Figure 8). The table contains the 32-bit base address of a given segment. The physical address is formed by adding the base address obtained from the table to the offset.

Paging provides an additional memory management mechanism which operates only in Protected Mode. Paging provides a means of managing the very large segments of the Am386SXL microprocessor, as paging operates beneath segmentation. The page mechanism translates the protected linear address which comes from the segmentation unit into a physical address. Figure 9 shows the complete Am386SXL CPU addressing mechanism with paging enabled.



Figure 7. Debug Registers

# Segmentation

Segmentation is one method of memory management. Segmentation provides the basis for protection. Segments are used to encapsulate regions of memory which have common attributes. For example, all of the code of a given program could be contained in a segment, or an operating system table may reside in a segment. All information about each segment is stored in an 8-byte data structure called a descriptor. All of the descriptors in a system are contained in descriptor tables which are recognized by hardware.

# Terminology

The following terms are used throughout the discussion of descriptors, privilege levels, and protection:

- PL: Privilege Level—One of the four hierarchical privilege levels. Level 0 is the most privileged level and level 3 is the least privileged.
- RPL: Requestor Privilege Level—The privilege level of the original supplier of the selector. RPL is determined by the least two significant bits of a selector.
- DPL: Descriptor Privilege Level—This is the least privileged level at which a task may access that descriptor (and the segment associated with that descriptor). Descriptor Privilege Level is determined by bits 6:5 in the Access Right Byte of a descriptor.

- CPL: Current Privilege Level—The privilege level at which a task is currently executing, which equals the privilege level of the code segment being executed. CPL can also be determined by examining the lowest 2 bits of the CS register, except for conforming code segments.
- EPL: Effective Privilege Level The effective privilege level is the least privileged of the RPL and the DPL. EPL is the numerical maximum of RPL and DPL.
- Task: One instance of the execution of a program. Tasks are also referred to as processes.

# **Descriptor Tables**

The descriptor tables define all of the segments which are used in an Am386SXL microprocessor system. There are three types of tables which hold descriptors: the Global Descriptor Table, Local Descriptor Table, and Interrupt Descriptor Table. All of the tables are variable length memory arrays and can vary in size from 8 bytes to 64 Kb. Each table can hold up to 8192 8-byte descriptors. The upper 13 bits of a selector are used as an index into the descriptor table. The tables have registers associated with them which hold the 32-bit linear base address and the 16-bit limit of each table.



15021B-018

Figure 8. Protected Mode Addressing







Figure 10. Descriptor Table Registers

Each of the tables has a register associated with it: GDTR, LDTR, and IDTR (see Figure 1). The LGDT, LLDT, and LIDT instructions load the base and limit of the Global, Local, and Interrupt Descriptor Tables into the appropriate register. The SGDT, SLDT, and SIDT store the base and limit values. These are privileged instructions.

#### **Global Descriptor Table**

The Global Descriptor Table (GDT) contains descriptors which are available to all of the tasks in a system. The GDT can contain any type of segment descriptor except for interrupt and trap descriptors. Every Am386SXL CPU system contains a GDT.

The first slot of the Global Descriptor Table corresponds to the null selector and is not used. The null selector defines a null pointer value.

#### Local Descriptor Table

LDTs contain descriptors which are associated with a given task. Generally, operating systems are designed so that each task has a separate LDT. The LDT may contain only code, data, stack, task gate, and call gate descriptors. LDTs provide a mechanism for isolating a given task's code and data segments from the rest of the operating system, while the GDT contains descriptors for segments which are common to all tasks. A segment cannot be accessed by a task if its segment descriptor does not exist in either the current LDT or the GDT. This provides both isolation and protection for a task's segments while still allowing global data to be shared among tasks.

Unlike the 6-byte GDT or IDT registers which contain a base address and limit, the visible portion of the LDT register contains only a 16-bit selector. This selector refers to a Local Descriptor Table descriptor in the GDT (see Figure 1).

#### Interrupt Descriptor Table

The third table needed for Am386SXL microprocessor systems is the Interrupt Descriptor Table. The IDT contains the descriptors which point to the location of the up to 256 interrupt service routines. The IDT may contain only task gates, interrupt gates, and trap gates. The IDT should be at least 256 bytes in size in order to hold the descriptors for the 32 interrupts reserved for future use. Every interrupt used by a system must have an entry in the IDT. The IDT entries are referenced by INT instructions, external interrupt vectors, and exceptions.

#### Descriptors

The object to which the segment selector points to is called a descriptor. Descriptors are eight byte quantities which contain attributes about a given region of linear address space. These attributes include the 32-bit base linear address of the segment, the 20-bit length and granularity of the segment, the protection level, read, write, or execute privileges, the default size of the operands (16 bit or 32 bit), and the type of segment. All of the attribute information about a segment is contained in 12 bits in the segment descriptor. Figure 11 shows the general format of a descriptor. All segments on the Am386SXL microprocessor have three attribute fields in common: the P bit, the DPL bit, and the S bit. The P (Present) Bit is 1 if the segment is loaded in physical memory. If P=0, then any attempt to access this segment causes a Not Present exception (number 11). The Descriptor Privilege Level (DPL) is a two bit field which specifies the protection level, 0-3, associated with a segment.

The Am386SXL microprocessor has two main categories of segments: system segments and nonsystem segments (for code and data). The segment bit (S) determines if a given segment is a system segment or a code or data segment. If the S bit is 1, then the segment is either a code or data segment; if it is 0, then the segment is a system segment.

#### Code and Data Descriptors (S=1)

Figure 12 shows the general format of a code and data descriptor, and Table 11 illustrates how the bits in the Access Right Byte are interpreted.

Code and data segments have several descriptor fields in common. The accessed bit (A) is set whenever the processor accesses a descriptor. The granularity bit (G) specifies if a segment length is byte-granular or page-granular.



Figure 11. Segment Descriptors

|     |                                                    |       |      |      |     |                |                                          |                                          |                           | AMD 🖌      |
|-----|----------------------------------------------------|-------|------|------|-----|----------------|------------------------------------------|------------------------------------------|---------------------------|------------|
| 31  |                                                    |       |      |      |     |                |                                          | (                                        | 0_Byte                    | Address    |
|     | Segmen                                             | t Ba  | se 1 | 15-0 | )   |                | Segment Limit 15                         | 5–0                                      |                           | 0          |
|     | Base 31–24                                         | G     | D    | 0    | AVL | Limit<br>19–16 | Access Rights Bytes                      | Base<br>23–16                            | ]                         | +4         |
| D/B | 1 = Default Instruction<br>0 = Default Instruction |       |      |      |     |                | Granularity Bit 1 = Segmen<br>0 = Segmen | ent legnth is page<br>ent length is byte | le-granular<br>∋-granular |            |
| AVL | Available field for us                             | ser o | r OS | 3    |     | 0              | Bit must be zero for compatib            | cility with future                       | processors                |            |
|     |                                                    |       |      |      |     |                |                                          |                                          |                           | 15021B-023 |





15021B-024



6 7

80286 Trap Gate

#### Table 11. Access Rights Byte Definition for Code and Data Descriptors

| Bit<br>Position | Name                              |                  | Function                                                                                                                     |                               |
|-----------------|-----------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------|-------------------------------|
| 7               | Present (P)                       | P = 1<br>P = 0   | Segment is mapped into physical memory.<br>No mapping to physical memory exists, Base and L<br>not used.                     | imit are                      |
| 6–5             | Descriptor Privilege Levels (DPL) |                  | Segment privilege attribute used in privilege tests.                                                                         |                               |
| 4               | Segment Descriptor (S)            | S=1<br>S=0       | Code or Data (includes stacks) Segment Descriptor<br>System Segment Descriptor or Gate Descriptor.                           |                               |
| 3               | Executable (E)                    | E=0              | Descriptor type is data segment:                                                                                             |                               |
| 2               | Expansion Direction (ED)          | ED = 0<br>ED = 1 | Expand up segment, offsets must be ≤ limit.<br>Expand down segment, offsets must be > limit.                                 | If Data<br>Segment<br>(S = 1, |
| 1               | Writeable (W)                     | W = 0<br>W = 1   | Data segment may not be written into.<br>Data segment may be written into.                                                   | E = 0)                        |
| 3               | Executable (E)                    | E=1              | Descriptor type is code segment:                                                                                             | Korda                         |
| 2               | Conforming (C)                    | C = 1            | Code segment may only be executed when<br>CPL≥DPL and CPL remains unchanged.                                                 | If Code<br>Segment<br>(S = 1, |
| 1               | Readable (R)                      | R=0<br>R=1       | Code segment may not be read.<br>Code segment may be read.                                                                   | È = 1)                        |
| 0               | Accessed (A)                      | A = 0<br>A = 1   | Segment has not been accessed.<br>Segment selector has been loaded into segment re<br>or used by selector test instructions. | gister                        |

#### System Descriptor Formats (S=0)

System segments describe information about operating system tables, task, and gates. Figure 13 shows the general format of system segment descriptors, and the various types of system segments. Am386SXL CPU system descriptors (which are the same as Am386DX CPU system descriptors) contain a 32-bit base linear address and a 20-bit segment limit. 80286 system descriptors have a 24-bit base address and a 16-bit segment limit. 80286 system descriptors are identified by the upper 16 bits being all zero.

# Differences Between Am386SXL Microprocessor and 80286 Descriptors

In order to provide operating system compatibility with the 80286, the Am386SXL CPU supports all of the 80286 segment descriptors. The 80286 system segment descriptors contain a 24-bit base address and 16-bit limit, while the Am386SXL CPU system segment descriptors have a 32-bit base address, a 20-bit limit field, and a granularity bit. The word count field specifies the number of 16-bit quantities to copy for 80286 call gates and 32-bit quantities for Am386SXL CPU call gates.

#### Selector Fields

A selector in Protected Mode has three fields: Local or Global Descriptor Table Indicator (TI), Descriptor Entry Index (Index), and Requestor (the selector's) Privilege Level (RPL), as shown in Figure 14. The TI bit selects either the Global Descriptor Table or the Local Descriptor Table. The Index selects one of 8K descriptors in the appropriate descriptor table. The RPL bits allow high speed testing of the selector's privilege attributes.

#### Segment Descriptor Cache

In addition to the selector value, every segment register has a segment descriptor cache register associated with it. Whenever a segment register's contents are changed, the 8-byte descriptor associated with the selector is automatically loaded (cached) on the chip. Once loaded, all references to that segment use the cached descriptor information instead of reaccessing the descriptor. The contents of the descriptor cache are not visible to the programmer. Since descriptor caches only change when a segment register is changed, programs which modify the descriptor tables must reload the appropriate segment registers after changing a descriptor's value.

### Protection

The Am386SXL microprocessor has four levels of protection which are optimized to support a multitasking operating system and to isolate and protect user programs from each other and the operating system. The privilege levels control the use of privileged instructions, I/O instructions, and access to segments and segment descriptors. The Am386SXL microprocessor also offers an additional type of protection on a page basis when paging is enabled.

The four-level hierarchical privilege system is an extension of the user/supervisor privilege mode commonly used by minicomputers. The user/supervisor mode is fully supported by the Am386SXL microprocessor paging mechanism. The Privilege Levels (PL) are numbered 0 through 3. Level 0 is the most privileged level.



Figure 14. Example Descriptor Selection

15021B-027

| Control Transfer Types                                        | Operation Types                                                      | Descriptor<br>Referenced  | Descriptor<br>Table |
|---------------------------------------------------------------|----------------------------------------------------------------------|---------------------------|---------------------|
| Intersegment within the same privilege level                  | JMP, CALL, RET, IRET*                                                | Code Segment              | GDT/LDT             |
| Intersegment to the same or higher privilege level            | CALL                                                                 | Call Gate                 | GDT/LDT             |
| Interrupt within task may change CPL                          | Interrupt Instruction,<br>Exception, External<br>Interrupt           | Trap or Interrupt<br>Gate | IDT                 |
| Intersegment to a lower privilege level<br>(changes task CPL) | RET, IRET*                                                           | Code Segment              | GDT/LDT             |
|                                                               | CALL, JMP                                                            | Task State<br>Segment     | GDT                 |
|                                                               | CALL, JMP                                                            | Task Gate                 | GDT/LDT             |
| Task Switch                                                   | IRET**<br>Interrupt Instruction,<br>Exception, External<br>Interrupt | Task Gate                 | IDT                 |

#### Table 12. Descriptor Types Used for Control Transfer

\*NT (Nested Task bit of flag register) = 0

\*\*NT (Nested Task bit of flag register) = 1

#### **Rules of Privilege**

The Am386SXL microprocessor controls access to both data and procedures between levels of a task, according to the following rules:

- —Data stored in a segment with privilege level p can be accessed only by code executing at a privilege level at least as privileged as p.
- —A code segment/procedure with privilege level p can only be called by a task executing at the same or lesser privilege level than p.

#### **Privilege Levels**

At any point in time, a task on the Am386SXL microprocessor always executes at one of the four privilege levels. The Current Privilege Level (CPL) specifies what the task's privilege level is. A task's CPL may only be changed by control transfers through gate descriptors to a code segment with a different privilege level. Thus, an application program running at PL=3 may call an operating system routine at PL=1 (via a gate) which would cause the task's CPL to be set to 1 until the operating system routine was finished.

#### Selector Privilege (RPL)

The privilege level of a selector is specified by the RPL field. The selector's RPL is only used to establish a less trusted privilege level than the current privilege level of the task for the use of a segment. This level is called the task's Effective Privilege Level (EPL). The EPL is defined as being the least privileged (numerically larger) level of a task's CPL and a selector's RPL. The RPL is most commonly used to verify that pointers passed to an operating system procedure do not access data that is

of higher privilege than the procedure that originated the pointer. Since the originator of a selector can specify any RPL value, the Adjust RPL (ARPL) instruction is provided to force the RPL bits to the originator's CPL.

#### I/O Privilege

The I/O Privilege Level (IOPL) lets the operating system code executing at CPL = 0 define the least privileged level at which I/O instructions can be used. An Exception 13 (General Protection Violation) is generated if an I/O instruction is attempted when the CPL of the task is less privileged then the IOPL. The IOPL is stored in bits 13 and 14 of the EFLAGS register. The following instructions cause an Exception 13 if the CPL is greater than IOPL: IN, INS, OUT, OUTS, STI, CLI, and LOCK prefix.

#### **Descriptor Access**

There are basically two types of segment accesses: those involving code segments such as control transfers, and those involving data accesses. Determining the ability of a task to access a segment involves the type of segment to be accessed, the instruction used, the type of descriptor used, and CPL, RPL, and DPL as described above.

Any time an instruction loads a data segment register (DS, ES, FS, GS) the Am386SXL CPU makes protection validation checks. Selectors loaded in the DS, ES, FS, GS registers must refer only to data segment or readable code segments.

Finally, the privilege validation checks are performed. The CPL is compared to the EPL and if the EPL is more privileged than the CPL, an Exception 13 (General Protection Fault) is generated.

| Г             | 31       | ng gilik lan mung din lanan gulimber opposition din person                                                     |           |                     | 972 124 (a) | 16             | 15        |        |       |      |                                                                                                                 |                                           |                          | 0            | ] TSS<br>Base |
|---------------|----------|----------------------------------------------------------------------------------------------------------------|-----------|---------------------|-------------------------------------------------|----------------|-----------|--------|-------|------|-----------------------------------------------------------------------------------------------------------------|-------------------------------------------|--------------------------|--------------|---------------|
| [             | Γ        | 000000000000000000000000000000000000000                                                                        |           |                     |                                                 |                |           |        |       |      |                                                                                                                 | Ba                                        | ck Link                  |              | Dase          |
|               | Γ        |                                                                                                                |           |                     | ESPO                                            | )              |           |        |       |      |                                                                                                                 |                                           |                          | 4            | )             |
|               | Γ        | 000000000000000000000000000000000000000                                                                        |           |                     |                                                 |                |           |        |       |      |                                                                                                                 | 5                                         | SS0                      | 8            |               |
|               |          |                                                                                                                |           |                     | ESP                                             | 1              |           |        |       |      |                                                                                                                 |                                           |                          | l c          | Stacks<br>for |
|               |          | 000000000000000000000000000000000000000                                                                        |           |                     |                                                 |                |           |        |       |      |                                                                                                                 | 5                                         | SS1                      | 10           | ( CPL         |
|               |          |                                                                                                                |           |                     | ESP2                                            |                |           |        |       |      |                                                                                                                 |                                           |                          | 14           | 0, 1, 2       |
|               |          | 000000000000000000000000000000000000000                                                                        |           |                     | feftið för sun se stör fafti                    |                |           |        |       |      |                                                                                                                 |                                           | SS2                      | 18           |               |
|               | F        |                                                                                                                |           |                     | CR3                                             |                |           |        |       |      |                                                                                                                 |                                           |                          | 10           | {             |
|               | F        | n an                                                                       |           |                     | EIP                                             |                |           |        |       |      | ,                                                                                                               | ******                                    |                          | 20           |               |
|               | F        |                                                                                                                |           |                     | EFLAG                                           | s              |           |        |       |      |                                                                                                                 |                                           |                          | 24           |               |
| (             | F        |                                                                                                                |           |                     | EAX                                             |                |           |        |       |      |                                                                                                                 |                                           |                          | 28           |               |
| 1             |          | and a second of the second |           |                     | ECX                                             |                |           |        |       |      |                                                                                                                 |                                           | ing and the state of the | 20           |               |
|               |          | and "All annual " Andrewall II an and "An area                                                                 |           |                     | EDX                                             |                |           |        |       |      |                                                                                                                 |                                           |                          | 30           |               |
|               |          |                                                                                                                |           |                     | EBX                                             |                |           |        |       |      |                                                                                                                 |                                           |                          | 34           |               |
|               |          |                                                                                                                |           |                     | ESP                                             |                |           |        |       |      |                                                                                                                 |                                           |                          | 38           | Current       |
|               |          |                                                                                                                |           |                     | EBP                                             |                |           |        |       |      |                                                                                                                 |                                           |                          | 30           | Task State    |
| 1             |          |                                                                                                                |           |                     | ESI                                             |                |           |        |       |      |                                                                                                                 |                                           |                          | 40           | - Clair       |
| 1             | F        |                                                                                                                |           |                     | EDI                                             |                |           |        |       |      |                                                                                                                 |                                           |                          | 44           |               |
|               | F        | 000000000000000000000000000000000000000                                                                        |           |                     |                                                 |                |           |        |       |      |                                                                                                                 |                                           | ES                       | 48           |               |
|               |          | 000000000000000000000000000000000000000                                                                        |           |                     |                                                 |                |           |        |       |      | and the second secon | in an | CS                       | 40           |               |
|               |          | 000000000000000000000000000000000000000                                                                        |           |                     |                                                 |                |           |        |       |      |                                                                                                                 |                                           | SS                       | 50           |               |
|               |          | 000000000000000000000000000000000000000                                                                        |           |                     |                                                 |                |           |        |       |      |                                                                                                                 |                                           | DS                       | 54           |               |
|               | F        | 000000000000000000000000000000000000000                                                                        |           |                     |                                                 |                |           |        |       |      |                                                                                                                 |                                           | FS                       | 58           |               |
|               |          | 000000000000000000000000000000000000000                                                                        |           |                     |                                                 |                |           |        |       |      |                                                                                                                 |                                           | GS                       | 5C           |               |
|               |          | 000000000000000000000000000000000000000                                                                        |           |                     |                                                 |                |           |        |       |      |                                                                                                                 | 1                                         | LDT                      | 60           | J             |
|               | Γ        | BIT_MAP_OFFSET(                                                                                                | 15:0      | )                   |                                                 |                |           | 000    | 00000 | 0000 | 0000                                                                                                            |                                           | Т                        | 64           | Debug         |
|               | ٦.       | Available                                                                                                      |           |                     |                                                 | ~              |           |        |       |      |                                                                                                                 |                                           |                          | 68           | Trap          |
|               | Ť        |                                                                                                                |           |                     | Syst                                            |                | tatus, e  | ətc.   |       |      |                                                                                                                 |                                           | 6                        | *)           | Bit           |
|               | F        | 1 04                                                                                                           | 23        | unu Pirite innensee |                                                 |                | rss<br>45 |        |       |      | 7                                                                                                               |                                           |                          |              |               |
|               | 3        |                                                                                                                | 55        |                     |                                                 | 16             | 15        |        |       | 8    |                                                                                                                 |                                           | 32                       | 1 2-1        | MAP_OFF       |
|               | 9        |                                                                                                                | 55<br>87  |                     |                                                 | 48<br>80       | 47<br>79  |        |       | 72   | 39<br>71                                                                                                        |                                           |                          | 4            |               |
|               | F        | 5 00                                                                                                           | <u>°′</u> |                     |                                                 | 00             | /9        |        |       | 12   |                                                                                                                 |                                           | 64<br>96                 | -1           | SET + C       |
|               | $\vdash$ |                                                                                                                |           |                     |                                                 |                |           |        |       |      |                                                                                                                 |                                           | 90                       | -            | SET + 10      |
| cess TSS      | ┢        |                                                                                                                |           |                     |                                                 |                |           |        |       | -    |                                                                                                                 |                                           |                          | -            | 361 + 10      |
| ights Limit   | ሯ        |                                                                                                                |           |                     |                                                 |                |           |        |       |      |                                                                                                                 |                                           | 6                        | ř            |               |
| BASE          | F        | 65407                                                                                                          |           |                     | I/O P                                           | ermis          | sion Bi   | tmap   |       |      |                                                                                                                 |                                           |                          |              | SET + 1FE     |
| Program 0     |          | 65439                                                                                                          |           |                     | (One                                            | e Bit p        | er Byte   | e 1/O  |       |      |                                                                                                                 |                                           |                          | -            | SET + 1FF0    |
| Invisible     |          | 65471                                                                                                          |           |                     | Port                                            | . Bitm         | ap mag    | y be   |       |      |                                                                                                                 |                                           |                          | -            | SET + 1FF4    |
| Task Register | F        | 65503                                                                                                          |           |                     | truncate                                        | ed usi         | ng TSS    | S Limi | t.)   |      |                                                                                                                 |                                           | 65472                    | -            | SET + 1FF8    |
| Selector      | F        | 65535                                                                                                          | -         |                     |                                                 | Т              |           |        |       |      |                                                                                                                 |                                           | 65504                    | -            | SET + 1FF0    |
| 15 0          | L        |                                                                                                                | L         |                     |                                                 | A              |           |        |       |      |                                                                                                                 | "FFH"                                     |                          |              | SET + 2000    |
|               |          |                                                                                                                |           |                     |                                                 |                |           |        |       | L    |                                                                                                                 |                                           |                          |              |               |
|               | 31       |                                                                                                                |           |                     | TSS                                             | Descri         | iptor (ir | GDT    | )     |      |                                                                                                                 | 1                                         | SS Limi                  | t = OFF<br>0 | SET + 2000    |
|               | ř        | Segmer                                                                                                         | nt Ba     | se 15-4             |                                                 |                | <u> </u>  |        |       | Seam | ient Limi                                                                                                       | t 15_0                                    |                          | -ĭ           |               |
| L             | ▶├       |                                                                                                                | T         |                     | T T                                             | Limit<br>19–16 | -+        |        |       | Ť    |                                                                                                                 | T                                         | <b>D</b>                 |              |               |
|               |          | Base 31-24                                                                                                     | G         | 1 0                 | 0                                               | i umit         | .   F     | . ( )  | PLIO  | 1    | Туре                                                                                                            |                                           | Base                     |              |               |

Type = 9: Available TSS. Type = B: Busy TSS.

15022B--006

Figure 15. TSS and TSS Registers

|     | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31  | 1  | 1  | 1  | 1  | 0  | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 0  | 1  | 0  | 0  | 1  | 1  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |
| 63  | 0  | 0  | 1  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 0  | 0  | 1  | 0  | 1  | 0  | 1  | 1  | 1  | 1  | 1  | 1  | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |
| 95  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 127 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 2   | L. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 6 |
| •   |    |    |    |    |    |    |    |    |    |    |    | et | C. |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | • |

I/O Ports Accessible: 2  $\rightarrow$  9, 12, 13, 15, 20  $\rightarrow$  24, 27, 33, 34, 40, 41, 48, 50, 52, 53, 58  $\rightarrow$  60, 62, 63, 96  $\rightarrow$  127

15022B-032b



The rules regarding the stack segment are slightly different than those involving data segments. Instructions that load selectors into SS must refer to data segment descriptors for writeable data segments. The DPL and RPL must equal the CPL of all other descriptor types or a privilege level violation will cause an Exception 13. A stack not present fault causes an Exception 12.

#### **Privilege Level Transfers**

Inter-segment control transfers occur when a selector is loaded in the CS register. For a typical system most of these transfers are simply the result of a call or a jump to another routine. There are five types of control transfers which are summarized in Table 12. Many of these transfers result in a privilege level transfer. Changing privilege levels is done only by control transfers, using gates, task switches, and interrupt or trap gates.

Control transfers can only occur if the operation which loaded the selector references the correct desriptor type. Any violation of these descriptor usage rules will cause an Exception 13.

#### **CALL Gates**

Gates provide protected indirect CALLs. One of the major uses of gates is to provide a secure method of privilege transfers within a task. Since the operating system defines all of the gates in a system, it can ensure that all gates only allow entry into a few trusted procedures.

#### **Task Switching**

A very important attribute of any multitasking/multi-user operating system is its ability to rapidly switch between tasks or processes. The Am386SXL microprocessor directly supports this operation by providing a task switch instruction in hardware. The task switch operation saves the entire state of the machine (all of the registers, address space, and a link to the previous task), loads a new execution state, performs protection checks, and commences execution in the new task. Like transfer of control by gates, the task switch operation is invoked by executing an inter-segment JMP or CALL instruction which refers to a Task State Segment (TSS), or a task gate descriptor in the GDT or LDT. An INT n instruction, exception, trap, or external interrupt may also invoke the task switch operation if there is a task gate descriptor in the associated IDT descriptor slot.

The TSS descriptor points to a segment (see Figure 15) containing the entire execution state. A task gate descriptor contains a TSS selector. The Am386SXL microprocessor supports both 80286 and Am386SXL CPU TSSs. The limit of an Am386SXL CPU TSS must be greater than 64H (2BH for a 80286 TSS), and can be as large as 16 Mb. In the additional TSS space, the operating system is free to store additional information such as the reason the task is inactive, the time the task has spent running, or open files belonging to the task.

Each task must have a TSS associated with it. The current TSS is identified by a special register in the Am386SXL microprocessor called the Task State Segment Register (TR). This register contains a selector referring to the task state segment descriptor that defines the current TSS. A hidden base and limit register associated with TSS descriptor are loaded whenever TR is loaded with a new selector. Returning from a task is accomplished by the IRET instruction. When IRET is executed, control is returned to the task which was interrupted. The currently executing task's state is saved in the TSS and the old task state is restored from its TSS.

Several bits in the flag register and machine status word (CR0) give information about the state of a task which is useful to the operating system. The Nested Task bit (NT) controls the function of the IRET instruction. If NT = 0, the IRET instruction performs the regular return. If NT = 1, IRET performs a task switch operation base to the previous task. The NT bit is set or reset in the following fashion:

When a CALL or INT instruction initiates a task switch, the new TSS will be marked busy and the back link field of the new TSS set to the old TSS selector. The NT bit of the new task is set by CALL or INT initiated task switches. An interrupt that does not cause a task switch will clear NT (the NT bit will be restored after execution of the interrupt handler). NT may also be set or cleared by POPF or IRET instructions. The Am386SXL microprocessor task state segment is marked busy by changing the descriptor type field from Type 9 to Type 0BH. An 80286 TSS is marked busy by changing the descriptor type field from Type 1 to Type 3. Use of a selector that references a busy task state segment causes an Exception 13.

The VM (Virtual Mode) bit is used to indicate if a task is a Virtual 8086 task. If VM = 1 then the tasks will use the Real Mode addressing mechanism. The Virtual 8086 environment is only entered and exited by a task switch.

The coprocessor's state is not automatically saved when a task switch occurs. The Task Switched Bit (TS) in the CR0 register helps deal with the coprocessor's state in a multitasking environment. Whenever the Am386SXL microprocessor switches tasks, it sets the TS bit. The Am386SXL CPU detects the first use of a processor extension instruction after a task switch and causes the processor extension Not Available Exception 7. The exception handler for Exception 7 may then decide whether to save the state of the coprocessor.

The T bit in the Am386SXL microprocessor TSS indicates that the processor should generate a debug exception when switching to a task. If T = 1, then upon entry to a new task a debug Exception 1 will be generated.

#### Initialization and Transition To Protected Mode

Since the Am386SXL microprocessor begins executing in Real Mode immediately after RESET, it is necessary to initialize the system tables and registers with the appropriate values. The GDT and IDT registers must refer to a valid GDT and IDT. The IDT should be at least 256 bytes long, and the GDT must contain descriptors for the initial code and data segments.

Protected Mode is enabled by loading CR0 with PE bit set. This can be accomplished by using the MOV CR0. R/M instruction. After enabling Protected Mode, the next instruction should execute an intersegment JMP to load the CS register and flush the instruction decode queue. The final step is to load all of the data segment registers with the initial selector values.

An alternate approach to entering Protected Mode is to use the built in task-switch to load all of the registers. In this case the GDT would contain two TSS descriptors in addition to the code and data descriptors needed for the first task. The first JMP instruction in Protected Mode would jump to the TSS causing a task switch and loading all of the registers with the values stored in the TSS. The Task State Segment Register should be initialized to point to a valid TSS descriptor.

# Paging

Paging is another type of memory management useful for virtual memory multitasking operating systems. Unlike segmentation, which modularizes programs and data into variable length segments, paging divides programs into multiple uniform size pages. Pages bear no direct relation to the logical structure of a program. While segment selectors can be considered the logical name of a program module or data structure, a page most likely corresponds to only a portion of a module or data structure.

# **Page Organization**

The Am386SXL microprocessor uses two levels of tables to translate the linear address (from the segmentation unit) into a physical address. There are three components to the paging mechanism of the Am386SXL CPU: the Page Directory, the Page Tables, and the page itself (Page Frame). All memory-resident elements of the Am386SXL microprocessor paging mechanism are the same size, namely 4 Kb. A uniform size for all of the elements simplifies memory allocation and reallocation schemes, since there is no problem with memory fragmentation. Figure 17 shows how the paging mechanism works.



Figure 17. Paging Mechanism

| 31                       | 12 | 11 | 10                     | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2      | 1           | 0 |
|--------------------------|----|----|------------------------|---|---|---|---|---|---|---|--------|-------------|---|
| Page Table Address 31–12 |    | So | stem<br>ftwar<br>finea |   | 0 | 0 | D | A | 0 | 0 | U<br>s | R<br>-<br>W | Ρ |

15022B-037

Figure 18. Page Directory Entry (Points to Page Table)

| 31                       | 12 | 11 | 10                     | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2           | 1           | 0 |
|--------------------------|----|----|------------------------|---|---|---|---|---|---|---|-------------|-------------|---|
| Page Frame Address 31–12 |    | Só | stem<br>ftwar<br>finea | е | 0 | 0 | D | A | 0 | 0 | U<br>-<br>S | R<br>-<br>W | Р |
|                          |    |    |                        |   |   |   |   |   |   |   |             |             |   |



### Page Fault Register

CR2 is the Page Fault Linear Address register. It holds the 32-bit linear address which caused the last Page Fault detected.

#### Page Descriptor Base Register

CR3 is the Page Directory Physical Base Address Register. It contains the physical starting address of the Page Directory (this value is truncated to a 24-bit value associated with the Am386SXL CPU's 16-Mb physical memory limitation). The lower 12 bits of CR3 are always zero to ensure that the Page Directory is always page aligned. Loading it with a MOV CR3, reg instruction causes the Page Table entry cache to be flushed, as will a task switch through a TSS which changes the value of CR0.

#### Page Directory

The Page Directory is 4-Kb long and allows up to 1024 Page Directory entries. Each Page Directory entry contains information about the Page Table and the address of the next level of tables, the Page Tables. The contents of a Page Directory entry are shown in Figure 18. The upper 10 bits of the linear address (A31-A22) are used as an index to select the correct Page Directory entry.

The Page Table address contains the upper 20 bits of a 32-bit physical address that is used as the base address for the next set of tables, the Page Tables. The lower 12 bits of the Page Table addresses appear on 4-Kb boundaries. For an Am386DX CPU system, the upper 20 bits will select one of 2<sup>20</sup> Page Tables, but for an Am386SXL microprocessor system, the upper 20 bits only select one of 2<sup>12</sup> Page Tables. Again, this is because the Am386SXL CPU is limited to a 24-bit physical address, and the upper 8 bits (A31–A24) are truncated when the address is output on its 24 address pins.

# Page Tables

Each Page Table is 4-Kb long and allows up to 1024 Page Table entries. Each Page Table entry contains information about the Page Frame and its address. The contents of a Page Table entry are shown in Figure 19. The middle 10 bits of the linear address (A21–A12) are used as an index to select the correct Page Table entry.

The Page Frame address contains the upper 20 bits of a 32-bit physical address which is used as the base address for the Page Frame. The lower 12 bits of the Page Frame address are zero so that the Page Frame addresses appear on 4-Kb boundaries. For an Am386DX CPU system, the upper 20 bits will select one of 2<sup>20</sup> Page Frames, but for an Am386SXL microprocessor system, the upper 20 bits only select one of 2<sup>12</sup> Page Frames. Again, this is because the Am386SXL CPU is limited to a 24-bit physical address space, and the upper 8 bits (A31–A24) are truncated when the address is output on its 24 address pins.

#### Page Directory/Table Entries

The lower 12 bits of the Page Table entries and Page Directory entries contain statistical information about pages and Page Tables, respectively. The P (Present) bit indicates if a Page Directory or Page Table entry can be used in address translation. If P = 1, the entry can be used for address translation. If P = 0, the entry cannot be used for translation. All of the other bits, are available for use by the software. For example, the remaining 31 bits could be used to indicate where on disk the page is stored.

The A (Accessed) bit is set by the Am386SXL CPU for both types of entries before a read or write access occurs to an address covered by the entry. The D (Dirty) bit is set to 1 before a write to an address covered by that Page Table entry occurs. The D bit is undefined for Page Directory entries. When the P, A, and D bits are updated by the Am386SXL CPU, the processor generates a Read-Modify-Write cycle which locks the bus and prevents conflicts with other processors or peripherals. Software which modifies these bits should use the LOCK prefix to ensure the integrity of the Page Tables in multi-master systems.

The 3 bits marked system software definable (in Figures 18 and 19) are software definable. System software writers are free to use these bits for whatever purpose they wish.

#### Page Level Protection (R/W, U/S Bits)

The Am386SXL microprocessor provides a set of protection attributes for paging systems. The paging mechanism distinguishes between two levels of protection: User, which corresponds to level 3 of the segmentation based protection; and Supervisor, which encompasses all of the other protection levels (0, 1, and 2). Programs executing at Level 0, 1, or 2 bypass the page protection, although segmentation-based protection is still enforced by the hardware.

The U/S and R/W bits are used to provide User/Supervisor and Read/Write protection for individual pages, or for all pages covered by a Page Table Directory entry. The U/S and R/W bits in the second level Page Table entry apply only to the page described by that entry. The U/S and R/W bits in the first level Page Directory Table apply to all pages described by the Page Table pointed to by that directory entry. The U/S and R/W bits for a given page are obtained by taking the most restrictive of the U/S and R/W bits from the Page Directory Table entries and using these bits to address the page.

#### **Translation Look-Aside Buffer**

The Am386SXL microprocessor paging hardware is designed to support demand paged virtual memory systems. However, performance would degrade substantially if the processor was required to access two levels of tables for every memory reference. To solve this problem, the Am386SXL CPU keeps a cache of the most recently accessed pages; this cache is called the Translation Look-Aside Buffer (TLB). The TLB is a four-way set associative 32-entry Page Table cache. It automatically keeps the most commonly used Page Table entries in the processor. The 32-entry TLB coupled with a 4K page size results in coverage of 128 Kb of memory addresses. For many common multitasking systems, the TLB will have a hit rate of greater than 98%. This means that the processor will only have to access the two-level page structure for less than 2% of all memory references.

#### Paging Operation

The paging hardware operates in the following fashion. The paging unit hardware receives a 32-bit linear address from the segmentation unit. The upper 20 linear address bits are compared with all 32 entries in the TLB to determine if there is a match. If there is a match (i.e., a TLB hit), then the 24-bit physical address is calculated and is placed on the address bus.

If the Page Table entry is not in the TLB, the Am386SXL microprocessor will read the appropriate Page Directory entry. If P = 1 on the Page Directory entry, indicating that the Page Table is in memory, then the Am386SXL CPU will read the appropriate Page Table entry and set the Access bit. If P = 1 on the Page Table entry, indicating that the page is in memory, the Am386SXL microprocessor will update the Access and Dirty bits as needed and fetch the operand. The upper 20 bits of the linear address, read from the Page Table.

will be stored in the TLB for future accesses. If P = 0 for either the Page Directory entry or the Page Table entry, then the processor will generate a Page Fault (Exception 14).

The processor will also generate a Page Fault (Exception 14) if the memory reference violated the page protection attributes. CR2 will hold the linear address which caused the Page Fault. Since Exception 14 is classified as a fault, CS:EIP will point to the instruction causing the Page Fault. The 16-bit error code, pushed as part of the Page Fault handler, will contain status bits which indicate the cause of the Page Fault.

The 16-bit error code is used by the operating system to determine how to handle the Page Fault. Figure 20 shows the format of the Page Fault error code and the interpretation of the bits. Even though the bits in the error code (U/S, W/R, and P) have similar names as the bits in the Page Directory/Table Entries, the interpretation of the error code bits is different. Figure 21 indicates what type of access caused the Page Fault.



Figure 20. Page Fault Error Code Format

U/S: The U/S bit indicates whether the access causing the fault occurred when the processor was executing in User Mode (U/S = 1) or in Supervisor mode (U/S = 0).

W/R: The W/R bit indicates whether the access causing the fault was a Read (W/R = 0) or a Write (W/R = 1).

**P**: The P bit indicates whether a Page Fault was caused by a not-present page (P = 0), or by a page level protection violation (P=1).

U = Undefined

| U/S | W/R | Access Type      |
|-----|-----|------------------|
| 0   | 0   | Supervisor* Read |
| 0   | 1   | Supervisor Write |
| 1   | 0   | User Read        |
| 1   | 1   | User Write       |

Descriptor table access will fault with U/S = 0, even if the program is executing at level 3.

Figure 21. Type of Access Causing Page Fault

#### **Operating System Responsibilities**

When the operating system enters or exits paging mode (by setting or resetting bit 31 in the CR0 register), a short JMP must be executed to flush the Am386SXL microprocessor's prefetch queue. This ensures that all instructions executed after the address mode change will generate correct addresses.

The Am386SXL microprocessor takes care of the page address translation process, relieving the burden from

an operating system in a demand-paged system. The operating system is responsible for setting up the initial Page Tables and handling any Page Faults. The operating system is also required to invalidate (i.e., flush) the TLB when any changes are made to any of the Page Table entries. The operating system must reload CR3 to cause the TLB to be flushed.

Setting up the tables is simply a matter of loading CR3 with the address of the Page Directory, and allocating space for the Page Directory and the Page Tables. The primary responsibility of the operating system is to implement a swapping policy and handle all of the Page Faults.

A final concern of the operating system is to ensure that the TLB cache matches the information in the paging tables. In particular, any time the operating systems sets the P (Present) bit of Page Table entry to zero, the TLB must be flushed by reloading CR3. Operating systems may want to take advantage of the fact that CR3 is stored as part of a TSS, to give every task or group of tasks its own set of Page Tables.

# Virtual 8086 Environment

The Am386SXL microprocessor allows the execution of 8086 application programs in both Real Mode and in Virtual 8086 Mode. The Virtual 8086 Mode allows the execution of 8086 applications, while still allowing the system designer to take full advantage of the Am386SXL CPU's protection mechanism.

#### Virtual 8086 Addressing Mechanism

One of the major differences between Am386SXL CPU Real and Protected modes is how the segment selectors are interpreted. When the processor is executing in Virtual 8086 Mode, the segment registers are used in a fashion identical to Real Mode. The contents of the segment register are shifted left four bits and added to the offset to form the segment base linear address.

The Am386SXL microprocessor allows the operating system to specify which programs use the 8086 address mechanism and which programs use Protected Mode addressing on a per task basis. Through the use of paging, the 1-Mb address space of the Virtual Mode task can be mapped to anywhere in the 4-Gb linear address space of the Am386SXL CPU. Like Real Mode, Virtual Mode addresses that exceed 1 Mb will cause an Exception 13. However, these restrictions should not prove to be important, because most tasks running in Virtual 8086 Mode will simply be existing 8086 application programs.

# Paging in Virtual Mode

The paging hardware allows the concurrent running of multiple Virtual Mode tasks, and provides protection and operating system isolation. Although it is not strictly necessary to have the paging hardware enabled to run Virtual Mode tasks, it is needed in order to run multiple Virtual Mode tasks or to relocate the address space of a Virtual Mode task to physical address space greater than 1 Mb.

The paging hardware allows the 20-bit linear address produced by a Virtual Mode program to be divided into as many as 256 pages. Each one of the pages can be located anywhere within the maximum 16-Mb physical address space of the Am386SXL microprocessor. In addition, since CR3 (the Page Directory Base Register) is loaded by a task switch, each Virtual Mode task can use a different mapping scheme to map pages to different physical locations. Finally, the paging hardware allows the sharing of the 8086 operating system code between multiple 8086 applications.

### Protection and I/O Permission Bit Map

All Virtual Mode programs execute at privilege level 3. As such, Virtual Mode programs are subject to all of the protection checks defined in Protected Mode. This is different from Real Mode, which implicitly is executing at privilege level 0. Thus, an attempt to execute a privileged instruction in Virtual Mode will cause an Exception 13 fault.

The following are privileged instructions, which may be executed only at Privilege level 0. Attempting to execute these instructions in Virtual 8086 Mode (or anytime  $CPL \ge 0$ ) causes an Exception 13 fault:

| LIDT; | MOV DRn, REG; | MOV reg,DRn;  |
|-------|---------------|---------------|
| LGDT; | MOV TRn, reg; | MOV reg, TRn; |
| LMSW; | MOV CRn, reg; | MOV reg,CRn;  |
| CLTS; |               |               |
| HLT;  |               |               |

Several instructions, particularly those applying to the multitasking and the protection model, are available only in Protected Mode. Therefore, attempting to execute the following instructions in Real Mode or in Virtual 8086 Mode generates an Exception 6 fault:

| LTR;  | STR;  |
|-------|-------|
| LLDT; | SLDT; |
| LAR;  | VERR; |
| LSL;  | VERW; |
| ARPL; |       |

The instructions which are IOPL sensitive in Protected Mode are:

| IN;   |      | STI; |
|-------|------|------|
| OUT ; |      | CLI  |
| INS;  | :    |      |
| OUTS  | 5;   |      |
| REP   | INS; |      |
| REP   | OUTS | ;    |
|       |      |      |

In Virtual 8086 Mode the following instructions are IOPL sensitive:

| INT n; | STI;  |
|--------|-------|
| PUSHF; | CLI;  |
| POPF;  | IRET; |

The PUSHF, POPF, and IRET instructions are IOPL sensitive in Virtual 8086 Mode only. This provision allows the IF flag to be virtualized to the virtual 8086 Mode program. The INT n software interrupt instruction is also IOPL sensitive in Virtual 8086 Mode. Note that the INT 3, INTO, and BOUND instructions are not IOPL sensitive in Virtual 8086 Mode.

The I/O instructions that directly refer to addresses in the processor's I/O space are IN, INS, OUT, and OUTS. The Am386SXL microprocessor has the ability to selectively trap references to specific I/O addresses. The structure that enables selective trapping is the I/O Permission Bit Map in the TSS segment (see Figures 15 and 16). The I/O permission map is a bit vector. The size of the map and its location in the TSS segment are variable. The processor locates the I/O permission map by means of the I/O map base field in the fixed portion of the TSS. The I/O map base field is 16-bits wide and contains the offset of the beginning of the I/O permission map.

In protected mode, when an I/O instruction (IN, INS, OUT, or OUTS) is encountered, the processor first checks whether CPL  $\leq$  IOPL. If this condition is true, the I/O operation may proceed. If not true, the processor checks the I/O permission map (in Virtual 8086 Mode, the processor consults the map without regard for the IOPL).

Each bit in the map corresponds to an I/O port byte address; for example, the bit for port 41 is found at I/O map base +5, bit offset 1. The processor tests all the bits that correspond to the I/O addresses spanned by an I/O operation; for example, a Dword operation tests four bits corresponding to four adjacent byte addresses. If any tested bit is set, the processor signals a general protection exception. If all the tested bits are zero, the I/O operations may proceed.

It is not necessary for the I/O permission map to represent all the I/O addresses. I/O addresses not spanned by the map are treated as if they had one-bits in the map. The I/O map base should be at least one byte less than the TSS limit; the last byte beyond the I/O mapping information must contain all 1s.

Because the I/O permission map is in the TSS segment, different tasks can have different maps. Thus, the operating system can allocate ports to a task by changing the I/O permission map in the task's TSS.

**Important Implementation Note**: Beyond the last byte of I/O mapping information in the I/O permission bit map **must** be a byte containing all 1s. The byte of all 1s must be within the limit of the Am386SXL CPU TSS segment (see Figure 15).

### Interrupt Handling

In order to fully support the emulation of an 8086 machine, interrupts in Virtual 8086 Mode are handled in a unique fashion. When running in Virtual Mode all interrupts and exceptions involve a privilege change back to the host Am386SXL microprocessor operating system. The Am386SXL CPU operating system determines if the interrupt comes from a Protected Mode

application, or from a Virtual Mode program, by examining the VM bit in the EFLAGS image stored on the stack.

When a Virtual Mode program is interrupted, and execution passes to the interrupt routine at level 0, the VM bit is cleared. However, the VM bit is still set in the EFLAG image on the stack.

The Am386SXL microprocessor operating system in turn handles the exception or interrupt and then returns control to the 8086 program. The Am386SXL microprocessor operating system may choose to let the 8086 operating system handle the interrupt, or it may emulate the function of the interrupt handler. For example, many 8086 operating system calls are accessed by PUSHing parameters on the stack, and then executing an INT n instruction. If the IOPL is set to 0, then all INT n instructions will be intercepted by the Am386SXL CPU operating system.

An Am386SXL microprocessor operating system can provide a Virtual 8086 environment which is totally transparent to the application software by intercepting and then emulating 8086 operating system's calls, and intercepting IN and OUT instructions.

#### Entering and Leaving Virtual 8086 Mode

Virtual 8086 Mode is entered by executing a 32-bit IRET instruction at CPL = 0, where the stack has a 1 in the VM bit of its EFLAGS image, or a Task Switch (at any CPL) to an Am386SXL microprocessor task whose Am386SXL CPU TSS has an EFLAGS image containing a 1 in the VM bit position, while the processor is executing in the Protected Mode. POPF does not affect the VM bit, but a PUSHF always pushes a 0 in the VM bit.

The transition out of Virtual 8086 Mode to Protected Mode occurs only on receipt of an interrupt or exception. In Virtual 8086 Mode, all interrupts and exceptions vector through the Protected Mode IDT, and enter an interrupt handler in Protected Mode. As part of the interrupt processing the VM bit is cleared.

Because the matching IRET must occur from Level 0, Interrupt or Trap Gates used to field an interrupt or exception out of Virtual 8086 Mode must perform an inter-level interrupt only to Level 0. Interrupt or Trap Gates through conforming segments, or through segments with DPL > 0, will raise a GP fault with the CS selector as the error code.

#### Task Switches To/From Virtual 8086 Mode

Tasks which can execute in Virtual 8086 Mode must be described by a TSS with the Am386SXL CPU format (Type 9 or 11 descriptor). A task switch out of Virtual 8086 Mode will operate exactly the same as any other task switch out of a task with an Am386SXL CPU TSS. All of the programmer visible state, including the EFLAGS register with the VM bit set to 1, is stored in the TSS. The segment registers in the TSS will contain 8086 segment base values rather than selectors.

A task switch into a task described by an Am386SXL CPU TSS will have an additional check to determine if

the incoming task should be resumed in Virtual 8086 Mode, Tasks described by 80286 format TSSs cannot be resumed in Virtual 8086 Mode, so no check is reguired there (the FLAGS image in 80286 format TSS has only the low-order 16 FLAGS bits). Before loading the segment register images from an Am386SXL CPU TSS, the FLAGS image is loaded, so that the segment registers are loaded from the TSS image as 8086 segment base values. The task is now ready to resume in Virtual 8086 Mode.

#### Transitions Through Trap and Interrupt Gates, and IRET

A task switch is one way to enter or exit Virtual 8086 Mode. The other method is to exit through a Trap or Interrupt gate, as part of handling an interrupt, and to enter as part of executing an IRET instruction. The transition out must use an Am386SXL CPU Trap Gate (Type 14), or Am386SXL CPU Interrupt Gate (Type 15), which must point to a non-conforming Level 0 segment (DPL = 0) in order to permit the trap handler to IRET back to the Virtual 8086 program. The Gate must point to a non-conforming Level 0 segment to perform a level switch to Level 0 so that the matching IRET can change the VM bit. Am386SXL CPU gates must be used since 80286 gates save only the lower 16 bits of the EFLAGS register (the VM bit will not be saved). Also, the 16-bit IRET used to terminate the 80286 interrupt handler will pop only the lower 16 bits from FLAGS, and will not affect the VM bit. The action taken for an Am386SXL CPU Trap or Interrupt gate, if an interrupt occurs while the task is executing in Virtual 8086 Mode, is given by the following sequence:

- 1. Save the FLAGS register in a temp to push later. Turn off the VM, TF, and IF bits.
- Interrupt and Trap gates must perform a level switch from 3 (where the Virtual 8086 Mode program executes) to 0 (so IRET can return).
- 3. Push the 8086 segment register values onto the new stack, in this order: GS, FS, DS, and ES. These are pushed as 32-bit quantities. Then load these 4 registers with null selectors (0).
- 4. Push the old 8086 stack pointer onto the new stack by pushing the SS register (as 32 bits), then pushing the 32-bit ESP register saved above.
- 5. Push the 32-bit EFLAGS register saved in step 1.
- 6. Push the old 8086 instruction onto the new stack by pushing the CS register (as 32 bits), then pushing the 32-bit EIP register.
- 7. Load up the new CS:EIP value from the interrupt gate, and begin execution of the interrupt routine in protected mode.

The transition out of Virtual 8086 Mode performs a level change and stack switch, in addition to changing back to protected mode. Also, all of the 8086 segment register images are stored on the stack (behind the SS:ESP image), and then loaded with null (0) selectors before entering the interrupt handler. This will permit the

handler to safely save and restore the DS, ES, FS, and GS registers as 80286 selectors. This is needed so that interrupt handlers, which do not care about the mode of the interrupted program, can use the same prologue and epilogue code for state saving, regardless of whether or not a native mode or Virtual 8086 Mode program was interrupted. Restoring null selectors to these registers before executing the IRET will cause a trap in the interrupt handler. Interrupt routines which expect or return values in the segment registers will have to obtain/return values from the 8086 register images pushed onto the new stack. They will need to know the mode of the interrupted program in order to know where to find/return segment registers, and also to know how to interpret segment register values.

The IRET instruction will perform the inverse of the above sequence. Only the extended IRET instruction (operand size = 32) can be used, and must be executed at Level 0, to change the VM bit to 1.

- 1. If the NT bit in the FLAGS register is On, an intertask return is performed. The current state is stored in the current TSS, and the link field in the current TSS is used to locate the TSS for the interrupted task which is to be resumed. Otherwise, continue with the following sequence.
- 2. Read the FLAGS image from SS:8[ESP] into the FLAGS register. This will set VM to the value active in the interrupted routine.
- Pop off the instruction pointer CS:EIP. EIP is popped first, then a 32-bit word is popped which contains the CS value in the lower 16 bits. If VM = 0, this CS load is done as a protected mode segment load. If VM = 1, this will be done as an 8086 segment load.
- 4. Increment the ESP register by 4 to bypass the FLAGS image which was popped in step 1.
- 5. If VM = 1, load segment registers ES, DS, FS, and GS from memory locations SS:[ESP + 8], SS:[ESP + 12], SS:[ESP + 16], and SS:[ESP = 20], respectively, where the new value of ESP stored in step 4 is used. Since VM = 1, these are done as 8086 segment register loads.

Else if VM = 0, check that the selectors in ES, DS, FS, and GS are valid in the interrupted routines. Null out invalid selectors to trap, if an attempt is made to access through them.

- 6. If RPL (CS) > CPL, pop the stack pointer SS:ESP from the stack. The ESP register is popped first, followed by 32 bits containing SS in the lower 16 bits. If VM = 0, SS is loaded as a protected mode segment register load. If VM = 1, an 8086 segment register load is used.
- Resume execution of the interrupted routine. The VM bit in the FLAGS register (restored from the interrupt routine's stack image in step 1) determines whether the processor resumes the interrupted routine in Protected Mode or Virtual 8086 Mode.

# FUNCTIONAL DATA

The Am386SXL microprocessor features a straightforward functional interface to the external hardware. The Am386SXL CPU has separate parallel buses for data and address. The data bus is 16-bits in width, and bi-directional. The address bus outputs 24-bit address values using 23 address lines and two Byte Enable signals.

The Am386SXL microprocessor has two selectable address bus cycles: address pipelined and non-address pipelined. The address pipelining option allows as much time as possible for data access by starting the pending bus cycle before the present bus cycle is finished. A non-pipelined bus cycle gives the highest bus performance by executing every bus cycle in two processor CLK cycles. For maximum design flexibility, the address pipelining option is selectable on a cycle-by-cycle basis.

The processor's bus cycle is the basic mechanism for information transfer, either from system to processor, or from processor to system. The Am386SXL microprocessor bus cycles perform data transfer in a minimum of only two clock periods. The maximum transfer bandwidth at 16 MHz is therefore 16 Mb/s. However, any bus cycle will be extended for more than two clock periods if external hardware withholds acknowledgment of the cycle.

The Am386SXL microprocessor can relinquish control of its local buses to allow mastership by other devices, such as Direct Memory Access (DMA) channels. When

relinquished, HLDA is the only output pin driven by the Am386SXL microprocessor, providing near complete isolation of the processor from its system (all other output pins are in a float condition).

# **Signal Description Overview**

Below is a brief description of the Am386SXL microprocessor input and output signals arranged by functional groups.

Example signal: M/IO—High voltage indicates memory selected

-Low voltage indicates I/O selected

The signal descriptions sometimes refer to Switching timing parameters, such as t25 Reset Setup Time and t26 Reset Hold Time. The values of these parameters can be found in the Switching Characteristics table.

### Clock (CLK2)

CLK2 provides the fundamental timing for the Am386SXL microprocessor. It is divided by two internally to generate the internal processor clock used for instruction execution. The internal clock is comprised of two phases, phase one and phase two. Each CLK2 period is a phase of the internal clock. Figure 23 illustrates the relationship. If desired, the phase of the internal processor clock can be synchronized to a known phase by ensuring the falling edge of the RESET signal meets the applicable setup and hold times, t25 and t26.



15022B-010

Figure 22. Functional Signal Groups

15022B-011



Figure 23. CLK2 Signal and Internal Processor Clock

#### Data Bus (D15–D0)

These three-state, bi-directional signals provide the general purpose data path between the Am386SXL microprocessor and other devices. The data bus outputs are active High and will float during Bus Hold Acknowledge. Data bus reads require that read-data setup and hold times (t21 and t22) be met relative to CLK2 for correct operation.

#### Address Bus (A23-A1, BHE, BLE)

These three-state outputs provide physical memory addresses or I/O port addresses. A23–A16 are Low during I/O transfers, except for I/O transfers automatically generated by coprocessor instructions. During coprocessor I/O transfers, A22–A16 are driven Low and A23 is driven High, so that this address line can be used by external logic to generate the coprocessor select signal. Thus, the I/O address driven by the Am386SXL microprocessor for coprocessor commands is 8000F8H, the I/O addresses driven by the Am386SXL CPU for coprocessor data are 8000FCH or 8000FEH or cycles to a 387SX math coprocessor.

The address bus is capable of addressing 16 Mb of physical memory space (000000H through FFFFFH), and 64 Kb of I/O address space (000000H through 00FFFH) for programmed I/O. The address bus is active High and will float during Bus Hold Acknowledge.

The Byte Enable outputs,  $\overline{BHE}$  and  $\overline{BLE}$ , directly indicate which bytes of the 16-bit data bus are involved with the current transfer.  $\overline{BHE}$  applies to D15–D8 and  $\overline{BLE}$  applies to D7–D0. If both  $\overline{BHE}$  and  $\overline{BLE}$  are asserted, then 16 bits of data are being transferred. See Table 13 for a complete decoding of these signals. The Byte Enables are active Low and will float during Bus Hold Acknowledge.

# Bus Cycle Definition Signals (W/ $\overline{R}$ , D/ $\overline{C}$ , M/ $\overline{IO}$ , LOCK)

These three-state outputs define the type of bus cycle being performed: W/R distinguishes between write and read cycles;  $D/\overline{C}$  distinguishes between data and control cycles;  $M/\overline{O}$  distinguishes between memory and I/O cycles; and,  $\overline{LOCK}$  distinguishes between locked and unlocked bus cycles. All of these signals are active Low and will float during Bus Acknowledge.

The primary bus cycle definition signals are  $W/\overline{R}$ ,  $D/\overline{O}$ , and  $M/\overline{IO}$ , since these are the signals driven valid as ADS (Address Status output) becomes active. The LOCK is driven valid at the same time the bus cycle begins, which, due to address pipelining, could be after ADS becomes active. Exact bus cycle definitions, as a function of  $W/\overline{R}$ ,  $D/\overline{C}$ , and  $M/\overline{IO}$ , are given in Table 14.

Table 13. Byte Enable Definitions

| BHE | BLE | Function                                              |
|-----|-----|-------------------------------------------------------|
| 0   | 0   | Word Transfer                                         |
| 0   | 1   | Byte transfer on upper byte of the data bus, D15–D8   |
| 1   | 0   | Byte transfer on lower byte<br>of the data bus, D7–D0 |
| 1   | 1   | Never occurs                                          |

LOCK indicates that other system bus masters are not to gain control of the system bus while it is active. LOCK is activated on the CLK2 edge that begins the first locked bus cycle (i.e., it is not active at the same time as the other bus cycle definition pins) and is deactivated when READY is returned at the end of the last bus cycle

| M/ĪO | D/C | W/R | Bus Cycle Type                             |                                                | Locked?     |
|------|-----|-----|--------------------------------------------|------------------------------------------------|-------------|
| 0    | 0   | 0   | Interrupt Acknowledge                      |                                                | Yes         |
| 0    | 0   | 1   | Does not occur                             |                                                | _           |
| 0    | 1   | 0   | I/O Data Read                              |                                                | No          |
| 0    | 1   | 1   | I/O Data Write                             |                                                | No          |
| 1    | 0   | 0   | Memory Code Read                           |                                                | No          |
| 1    | 0   | 1   | Halt:<br>Address = 2<br>BHE = 1<br>BLE = 0 | Shutdown:<br>Address = 0<br>BHE = 1<br>BLE = 0 | Νο          |
| 1    | 1   | 0   | Memory Data Read                           |                                                | Some Cycles |
| 1    | 1   | 1   | Memory Data Write                          |                                                | Some Cycles |

#### Table 14. Bus Cycle Definition

which is to be locked. The beginning of a bus cycle is determined when  $\overline{\text{READY}}$  is returned in a previous bus cycle and another is pending ( $\overline{\text{ADS}}$  is active), or the clock in which  $\overline{\text{ADS}}$  is driven active if the bus was idle. This means that it follows more closely with the write data rules when it is valid, but may cause the bus to be locked longer than desired. The LOCK signal may be explicitly activated by the LOCK prefix on certain instructions.

LOCK is always asserted when executing the XCHG instruction, during descriptor updates, and during the interrupt acknowledge sequence.

# Bus Control Signals (ADS, READY, NA)

The following signals allow the processor to indicate when a bus cycle has begun, and allow other system hardware to control address pipelining and bus cycle termination.

# Address Status (ADS)

This three-state output indicates that a valid bus cycle definition and address (W/R, D/C, M/IO, BHE, BLE, and A23–A1) are being driven at the Am386SXL microprocessor pins. ADS is an active Low output. Once ADS is driven active, valid address, Byte Enables, and definition signals will not change. In addition, ADS will remain active until its associated bus cycle begins (when READY is returned for the previous bus cycle when running pipelined bus cycles). When address pipelining is utilized, maximum throughput is achieved by initiating bus cycles when ADS and READY are active in the same clock cycle. ADS will float during Bus Hold Acknowledge. See sections Non-Pipelined Address and Pipelined Address for additional information on how ADS is asserted for different bus states.

# Transfer Acknowledge (READY)

This input indicates the current bus cycle is complete, and the active bytes indicated by  $\overrightarrow{BHE}$  and  $\overrightarrow{BLE}$  are accepted or provided. When  $\overrightarrow{READY}$  is sampled active during a read cycle or interrupt acknowledge cycle, the Am386SXL microprocessor latches the input data and terminates the cycle. When  $\overrightarrow{READY}$  is sampled active during a write cycle, the processor terminates the bus cycle.

READY is ignored on the first bus state of all bus cycles, and sampled each bus state thereafter until asserted. READY must eventually be asserted to acknowledge every bus cycle, including Halt Indication and Shutdown Indication bus cycles. When being sampled, READY must always meet setup and hold times (t19 and t20) for correct operation.

# Next Address Request (NA)

This is used to request address pipelining. This input indicates the system is prepared to accept new values of BHE, BLE, A23–A1, W/R, D/C, and M/IO from the Am386SXL CPU even if the end of the current cycle is not being acknowledged on READY. If this input is active when sampled, the next address is driven onto the bus, provided the next bus request is already pending internally. NA is ignored in CLK cycles in which ADS or READY is activated. This signal is active Low and must satisfy setup and hold times (t15 and t16) for correct operation. See sections Read and Write Cycles and Pipelined Address for additional information.

#### **Bus Arbitration Signals (HOLD, HLDA)**

This section describes the mechanism by which the processor relinquishes control of its local buses when requested by another bus master device. See section Entering and Exiting Hold Acknowledge for additional information.

#### Bus Hold Request (HOLD)

This input indicates some device other than the Am386SXL microprocessor requires bus mastership. When control is granted, the Am386SXL CPU floats A23–A1, BHE, BLE, D15–D0, LOCK, M/IO, D/C, W/R, and  $\overline{\text{ADS}}$ , and then activates HLDA, thus entering the Bus Hold Acknowledge state. The local bus will remain granted to the requesting master until HOLD becomes inactive. When HOLD becomes inactive, the Am386SXL microprocessor will deactivate HLDA and drive the local bus (at the same time), thus terminating the Hold Acknowledge condition.

HOLD must remain asserted as long as any other device is a local bus master. External pull-up resistors may be required when in the Hold Acknowledge (HLDA) state, since none of the Am386SXL microprocessor floated outputs have internal pull-up resistors. See section Resistor Recommendations for additional information. HOLD is not recognized while RESET is active. If RESET is asserted while HOLD is asserted, RESET has priority and places the bus into an idle state, rather than the Hold Acknowledge (high impedance) state.

HOLD is a level-sensitive, active High, synchronous input. HOLD signals must always meet setup and hold times (t23 and t24) for correct operation.

#### Bus Hold Acknowledge (HLDA)

When active (High), this output indicates the Am386SXL microprocessor has relinquished control of its local bus in response to an asserted HOLD signal, and is in the Bus Hold Acknowledge state.

The Bus Hold Acknowledge state offers near complete signal isolation. In the HLDA state is the only signal being driven by the Am386SXL microprocessor. The other output or bi-directional signals (D15–D0,  $\overline{BHE}$ , BLE, A23–A1, W/R, D/C, M/IO, LOCK, and  $\overline{ADS}$ ) are in a high-impedance state so the requesting bus master may control them. These pins remain Off throughout the time that HLDA remains active (see Table 15). Pull-up resistors may be desired on several signals to avoid spurious activity when no bus master is driving them. See section Resistor Recommendations for additional information.

When the HOLD signal is made inactive, the Am386SXL microprocessor will deactivate HLDA and drive the bus. One rising edge on the NMI input is remembered for processing after the HOLD input is negated.

#### Table 15. Output Pin State During HOLD

| Pin Value  | Pin Names                                                      |
|------------|----------------------------------------------------------------|
| 1<br>Float | HLDA<br>LOCK, M/IO, D/O, W/R, ADS,<br>A23-A1, BHE, BLE, D15-D0 |

In addition to the normal usage of Hold Acknowledge with DMA controllers or master peripherals, the near complete isolation has particular attractiveness during system test when test equipment drives the system, and in hardware fault-tolerant applications.

#### **HOLD Latencies**

The maximum possible HOLD latency depends on the software being executed. The actual HOLD latency at any time depends on the current bus activity, the state of the LOCK signal (internal to the CPU) activated by the LOCK prefix, and interrupts. The Am386SXL microprocessor will not honor a HOLD request until the current bus operation is complete.

The Am386SXL microprocessor breaks 32-bit data or I/O accesses into 2 internally locked 16-bit bus cycles; the LOCK signal is not asserted. The Am386SXL microprocessor breaks unaligned 16-bit or 32-bit data or I/O accesses into 2 or 3 internally locked 16-bit bus cycles. Again, the LOCK signal is not asserted but a HOLD request will not be recognized until the end of the entire transfer.

Wait states affect HOLD latency. The Am386SXL microprocessor will not honor a HOLD request until the end of the current bus operation, no matter how many wait states are required. Systems with DMA where data transfer is critical must insure that READY returns promptly.

# Coprocessor Interface Signals (PEREQ, BUSY, ERROR)

In the following sections are descriptions of signals dedicated to the math coprocessor interface. In addition to the data bus, address bus, and bus cycle definition signals, the following signals control communication between the Am386SXL microprocessor and its 387SX math coprocessor extension.

#### Coprocessor Request (PEREQ)

When asserted (High), this input signal indicates a coprocessor request for a data operand to be transferred to/from memory by the Am386SXL Micro-processor. In response, the Am386SXL microprocessor transfers information between the math coprocessor and memory. Because the Am386SXL CPU has internally stored the math coprocessor op-code being executed, it performs the requested data transfer with the correct direction and memory address.

PEREQ is level-sensitive active High asynchronous signal. Setup and hold times (t29 and t30) relative to the CLK2 signal must be met to guarantee recognition at a particular clock edge. This signal is provided with a weak internal pull-down resistor of around 20 Kohms to Ground so that it will not float active when left unconnected.

# Coprocessor Busy (BUSY)

When asserted Low, this input indicates that the coprocessor is still executing an instruction, and is not yet able to accept another. When the Am386SXL micro-processor encounters any coprocessor instruction which operates on the numerics stack (e.g., load, pop, or arithmetic operation), or the WAIT instruction, this input is first automatically sampled until it is seen to be inactive. This sampling of the BUSY input prevents overrunning the execution of a previous coprocessor instruction.

The FNINIT, FNSTENV, FNSAVE, FNSTSW, FNSTCW, and FNCLEX coprocessor instructions are allowed to execute even if BUSY is active, since these instructions are used for coprocessor initialization and exception-clearing.

BUSY is an active Low, level-sensitive, asynchronous signal. Setup and hold times (t29 and t30), relative to the CLK2 signal, must be met to guarantee recognition at a particular clock edge. This pin is provided with a weak internal pull-up resistor of around 20 Kohms to  $V_{cc}$  so that it will not float active when left unconnected.

BUSY serves an additional function. If BUSY is sampled Low at the falling edge of RESET, the Am386SXL microprocessor performs an internal self-test (see section Bus Activity During and Following Reset). If BUSY is sampled High, no self-test is performed.

# Coprocessor Error (ERROR)

When asserted Low, this input signal indicates that the previous coprocessor instruction generated a coprocessor error of a type not masked by the coprocessor's control register. This input is automatically sampled by the Am386SXL microprocessor when a coprocessor instruction is encountered, and if active, the Am386SXL CPU generates Exception 16 to access the error-handling software.

Several coprocessor instructions, generally those which clear the numeric error flags in the coprocessor or save coprocessor state, do execute without the Am386SXL CPU generating Exception 16 even if ERROR is active. These instructions are FNINIT, FNCLEX, FNSTSW, FNSTSWAX, FNSTCW, FNSTENV, and FNSAVE.

ERROR is an active Low, level-sensitive, asynchronous signal. Setup and hold times (t29 and t30), relative to the CLK2 signal, must be met to guarantee recognition at a particular clock edge. This pin is provided with a weak internal pull-up resistor of around 20 Kohms to  $V_{cc}$  so that it will not float active when left unconnected.

#### Interrupt Signals (INTR, NMI, RESET)

The following descriptions cover inputs that can interrupt or suspend execution of the processor's current instruction stream.

#### Maskable Interrupt Request (INTR)

When asserted, this input indicates a request for interrupt service, which can be masked by the Am386SXL microprocessor Flag Register IF bit. When the Am386SXL CPU responds to the INTR input, it performs two interrupt acknowledge bus cycles and, at the end of the second, latches an 8-bit interrupt vector on D7–D0 to identify the source of the interrupt.

INTR is an active High, level-sensitive, asynchronous signal. Setup and hold times (t27 and t28), relative to the CLK2 signal, must be met to guarantee recognition at a particular clock edge. To assure recognition of an INTR request, INTR should remain active until the first interrupt acknowledge bus cycle begins. INTR is sampled at the beginning of every instruction in the Am386SXL microprocessor's Execution Unit. In order to be recognized at a particular instruction boundary, INTR must be active at least eight CLK2 clock periods before the beginning of the instruction. If recognized, the Am386SXL CPU will begin execution of the interrupt.

#### Non-Maskable Interrupt Request (NMI)

This input indicates a request for interrupt service which cannot be masked by software. The non-maskable interrupt request is always processed according to the pointer or gate in slot 2 of the interrupt table. Because of the fixed NMI slot assignment, no interrupt acknowledge cycles are performed when processing NMI.

NMI is an active High, rising edge-sensitive, asynchronous signal. Setup and hold times (t27 and t28), relative to the CLK2 signal, must be met to guarantee recognition at a particular clock edge. To assure recognition of NMI, it must be inactive for at least eight CLK2 periods, and then be active for at least eight CLK2 periods before the beginning of the instruction boundary in the Am386SXL microprocessor's Execution Unit.

Once NMI processing has begun, no additional NMI's are processed until after the next IRET instruction, which is typically the end of the NMI service routine. If NMI is re-asserted prior to that time, however, one rising edge on NMI will be remembered for processing after executing the next IRET instruction.

#### Interrupt Latency

The time that elapses before an interrupt request is serviced (interrupt latency) varies according to several factors. This delay must be taken into account by the interrupt source. Any of the following factors can affect interrupt latency:

- 1. If interrupts are masked, an INTR request will not be recognized until interrupts are re-enabled.
- If an NMI is currently being serviced, an incoming NMI request will not be recognized until the Am386SXL microprocessor encounters the IRET instruction.

- An interrupt request is recognized only on an instruction boundary of the Am386SXL microprocessor's Execution Unit except for the following cases:
  - Repeat string instructions can be interrupted after each iteration.
  - —If the instruction loads the Stack Segment register, an interrupt is not processed until after the following instruction, which should be an ESP. This allows the entire stack pointer to be loaded without interruption.
  - If an instruction sets the interrupt flag (enabling interrupts), an interrupt is not processed until after the next instruction.

The longest latency occurs when the interrupt request arrives while the Am386SXL microprocessor is executing a long instruction such as multiplication, division, or a task switch in the Protected Mode.

- 4. Saving the Flags register and CS:EIP registers.
- 5. If interrupt service routine requires a task switch, time must be allowed for the task switch.
- 6. If the interrupt service routine saves registers that are not automatically saved by the Am386SXL microprocessor.

#### Reset

This input signal suspends any operation in progress and places the Am386SXL microprocessor in a known reset state. The Am386SXL CPU is reset by asserting RESET for 15 or more CLK2 periods (80 or more CLK2 periods before requesting self-test). When RESET is active, all other input pins, except FLT, are ignored, and all other bus pins are driven to an Idle Bus state, as shown in Table 16. If RESET and HOLD are both active at a point in time, RESET takes priority even if the Am386SXL microprocessor was in a Hold Acknowledge state prior to RESET active.

Reset is an active High, level-sensitive, synchronous signal. Setup and hold times (t25 and t26) must be met in order to assure proper operation of the Am386SXL microprocessor.

# **Bus Transfer Mechanism**

All data transfers occur as a result of one or more bus cycles. Logical data operands of byte and word lengths may be transferred without restrictions on physical address alignment. Any byte boundary may be used, although two physical bus cycles are performed as required for unaligned operand transfers.

The Am386SXL microprocessor address signals are designed to simplify external system hardware. Higherorder address bits are provided by A23–A1. BHE and BLE provide linear selects for the two bytes of the 16-bit data bus.

Byte Enable outputs  $\overline{BHE}$  and  $\overline{BLE}$  are asserted when their associated data bus bytes are involved with the present bus cycle, as listed in Table 17.

Each bus cycle is composed of at least two bus states. Each bus state requires one processor clock period. Additional bus states added to a single bus cycle are called wait states. See section Bus Functional Description.

| Pin Name | Signal Level During Reset |
|----------|---------------------------|
| ADS      | 1                         |
| D15–D0   | Float                     |
| BHE, BLE | 0                         |
| A23-A1   | 1                         |
| W/R      | 0                         |
| D/C      | 1                         |
| M/IO     | 0                         |
| LOCK     | 1                         |
| HLDA     | 0                         |
|          |                           |

#### Table 16. Pin State (Bus Idle) During Reset

# Table 17. Byte Enables and AssociatedData and Operand Bytes

| Byte Enable Signal | Associated Data Bus Signals      |  |
|--------------------|----------------------------------|--|
| BLE                | D7–D0 (Byte 0—least significant) |  |
| BHE                | D15–D8 (Byte 1—most significant) |  |

# Memory and I/O Spaces

Bus cycles may access physical memory space or I/O space. Peripheral devices in the system may either be memory-mapped, I/O-mapped, or both. As shown in Figure 24, physical memory addresses range from 000000H to 0FFFFFH (16 Mb) and I/O addresses from 000000H to 00FFFFH (64 kb). Note the I/O addresses used by the automatic I/O cycles for coprocessor communication are 8000F8H to 8000FFH, beyond the address range of programmed I/O, to allow easy generation of a coprocessor chip select signal using the A23 and M/IO signals.

# **Bus Functional Description**

The Am386SXL microprocessor has separate, parallel buses for data and address. The data bus is 16-bits in width, and bi-directional. The address bus provides a 24-bit value using 23 signals for the 23 upper-order address bits and 23 Byte Enable signals to directly indicate the active bytes. These buses are interpreted and controlled by several definition signals.



Note: Since A23 is High during automatic communication with coprocessor, A23 High and M/IO Low can be used to easily generate a coprocessor select signal.

15022B-012



Figure 24. Physical Memory and I/O Spaces

15022B--013





The definition of each bus cycle is given by three signals:  $M\overline{IO}$ ,  $W/\overline{R}$ , and  $D/\overline{O}$ . At the same time, a valid address is present on the Byte Enable signals,  $\overline{BHE}$  and  $\overline{BLE}$ , and the other address signals, A23–A1. A status signal,  $\overline{ADS}$ , indicates when the Am386SXL microprocessor issues a new bus cycle definition and address.

Collectively, the address bus, data bus, and all associated control signals are referred to simply as the bus. When active, the bus performs one of the bus cycles below:

- 1. Read from memory space;
- 2. Locked read from memory space;
- 3. Write to memory space;
- 4. Locked write to memory space;
- 5. Read from I/O space (or math coprocessor);

- 6. Write to I/O space (or math coprocessor);
- Interrupt acknowledge (always locked);
- 8. Indicate halt, or indicate shutdown.

Table 14 shows the encoding of the bus cycle definition signals for each bus cycle. See section Bus Cycle Definition Signals for additional information.

When the Am386SXL microprocessor bus is not performing one of the activities listed above, it is either idle or in the Hold Acknowledge state, which may be detected externally. The idle state can be identified by the Am386SXL CPU giving no further assertions on its address strobe output (ADS) since the beginning of its most recent cycle, and the most recent bus cycle having been terminated. The Hold Acknowledge state is identified by the Am386SXL microprocessor asserting its Hold Acknowledge (HLDA) output.



Figure 26. Fastest Read Cycles with Pipelined Address Timing

The shortest time unit of bus activity is a bus state. A bus state is one processor clock period (two CLK2 periods) in duration. A complete data transfer occurs during a bus cycle, composed of two or more bus states.

The fastest Am386SXL microprocessor bus cycle requires only two bus states. For example, three consecutive bus read cycles, each consisting of two bus states, are shown in Figure 25. The bus states in each cycle are named T1 and T2. Any memory or I/O address may be accessed by such a two-state bus cycle, if the external hardware is fast enough.

Every bus cycle continues until it is acknowledged by the external system hardware, using the Am386SXL microprocessor READY input. Acknowledging the bus cycle at the end of the first T2 results in the shortest bus cycle, requiring only T1 and T2. If READY is not immediately asserted however, T2 states are repeated indefinitely until the READY input is sampled active. The address pipelining option provides a choice of bus cycle timings. Pipelined or non-pipelined address timing is selectable on a cycle-by-cycle basis with the Next Address ( $\overline{NA}$ ) input.

When address pipelining is selected, the address ( $\overline{BHE}$ ,  $\overline{BLE}$ , and A23–A1) and definition ( $W/\overline{R}$ ,  $D/\overline{C}$ ,  $M/\overline{IO}$ , and  $\overline{LOCK}$ ) of the next cycle are available before the end of the current cycle. To signal their availability, the Am386SXL microprocessor address status output ( $\overline{ADS}$ ) is asserted. Figure 26 illustrates the fastest read cycles with pipelined address timing.

Note from Figure 26 the fastest bus cycles using pipelined address require only two bus states, named T1P and T2P. Therefore, cycles with pipelined address timing allow the same data bandwidth as non-pipelined cycles, but address-to-data access time is increased by one T-state time compared to that of a non-pipelined cycle.



Note: Idle states are shown here for diagram variety only. Write cycles are not always followed by an idle state; an active bus cycle can immediately follow the write cycle.

15022B-015

#### Figure 27. Various Bus Cycles with Non-Pipelined Address (Zero Wait States)

#### **Read and Write Cycles**

Data transfers occur as a result of bus cycles, classified as read or write cycles. During read cycles, data is transferred from an external device to the processor. During write cycles, data is transferred from the processor to an external device.

Two choices of address timing are dynamically selectable: non-pipelined or pipelined. After an idle bus state, the processor always uses non-pipelined address timing. However, the  $\overline{NA}$  (Next Address) input may be asserted to select pipelined address timing for the next bus cycle. When pipelining is selected and the Am386SXL microprocessor has a bus request pending internally, the address and definition of the next cycle is made available even before the current bus cycle is acknowledged by  $\overline{READY}$ .

Terminating a read or write cycle, like any bus cycle, requires acknowledging the cycle by asserting the READY input. Until acknowledged, the processor inserts wait states into the bus cycle, to allow adjustment for the speed of any external device. External hardware, which has decoded the address and bus cycle type, asserts the READY input at the appropriate time.

At the end of the second bus state within the bus cycle, READY is sampled. At that time, if external hardware acknowledges the bus cycle by asserting READY, the bus cycle terminates as shown in Figure 27. If READY is negated, as in Figure 28, the Am386SXL microprocessor executes another bus state (a wait state) and READY is sampled again at the end of that state. This continues indefinitely until the cycle is acknowledged by READY asserted.

When the current cycle is acknowledged, the Am386SXL microprocessor terminates it. When a read cycle is acknowledged, the Am386SXL CPU latches the infor-mation present at its data pins. When a write cycle is acknowledged, the Am386SXL microprocessor's write data remains valid throughout phase one of the next bus state, to provide write data hold time.



Note: Idle states are shown here for diagram variety only. Write cycles are not always followed by an idle state; an active bus cycle can immediately follow the write cycle.

15022B-016

#### Figure 28. Various Bus Cycles with Non-Pipelined Address (Various Number of Wait States)

#### Non-Pipelined Address

Any bus cycle may be performed with non-pipelined address timing. For example, Figure 27 shows a mixture of read and write cycles with non-pipelined address timing. Figure 27 shows that the fastest possible cycles with non-pipelined address have two bus states per bus cycle. The states are named T1 and T2. In phase one of T1, the address signals and bus cycle definition signals are driven valid and, to signal their availability, address strobe ( $\overline{\text{ADS}}$ ) is simultaneously asserted.

During read or write cycles the data bus behaves as follows. If the cycle is a read, the Am386SXL microprocessor floats its data signal to allow driving by the external device being addressed. The Am386SXL microprocessor requires that all data bus pins be at a valid logic state (High or Low) at the end of each read cycle, when READY is asserted. The system **must** be designed to meet this requirement. If the cycle is a write, data signals are driven by the Am386SXL CPU beginning in phase two of T1 until phase one of the bus state following cycle acknowledgment. Figure 28 illustrates non-pipelined bus cycles with one wait state added to Cycles 2 and 3. READY is sampled inactive at the end of the first T2 in Cycles 2 and 3. Therefore, Cycles 2 and 3 have T2 repeated again. At the end of the second T2, READY is sampled active.

When address pipelining is not used, the address and bus cycle definition remain valid during all wait states. When wait states are added, and it is desirable to maintain non-pipelined address timing, it is necessary to negate  $\overline{NA}$  during each T2 state, except the last one, as shown in Figure 28, Cycles 2 and 3. If  $\overline{NA}$  is sampled active during a T2 other than the last one, the next state would be T2I or T2P instead of another T2.

The bus states and transitions, when address pipelining is not used, are completely illustrated by Figure 29. The bus transitions between four possible states, T1, T2, Ti, and Th. Bus cycles consist of T1 and T2, with T2 being repeated for wait states. Otherwise the bus may be idle, Ti, or in the Hold Acknowledge state Th.



T2— Subsequent clocks of a bus cycle when NA has not been sampled asserted in the current bus cycle.

Ti -- Idle state.

Th-Hold Acknowledge state (Am386SXL CPU asserts HLDA).

The fastest bus cycle consists of two states: T1 and T2.

Four basic bus states describe bus operation when not using pipelined address.

15022B-017

#### Figure 29. Bus States (Not Using Pipelined Address)

Bus cycles always begin with T1. T1 always leads to T2. If a bus cycle is not acknowledged during T2 and  $\overline{NA}$  is inactive, T2 is repeated. When a cycle is acknowledged during T2, the following state will be T1 of the next bus cycle, if a bus request is pending internally, or Ti, if there is no bus request pending, or Th, if the HOLD input is being asserted.

Use of pipelined address allows the Am386SXL microprocessor to enter three additional bus states not shown in Figure 29. Figure 33 is the complete bus state diagram, including pipelined address cycles.

#### **Pipelined Address**

Address pipelining is the option of requesting the address and the bus cycle definition of the next internally pending bus cycle before the current bus cycle is acknowledged with READY asserted. ADS is asserted by the Am386SXL microprocessor when the next address is issued. The address pipelining option is controlled on a cycle-by-cycle basis with the NA input signal.

Once a bus cycle is in progress and the current address has been valid for at least one entire bus state, the  $\overline{NA}$ input is sampled at the end of every phase one until the bus cycle is acknowledged. During non-pipelined bus cycles,  $\overline{NA}$  is sampled at the end of phase one in every T2. An example is Cycle 2 in Figure 30, during which  $\overline{NA}$  is sampled at the end of phase one of every T2 (it was asserted once during the first T2 and has no further effect during that bus cycle).



Note: Following any idle bus state (Ti), addresses are non-pipelined. Within non-pipelined bus cycles, NA is only sampled during wait states. Therefore, to begin address pipelining during a group of non-pipelined bus cycles requires a non-pipelined cycle with at least one wait state (Cycle 2 above).

15022B-018



If  $\overline{NA}$  is sampled active, the Am386SXL microprocessor is free to drive the address and bus cycle definition of the next bus cycle, and assert  $\overline{ADS}$ , as soon as it has a bus request internally pending. It may drive the next address as early as the next bus state, whether the current bus cycle is acknowledged at that time or not.

Regarding the details of address pipelining, the Am386SXL CPU has the following characteristics:

 The next address may appear as early as the bus state after NA was sampled active (see Figures 30 and 31). In that case, state T2P is entered immediately. However, when there is not an internal bus request already pending, the next address will not be available immediately after NA is asserted and T2I is entered instead of T2P (see Figure 32, Cycle 3). Provided the current bus cycle is not yet acknowledged by READY asserted, T2P will be entered as soon as the Am386SXL microprocessor does drive the next address. External hardware should therefore observe the ADS output as confirmation the next address is actually being driven on the bus.

- Any address which is validated by a pulse on the ADS output will remain stable on the address pins for at least two processor clock periods. The Am386SXL CPU cannot produce a new address more frequently than every two processor clock periods (see Figures 30, 31, and 32).
- Only the address and bus cycle definition of the very next bus cycle is available. The pipelining capability cannot look further than one bus cycle ahead (see Figure 32, Cycle 1).



Note: Following any idle bus state (Ti) the address is always non-pipelined and NA is only sampled during wait states. To start address pipelining after an idle state requires a non-pipelined cycle with at least one wait state (Cycle 1 above). The pipelined cycles (2, 3, and 4 above) are shown with various numbers of wait states.

15022B-019



The complete bus state transition diagram, including operation with pipelined address, is given in Figure 33. Note that it is a superset of the diagram for non-pipelined address only, and the three additional bus states for pipelined address are drawn in bold. The fastest bus cycle with pipelined address consists of just two bus states, T1P and T2P (recall for non-pipelined address it is T1 and T2). T1P is the first bus state of a pipelined cycle.



15022A-020

#### Figure 32. Details of Address Pipelining During Cycles with Wait States



Using pipelined address, the fastest bus cycle consists of T1P and T2P.

15022B-021

#### Figure 33. Complete Bus States (Including Pipelined Address)

#### Initiating and Maintaining Pipelined Address

Using the state diagram Figure 33, observe the transitions from an idle state (Ti) to the beginning of a pipelined bus cycle (T1P). From an idle state (Ti) the first bus cycle must begin with T1, and is therefore a non-pipelined bus cycle. The next bus cycle will be pipelined, however, provided  $\overline{NA}$  is asserted and the first bus cycle ends in a T2P state (the address for the next bus cycle is driven during T2P). The fastest path from an idle state to a bus cycle with pipelined address is shown in bold below:

#### Ti, Ti, Ti, T1–T2–T2P, T1P–T2P,

| ldle   | Non-Pipelined | Pipelined |
|--------|---------------|-----------|
| States | Cycle         | Ċycle     |

T1-T2-T2P are the states of the bus cycle that establish address pipelining for the next bus cycle, which begins with T1P. The same is true after a bus hold state, shown below:

#### Th, Th, Th, T1-T2-T2P, T1P-T2P,

| Hold Acknowledge | Non-Pipelined | Pipelined |
|------------------|---------------|-----------|
| States           | Cycle         | Ċycle     |

The transition to pipelined address is shown functionally by Figure 31, Cycle 1. Note that Cycle 1 is used to transition into pipelined address timing for the subsequent Cycles 2, 3, and 4, which are pipelined. The  $\overline{NA}$  input is asserted at the appropriate time to select address pipelining for Cycle 2, 3, and 4.

Once a bus cycle is in progress and the current address has been valid for one entire bus state, the NA input is sampled at the end of every phase one until the bus cycle is acknowledged. Sampling begins in T2 during Cycle 1 in Figure 31. Once NA is sampled active during the current cycle, the Am386SXL microprocessor is free to drive a new address and bus cycle definition on the bus as early as the next bus state. In Figure 31, Cycle 1 for example, the next address is driven during state T2P. Thus, Cycle 1 makes the transition to pipelined address timing, since it begins with T1 but ends with T2P. Because the address for Cycle 2 is available before Cycle 2 begins, Cycle 2 is called a pipelined bus cycle, and it begins with T1P. Cycle 2 begins as soon as READY asserted terminates Cycle 1.

Examples of transition bus cycles are Figure 31, Cycle 1 and Figure 30, Cycle 2. Figure 31 shows transition during the very first cycle after an idle bus state, which is the fastest possible transition into address pipelining. Figure 30, Cycle 2 shows a transition cycle occurring during a burst of bus cycles. In any case, a transition cycle is the same whenever it occurs: it consists at least of T1, T2 ( $\overline{NA}$  is asserted at that time), and T2P (provided the Am386SXL microprocessor has an internal bus request already pending, which it almost always has). T2P states are repeated if wait states are added to the cycle. Note that only three states (T1, T2, and T2P) are required in a bus cycle performing a transition from non-pipelined address into pipelined address timing (e.g., Figure 31, Cycle 1). Figure 31, Cycles 2, 3, and 4 show that address pipelining can be maintained with two-state bus cycles consisting only of T1P and T2P.

Once a pipelined bus cycle is in progress, pipelined timing is maintained for the next cycle by asserting NA and detecting that the Am386SXL microprocessor enters T2P during the current bus cycle. The current bus cycle must end in state T2P for pipelining to be maintained in the next cycle. T2P is identified by the assertion of ADS. Figures 30 and 31, however, each show pipelining ending after Cycle 4, because Cycle 4 ends in T2I. This indicates the Am386SXL CPU did not have an internal bus request prior to the acknowledgement of Cycle 4. If a cycle ends with a T2 or T2I, the next cycle will not be pipelined.

Realistically, address pipelining is almost always maintained as long as NA is sampled asserted. This is so because in the absence of any other request, a code prefetch request is always internally pending until the instruction decoder and code prefetch queue are completely full. Therefore, address pipelining is maintained for long bursts of bus cycles, if the bus is available (i.e., HOLD inactive), and NA is sampled active in each of the bus cycles.

#### Interrupt Acknowledge (INTA ) Cycles

In response to an interrupt request on the INTR input when interrupts are enabled, the Am386SXL microprocessor performs two interrupt acknowledge cycles. These bus cycles are similar to read cycles in that bus definition signals define the type of bus activity taking place, and each cycle continues until acknowledged by READY sampled active.

The state of A2 distinguishes the first and second interrupt acknowledge cycles. The byte address driven during the first interrupt acknowledge cycle is 4 (A23–A3, A1, BLE Low, A2 and BHE High). The byte address driven during the second interrupt acknowledge cycle is 0 (A23–A1, BLE Low, and BHE High).

The LOCK output is asserted from the beginning of the first interrupt acknowledge cycle until the end of the second interrupt acknowledge cycle. Four idle bus states (Ti) are inserted by the Am386SXL microprocessor between the two interrupt acknowledge cycles for compatibility with spec TRHRL of the 8259A Interrupt Controller.

During both interrupt acknowledge cycles, D15–D0 float. No data is read at the end of the first interrupt acknowledge cycle. At the end of the second interrupt acknowledge cycle, the Am386SXL microprocessor will read an external interrupt vector from D7–D0 of the data bus. The vector indicates the specific interrupt number (from 0–255) requiring service.

### Halt Indication Cycle

The execution unit halts as a result of executing a HLT instruction. Signaling its entrance into the halt state, a halt indication cycle is performed. The halt indication cycle is identified by the state of the bus definition signals shown on page 39, Bus Cycle Definition Signals, and an address of 2. The halt indication cycle must be acknowledged by  $\overrightarrow{READY}$  asserted. A halted Am386SXL CPU resumes execution when INTR (if interrupts are enabled), NMI, or RESET is asserted.

#### **Shutdown Indication Cycle**

The Am386SXL microprocessor shuts down as a result of a protection fault while attempting to process a double fault. Signaling its entrance into the shutdown state, a shutdown indication cycle is performed. The shutdown indication cycle is identified by the state of the bus definition signals shown in section Bus Cycle Definition Signals and an address of 0. The shutdown indication cycle must be acknowledged by READY asserted. A shut-down Am386SXL microprocessor resumes execution when NMI or RESET is asserted.

#### Entering and Exiting Hold Acknowledge

The Bus Hold Acknowledge state (Th) is entered in response to the HOLD input being asserted. In the Bus Hold Acknowledge state, the Am386SXL microprocessor floats all outputs or bi-directional signals, except for HLDA. HLDA is asserted as long as the Am386SXL CPU remains in the Bus Hold Acknowledge state. In the Bus Hold Acknowledge state, all inputs except HOLD, FLT, and RESET are ignored.



Interrupt Vector (0–255) is read on D7–D0 at end of second Interrupt Acknowledge bus cycle. Because each Interrupt Acknow-ledge bus cycle is followed by idle bus states, asserting NA has no practical effect. Choose the approach which is simplest for your system hardware design.

15022B-022



Th may be entered from a bus idle state, as in Figure 37, or after the acknowledgement of the current physical bus cycle, if the LOCK signal is not asserted, as in Figures 38 and 39.

Th is exited in response to the HOLD input being negated. The following state will be Ti if no bus request is pending, as in Figure 37. The following bus state will be T1 if a bus request is internally pending, as in Figures 38 and 39. Th is exited in response to RESET being asserted.

If a rising edge occurs on the edge-triggered NMI input while in Th, the event is remembered as a nonmaskable interrupt 2 and is serviced when Th is exited, unless the Am386SXL microprocessor is reset before Th is exited.

#### **Reset During Hold Acknowledge**

RESET being asserted takes priority over HOLD being asserted. If RESET is asserted while HOLD remains asserted, the Am386SXL microprocessor drives its pins to defined states during reset, as in Table 16 (Pin State During Reset), and performs internal reset activity as usual. If HOLD remains asserted when RESET is inactive, the Am386SXL CPU enters the Hold Acknowledge state before performing its first bus cycle, provided HOLD is still asserted when the Am386SXL microprocessor would otherwise perform its first bus cycle.

#### FLOAT

Activating the  $\overline{FLT}$  input floats all Am386SXL microprocessor bi-directional and output signals, including HLDA. Asserting  $\overline{FLT}$  isolates the Am386SXL microprocessor from the surrounding circuitry.

As the Am386SXL microprocessor is packaged in a surface mount PQFP, it cannot be removed from the motherboard when In-Circuit Emulation (ICE) is needed. The FLT input allows the Am386SXL CPU to be electrically isolated from the surrounding circuitry. This allows connection of an emulator to the Am386SXL microprocessor PQFP without removing it from the PCB. This method of emulation is referred to as ON-Circuit Emulation (ONCE).



### **Entering and Exiting FLOAT**

FLT is an asynchronous, active Low input. It is recognized on the rising edge of CLK2. When recognized, it aborts the current bus cycle and floats the outputs of the Am386SXL microprocessor (Figure 41). FLT must be held Low for a minimum of 16-CLK2 cycles. Reset should be asserted and held asserted until after FLT is deasserted. This will ensure that the Am386SXL CPU will exit FLOAT in a valid state.

Asserting the  $\overline{FLT}$  input unconditionally aborts the current bus cycle and forces the Am386SXL CPU into the FLOAT mode. Since activating  $\overline{FLT}$  unconditionally forces the Am386SXL CPU into FLOAT mode, the Am386SXL microprocessor is not guaranteed to enter FLOAT in a valid state. After deactivating  $\overline{FLT}$ , the Am386SXL CPU is not guaranteed to exit FLOAT mode in a valid state. This is not a problem, as the  $\overline{FLT}$  pin is meant to be used only during ONCE. After exiting FLOAT, the Am386SXL microprocessor must be reset to return it to a valid state. Reset should be asserted

before FLT is deasserted. This will ensure that the Am386SXL CPU will exit FLOAT in a valid state.

FLT has an internal pull-up resistor, and if it is not used it should be unconnected.

#### **Bus Activity During and Following Reset**

RESET is the highest priority input signal, capable of interrupting any processor activity when it is asserted. A bus cycle in progress can be aborted at any stage, or idle states and Bus Hold Acknowledge states discontinued, so that the reset state is established.

RESET should remain asserted for at least 15-CLK2 periods to ensure it is recognized throughout the Am386SXL microprocessor, and at least 80-CLK2 periods if self-test is going to be requested at the falling edge. RESET asserted pulses less than 15-CLK2 periods may not be recognized. RESET pulses less than 80-CLK2 periods followed by a self-test may cause the self-test to report a failure when no true failure exists.



Figure 36. Example Shutdown Indication Cycle from Non-Pipelined Cycle

Provided the RESET falling edge meets setup and hold times (t25 and t26), the internal processor clock phase is defined at that time as illustrated by Figure 40 and Figure 48.

A self-test may be requested at the time RESET goes inactive by having the  $\overline{\text{BUSY}}$  input at a Low level, as shown in Figure 40. The self-test requires approximately ( $2^{20}$  + 60) CLK2 periods to complete. The self-test duration is not affected by the test results. Even if the self-test indicates a problem, the Am386SXL microprocessor attempts to proceed with the reset sequence afterwards.

After the RESET falling edge (and after the self-test if it was requested), the Am386SXL microprocessor performs an internal initialization sequence for approximately 350- to 450-CLK2 periods.

### Self-Test Signature

Upon completion of self-test (if self-test was requested by driving BUSY Low at the falling edge of RESET) the EAX register will contain a signature of 00000000H, indicating the Am386SXL microprocessor passed its self-test of microcode and major PLA contents with no problems detected. The passing signature in EAX, 00000000H, applies to all revision levels. Any non-zero signature indicates the unit is faulty.

### **Component and Revision Identifiers**

To assist users the Am386SXL microprocessor, after reset, holds a component identifier and revision identifier in its DX register. The upper 8 bits of DX hold 23H as identification of the Am386DX microprocessor architecture. The upper nibble, 02H, refers to the second member of the Am386DX microprocessor Family). The lower 8 bits of DX hold an 8-bit unsigned binary number related to the component revision level. The revision identifier will, in general, chronologically track those component steppings which are intended to have certain improvements or distinction from previous steppings. The Am386SXL microprocessor revision identifier will track that of the Am386DX CPU where possible.



Note: For maximum design flexibility the Am386SXL CPU has no internal pull-up resistors on its outputs. Your design may require an external pull-up on ADS and other outputs to keep them negated during float periods.

15022B-025

### Figure 37. Requesting Hold from Idle Bus



Note: HOLD is a synchronous input and can be asserted at any CLK2 edge, provided setup and hold (t23 and t24) requirements are met. This waveform is useful for determining Hold Acknowledge latency.

15022B-026

Figure 38. Requesting Hold from Active Bus (NA Inactive)



15022B-027

Figure 39. Requesting Hold from Idle Bus (NA Active)



#### Notes:

1. BUSY should be held stable for 8-CLK2 periods before and after the CLK2 period in which RESET falling edge occurs.

2. If self-test is requested, the outputs remain in their reset state as shown here.

15022B--028



Figure 41. Entering and Exiting FLT

The revision identifier is intended to assist users to a practical extent. However, the revision identifier value is not guaranteed to change with every stepping revision, or to follow a completely uniform numerical sequence, depending on the type or intention of revision, or manufacturing materials required to be changed.

### Table 18. Component and Revision Identifier History

| Intel i386SX<br>Stepping | Am386SXL<br>Microprocessor<br>Revision | Revision Identifier |
|--------------------------|----------------------------------------|---------------------|
| В                        | A1                                     | 05H                 |
| С                        | В                                      | 08H                 |

# Coprocessor Interfacing

The Am386SXL microprocessor provides an automatic interface for a 387SX math coprocessor. A 387SX math coprocessor uses an I/O mapped interface driven automatically by the Am386SXL CPU and assisted by three dedicated signals: BUSY, ERROR, and PEREQ.

As the Am386SXL microprocessor begins supporting a math coprocessor instruction, it tests the BUSY and ERROR signals to determine if the coprocessor can accept its next instruction. Thus, the BUSY and ERROR inputs eliminate the need for any preamble bus cycles for communication between processor and math coprocessor. A 387SX math coprocessor can be given its command op-code immediately. The dedicated signals provide instruction synchronization and eliminate the need of using the WAIT op-code (9BH) for 387SX math coprocessor instruction synchronization (the WAIT op-code was required when the 8086 or 8088 was used with the 8087 math coprocessor).

Custom math coprocessors can be included in Am386SXL microprocessor based systems by memory-mapped or I/O-mapped interfaces. Such math coprocessor interfaces allow a completely custom protocol, and are not limited to a set of math coprocessor protocol primitives. Instead, memory-mapped or I/O-mapped interfaces may use all applicable instructions for high-speed math coprocessor communication. The BUSY and ERROR inputs of the Am386SXL microprocessor may also be used for the custom math coprocessor interface, if such hardware assist is desired. These signals can be tested by the WAIT op-code (9BH). The WAIT instruction will wait until the **BUSY** input is inactive (interruptable by an NMI or enabled INTR input), but generates an Exception 16 fault if the ERROR pin is active when the BUSY goes (or is) inactive. If the custom math coprocessor interface is memory-mapped, protection of the addresses used for the interface can be provided with the Am386SXL

CPU's on-chip paging or segmentation mechanisms. If the custom interface is I/O-mapped, protection of the interface can be provided with the IOPL (I/O Privilege Level) mechanism.

A 387SX math coprocessor interface is I/O mapped as shown in Table 19. Note that a 387SX math coprocessor interface addresses are beyond the 0H–0FFFFH range for programmed I/O. When the Am386SXL microprocessor supports the 387SX math coprocessor, the Am386SXL CPU automatically generates bus cycles to the coprocessor interface addresses.

| Table 19. Math Copr | ocessor Por | Address |
|---------------------|-------------|---------|
|---------------------|-------------|---------|

| Address in Am386SXL<br>CPU I/O Space | 387SX-Compatible Math<br>Coprocessor Register |
|--------------------------------------|-----------------------------------------------|
| 8000F8H                              | Op-code Register                              |
| 8000FCH/8000FEH*                     | Operand Register                              |

\*Generated as 2nd bus cycle during Dword transfer.

To correctly map a 387SX math coprocessor registers to the appropriate I/O addresses, connect the CMD0 and CMD1 lines of a 387SX math coprocessor, as listed in Table 20.

#### Table 20. Connections for CMD0 and CMD1 Inputs for a 387SX

| Signal | Connection                                  |
|--------|---------------------------------------------|
| CMD0   | Connected directly to 386SXL CPU A2 signal. |
| CMD1   | Connect to ground.                          |

### Software Testing for Math Coprocessor Presence

When software is used to test for math coprocessor (387SX) presence, it should use only the following math coprocessor op-codes: FINIT, FNINIT, FSTCW mem, FSTSW mem, and FSTSW AX. To use other math coprocessor op-codes when a math coprocessor is known to be not present, first set EM = 1 in the Am386SXL CPU's CR0 register.

# PACKAGE THERMAL SPECIFICATIONS

The Am386SXL microprocessor is specified for operation when case temperature is within the range of 0°C-100°C. The case temperature may be measured in any environment to determine whether the Am386SXL CPU is within specified operating range. The case temperature should be measured at the center of the top surface opposite the pins.

The ambient temperature is guaranteed as long as Tc is not violated. The ambient temperature can be calculated from the  $\theta_{ic}$  and  $\theta_{ja}$  from the following equations:

 $Tj = Tc + P \cdot \theta jc$   $Ta = Tj - P \cdot \theta ja$  $Tc = Ta + P \cdot [\theta ja - \theta jc]$ 

## ELECTRICAL SPECIFICATIONS

The following sections describe recommended electrical connections for the Am386SXL microprocessor, and its electrical specifications.

### **Power and Grounding**

The Am386SXL CPU has modest power requirements. However, its high clock frequency and 47 output buffers (address, data, control, and HLDA) can cause power surges as multiple output buffers drive new signal levels simultaneously. For clean on-chip power distribution at high frequency, 14 V<sub>cc</sub> and 18 V<sub>ss</sub> pins separately feed functional units of the Am386SXL microprocessor.

Power and ground connections must be made to all external  $V_{\rm cc}$  and  $V_{\rm ss}$  pins of the Am386SXL microprocessor. On the circuit board, all  $V_{\rm cc}$  pins should be connected on a  $V_{\rm cc}$  plane, and  $V_{\rm ss}$  pins should be connected on a GND plane.

#### **Power Decoupling Recommendations**

Liberal decoupling capacitors should be placed near the Am386SXL microprocessor. The Am386SXL CPU driving its 24-bit address bus and 16-bit data bus at high frequencies can cause transient power surges, particularly when driving large capacitive loads. Low inductance capacitors and interconnects are recommended for best high frequency electrical performance. Inductance can be reduced by shortening circuit board traces between the Am386SXL microprocessor and decoupling capacitors as much as possible.

#### **Resistor Recommendations**

The ERROR, FLT, and BUSY inputs have internal pullup resistors of approximately 20 Kohms, and the PEREQ input has an internal pull-down resistor of approximately 20 Kohms, built into the Am386SXL microprocessor to keep these signals inactive when a 387SX-compatible math coprocessor is not present in the system (or temporarily removed from its socket).

In typical designs, the external pull-up resistors shown in Table 21 are recommended. However, a particular design may have reason to adjust the resistor values recommended here, or alter the use of pull-up resistors in other ways.

#### **Other Connection Recommendations**

For reliable operation, always connect unused inputs to an appropriate signal level. NC pins should always remain unconnected. Connection of NC pins to  $V_{cc}$  or  $V_{ss}$  will result in component malfunction or incompatibility with future steppings of the Am386SXL CPU.

Particularly when not using the interrupts or bus hold (as when first prototyping), prevent any chance of spurious activity by connecting these associated inputs to GND.

| Pin | Signal |
|-----|--------|
| 40  | INTR   |
| 38  | NMI    |
| 4   | HOLD   |

If not using address pipelining, connect pin 6 ( $\overline{NA}$ ) through a pull-up in the range of 20 Kohms to V<sub>cc</sub>.

| Table 21. Recommended Resistor Pull-Ups to $V_{cc}$ |  |
|-----------------------------------------------------|--|
|-----------------------------------------------------|--|

| Pin | Signal | Pull-Up Value | Purpose                                                                 |
|-----|--------|---------------|-------------------------------------------------------------------------|
| 16  | ADS    | 20 Kohms ±10% | Lightly pull ADS inactive during Am386SXL CPU Hold Acknowledge states.  |
| 26  | LOCK   | 20 Kohms ±10% | Lightly pull LOCK inactive during Am386SXL CPU Hold Acknowledge states. |

### **ABSOLUTE MAXIMUM RATINGS**

Ambient Temperature under bias .....-65 to 125°C Storage Temperature .....-65 to 150°C

Stresses above those listed may cause permanent damage to the device. Exposure to absolute maximum rating conditions for extended periods of time may affect device reliability.

# **OPERATING RANGES**

Supply Voltage with respect to V<sub>ss</sub> .... -0.5 V to 7 V Voltage on other pins ..... -0.5 V to (V<sub>cc</sub> + 0.5)V

Operating ranges define those limits between which the functionality of the device is guaranteed.

# DC CHARACTERISTICS over COMMERCIAL operating ranges

Vcc = 5 V ±10%; Tcase = 0°C to 100°C

| Symbol            | Parameter Description                                                                                                                                                                                                  | Notes                                                                                                                               | Min                                                        | Max                  | Unit           |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|----------------------|----------------|
| V <sub>IL</sub>   | Input Low Voltage                                                                                                                                                                                                      |                                                                                                                                     | -0.3                                                       | +0.8                 | V              |
| V <sub>IH</sub>   | Input High Voltage                                                                                                                                                                                                     |                                                                                                                                     | 2.0                                                        | V <sub>cc</sub> +0.3 | V              |
| VILC              | CLK2 Input Low Voltage                                                                                                                                                                                                 |                                                                                                                                     | 0.3                                                        | +0.8                 | V              |
| V <sub>IHC</sub>  | CLK2 Input High Voltage                                                                                                                                                                                                |                                                                                                                                     | V <sub>cc</sub> -0.8                                       | V <sub>cc</sub> +0.3 | V              |
| V <sub>ol</sub>   | $\begin{array}{l} \mbox{Output Low Voltage} \\ I_{oL} = 4 \mbox{ mA:} & A23-A1, \mbox{D15-D0} \\ I_{oL} = 5 \mbox{ mA:} & \mbox{BHE, BLE, W/R,} \\ & \mbox{D/C, M/IO, LOCK,} \\ \hline & \mbox{ADS, HLDA} \end{array}$ |                                                                                                                                     |                                                            | 0.45<br>0.45         | v<br>v         |
| V <sub>он</sub>   | $\begin{array}{llllllllllllllllllllllllllllllllllll$                                                                                                                                                                   |                                                                                                                                     | 2.4<br>V <sub>cc</sub> -0.5<br>2.4<br>V <sub>cc</sub> -0.5 |                      | v<br>v<br>v    |
| lu                | Input Leakage Current (for all pins ex-<br>cept PEREQ, BUSY, FLT, and ERROR)                                                                                                                                           | $0 V \leq V_{iN} \leq V_{cc}$                                                                                                       |                                                            | ±15                  | μA             |
| l <sub>in</sub>   | Input Leakage Current (PEREQ pin)                                                                                                                                                                                      | V <sub>IH</sub> = 2.4 V (Note 1)                                                                                                    |                                                            | 200                  | μΑ             |
| l <sub>il</sub>   | Input Leakage Current<br>(BUSY, ERROR, and FLT pins)                                                                                                                                                                   | V <sub>IL</sub> = 0.45 V (Note 2)                                                                                                   |                                                            | -400                 | μA             |
| I <sub>LO</sub>   | Output Leakage Current                                                                                                                                                                                                 | 0.45 V ≤ V <sub>oυτ</sub> ≤ V <sub>cc</sub>                                                                                         |                                                            | ±15                  | μΑ             |
| l <sub>cc</sub>   | Supply Current<br>CLK2 = 32 MHz: with –16*<br>CLK2 = 40 MHz: with –20<br>CLK2 = 50 MHz: with –25                                                                                                                       | (Note 4)<br>I <sub>cc</sub> Typ = 135 mA (Note 3)<br>I <sub>cc</sub> Typ = 165 mA (Note 3)<br>I <sub>cc</sub> Typ = 210 mA (Note 3) |                                                            | 160<br>200<br>250    | mA<br>mA<br>mA |
| I <sub>ccsb</sub> | Standby Current                                                                                                                                                                                                        | I <sub>ccsв</sub> Тур = 0.02 mA (Note 5)                                                                                            |                                                            | 0.15                 | mA             |
| C <sub>IN</sub>   | Input Capacitance                                                                                                                                                                                                      | F <sub>c</sub> = 1 MHz (Note 4)                                                                                                     |                                                            | 10                   | pF             |
| С <sub>оит</sub>  | Output or I/O Capacitance                                                                                                                                                                                              | F <sub>c</sub> = 1 MHz (Note 4)                                                                                                     |                                                            | 12                   | pF             |
| С <sub>сік</sub>  | CLK2 Capacitance                                                                                                                                                                                                       | F <sub>c</sub> = 1 MHz (Note 4)                                                                                                     |                                                            | 20                   | pF             |

Notes: Tested at the minimum operating frequency of the part. \*Contact AMD for 16-MHz availability. 1. PEREQ input has an internal pull-down resistor.

 BUSY, FLT, and ERROR inputs each have an internal pull-up resistor.

 I<sub>cc</sub> Max measurement at worst case frequency, V<sub>cc</sub>, and temperature, outputs unloaded.

4. Not 100% tested.

5. Inputs at rails, outputs unloaded, PEREQ Low, ERROR High, BUSY High, and FLT High.

# SWITCHING CHARACTERISTICS

The switching characteristics given consist of output delays, input setup requirements, and input hold requirements. All switching characteristics are relative to the CLK2 rising edge crossing the 2.0 V level.

Switching characteristic measurement is defined by Figure 42. Inputs must be driven to the voltage levels indicated by Figure 42 when switching characteristics are measured. Output delays are specified with minimum and maximum limits measured, as shown. The minimum delay times are hold times provided to external circuitry. Input setup and hold times are specified as minimums, defining the smallest acceptable sampling window. Within the sampling window, a synchronous input signal must be stable for correct operation.

Outputs ADS, W/R, D/C, M/IO, LOCK, BHE, BLE, A23–A1, and HLDA only change at the beginning of phase one. D15–D0 (write cycles) only change at the beginning of phase two. The READY, HOLD, BUSY, ERROR, PEREQ, FLT, and D15–D0 (read cycles) inputs are sampled at the beginning of phase one. The NA, INTR, and NMI inputs are sampled at the beginning of phase two.



15022B-030



# SWITCHING CHARACTERISTICS

Switching Characteristics at 25 MHz:  $V_{cc} = 5 V \pm 10\%$ ;  $T_{case} = 0^{\circ}C$  to  $100^{\circ}C$ 

|        |                                    |                                            | Ref.   |     |     | <u> </u> |
|--------|------------------------------------|--------------------------------------------|--------|-----|-----|----------|
| Symbol | Parameter Description              | Notes                                      | Figure | Min | Max | Unit     |
|        | Operating Frequency                | Half CLK2 freq.                            |        | 0   | 25  | MHz      |
| 1      | CLK2 Period                        |                                            | 43     | 20  |     | ns       |
| 2a     | CLK2 High Time                     | at 2 V                                     | 43     | 7   |     | ns       |
| 2b     | CLK2 High Time                     | at (V <sub>cc</sub> -0.8 V)                | 43     | 4   |     | ns       |
| 3a     | CLK2 Low Time                      | at 2 V                                     | 43     | 7   |     | ns       |
| 3b     | CLK2 Low Time                      | at 0.8 V                                   | 43     | 5   |     | ns       |
| 4      | CLK2 Fall Time                     | (V <sub>cc</sub> -0.8 V) to 0.8 V (Note 3) | 43     |     | 7   | ns       |
| 5      | CLK2 Rise Time                     | 0.8 V to (V <sub>cc</sub> -0.8 V) (Note 3) | 43     |     | 7   | ns       |
| 6      | A23–A1 Valid Delay                 | C <sub>L</sub> = 50 pF                     | 46     | 4   | 17  | ns       |
| 7      | A23-A1 Float Delay                 | (Note 1)                                   | 50     | 4   | 30  | ns       |
| 8      | BHE, BLE, LOCK Valid Delay         | C <sub>L</sub> = 50 pF                     | 46     | 4   | 17  | ns       |
| 9      | BHE, BLE, LOCK Float Delay         | (Note 1)                                   | 50     | 4   | 30  | ns       |
| 10     | M/ĪO, D/C, W/R, ADS Valid Delay    | C <sub>L</sub> = 50 pF                     | 46     | 4   | 17  | ns       |
| 11     | W/R, M/IO, D/C, ADS Float Delay    | (Note 1)                                   | 50     | 4   | 30  | ns       |
| 12     | D15–D0 Write Data Valid Delay      | С <sub>L</sub> = 50 рF                     | 46     | 7   | 23  | ns       |
| 12a    | D15–D0 Write Data Hold Time        | C <sub>L</sub> = 50 pF                     |        | 2   |     | ns       |
| 13     | D15–D0 Write Data Float Delay      | (Note 1)                                   | 47     | 4   | 22  | ns       |
| 14     | HLDA Valid Delay                   | C <sub>L</sub> = 50 pF                     | 46     | 4   | 22  | ns       |
| 15     | NA Setup Time                      |                                            | 45     | 5   |     | ns       |
| 16     | NA Hold Time                       |                                            | 45     | 3   |     | ns       |
| 19     | READY Setup Time                   |                                            | 45     | 9   |     | ns       |
| 20     | READY Hold Time                    |                                            | 45     | 4   |     | ns       |
| 21     | D15–D0 Read Data Setup Time        |                                            | 45     | 7   |     | ns       |
| 22     | D15–D0 Read Data Hold Time         |                                            | 45     | 5   |     | ns       |
| 23     | HOLD Setup Time                    |                                            | 45     | 9   |     | ns       |
| 24     | HOLD Hold Time                     |                                            | 45     | 3   |     | ns       |
| 25     | RESET Setup Time                   |                                            | 51     | 8   |     | ns       |
| 26     | RESET Hold Time                    |                                            | 51     | 3   |     | ns       |
| 27     | NMI, INTR Setup Time               | (Note 2)                                   | 45     | 6   |     | ns       |
| 28     | NMI, INTR Hold Time                | (Note 2)                                   | 45     | 6   |     | ns       |
| 29     | PEREQ, ERROR, BUSY, FLT Setup Time | (Note 2)                                   | 45     | 6   |     | ns       |
| 30     | PEREQ, ERROR, BUSY, FLT Hold Time  | (Note 2)                                   | 45     | 5   |     | ns       |

Notes: 1. Float condition occurs when maximum output current becomes less than  $I_{LO}$  in magnitude. Float delay is not 100% tested.

2. These inputs are allowed to be asynchronous to CLK2. The setup and hold specifications are given for testing purposes, to assure recognition within a specific CLK2 period.

3. These are not tested. They are guaranteed by design characterization.

# SWITCHING CHARACTERISTICS (continued)

Switching Characteristics at 20 MHz:  $V_{cc} = 5 V \pm 10\%$ ;  $T_{case} = 0^{\circ}C$  to  $100^{\circ}C$ 

| Symbol | Parameter Description              | Notes                             |          | Ref.<br>Figure | Min | Max | Unit |
|--------|------------------------------------|-----------------------------------|----------|----------------|-----|-----|------|
|        | Operating Frequency                | Half CLK2 freq.                   |          |                | 0   | 20  | MHz  |
| 1      | CLK2 Period                        |                                   |          | 43             | 25  |     | ns   |
| 2a     | CLK2 High Time                     | at 2 V                            |          | 43             | 8   |     | ns   |
| 2b     | CLK2 High Time                     | at (V <sub>cc</sub> -0.8 V)       |          | 43             | 5   |     | ns   |
| 3a     | CLK2 Low Time                      | at 2 V                            |          | 43             | 8   |     | ns   |
| Зb     | CLK2 Low Time                      | at 0.8 V                          |          | 43             | 6   |     | ns   |
| 4      | CLK2 Fall Time                     | (V <sub>cc</sub> -0.8 V) to 0.8 V | (Note 3) | 43             |     | 8   | ns   |
| 5      | CLK2 Rise Time                     | 0.8 V to (V <sub>cc</sub> -0.8 V) | (Note 3) | 43             |     | 8   | ns   |
| 6      | A23–A1 Valid Delay                 | C <sub>L</sub> = 120 pF           | (Note 4) | 46             | 4   | 30  | ns   |
| 7      | A23–A1 Float Delay                 |                                   | (Note 1) | 50             | 4   | 32  | ns   |
| 8      | BHE, BLE, LOCK Valid Delay         | C <sub>L</sub> = 75 pF            | (Note 4) | 46             | 4   | 30  | ns   |
| 9      | BHE, BLE, LOCK Float Delay         |                                   | (Note 1) | 50             | 4   | 32  | ns   |
| 10a    | M/ĪŌ, D/Շ Valid Delay              | C <sub>L</sub> = 75 pF            | (Note 4) | 46             | 4   | 28  | ns   |
| 10b    | W/R, ADS Valid Delay               | C <sub>L</sub> = 75 pF            | (Note 4) | 46             | 4   | 26  | ns   |
| 11     | W/R, M/IO, D/C, ADS Float Delay    |                                   | (Note 1) | 50             | 6   | 30  | ns   |
| 12     | D15–D0 Write Data Valid Delay      | C <sub>L</sub> = 120 p            | (Note 4) | 46             | 4   | 38  | ns   |
| 13     | D15–D0 Write Data Float Delay      |                                   | (Note 1) | 50             | 4   | 27  | ns   |
| 14     | HLDA Valid Delay                   | С <sub>L</sub> = 75 рF            | (Note 4) | 46             | 4   | 28  | ns   |
| 15     | NA Setup Time                      |                                   |          | 45             | 5   |     | ns   |
| 16     | NA Hold Time                       |                                   |          | 45             | 12  |     | ns   |
| 19     | READY Setup Time                   |                                   |          | 45             | 12  |     | ns   |
| 20     | READY Hold Time                    |                                   |          | 45             | 4   |     | ns   |
| 21     | D15–D0 Read Data Setup Time        |                                   |          | 45             | 9   |     | ns   |
| 22     | D15–D0 Read Data Hold Time         |                                   |          | 45             | 6   |     | ns   |
| 23     | HOLD Setup Time                    |                                   |          | 45             | 17  |     | ns   |
| 24     | HOLD Hold Time                     |                                   |          | 45             | 5   |     | ns   |
| 25     | RESET Setup Time                   |                                   |          | 51             | 12  |     | ns   |
| 26     | RESET Hold Time                    |                                   |          | 51             | 4   |     | ns   |
| 27     | NMI, INTR Setup Time               |                                   | (Note 2) | 45             | 16  |     | ns   |
| 28     | NMI, INTR Hold Time                |                                   | (Note 2) | 45             | 16  |     | ns   |
| 29     | PEREQ, ERROR, BUSY, FLT Setup Time |                                   | (Note 2) | 45             | 14  |     | ns   |
| 30     | PEREQ, ERROR, BUSY, FLT Hold Time  |                                   | (Note 2) | 45             | 5   |     | ns   |

Notes: 1. Float condition occurs when maximum output current becomes less than I<sub>Lo</sub> in magnitude. Float delay is not 100% tested. 2. These inputs are allowed to be asynchronous to CLK2. The setup and hold specifications are given for testing purposes, to

assure recognition within a specific CLK2 period.

3. These are not tested. They are guaranteed by design characterization.

4. Tested with C<sub>L</sub> set at 50 pF and derated to support the indicated distributed capacitive load. See Figures 52 and 53 for the capacitive derating curve.

# SWITCHING CHARACTERISTICS (continued)

Switching Characteristics at 16 MHz\*:  $V_{cc}$  = 5 V±10%;  $T_{case}$  = 0°C to 100°C

|        |                                    |                                         |      | Ref.   |     |     |      |
|--------|------------------------------------|-----------------------------------------|------|--------|-----|-----|------|
| Symbol | Parameter Description              | Notes                                   |      | Figure | Min | Max | Unit |
|        | Operating Frequency                | Half CLK2 freq.                         |      |        | 0   | 16  | MHz  |
| 1      | CLK2 Period                        |                                         |      | 43     | 31  |     | ns   |
| 2a     | CLK2 High Time                     | at 2 V                                  |      | 43     | 9   |     | ns   |
| 2b     | CLK2 High Time                     | at (V <sub>cc</sub> -0.8 V)             |      | 43     | 5   |     | ns   |
| 3a     | CLK2 Low Time                      | at 2 V                                  |      | 43     | 9   |     | ns   |
| Зb     | CLK2 Low Time                      | at 0.8 V                                |      | 43     | 7   |     | ns   |
| 4      | CLK2 Fall Time                     | $(V_{cc}$ -0.8 V) to 0.8 V (Note        | ə 3) | 43     |     | 8   | ns   |
| 5      | CLK2 Rise Time                     | 0.8 V to (V <sub>cc</sub> -0.8 V) (Note | ∋3)  | 43     |     | 8   | ns   |
| 6      | A23–A1 Valid Delay                 | $C_L = 120  pF$ (Note                   | ə 4) | 46     | 4   | 36  | ns   |
| 7      | A23-A1 Float Delay                 | (Note                                   | ə 1) | 50     | 4   | 40  | ns   |
| 8      | BHE, BLE, LOCK Valid Delay         | $C_L = 75  pF$ (Note                    | ə 4) | 46     | 4   | 36  | ns   |
| 9      | BHE, BLE, LOCK Float Delay         | (Note                                   | ə 1) | 50     | 4   | 40  | ns   |
| 10     | W/R, M/IO, D/C, ADS Valid Delay    | $C_L = 75  pF$ (Note                    | ə 4) | 46     | 4   | 33  | ns   |
| 11     | W/R, M/IO, D/C, ADS Float Delay    | (Note                                   | ə 1) | 50     | 6   | 35  | ns   |
| 12     | D15–D0 Write Data Valid Delay      | $C_{L} = 120  pF$ (Note                 | e 4) | 46     | 4   | 40  | ns   |
| 13     | D15–D0 Write Data Float Delay      | (Note                                   | e 1) | 50     | 4   | 35  | ns   |
| 14     | HLDA Valid Delay                   | $C_L = 75  pF$ (Note                    | ə 4) | 46     | 4   | 33  | ns   |
| 15     | NA Setup Time                      |                                         |      | 45     | 5   |     | ns   |
| 16     | NA Hold Time                       |                                         |      | 45     | 21  |     | ns   |
| 19     | READY Setup Time                   |                                         |      | 45     | 19  |     | ns   |
| 20     | READY Hold Time                    |                                         |      | 45     | 4   |     | ns   |
| 21     | D15–D0 Read Data Setup Time        |                                         |      | 45     | 9   |     | ns   |
| 22     | D15–D0 Read Data Hold Time         |                                         |      | 45     | 6   |     | ns   |
| 23     | HOLD Setup Time                    |                                         |      | 45     | 26  |     | ns   |
| 24     | HOLD Hold Time                     |                                         |      | 45     | 5   |     | ns   |
| 25     | RESET Setup Time                   |                                         |      | 51     | 13  |     | ns   |
| 26     | RESET Hold Time                    |                                         |      | 51     | 4   |     | ns   |
| 27     | NMI, INTR Setup Time               | (Note                                   | ə 2) | 45     | 16  |     | ns   |
| 28     | NMI, INTR Hold Time                | (Note                                   | e 2) | 45     | 16  |     | ns   |
| 29     | PEREQ, ERROR, BUSY, FLT Setup Time | (Note                                   | ə 2) | 45     | 16  |     | ns   |
| 30     | PEREQ, ERROR, BUSY, FLT Hold Time  | (Note                                   | e 2) | 45     | 5   |     | ns   |

Notes: \*Contact AMD for 16-MHz availability.

1. Float condition occurs when maximum output current becomes less than  $I_{Lo}$  in magnitude. Float delay is not 100% tested.

2. These inputs are allowed to be asynchronous to CLK2. The setup and hold specifications are given for testing purposes, to assure recognition within a specific CLK2 period.

3. These are not tested. They are guaranteed by design characterization.

 Tested with C<sub>L</sub> set at 50 pF and derated to support the indicated distributed capacitive load. See Figures 52 and 53 for the capacitive derating curve.



15022B-031





15022B-032





### SWITCHING WAVEFORMS







Figure 49. Write Data Valid Delay Timing (20 MHz)







15022B-036

Figure 51. RESET Setup and Hold Timing and Internal Phase







15022B-038





### DIFFERENCES BETWEEN THE Am386SXL CPU AND THE Am386DX CPU

The following are the major differences between the Am386SXL CPU and the Am386DX CPU:

1. The Am386SXL CPU generates byte selects on BHE and BLE (like the 8086 and 80286) to distinguish the upper and lower bytes on its 16-bit data bus. The Am386DX CPU uses four byte





selects,  $\overline{\text{BE3}}$ - $\overline{\text{BE0}}$ , to distinguish between the different bytes on its 32-bit bus.

- The Am386SXL CPU has no bus sizing option. The Am386DX CPU can select between either a 32-bit bus or a 16-bit bus by use of the BS16 input. The Am386SXL CPU has a 16-bit bus size.
- 3. The NA pin operation in the Am386SXL CPU is identical to that of the NA pin on the Am386DX CPU

with one exception: the Am386DX CPU  $\overline{NA}$  pin cannot be activated on 16-bit bus cycles (where  $\overline{BS16}$  is Low in the Am386DX CPU case), whereas  $\overline{NA}$  can be activated on any Am386SXL CPU bus cycle.

4. The contents of all Am386SXL CPU registers at reset are identical to the contents of the Am386DX CPU registers at reset, except the DX register. The DX register contains a component-stepping identifier at reset, that is,

in Am386DX CPU, after reset

DH = 3 indicates Am386DX CPU DI = revision number;

in Am386SXL CPU, after reset

DH = 23H indicates Am386SXL CPU DL = revision number.

- 5. The Am386DX CPU uses A31 and M/IO as selects for the math coprocessor. The Am386SXL CPU uses A23 and M/IO as selects.
- 6. The Am386DX CPU prefetch unit fetches code in four-byte units. The Am386SXL CPU prefetch unit reads two bytes as one unit (like the 80286). In BS16 mode, the Am386DX CPU takes two consecutive bus cycles to complete a prefetch request. If there is a data read or write request after the prefetch starts, the Am386DX CPU will fetch all four bytes before addressing the new request.
- 7. Both Am386DX CPU and Am386SXL CPU have the same logical address space. The only difference is that the Am386DX CPU has a 32-bit physical address space and the Am386SXL CPU has a 24-bit physical address space. The Am386SXL CPU has a physical memory address space of up to 16 Mb instead of the 4 Gb available to the Am386DX CPU. Therefore, in Am386SXL CPU systems, the operating system must be aware of this physical memory limit and should allocate memory for applications programs within this limit. If an Am386DX CPU system uses only the lower 16 Mb of physical address, then there will be no extra effort required to migrate Am386DX CPU software to the Am386SXL CPU. Any application which uses more than 16 Mb of memory can run on the Am386SXL CPU, if the operating system utilizes the Am386SXL CPU's paging mechanism. In spite of this difference in physical address space, the Am386SXL CPU and Am386DX CPU can run the same operating systems and applications within their respective physical memory constraints.
- The Am386SXL CPU has an input called FLT which three-states all bi-directional and output pins, including HLDA, when asserted. It is used with ON-Circuit Emulation (ONCE).

### INSTRUCTION SET

This section describes the instruction set. The Instruction Set Clock Count Summary lists all instructions along with instruction encoding diagrams and clock counts. Further details of the instruction encoding are then provided in the following sections, which completely describe the encoding structure and the definition of all fields occurring within instructions.

# The Am386SXL CPU Instruction Encoding and Clock Count Summary

To calculate elapsed time for an instruction, multiply the instruction clock count, as listed in the Instruction Set Clock Count Summary, by the processor clock period (e.g., 40 ns for a 25-MHz, 50 ns for a 20-MHz, and 62.5 ns for a 16-MHz Am386SXL microprocessor. The actual clock count of an Am386SXL CPU program will average 5% more than the calculated clock count due to instruction sequences which execute faster than they can be fetched from memory.

#### Instruction Clock Count Assumptions

- 1. The instruction has been prefetched, decoded, and is ready for execution.
- 2. Bus cycles do not require wait states.
- 3. There are no local bus HOLD requests delaying processor access to the bus.
- 4. No exceptions are detected during instruction execution.
- 5. If an effective address is calculated, it does not use two general register components. One register, scaling and displacement can be used within the clock counts shown. However, if the effective address calculation uses two general register components, add 1 clock to the clock count shown.

### Instruction Clock Count Notation

- If two clock counts are given, the smaller refers to a register operand and the larger refers to a memory operand.
- 2. n = number of times repeated.
- 3. *m* = number of components in the next instruction executed, where the entire displacement (if any) counts as one component, the entire immediate data (if any) counts as one component, and all other bytes of the instruction and prefix(es) each count as one component.

#### **Misaligned or 32-Bit Operand Accesses**

- If instructions access a misaligned 16-bit operand or 32-bit operand on even address add:
  - 2\* clocks for read or write
  - 4\*\* clocks for read and write
- If instructions access a 32-bit operand on odd address add:
  - 4\* clocks for read or write
  - 8\*\* clocks for read and write

#### Wait States

Wait states add 1 clock per wait state to instruction execution for each data access.

# Am386SXL Instruction Set Clock Count Summary

| Instruction         Format         Refer<br>and above<br>and above<br>and above<br>above above<br>and above<br>above above<br>above above<br>above above<br>above above<br>Begister /A fram SFER<br>MOV above<br>Register /A fram SFER<br>MOV above<br>MOV 2X - Move with Sign Extramion<br>MOV 2X - Move with Sign Extramion<br>MOV 2X - Move with Sign Extramion<br>MOV 2X - Move with Sign Extramion<br>PUSH = Push-<br>PUSH = Push-<br>Register /A fram SFER<br>MOV above<br>MOV 2X - Move with Sign Extramion<br>PUSH = Push-<br>Register /A fram SFER<br>MOV 2X - Move with Sign Extramion<br>PUSH = Push-<br>Register /A fram SFER<br>MOV 2X - Move with Sign Extramion<br>PUSH = Push-<br>Register /A fram SFER<br>MOV 2X - Move with Sign Extramion<br>PUSH = Push-<br>Register /A fram SFER<br>MOV 2X - Move with Sign Extramion<br>PUSH = Push-<br>Register /A fram SFER<br>MOV 2X - Move with Sign Extramion<br>PUSH = Push Above with Above With Sign Extramion<br>PUSH = Push Above With Sign Extramion<br>PUSH = Push Above With Sign Extramion<br>PU |                                                 |                                              | Clock                               | Count                           | No                                  | tes                                     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|----------------------------------------------|-------------------------------------|---------------------------------|-------------------------------------|-----------------------------------------|
| GENERAL DATA TRANSFER         Inc.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Instruction                                     | Format                                       | Real<br>Address<br>Mode/<br>Virtual | Protected<br>Virtual<br>Address | Real<br>Address<br>Mode/<br>Virtual | Protected<br>Virtual<br>Address<br>Mode |
| MOV = Move:       I       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0 <td< td=""><td></td><td></td><td></td><td></td><td></td><td></td></td<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                 |                                              |                                     |                                 |                                     |                                         |
| Accumulator function         Immediate of Register         I 0 0 0 1 0 1 w mod reg r/m         P/24         2/4         2/4         b           Register/Memory to Register         1 0 0 0 1 1 w mod reg r/m         immediate data         2         2/2         2/2         b           Immediate Degister/Memory         1 0 1 1 w reg         immediate data         2         2         2           Memory to Accumulator (effort form)         1 0 1 0 0 0 0 w full displacement         4         4         b           Accumulator (about form)         1 0 1 0 0 0 1 w full displacement         2'         2'         b         h           Register/Memory to Segment Register         1 0 0 0 1 1 1 0 mod sreg r/m         2/2         2/2         b         h           MOVSX = Move with Sign Extension              b           Register from Register/Memory         0 0 0 1 1 1 1 1 0 1 1 1 w mod reg r/m         3/6'         3/6'         b            PUSH = Push:           1 1 1 1 1 1 1 1 0 1 reg         2'         4         b           Segment Register/Memory         0 1 0 1 0 reg         1 0 1 0 reg         2'         4         b           PUSH = Push:          1 1 1 1 0 reg 3 0 00         2'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                 |                                              |                                     |                                 |                                     |                                         |
| Immediate Dregister/Memory         I 1 0 0 0 1 1 w         mod 0 0 0 . r/m         immediate data         2/2         2/2*         b           Memory to Accumulator (short form)         10 1 1 w         reg         immediate data         2         2           Memory to Accumulator (short form)         10 1 0 0 0 0 w         full displacement         4*         4*         b           Accumulator to Memory (abort form)         10 1 0 0 0 1 1 0 mod sreg 3 .r/m         2/2         2/2         b         h           Register/Memory to Segment Register         10 0 0 1 1 1 0 mod sreg 3 .r/m         2/2         2/2         b         h           MOVSX = Move with Sign Extension         Register/Memory         0 0 0 0 1 1 1 1 1 0 1 1 0 1 1 w         mod reg _r/m         3/6*         b         h           MOVSX = Move with Zero Extension         Register/Memory         0 0 0 0 1 1 1 1 1 0 1 1 0 1 1 w         mod reg _r/m         3/6*         b         h           PUSH = Push:         Register /Memory         0 1 0 1 0 0 reg         10         2         4         b           Segment Register (ES,CS,SS, or DS) (abort form)         0 1 0 1 1 0 reg         2/2         4         b           Segment Register (ES,CS,SS, or DS) (abort form)         0 0 0 0 1 1 1 1 1 0 sreg 3 000         2         4         b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Register to Register/Memory                     | 1 0 0 0 1 0 0 w mod reg r/m                  | 2/2                                 | 2/2*                            | b                                   | h                                       |
| Immediate to Register (abort form)         1011 w reg         immediate data         2         2           Memory to Accumulator (abort form)         101000         full displacement         4*         4*         b           Accumulator to Memory (abort form)         101000         full displacement         2*         2*         b           Register/Memory to Segment Register         10001110         mod sreg3 r/m         25         22/2         b         h           Segment Register to Register/Memory         10001110         mod sreg3 r/m         26         22/2         b         h           MOVSX Move with Sign Extension                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Register/Memory to Register                     | 1000101w mod reg r/m                         | 2/4                                 | 2/4*                            | b                                   | h                                       |
| Memory to Accumulator (short form)       1 0 1 0 0 0 0 w       full displacement       4*       4*       b         Accumulator to Memory (short form)       1 0 1 0 0 0 1 w       full displacement       2*       2*       b         Register/Memory to Segment Register       1 0 0 0 1 1 1 0       mod sreg 3 r/m       225       2223       b       h         Segment Register to Register/Memory       1 0 0 0 1 1 1 0       mod sreg 3 r/m       22       22       b       h         MOVSX = Move with Signet Register/Memory       0 0 0 0 1 1 1 1 1 0 1 1 1 1 1 w       mod reg 7/m       36*       36*       b       h         MOVZX = Move with Zero Extension       n       n       n       n       n       n       n       n         Register/Memory       0 0 0 0 1 1 1 1 1 0 1 1 0 1 1 w       mod reg 7/m       36*       36*       b       n         PUSH = Push:       n       n       n       n       n       n       n       n         Register/Memory       1 0 1 0 1 0 reg       2       4       b       n       n       n         Segment Register/Memory       1 0 1 0 1 0 s 0 immediate data       2       4       b       n       n         Register (ES, CS, SS, DS, FS, or GS)       0 0 0 0 1 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Immediate to Register/Memory                    | 1 1 0 0 0 1 1 w mod 0 0 0 r/m immediate data | 2/2                                 | 2/2*                            | b                                   | h                                       |
| Accumulator to Memory (abort form)       1 0 1 0 0 0 1 w       full displacement       2°       2°       b         Register/Memory to Segment Register       1 0 0 0 1 1 1 0       mod sreg 3 r/m       2/5       22/23       b       h         Segment Register to Register/Memory       1 0 0 0 1 1 0 0       mod sreg 1 r/m       2/2       2/2       b       h         Register/Memory       0 0 0 0 1 1 1 1 0       mod sreg 1 r/m       3/6°       3/6°       b       h         MOVSX = Move with Sign Extension       n       n       n       n       n       n       n         Register/Memory       0 0 0 0 1 1 1 1 1 0 1 1 0 1 1 w       mod reg r/m       3/6°       3/6°       b       n         MOVSX = Move with Zero Extension       n       n       n       n       n       n       n         Register/Memory       0 0 0 0 1 1 1 1 1 0 1 1 0 r/m       s/6°       3/6°       b       n       n         PUSH = Push:       n       n       n       n       n       n       n       n         Register/Memory       0 1 0 1 0 reg       2       4       b       n       n       n         Segment Register (ES, CS, SS, DS, FS, or GS)       0 0 0 1 1 1 1 1 0 sreg 3 0 0 0       2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Immediate to Register (short form)              | 1 0 1 1 w reg immediate data                 | 2                                   | 2                               |                                     |                                         |
| Register/Memory to Segment Register       1 0 0 0 1 1 1 0 mod sreg 3 r/m       2/5       22/23       b       h         Segment Register to Register/Memory       1 0 0 0 1 1 0 0 mod sreg 1/m       2/2       2/2       b       h         MOVSX=Move with Sign Extension       Image: Segment Register/Memory       0 0 0 0 1 1 1 1 1 0 1 1 1 1 1 m mod reg 1/m       3/6*       3/6*       b       h         Register/Momory       0 0 0 0 1 1 1 1 0 1 1 1 1 1 1 m mod reg 1/m       3/6*       3/6*       b       h         PUSH=Push:       Image: Segment Register/Memory       0 0 0 0 1 1 1 1 0 1 1 0 r/m       5/7*       7/9*       b       h         Register/Memory       1 1 1 1 1 1 1 1 1 1 1 1 0 r/m       5/7*       7/9*       b       h       h         PUSH=Push:       Image: Segment Register (ES,CS,SS, or DS) (short form)       000 sreg 2 110       2       4       b       h         Segment Register (ES,CS,SS, or DS) (short form)       000 sreg 2 110       2       4       b       h         PUSH=Push:       Immediate data       2       4       b       h       h         Register (Short form)       0 1 1 0 1 0 s 0       immediate data       2       4       b       h         PUSHA=Push All       0 1 1 0 1 0 s 0 1 1 1 1 mod 0 0 0 r/m       <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Memory to Accumulator (short form)              | 1 0 1 0 0 0 0 w full displacement            | 4.                                  | 4.                              | ь                                   | h                                       |
| Segment Register to Register/Memory         1 0 0 0 1 1 0 0 mod sreg r/m         2/2         2/2         b           MOVSX = Move with Sign Extension         0 0 0 0 1 1 1 1 1 0 1 1 1 1 1 1 1 1 w mod reg r/m         3/6*         b         b           Register from Register/Memory         0 0 0 0 1 1 1 1 1 0 1 1 1 1 1 1 1 1 w mod reg r/m         3/6*         b         b           MOVSX = Move with Zero Extension            5/7*         7/9*         b           Register from Register/Memory         0 0 0 0 1 1 1 1 1 0 1 1 0 1 1 w mod reg r/m         3/6*         3/6*         b           PUSH = Push:                 Register (form Register (ES, CS, SS, or DS) (abort form)         0 1 0 1 o reg         2         4         b           Segment Register (ES, CS, SS, OS, FS, or GS)         0 0 1 1 0 1 0 s o immediate data         2         4         b           PUSH = Push All         0 1 1 0 1 0 s o immediate data         2         4         b           PUSH = Push All         0 1 1 0 1 0 s o immediate data         2         4         b           POP = Pop           7/9         b         6           Register (Memory         1 0 0 0 1 1 1 1 mod 0 0 0 r/m         5/7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Accumulator to Memory (short form)              | 1 0 1 0 0 0 1 w full displacement            | 2*                                  | 2*                              | b                                   | h                                       |
| MOVSX = Move with Sign Extension         Register (from Register/Memory       0 0 0 0 1 1 1 1 1 0 1 1 1 1 1 1 w mod reg r/m       36°       36°       b         MOVZX = Move with Zero Extension       Image: Second Seco                                                                                                                                                                                                                                                                                                                                                            | Register/Memory to Segment Register             | 1 0 0 0 1 1 1 0 mod sreg 3 r/m               | 2/5                                 | 22/23                           | ь                                   | h, i, j                                 |
| Register from Register/Memory       0 0 0 0 1 1 1 1 1 0 1 1 1 1 1 w mod reg r/m       3/6*       3/6*       b         MOVZX = Move with Zero Extension       0 0 0 0 1 1 1 1 1 0 1 1 0 1 1 w mod reg r/m       3/6*       3/6*       b         Register from Register/Memory       0 0 0 0 1 1 1 1 1 0 1 1 0 1 1 w mod reg r/m       3/6*       3/6*       b         PUSH = Push:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Segment Register to Register/Memory             | 1 0 0 0 1 1 0 0 mod sreg r/m                 | 2/2                                 | 2/2                             | ь                                   | h                                       |
| MOVZX = Move with Zero Extension           Register from Register/Memory         0 0 0 0 1 1 1 1 1 0 1 1 0 1 1 w mod reg //m         3/6*         3/6*         b           PUSH = Push:         Register/Memory         1 1 1 1 1 1 1 1 1 mod 1 1 0 r/m         5/7*         7/9*         b           Register (short form)         0 1 0 1 0 reg         2         4         b           Segment Register (ES, CS, SS, or DS) (short form)         000 sreg 2 110         2         4         b           Segment Register (ES, CS, SS, DS, FS, or GS)         0 0 0 0 1 1 1 1 1 0 sreg 3 000         2         4         b           PUSHA = Push All         0 1 1 0 0 0 0 0         immediate data         2         4         b           PUSHA = Push All         0 1 1 0 1 0 s 0         immediate data         2         4         b           POP = Pop         Register (ES, CS, SS, or DS)         0 0 0 1 1 1 1 mod 0 0 0 r/m         5/7         7/9         b           Register (short form)         0 1 0 1 1 1 reg         6         6         b         b           Segment Register (ES, CS, SS, DS, FS, or GS)         0 0 0 0 1 1 1 1 1 0 sreg 3 0 0 1         7         25         b         h           Segment Register (ES, CS, SS, DS, FS, or GS)         0 0 0 0 1 1 1 1 1 0 sreg 3 0 0 1         7         25                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | MOVSX = Move with Sign Extension                |                                              |                                     |                                 |                                     |                                         |
| Register from Register/Memory       0 0 0 0 1 1 1 1 1 0 1 1 0 1 1 w mod reg r/m       3/6*       3/6*       b         PUSH = Push:       I       1 1 1 1 1 1 1 1 1 mod 1 1 0 r/m       5/7*       7/9*       b         Register/Memory       1 1 1 1 1 1 1 1 1 mod 1 1 0 r/m       5/7*       7/9*       b         Register (short form)       0 1 0 1 0 reg       2       4       b         Segment Register (ES, CS, SS, or DS) (short form)       000 sreg 2 110       2       4       b         Segment Register (ES, CS, SS, DS, FS, or GS)       0 0 0 0 1 1 1 1 1 0 sreg 3 000       2       4       b         PUSHA = Push All       0 1 1 0 1 0 s 0 1 mediate data       2       4       b       Immediate         POP = Pop       I       0 1 0 1 1 1 mod 0 0 0 r/m       18       34       b       Immediate         Register (Memory       1 0 0 0 1 1 1 1 mod 0 0 0 r/m       5/7       7/9       b       Immediate         POP = Pop       I       0 1 0 1 1 reg       6       6       b       Immediate         Segment Register (ES, CS, SS, DS, FS, or GS)       000 sreg 2 111       7       25       b       Immediate         Segment Register (ES, CS, SS, DS, FS, or GS)       0 0 0 0 1 1 1 1 10 sreg 3 001       7       25       b <t< td=""><td>Register from Register/Memory</td><td>0000111111011111w modreg r/m</td><td>3/6*</td><td>3/6*</td><td>ь</td><td>h</td></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Register from Register/Memory                   | 0000111111011111w modreg r/m                 | 3/6*                                | 3/6*                            | ь                                   | h                                       |
| PUSH = Push:       IIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIII                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | MOVZX = Move with Zero Extension                |                                              | -                                   |                                 |                                     |                                         |
| Register/Memory       1 1 1 1 1 1 1 1 1 1 mod 1 1 0 r/m       57"       779"       b         Register (short form)       0 1 0 1 0 reg       2       4       b         Segment Register (ES,CS,SS, or DS) (short form)       000 sreg 2 110       2       4       b         Segment Register (ES,CS,SS, or DS) (short form)       0 0 0 0 1 1 1 1 1 0 sreg 3 000       2       4       b         Immediate       0 1 1 0 1 0 s 0 immediate data       2       4       b         PUSHA=Push All       0 1 1 0 0 0 0 0       18       34       b         POP=Pop       Immediate       0 1 0 0 1 1 1 1 mod 0 0 0 r/m       577       779       b         Register (short form)       0 1 0 0 1 1 1 1 mod 0 0 0 r/m       577       779       b       F         Register (short form)       0 1 0 1 1 1 reg       6       6       b       F         Segment Register (ES, CS, SS, or DS)       0 0 0 0 sreg 2 111       7       25       b       h         Segment Register (ES, CS, SS, DS, FS, or GS)       0 0 1 1 1 1 0 sreg 3 001       7       25       b       h         Segment Register (ES, CS, SS, DS, FS, or GS)       0 1 0 0 0 1 1 1 1 1 0 sreg 3 001       7       25       b       h         POPA=Pop Ali       0 1 0 0 0 0 1 1 1 m mod reg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Register from Register/Memory                   | 0000111111011011w/modreg r/m                 | ] 3/6⁺                              | 3/6*                            | ь                                   | h                                       |
| Register (short form)       0 1 0 1 0 reg       2       4       b         Segment Register (ES, CS, SS, or DS) (short form)       000 sreg 2 110       2       4       b         Segment Register (ES, CS, SS, DS, FS, or GS)       0 0 0 0 1 1 1 1 1 0 sreg 3 000       2       4       b         Immediate       0 1 1 0 1 0 s 0       immediate data       2       4       b         PUSHA=Push All       0 1 1 0 0 0 0 0       18       34       b         POP=Pop       Immediate data       5/7       7/9       b         Register (short form)       0 1 0 1 1 1 mod 0 0 0 r/m       5/7       7/9       b         Register (short form)       0 1 0 1 1 reg       6       6       b         Segment Register (ES, CS, SS, or DS)       000 sreg 2 111       7       25       b       h         Segment Register (ES, CS, SS, or DS)       0 0 0 1 1 1 1 1 0 sreg 3 001       7       25       b       h         POPA=Pop All       0 1 1 0 0 0 0 1       14       0 1 0 0 0 1       24       40       b         Register (Memory with Register       1 0 0 0 0 1 1 w mod reg r/m       3/5**       3/5**       b, f       m         Register with Accumulator (short form)       1 0 0 1 0 reg       3       3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | PUSH = Push:                                    |                                              |                                     |                                 |                                     |                                         |
| Segment Register (ES,CS,SS, or DS) (short form)       000 sreg 2 110       2       4       b         Segment Register (ES,CS,SS, DS, FS, or GS)       00001111110 sreg 3 000       2       4       b         Immediate       011010s0       immediate data       2       4       b         PUSHA=Push All       01100000       18       34       b         POP=Pop       1000011111 mod 000 r/m       5/7       7/9       b         Register/Memory       100001111 reg       6       6       b         Segment Register (ES, CS, SS, or DS)       000 sreg 2 111       7       25       b       h         Segment Register (ES, CS, SS, DS, FS, or GS)       0000 sreg 2 111       7       25       b       h         Segment Register (ES, CS, SS, DS, FS, or GS)       0000 sreg 2 111       7       25       b       h         POPA=Pop All       01100001       7       25       b       h         Register/Memory with Register       1000011 w mod reg       3/5**       3/5**       b, f       h         N=Input From:       CLK Count Virtual 8086 Mode       3       3       I       I       I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Register/Memory                                 | 1 1 1 1 1 1 1 1 mod 1 1 0 r/m                | 5/7*                                | 7/9*                            | ь                                   | h                                       |
| Segment Register (ES, CS, SS, DS, FS, or GS)       0 0 0 0 1 1 1 1 1 0 sreg 3 000       2       4       b         Immediate       0 1 1 0 1 0 s 0       immediate data       2       4       b         PUSHA = Push All       0 1 1 0 0 0 0 0       18       34       b         POP = Pop       1       0 0 0 0 1 1 1 1 mod 0 0 0 r/m       5/7       7/9       b         Register (Memory       1 0 0 0 1 1 1 1 mod 0 0 0 r/m       5/7       7/9       b         Register (short form)       0 1 0 1 1 reg       6       6       b         Segment Register (ES, CS, SS, or DS)       000 sreg 2 111       7       25       b       h         POPA = Pop All       0 1 1 0 0 0 0 1       1 0 sreg 3 001       7       25       b       h         POPA = Pop All       0 1 1 0 0 0 0 1       1 0 0 0 0 1       24       40       b       h         XCHG = Exchange       3       3       3       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1 <td< td=""><td>Register (short form)</td><td>0 1 0 1 0 reg</td><td>2</td><td>4</td><td>ь</td><td>h</td></td<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Register (short form)                           | 0 1 0 1 0 reg                                | 2                                   | 4                               | ь                                   | h                                       |
| Immediate       0 1 1 0 1 0 s 0 immediate data       2       4       b         PUSHA=Push All       0 1 1 0 0 0 0 0       18       34       b         POP=Pop       18       34       b         Register/Memory       1 0 0 0 1 1 1 1 mod 0 0 0 r/m       5/7       7/9       b         Register (short form)       0 1 0 1 1 reg       6       6       b         Segment Register (ES, CS, SS, or DS)       000 sreg 2 111       7       25       b       h         Segment Register (ES, CS, SS, DS, FS, or GS)       0 0 0 0 1 1 1 1 10 sreg 3 001       7       25       b       h         POPA=Pop All       0 1 1 0 0 0 0 1       1 0 0 0 0 1 1 1 w mod reg r/m       3/5**       3/5**       b, f       f         Register/Memory with Register       1 0 0 0 0 1 1 w mod reg r/m       3       3       i       i         Register with Accumulator (short form)       1 0 0 1 0 reg       3       3       i       i         N= Input From:       Virtual 8086 Mode       i       i       i       i       i                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Segment Register (ES,CS,SS, or DS) (short form) | 000 sreg 2 110                               | 2                                   | 4                               | ь                                   | h                                       |
| PUSHA = Push All       0 1 1 0 0 0 0 0       18       34       b         POP = Pop       Image: transmission of transmissi transmission of transmission of transmission                                                                                                                                                                                                                                                                                                                                   | Segment Register (ES, CS, SS, DS, FS, or GS)    | 0 0 0 0 1 1 1 1 10 sreg 3 000                | 2                                   | 4                               | ь                                   | h                                       |
| POP=Pop       Image: Segment Register (Memory in the segment Register (ES, CS, SS, or DS)       Image: Image: Segment Register (ES, CS, SS, or DS)       Image: Segment Register (ES, CS, SS, or DS)       Image: Segment Register (ES, CS, SS, or DS)       Image: Segment Register (ES, CS, SS, OS, FS, or GS)       Image: Segment Register (ES, CS, SS, DS, FS, or GS)       Image: Segment Register (ES, CS, SS, DS, FS, or GS)       Image: Segment Register (ES, CS, SS, DS, FS, or GS)       Image: Segment Register (ES, CS, SS, DS, FS, or GS)       Image: Segment Register (ES, CS, SS, DS, FS, or GS)       Image: Segment Register (ES, CS, SS, DS, FS, or GS)       Image: Segment Register (ES, CS, SS, DS, FS, or GS)       Image: Segment Register (ES, CS, SS, DS, FS, or GS)       Image: Segment Register (ES, CS, SS, DS, FS, or GS)       Image: Segment Register (ES, CS, SS, DS, FS, or GS)       Image: Segment Register (ES, CS, SS, DS, FS, or GS)       Image: Segment Register (ES, CS, SS, DS, FS, or GS)       Image: Segment Register (ES, CS, SS, DS, FS, or GS)       Image: Segment Register (ES, CS, SS, DS, FS, or GS)       Image: Segment Register (ES, CS, SS, DS, FS, or GS)       Image: Segment Register (ES, CS, SS, DS, FS, or GS)       Image: Segmet Register (ES, CS, SS, DS, FS, or GS)       Image: Segmet Register (ES, CS, SS, DS, FS, or GS)       Image: Segmet Register (ES, CS, SS, DS, FS, or GS)       Image: Segmet Register (ES, CS, SS, DS, FS, or GS)       Image: Segmet Register (ES, CS, SS, DS, FS, or GS)       Image: Segmet Register (ES, CS, SS, DS, FS, or GS)       Image: Segmet Register (ES, CS, SS, DS, FS, or GS)       Image: Segmet Register (ES, CS, SS, DS, FS, or GS)       Image: Segmet Register (ES, CS, SS, DS, FS, or GS)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Immediate                                       | 0 1 1 0 1 0 s 0 immediate data               | 2                                   | 4                               | ь                                   | h                                       |
| Register//Memory       1 0 0 0 1 1 1 1 mod 0 0 0 r/m       5/7       7/9       b         Register (short form)       0 1 0 1 1 reg       6       6       b         Segment Register (ES, CS, SS, or DS)       000 sreg 2 111       7       25       b       h         Segment Register (ES, CS, SS, DS, FS, or GS)       0 0 0 0 1 1 1 1 10 sreg 3 001       7       25       b       h         POPA=Pop All       0 1 1 0 0 0 0 1       1 0 0 0 0 1       24       40       b       b         XCHG=Exchange       1 0 0 0 0 1 1 w mod reg r/m       3/5**       3/5**       b, f       f         Register (with Accumulator (short form)       1 0 0 1 0 reg       3       3       i       i         IN=Input From:       Virtual 8086 Mode       i       i       i       i       i                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | PUSHA = Push All                                | 0 1 1 0 0 0 0 0                              | 18                                  | 34                              | ь                                   | h                                       |
| Register (short form)       0 1 0 1 1 reg       6       6       b         Segment Register (ES, CS, SS, or DS)       000 sreg 2 111       7       25       b       h         Segment Register (ES, CS, SS, DS, FS, or GS)       0 0 0 0 1 1 1 1 10 sreg 3 001       7       25       b       h         POPA=Pop All       0 1 1 0 0 0 0 1       1       10 0 0 0 1       24       40       b         XCHG=Exchange       Register/Memory with Register       1 0 0 0 0 1 1 w mod reg r/m       3/5**       3/5**       b, f       f         Register with Accumulator (short form)       1 0 0 1 0 reg       3       3       I       I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | POP = Pop                                       |                                              |                                     |                                 |                                     |                                         |
| Segment Register (ES, CS, SS, or DS)       000 sreg 2 111       7       25       b       h         Segment Register (ES, CS, SS, DS, FS, or GS)       0 0 0 0 1 1 1 1 10 sreg 3 001       7       25       b       h         POPA = Pop All       0 1 1 0 0 0 0 1       24       40       b       b         XCHG = Exchange       7       3/5**       3/5**       b, f       b         Register/Memory with Register       1 0 0 0 0 1 1 w mod reg       r/m       3/5**       3/5**       b, f         IN= Input From:       Virtual 8086 Mode       Virtual 8086 Mode       1       1       1       1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Register/Memory                                 | 1 0 0 0 1 1 1 1 mod 0 0 0 r/m                | 5/7                                 | 7/9                             | ь                                   | h                                       |
| Segment Register (ES, CS, SS, DS, FS, or GS)       0 0 0 0 1 1 1 1 1 0 sreg 3 001       7       25       b       h         POPA=Pop All       0 1 1 0 0 0 0 1       24       40       b         XCHG=Exchange       24       40       b         Register/Memory with Register       1 0 0 0 0 1 1 w mod reg r/m       3/5**       3/5**       b, f         Register with Accumulator (short form)       1 0 0 1 0 reg       3       3       1         IN=Input From:       Virtual 8086 Mode       Virtual 8086 Mode       1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Register (short form)                           | 0 1 0 1 1 reg                                | 6                                   | 6                               | b                                   | h                                       |
| POPA = Pop All       0 1 1 0 0 0 0 1       24       40       b         XCHG = Exchange       1 0 0 0 0 1 1 w mod reg r/m       3/5**       3/5**       b, f         Register with Accumulator (short form)       1 0 0 1 0 reg       3       3         IN = Input From:       Virtual 8086 Mode       Virtual 8086 Mode       Image: CLK Count Virtual 8086 Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Segment Register (ES, CS, SS, or DS)            | 000 sreg 2 111                               | 7                                   | 25                              | ь                                   | h, i, j                                 |
| XCHG = Exchange     1000011 w mod reg r/m     3/5**     3/5**     b, f       Register/Memory with Register     100010 reg     3     3       IN = Input From:     CLK Count<br>Virtual 8086 Mode     I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Segment Register (ES, CS, SS, DS, FS, or GS)    | 0 0 0 0 1 1 1 1 10 sreg 3 001                | 7                                   | 25                              | b                                   | h, i, j                                 |
| Register/Memory with Register       1 0 0 0 0 1 1 w mod reg r/m       3/5**       3/5**       b, f         Register with Accumulator (short form)       1 0 0 1 0 reg       3       3         IN=Input From:       CLK Count<br>Virtual 8086 Mode       Instruction       Instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | POPA = Pop All                                  | 0 1 1 0 0 0 0 1                              | 24                                  | 40                              | b                                   | h                                       |
| Register with Accumulator (short form) 1 0 0 1 0 reg 3 3<br>IN = Input From: CLK Count<br>Virtual 8086 Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | XCHG = Exchange                                 |                                              |                                     |                                 |                                     |                                         |
| IN = Input From:<br>Uirtual 8086 Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Register/Memory with Register                   | 1 0 0 0 0 1 1 w mod reg r/m                  | 3/5**                               | 3/5**                           | b, f                                | f, h                                    |
| IN = Input From: Virtual 8086 Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Register with Accumulator (short form)          | 10010 reg                                    | 3                                   | 3                               |                                     |                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | IN = Input From:                                |                                              | e                                   |                                 |                                     |                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Fixed Port                                      | 1 1 1 0 0 1 0 w port number 28***            | 12*                                 | 6*/26*                          |                                     | s/t, m                                  |
| Variable Port 1 1 1 0 1 1 0 w 27*** 13* 7*/27* s                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Variable Port                                   | 1 1 1 0 1 1 0 w 27***                        | 13*                                 | 7*/27*                          |                                     | s/t, m                                  |

\* If CPL < IOPL \*\* If CPL > IOPL \*\* If CPL > IOPL \*\* Clock count shown applies if I/O permission allows I/O to the port in Virtual 8086 Mode. If I/O bit map denies permission Exception 13 fault occurs; refer to clock counts for INT3 instruction.

|                                       | · · · · · · · · · · · · · · · · · · · |                   | Clock                                            | Count                                   | Notes                                            |                                         |
|---------------------------------------|---------------------------------------|-------------------|--------------------------------------------------|-----------------------------------------|--------------------------------------------------|-----------------------------------------|
| Instruction                           | Format                                |                   | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode |
| OUT = Output To:                      |                                       | CLK Count         |                                                  |                                         |                                                  |                                         |
| Fixed Port                            | 1 1 1 0 0 1 1 w port number           | Virtual 8086 Mode | 10*                                              | 4*/24*                                  |                                                  | s/t, m                                  |
| Variable Port                         | 1 1 1 0 1 1 1 W                       | 25***             | 11.                                              | 5*/25*                                  |                                                  | s/t, m                                  |
| LEA = Load EA to Register             | 10001101 mod reg r/m                  |                   | 2                                                | 2                                       |                                                  |                                         |
| SEGMENT CONTROL                       | L                                     |                   |                                                  |                                         |                                                  |                                         |
| LDS = Load Pointer to DS              | 1 1 0 0 0 1 0 1 mod reg r/m           |                   | 7.                                               | 26*/28*                                 | ь                                                | h, i, j                                 |
| LES=Load Pointer to ES                | 1 1 0 0 0 1 0 0 mod reg r/m           |                   | 7.                                               | 26*/28*                                 | ь                                                | h, i, j                                 |
| LFS=Load Pointer to FS                | 0000111110110100                      | mod reg r/m       | 7*                                               | 26*/28*                                 | ь                                                | h, i, j                                 |
| LGS=Load Pointer to GS                | 00001111110110101                     | mod reg r/m       | 7*                                               | 26*/28*                                 | b                                                | h, i, j                                 |
| LSS=Load Pointer to SS                | 00001111 10110010                     | mod reg r/m       | 7.                                               | 26*/28*                                 | b                                                | h, i, j                                 |
| FLAG CONTROL                          | Lan                                   |                   |                                                  |                                         |                                                  |                                         |
| CLC = Clear Carry Flag                | 1111000                               |                   | 2                                                | 2                                       |                                                  |                                         |
| CLD = Clear Direction Flag            | 1111100                               |                   | 2                                                | 2                                       |                                                  |                                         |
| CLI=Clear Interrupt Enable Flag       | 1111010                               |                   | 8                                                | 8                                       |                                                  | m                                       |
| CLTS = Clear Task Switched Flag       |                                       |                   | 5                                                | 5                                       | c                                                |                                         |
| CMC = Complement Carry Flag           | 11110101                              |                   | 2                                                | 2                                       |                                                  |                                         |
| LAHF = Load AH into Flag              | 10011111                              |                   | 2                                                | 2                                       |                                                  |                                         |
| POPF = Pop Flags                      | 10011101                              |                   | 5                                                | 5                                       | b                                                | h, n                                    |
| PUSHF = Push Flags                    | 10011100                              |                   | 4                                                | 4                                       | ь                                                | h                                       |
| SAHF = Store AH into Flags            | 10011110                              |                   | 3                                                | 3                                       |                                                  |                                         |
| STC = Set Carry Flag                  | 1 1 1 1 0 0 1                         |                   | 2                                                | 2                                       |                                                  |                                         |
| STD = Set Direction Flag              | 1 1 1 1 1 0 1                         |                   |                                                  |                                         |                                                  |                                         |
| STI = Set Interrupt Enable Flag       | 1 1 1 1 0 1 1                         |                   | 8                                                | 8                                       |                                                  | m                                       |
| ARITHMETIC                            | L                                     |                   |                                                  |                                         |                                                  |                                         |
| ADD = Add                             |                                       |                   |                                                  |                                         |                                                  |                                         |
| Register to Register                  | 0 0 0 0 0 0 d w mod reg r/m           |                   | 2                                                | 2                                       |                                                  |                                         |
| Register to Memory                    | 0 0 0 0 0 0 0 w mod reg r/m           |                   | 7**                                              | 7**                                     | b                                                | h                                       |
| Memory to Register                    | 0 0 0 0 0 0 1 w mod reg r/m           |                   | 6*                                               | 6*                                      | b                                                | h                                       |
| Immediate to Register/Memory          | 100000sw mod 000 r/m                  | immediate data    | 2/7**                                            | 2/7**                                   | ь                                                | h                                       |
| Immediate to Accumulator (short form) | 0 0 0 0 0 1 0 w immediate data        |                   | 2                                                | 2                                       |                                                  |                                         |
| ADC = Add with Carry                  |                                       |                   |                                                  |                                         |                                                  |                                         |
| Register to Register                  | 000100dw mod reg r/m                  |                   | 2                                                | 2                                       |                                                  |                                         |
| -                                     |                                       |                   |                                                  | -                                       |                                                  |                                         |

\* If CPL < IOPL \*\* If CPL > IOPL \*\*\*Clock count shown applies if I/O permission allows I/O to the port in Virtual 8086 Mode. If I/O bit map denies permission Exception 13 fault occurs; refer to clock counts for INT3 instruction.

|                                         |                                        | Clock                                            | Count                                   | unt No                                           |                                         |
|-----------------------------------------|----------------------------------------|--------------------------------------------------|-----------------------------------------|--------------------------------------------------|-----------------------------------------|
| Instruction                             | Format                                 | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode |
| ADC = Add with Carry (continued)        |                                        |                                                  |                                         |                                                  |                                         |
| Register to Memory                      | 0 0 0 1 0 0 0 w mod reg r/m            | 7**                                              | 7**                                     | b                                                | h                                       |
| Memory to Register                      | 0 0 0 1 0 0 1 w mod reg r/m            | 6*                                               | 6*                                      | b                                                | h                                       |
| Immediate to Register/Memory            | 100000s w mod 0 1 0 r/m immediate data | 2/7**                                            | 2/7**                                   | ь                                                | h                                       |
| Immediate to Accumulator (short form)   | 0 0 0 1 0 1 0 w immediate data         | 2                                                | 2                                       |                                                  |                                         |
| INC = Increment                         |                                        |                                                  |                                         |                                                  |                                         |
| Register/Memory                         | 1 1 1 1 1 1 1 w mod 0 0 0 r/m          | 2/6**                                            | 2/6**                                   | b                                                | h                                       |
| Register (short form)                   | 0 1 0 0 0 reg                          | 2                                                | 2                                       |                                                  |                                         |
| SUB = Subtract                          |                                        |                                                  |                                         |                                                  |                                         |
| Register from Register                  | 0 0 1 0 1 0 d w mod reg r/m            | 2                                                | 2                                       |                                                  |                                         |
| Register from Memory                    | 0 0 1 0 1 0 0 w mod reg r/m            | 7**                                              | 7**                                     | b                                                | h                                       |
| Memory from Register                    | 0 0 1 0 1 0 1 w mod reg r/m            | 6*                                               | 6*                                      | b                                                | h                                       |
| Immediate from Register/Memory          | 100000sw mod 101 r/m immediate data    | 2/7**                                            | 2/7**                                   | ь                                                | h                                       |
| Immediate from Accumulator (short form) | 0 0 1 0 1 1 0 w immediate data         | 2                                                | 2                                       |                                                  |                                         |
| SBB=Subtract with Borrow                |                                        |                                                  |                                         |                                                  |                                         |
| Register from Register                  | 0 0 0 1 1 0 d w mod reg r/m            | 2                                                | 2                                       |                                                  |                                         |
| Register from Memory                    | 0 0 0 1 1 0 0 w mod reg r/m            | 7**                                              | 7**                                     | ь                                                | h                                       |
| Memory from Register                    | 0 0 0 1 1 0 1 w mod reg r/m            | 6*                                               | 6*                                      | ь                                                | h                                       |
| Immediate from Register/Memory          | 100000sw mod 011 r/m immediate data    | 2/7**                                            | 2/7**                                   | ь                                                | h                                       |
| Immediate from Accumulator (short form) | 0 0 0 1 1 1 0 w immediate data         | 2                                                | 2                                       |                                                  |                                         |
| DEC = Decrement                         |                                        |                                                  |                                         |                                                  |                                         |
| Register/Memory                         | 1 1 1 1 1 1 1 w reg 0 0 1 r/m          | 2/6                                              | 2/6                                     | b                                                | h                                       |
| Register (short form)                   | 0 1 0 0 1 reg                          | 2                                                | 2                                       |                                                  |                                         |
| CMP = Compare                           |                                        |                                                  |                                         |                                                  |                                         |
| Register with Register                  | 0 0 1 1 1 0 d w mod reg r/m            | 2                                                | 2                                       |                                                  |                                         |
| Memory with Register                    | 0 0 1 1 1 0 0 w mod reg r/m            | 5*                                               | 5⁺                                      | b                                                | h                                       |
| Register with Memory                    | 0 0 1 1 1 0 1 w mod reg r/m            | 6*                                               | 6*                                      | ь                                                | h                                       |
| Immediate with Register/Memory          | 100000s w mod 1 1 1 r/m immediate data | 2/5*                                             | 2/5*                                    | ь                                                | h                                       |
| Immediate with Accumulator (short form) | 0 0 1 1 1 1 0 w immediate data         | 2                                                | 2                                       |                                                  |                                         |
| NEG = Change Sign                       | 1 1 1 1 0 1 1 w mod 0 1 1 r/m          | 2/6*                                             | 2/6*                                    | ь                                                | h                                       |
|                                         |                                        |                                                  |                                         |                                                  |                                         |

\* If CPL≤IOPL \*\* If CPL>IOPL

|                                             |                                            | Clock                                            | Count                                   |                                                  | tes                                     |
|---------------------------------------------|--------------------------------------------|--------------------------------------------------|-----------------------------------------|--------------------------------------------------|-----------------------------------------|
| Instruction                                 | Format                                     | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode |
| AAS = ASCII Adjust for Subtract             | 00111111                                   | 4                                                | 4                                       |                                                  |                                         |
| DAA = Decimal Adjust for Add                |                                            | 4                                                | 4                                       |                                                  |                                         |
| DAS = Decimal Adjust for Subtract           | 0 0 1 0 1 1 1 1                            | 4                                                | 4                                       |                                                  |                                         |
| MUL = Multiply (unsigned)                   |                                            |                                                  |                                         |                                                  |                                         |
| Accumulator with Register Memory            | 1 1 1 1 0 1 1 w mod 1 0 0 r/m              |                                                  |                                         |                                                  |                                         |
| Multiplier – Byte<br>– Word<br>– Doubleword |                                            | 12-17/15-20*<br>12-25/15-28*<br>12-41/17-46*     | 2-25/15-28*                             | b, d<br>b, d<br>b, d                             | d, h<br>d, h<br>d, h                    |
| IMUL = Integer Multiply (signed)            |                                            |                                                  |                                         |                                                  |                                         |
| Accumulator with Register Memory            | 1 1 1 1 0 1 1 w mod 1 0 1 r/m              |                                                  |                                         |                                                  |                                         |
| Multiplier – Byte<br>– Word<br>– Doubleword |                                            | 12-17/15-20*<br>12-25/15-28*<br>12-41/17-46*     | 2-25/15-28*                             | b, d<br>b, d<br>b, d                             | d, h<br>d, h<br>d, h                    |
| Register with Register/Memory               | 000011111101011111 mod reg r/m             |                                                  |                                         | -,-                                              | -,                                      |
| Multiplier – Byte<br>– Word                 |                                            | 12-17/15-20*<br>12-25/15-28*                     | 1                                       | b, d<br>b, d                                     | d, h<br>d, h                            |
| - Doubleword                                |                                            | 12-41/17-46*                                     |                                         | b, d                                             | d, h                                    |
| Register/Memory with Immediate to Register  | 0 1 1 0 1 0 s 1 mod reg r/m immediate data |                                                  |                                         |                                                  |                                         |
| – Word<br>– Doubleword                      |                                            | 13–26<br>13–42                                   | 1 <b>3-26/14-27</b><br>13-42/16-45      | b, d<br>b, d                                     | d, h<br>d, h                            |
| DIV = Divide (unsigned)                     |                                            |                                                  |                                         |                                                  |                                         |
| Accumulator by Register/Memory              | 1 1 1 1 0 1 1 w mod 1 1 0 r/m              |                                                  |                                         |                                                  |                                         |
| Divisor – Byte<br>– Word<br>– Doubleword    |                                            | 14/17<br>22/25<br>38/43                          | 14/17<br>22/25<br>38/43                 | b, e<br>b, e<br>b, e                             | e, h<br>e, h<br>e, h                    |
| IDIV = Integer Divide (signed)              |                                            |                                                  |                                         |                                                  |                                         |
| Accumulator by Register/Memory              | 1 1 1 1 0 1 1 w mod 1 1 1 r/m              |                                                  |                                         |                                                  |                                         |
| Divisor – Byte<br>– Word<br>– Doubleword    |                                            | 19/22<br>27/30<br>43/48                          | 19/22<br>27/30<br>43/48                 | b, e<br>b, e<br>b, e                             | e, h<br>e, h<br>e, h                    |
| AAD = ASCII Adjust for Divide               | 1 1 0 1 0 1 0 1 0 0 0 0 1 0 1 0            | 19                                               | 19                                      |                                                  |                                         |
| AAM = ASCII Adjust for Multiply             | 1 1 0 1 0 1 0 0 0 0 0 0 1 0 1 0            | 17                                               | 17                                      |                                                  |                                         |
| CBW = Convert Byte to Word                  | 10011000                                   | 3                                                | 3                                       |                                                  |                                         |
| CWD = Convert Word to Double Word           | 10011001                                   | 2                                                | 2                                       |                                                  |                                         |
| LOGIC                                       |                                            |                                                  |                                         |                                                  |                                         |
| Shift/Rotate Instruction                    |                                            |                                                  |                                         |                                                  |                                         |
| Not Through Carry (ROL, ROR, SAL, SAR, SH   | IL, and SHR)                               |                                                  |                                         |                                                  |                                         |
| Register/Memory by 1                        | 1 1 0 1 0 0 0 w mod TTT r/m                | 3/7**                                            | 3/7**                                   | b                                                | h                                       |

# Am386SXL Instruction Set Clock Count Summary (continued)

|                                             |                                                                                                                                                                                                                   | Clock                                            | Count                                   | No                                               | tes                                     |
|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|-----------------------------------------|--------------------------------------------------|-----------------------------------------|
| Instruction                                 | Format                                                                                                                                                                                                            | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode |
| LOGIC (continued)                           |                                                                                                                                                                                                                   |                                                  |                                         |                                                  |                                         |
| Not Through Carry (ROL, ROR, SAL, SAR, S    | HL, and SHR) –(continued)                                                                                                                                                                                         |                                                  |                                         |                                                  |                                         |
| Register/Memory by CL                       | 1 1 0 1 0 0 1 w mod TTT r/m                                                                                                                                                                                       | 3/7*                                             | 3/7*                                    | ь                                                | h                                       |
| Register/Memory by Immediate Count          | 1 1 0 0 0 0 0 w mod TTT r/m (1)                                                                                                                                                                                   | 3/7*                                             | 3/7*                                    | ь                                                | h                                       |
| Through Carry (RCL and RCR)                 |                                                                                                                                                                                                                   |                                                  |                                         |                                                  |                                         |
| Register/Memory by 1                        | 1 1 0 1 0 0 0 w mod TTT r/m                                                                                                                                                                                       | 9/10*                                            | 9/10*                                   | ь                                                | h                                       |
| Register/Memory by CL                       | 1 1 0 1 0 0 1 w mod TTT r/m                                                                                                                                                                                       | 9/10*                                            | 9/10*                                   | ь                                                | h                                       |
| Register/Memory by Immediate Count          | 1 1 0 0 0 0 0 w mod TTT r/m (1)                                                                                                                                                                                   | 9/10*                                            | 9/10⁺                                   | ь                                                | h                                       |
| SHLD = Shift Left Double                    | TTT         Instruction           000         ROL           001         ROR           010         RCL           011         RCR           100         SHL/SAL           101         SHR           111         SAR |                                                  |                                         |                                                  |                                         |
| Register/Memory by Immediate                | 0 0 0 0 1 1 1 1 1 0 1 0 0 1 0 0 mod reg r/m (1)                                                                                                                                                                   | 3/7**                                            | 3/7**                                   |                                                  |                                         |
| Register/Memory by CL                       | 0 0 0 0 1 1 1 1 1 0 1 0 0 1 0 1 mod reg r/m                                                                                                                                                                       | 3/7**                                            | 3/7**                                   |                                                  |                                         |
| SHRD=Shift Right Double                     |                                                                                                                                                                                                                   |                                                  |                                         |                                                  |                                         |
| Register/Memory by Immediate                | 00001111110101100 mod reg r/m (1)                                                                                                                                                                                 | 3/7**                                            | 3/7**                                   |                                                  |                                         |
| Register/Memory by CL                       | 0 0 0 0 1 1 1 1 1 0 1 0 1 1 0 1 mod reg r/m                                                                                                                                                                       | 3/7**                                            | 3/7**                                   |                                                  |                                         |
| AND = And                                   |                                                                                                                                                                                                                   |                                                  |                                         |                                                  |                                         |
| Register to Register                        | 0 0 1 0 0 0 d w mod reg r/m                                                                                                                                                                                       | 2                                                | 2                                       |                                                  |                                         |
| Register to Memory                          | 0 0 1 0 0 0 0 w mod reg r/m                                                                                                                                                                                       | 7**                                              | 7**                                     | b                                                | h                                       |
| Memory to Register                          | 0 0 1 0 0 0 1 w mod reg r/m                                                                                                                                                                                       | 6*                                               | 6*                                      | b                                                | h                                       |
| Immediate to Register/Memory                | 1 0 0 0 0 0 0 w mod 1 0 0 r/m immediate data                                                                                                                                                                      | 2/7*                                             | 2/7**                                   | b                                                | h                                       |
| Immediate to Accumulator (short form)       | 0 0 1 0 0 1 0 w immediate data                                                                                                                                                                                    | 2                                                | 2                                       |                                                  |                                         |
| TEST = And Function to Flags, No Result     |                                                                                                                                                                                                                   |                                                  |                                         |                                                  |                                         |
| Register/Memory and Register                | 1 0 0 0 0 1 0 w mod reg r/m                                                                                                                                                                                       | 2/5*                                             | 2/5*                                    | b                                                | h                                       |
| Immediate Data and Register/Memory          | 1 1 1 1 0 1 1 w mod 0 0 0 r/m immediate data                                                                                                                                                                      | 2/5*                                             | 2/5*                                    | b                                                | h                                       |
| Immediate Data and Accumulator (short form) | 1 0 1 0 1 0 0 w immediate data                                                                                                                                                                                    | 2                                                | 2                                       |                                                  |                                         |
| OR = Or                                     |                                                                                                                                                                                                                   |                                                  |                                         |                                                  |                                         |
| Register to Register                        | 0 0 0 0 1 0 d w mod reg r/m                                                                                                                                                                                       | 2                                                | 2                                       |                                                  |                                         |
| Register to Memory                          | 0 0 0 0 1 0 0 w mod reg r/m                                                                                                                                                                                       | 7**                                              | 7**                                     | ь                                                | h                                       |
| Memory to Register                          | 0 0 0 0 1 0 1 w mod reg r/m                                                                                                                                                                                       | 6*                                               | 6*                                      | b                                                | h                                       |

\* If CPL ≤ IOPL \*\* If CPL > IOPL (1) Immediate 8-Bit Data

| Instruction         Format         Addression                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                              |                                             | Clock            | Count              | No               | es                                      |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|---------------------------------------------|------------------|--------------------|------------------|-----------------------------------------|
| Immediate to Register/Memory         1000000 w         mod 00117m         immediate data         2/7**         2/7**         b           Immediate to Accumulator (elorat form)         0000110 w         immediate data         2         2         1           Register to Register         001100 w         mod or gr         7**         2         2         1         6           Register to Register         0011000 w         mod reg         7**         7**         5         5           Memory to Register         0011000 w         mod reg         7***         2         2         1         6           Immediate to Register/Memory         100000 w         mod reg         r/***         2         2         1         6           Immediate to Accumulator (short form)         0011010 w         immediate data         2         2         1         6           NOT=invert Register/Memory         101001 w         mod 010 r/m         2         2         1         6           STRING MANIPULATION         Clock Courry         1010101 0         2         10         10         1         10         1         10         10         10         10         10         10         10         10         10         10 <th>Instruction</th> <th>Format</th> <th>Mode/<br/>Virtual</th> <th>Virtual<br/>Address</th> <th>Mode/<br/>Virtual</th> <th>Protected<br/>Virtual<br/>Address<br/>Mode</th>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Instruction                                  | Format                                      | Mode/<br>Virtual | Virtual<br>Address | Mode/<br>Virtual | Protected<br>Virtual<br>Address<br>Mode |
| Immediate to Accumulator (short form)         0 0 0 0 1 1 0 w         mmediate data         2         2           XOR = Exclusive Or         Register to Register         0 0 1 1 0 0 4 w         mod reg         r/m         2         2           Register to Register         0 0 1 1 0 0 4 w         mod reg         r/m         7"         7"         b           Memory to Register         0 0 1 1 0 0 1 w         mod reg         r/m         7"         2         2           Immediate to Register/Memory         1 0 0 0 0 0 0 w         mod 1 1 0 r/m         immediate data         2         2            NOT = Invert Register/Memory         1 1 1 0 1 1 w         mod 0 1 0 r/m         2/6"         2/6"         b         5           STRING MANIPULATION         0 1 1 0 1 1 0 1 1 0 w         29"**         15         9"29"         b         6           IOS = Input Byte/Word tom DX Port         0 1 1 0 1 1 1 0 w         29"**         14         8"28"         b         5           SCAS = Scan Byte/Word tom AL/AX/EXX         1 0 1 0 1 1 1 1 w         28"***         14         8"28"         b         5           SCAS = Scan Byte/Word tom AL/AX/EXX         1 0 1 0 1 1 1 1 w         28"****         5         5         b         6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | LOGIC (continued)                            |                                             |                  |                    |                  |                                         |
| XOR = Exclusive Or         Register to Register         0 0 1 1 0 0 4 w mod reg r/m         2         2           Register to Register         0 0 1 1 0 0 0 w mod reg r/m         7"         7"         b           Memory to Register         0 0 1 1 0 0 1 w mod reg r/m         6"         6"         b           Immediate to Register/Memory         1 0 0 0 0 0 0 w mod 1 1 0 r/m         immediate data         2         2           Immediate to Register/Memory         1 1 1 0 1 1 w mod reg r/m         immediate data         2         2           NOT = Invert Register/Memory         1 1 1 0 0 1 1 w mod 0 1 0 r/m         2/6"         2/6"         b           STRING MANIPULATION         Clock Count         2/2"         15         9"29"         b         a           COMPS = Compare Byte/Mord tom DX Port         0 1 1 0 1 1 0 1         10 0 1 1 0 w         29"**         15         5"         b           OUTS = Output Byte/Word to DX /AX/EAX         1 0 1 0 1 1 1 w         28"**         14         8"28"         b         a           SCAS = Scan Byte/Word to DX /AX/EAX         1 0 1 0 1 1 1 1 w         28"**         5         5         b         a           REPEATED STRING MANIPULATION         0 1 1 0 1 1 1 1 w         28"**         4         4         b         a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Immediate to Register/Memory                 | 100000w mod 001 r/m immediate dat           | a 2/7**          | 2/7**              | ь                | h                                       |
| Register to Register       0 0 1 1 0 0 d w mod reg r/m       2       2       1         Register to Memory       0 0 1 1 0 0 0 w mod reg r/m       6*       6*       6       6         Memory to Register       0 0 1 1 0 0 0 w mod reg r/m       6*       6*       6       6         Immediate to Register/Memory       1 0 0 0 0 0 0 w mod reg r/m       6*       6*       6*       6         NOT = Invert Register/Memory       1 1 1 1 0 1 0 w mediate data       2       2       7**       26**       26**       0         NOT = Invert Register/Memory       1 1 1 1 0 1 1 w med 0 1 0 r/m       immediate data       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*       10*                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Immediate to Accumulator (short form)        | 0 0 0 0 1 1 0 w immediate data              | 2                | 2                  |                  |                                         |
| Register to Memory         0 0 1 1 0 0 0 w mod reg         r/m         7**         7**         b           Memory to Register         0 0 1 1 0 0 0 w mod reg         r/m         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*         6*                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | XOR = Exclusive Or                           |                                             |                  |                    |                  |                                         |
| Memory to Register         Control of the control | Register to Register                         | 0 0 1 1 0 0 d w mod reg r/m                 | 2                | 2                  |                  |                                         |
| Intervalue to Register/Memory         1 0 0 0 0 0 0 w mod 1 1 0 r/m         immediate data         2/7**         2/7**         b           Immediate to Accumulator (shot form)         0 0 1 1 0 1 0 w         immediate data         2         2         2           NOT=invert Register/Memory         1 1 1 1 0 1 1 w         mod 0 1 0 r/m         2/6**         2/6**         b           STRING MANIPULATION         Clock Count         Virtual 80866         10*         10*         b           INS = Input Byte/Word from DX Port         0 1 1 0 1 0 1 1 0 w         29***         15         9*/29**         b         s/           LODS = Load Byte/Word to AL/AX/EAX         1 0 1 0 0 1 1 0 w         28***         14         8*/28**         b         s/           SCAS = Scan Byte/Word to DX Port         0 1 1 0 1 1 1 w         28****         14         8*/28**         b         s/           STOS = Store Byte/Word to DX Port         0 1 1 0 1 1 1 1 w         28******         4*         4*         b         s/           REPEATED STRING MANIPULATION         11 1 1 0 0 1 0 1 1 0 1 1 1         5**         5*         k         k           REPE CMPS = Compare String (Find match)         1 1 1 1 0 0 1 0 1 0 1 0 1 1 0 1 1 w         5**9n***         b         s/           REP DOD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Register to Memory                           | 0 0 1 1 0 0 0 w mod reg r/m                 | 7**              | 7**                | ъ                | h                                       |
| Immediate to Accumulator (short form)       0 0 1 1 0 1 0 w immediate data       2       2         NOT=Invert Register/Memory       1 1 1 1 0 1 1 w mod 0 1 0 r/m       2/6**       b         STRING MANIPULATION       Clock Count Virtual 8086       10*       b         CMPS = Compare Byte/Word       1 0 1 0 0 1 1 w       Clock Count Virtual 8086       10*       b         INS=Input Byte/Word from DX Port       0 1 1 0 1 1 0 w       29***       15       9*/29**       b       s/         LODS = Load Byte/Word to AL/AX/EAX       1 0 1 0 0 1 0 w       28***       14       8*/28**       b       s/         OUTS = Cutput Byte/Word to DX Port       0 1 1 0 1 1 1 w       28***       14       8*/28**       b       s/         SCAS = Scan Byte/Word       1 0 1 0 0 1 1 1 w       28***       14       8*/28**       b       s/         STRING MANIPULATION       1 0 1 0 1 0 1 1 1 w       7*       7*       b       s/         REPEATED STRING MANIPULATION       1 1 1 1 0 0 1 1 1 0 1 0 1 1 1 0 1 0 1 1 w       5*9n**       b       s/         REPNE CMPS = Compare String (Find non-match)       1 1 1 1 0 0 1 0 1 0 1 0 1 1 0 1 1 w       5*9n**       b       s/         REP LODS = Load String       1 1 1 1 0 0 1 0 1 0 0 1 0 0 1 0 0 1 w       7*4n*       5*6n*                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Memory to Register                           | 0 0 1 1 0 0 1 w mod reg r/m                 | 6*               | 6*                 | ь                | h                                       |
| NOT = Invert Register/Memory       1 1 1 1 0 1 1 w mod 0 1 0 r/m       2/6**       2/6**       b         STRING MANIPULATION       Clock Count       10*       10*       b         INS = Input Byte/Word from DX Port       0 1 1 0 1 1 0 w       29***       15       97/29**       b       s/         IODS = Load Byte/Word to AL/AX/EAX       1 0 1 0 0 1 1 0 w       29***       15       97/29**       b       s/         OUTS = Output Byte/Word to AL/AX/EAX       1 0 1 0 0 1 1 0 w       7       7**       b       s/         OUTS = Output Byte/Word to DX Port       0 1 1 0 1 1 1 1 w       28***       14       87/28**       b       s/         SCAS = Scan Byte/Word from AL/AX/EX       1 0 1 0 1 0 1 1 1 w       7*       7*       b       s/         STOS = Store Byte/Word from AL/AX/EX       1 0 1 0 1 0 1 1 1 w       5*       5*       b       s/         REPEATED STRING MANIPULATION       1 1 1 1 0 0 1 1 1 0 1 0 0 1 1 1 0 1 0 0 1 1 w       5*9n**       5*9n**       b       s/         REPE CMPS = Compare String (Find non-match)       1 1 1 1 0 0 1 0 1 0 1 0 0 1 1 w       5*9n**       5*9n**       b       s/         REP LODS = Load String       1 1 1 1 0 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Immediate to Register/Memory                 | 1 0 0 0 0 0 0 w mod 1 1 0 r/m immediate dat | a 2/7**          | 2/7**              | ь                | h                                       |
| STRING MANIPULATION       Clock Count<br>Virtual 8086<br>Mode       10*       10*       b         INS = Input Byte/Word from DX Port       0 1 1 0 1 1 0 w       29***       15       9*/29**       b       s/         LODS = Load Byte/Word to AL/AXEAX       10 1 0 1 1 0 w       29***       15       9*/29**       b       s/         LODS = Load Byte/Word to AL/AXEAX       10 1 0 1 1 0 w       29***       15       9*/29**       b       s/         MOVE = Move Byte/Word       10 1 0 1 1 0 w       29***       14       8*/28**       b       s/         OUTS = Output Byte/Word to DX Port       0 1 1 0 1 1 1 1 w       28***       14       8*/28**       b       s/         STOS = Store Byte/Word from AL/AXEX       10 1 0 1 0 1 1 1       7*       7*       b       s/         STOS = Store Byte/Word from AL/AXEX       10 1 0 1 0 1 1 1       5*       5*       s/       s/         REPEATED STRING MANIPULATION       11 1 1 0 0 1 0 1 0 1 0 1 1 1 0 0 1 1 w       5*9n**       5*9n**       b       s/         REPE CMPS = Compare String (Find non-match)       11 1 1 0 0 1 0 1 0 1 0 1 0 1 1 0 0 1 1 w       5*9n**       5*9n**       b       s//         REP LODS = Load String       11 1 1 0 0 1 0 1 0 1 0 1 0 1 0 1 0 0 1 0 w       7*4n*       b       s                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Immediate to Accumulator (short form)        | 0 0 1 1 0 1 0 w immediate data              | 2                | 2                  |                  |                                         |
| CMPS = Compare Byte/Word       1010011w       Clock Count<br>Virtual 8086<br>Mode       10'       10'       b         INS = Input Byte/Word from DX Port       0110110w       29'''       15       9'/29''       b       s/         LODS = Load Byte/Word to AL/AX/EAX       1010110w       29'''       5       5'       b       s/         MOVE = Move Byte/Word to DX Port       0110111w       7'       7''       b       s/         OUTS = Output Byte/Word to DX Port       0110111w       28'''       14''       8'/28''       b       s/         SCAS = Scan Byte/Word       1010111w       28''''       4''       4''       b       s/         STOS = Store Byte/Word from AL/AX/EX       10101011       5''       5''       5''       b       s/         REPEATED STRING MANIPULATION       11110011       1010011w       5+9n'''       5+9n'''       b       s/         REP INS = Input String (Find non-match)       11110010       1010011w       5+9n'''       5+9n'''       b       s/         REP INS = Input String       111110010       1010111w       5+9n'''       5+9n'''       b       s/         REP IODS = Load String       111110010       10101010w       ****       5+8n''       b       s/                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | NOT = Invert Register/Memory                 | 1 1 1 1 0 1 1 w mod 0 1 0 r/m               | 2/6**            | 2/6**              | ъ                | h                                       |
| CMPS = Compare Byte/Word       1010011w       Virtual 8066<br>Mode       10°       10°       b         INS = Input Byte/Word from DX Port       0110110w       29°**       15       9°/29°*       b       s/         LODS = Load Byte/Word to AL/AX/EAX       1010100w       7       7°*       b       s/         MOVE = Move Byte/Word to AL/AX/EAX       1010110w       7       7°*       b       s/         OUTS = Output Byte/Word to DX Port       0110111w       28***       14       8'28**       b       s/         SCAS = Scan Byte/Word from AL/AX/EX       101010101w       28***       14       8'28**       b       s/         STOS = Store Byte/Word from AL/AX/EX       101010101w       7*       7*       b       s/         STOS = Store Byte/Word from AL/AX/EX       10100111w       5*       5*       s/       s/         REPEACED STRING MANIPULATION       111100010       1010011w       5+9n**       b       s/         REP INS = Input String       111100010       10101010w       ****       13+6n*       7+6n*/       5       s/         REP LODS = Load String       11110010       10100100w       7+4n*       b       s/       s/         REP MOVS = Move String       11110010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | STRING MANIPULATION                          |                                             |                  |                    |                  |                                         |
| INS = Input Byte/Word from DX Port       0 1 1 0 1 1 0 w       28***       15       9*/29**       b       s/         LODS = Load Byte/Word to AL/AX/EAX       10 1 0 1 1 0 w       5       5*       b       b         MCVE = Move Byte/Word to AL/AX/EAX       10 1 0 0 1 0 w       7       7**       b       s/         OUTS = Output Byte/Word to DX Port       0 1 1 0 1 1 1 w       28***       14       8*/28**       b       s/         SCAS = Scan Byte/Word from AL/AX/EX       10 1 0 1 0 1 1 1 w       28***       14       8*/28**       b       s/         STOS = Store Byte/Word from AL/AX/EX       10 1 0 1 0 1 0 1 w       28***       14       8*/28**       b       s/         STOS = Store Byte/Word from AL/AX/EX       10 1 0 1 0 1 0 1 w       4*       4*       b       s/         STOS = Store Byte/Word from AL/AX/EX       10 1 0 1 0 1 0 1 0 1 0 1 0 1 0 0 1 1 w       5*       5*       5*       6*         REPEATED STRING MANIPULATION       11 1 1 0 0 1 0 1 0 1 0 1 0 0 1 1 0 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | CMPS = Compare Byte/Word                     | Virtual 80                                  | oc               | 10*                | ь                | h                                       |
| MOVE = Move Byte/Word       1 0 1 0 0 1 0 w       7       7"       b         OUTS = Output Byte/Word to DX Port       0 1 1 0 1 1 1 w       28"***       14       8"/28"*       b       s/         SCAS = Scan Byte/Word       1 0 1 0 1 0 1 1 1 w       7"       7"       b       7"       7"       b         STOS = Store Byte/Word from AL/AX/EX       1 0 1 0 1 0 1 0 1 w       4"       4"       b       4"       b         XLAT = Translate String       1 1 0 1 0 1 1 1       5"       5"       5"       """       b         REPEATED STRING MANIPULATION       #Repeated by Count in CX or ECX       """       1 1 1 1 0 0 1 0 1 0 1 1 0 1 0 1 1 w       5+9n**       5+9n**       b         REP INS = Ioput String       1 1 1 1 0 0 1 0 1 0 1 0 1 0 1 0 1 0 1 1 0 1 0 0 1 1 0 0 1 1 0 0 1 0 0 1 1 0 0 0 1 1 w       5+9n**       5+9n**       b         REP LODS = Load String       1 1 1 1 0 0 1 0 1 0 1 0 1 0 1 0 1 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | INS = Input Byte/Word from DX Port           | 0 1 1 0 1 1 0 w 29***                       | 15               | 9*/29**            | ь                | s/t, h, m                               |
| OUTS = Output Byte/Word to DX Port       0 1 1 0 1 1 1 1 w       28***       14       8*/28**       b       s/         SCAS = Scan Byte/Word       10 1 0 1 0 1 1 1 w       7*       7*       b         STOS = Store Byte/Word from AL/AX/EX       10 1 0 1 0 1 0 1 w       4*       4*       b         XLAT = Translate String       1 1 0 1 0 1 1 1       5*       5*       5*         REPEATED STRING MANIPULATION       8       5*       5*       5*       5*         REPE CMPS = Compare String (Find non-match)       1 1 1 1 0 0 1 0 1 0 1 0 1 0 1 1 0 0 1 1 w       5*9n**       5*9n**       b         REP INS = Input String       1 1 1 1 0 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | LODS = Load Byte/Word to AL/AX/EAX           | 1010110w                                    | 5                | 5⁺                 | ь                | h                                       |
| SCAS = Scan Byte/Word       10101111W       7'       7'       b         STOS = Store Byte/Word from AL/AX/EX       1010101W       4'       4'       b         XLAT = Translate String       11010111       5'       5'       5'       -         REPEATED STRING MANIPULATION       5'       5'       5'       -       -       -         REPE CMPS = Compare String (Find non-match)       1111001101010105       5'+9n''       5+9n''       5+9n''       b         REPNE CMPS = Compare String (Find match)       11110010001000011000011000000       5+9n''       5+9n''       b         REP INS = Input String       1111100010000100000000000000000000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | MOVE = Move Byte/Word                        | 1010010w                                    | 7                | 7**                | ь                | h                                       |
| STOS = Store Byte/Word from AL/AX/EX $1 \ 0 \ 1 \ 0 \ 1 \ 0 \ 1 \ 0 \ 1 \ 0 \ 1 \ 0 \ 1 \ 0 \ 1 \ 0 \ 1 \ 0 \ 1 \ 0 \ 1 \ 0 \ 1 \ 0 \ 1 \ 0 \ 1 \ 0 \ 1 \ 0 \ 1 \ 0 \ 1 \ 0 \ 1 \ 0 \ 0$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | OUTS = Output Byte/Word to DX Port           | 0 1 1 0 1 1 1 W 28***                       | 14               | 8*/28**            | ь                | s/t, h, m                               |
| XLAT = Translate String $1 1 0 1 0 1 1 1$ 5'       5'         REPEATED STRING MANIPULATION       Repeated by Count in CX or ECX       5       5'         REPE CMPS = Compare String (Find non-match) $1 1 1 1 0 0 1 1 1 0 1 0 0 1 1 w$ 5+9n**       5+9n**       b         REPNE CMPS = Compare String (Find match) $1 1 1 1 0 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | SCAS = Scan Byte/Word                        | 1010111w                                    | 7*               | 7*                 | ь                | h                                       |
| REPEATED STRING MANIPULATION         Repeated by Count in CX or ECX         REPE CMPS = Compare String (Find non-match) $1 1 1 1 0 0 1 1 1 0 0 0 1 1 w$ Step E CMPS = Compare String (Find match) $1 1 1 1 0 0 1 0 1 0 1 0 1 0 1 0 1 1 w$ REPNE CMPS = Compare String (Find match) $1 1 1 1 0 0 1 0 1 0 1 0 1 0 1 0 1 1 w$ REP INS = Input String $1 1 1 1 0 0 1 0 1 0 1 0 1 0 1 1 0 1 1 0 w$ REP LODS = Load String $1 1 1 1 0 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | STOS = Store Byte/Word from AL/AX/EX         | 1010101w                                    | 4.               | 4.                 | ь                | h                                       |
| Repeated by Count in CX or ECX         REPE CMPS = Compare String (Find non-match) $1 	ext{1} 	ext{1} 	ext{0} 	ext{0} 	ext{1} 	ext{1} 	ext{0} 	ext{1} 	ext{0} 	ext{1} 	ext{0} 	ext{1} 	ext{0} 	ext{1} 	ext{0} 	ext{1} 	ext{1} 	ext{1} 	ext{1} 	ext{0} 	ext{1} 	ext{1} 	ext{1} 	ext{1} 	ext{1} 	ext{0} 	ext{1} 	ext{1} 	ext{1} 	ext{1} 	ext{1} 	ext{0} 	ext{1} 	ext{2} 	ext{1} 	ex$                                                     | XLAT = Translate String                      | 1 1 0 1 0 1 1 1                             | 5*               | 5*                 |                  | h                                       |
| REPE CMPS = Compare String (Find non-match) $1 	ext{1} 	ext{1} 	ext{0} 	ext{0} 	ext{1} 	ext{1} 	ext{0} 	ext{0} 	ext{1} 	ext{1} 	ext{0} 	ext{0} 	ext{0} 	ext{0} 	ext{0} 	ext{1} 	ext{0} 	ext{0} 	ext{1} 	ext{0} 	ext{0} 	ext{1} 	ext{1} 	ext{0} 	ext{1} 	ext{1} 	ext{0} 	ext{1} 	ext{1} 	ext{1} 	ext{0} 	ext{1} 	ext{1} 	ext{1} 	ext{1} 	ext{0} 	ext{1} 	ext{1} $               | REPEATED STRING MANIPULATION                 |                                             |                  |                    |                  |                                         |
| REPNE CMPS = Compare String (Find match)          1         1         1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Repeated by Count in CX or ECX               |                                             |                  |                    |                  |                                         |
| REP INS = Input String       1 1 1 1 0 0 1 0       0 1 1 0 1 1 0 1 0       13+6n*       7+6n'/<br>27+6n**       6       s/n         REP LODS = Load String       1 1 1 1 0 0 1 0       1 0 1 0 1 0 1 0 1 0       5+6n*       5+6n*       b         REP MOVS = Move String       1 1 1 1 0 0 1 0       1 0 1 0 0 1 0 0       7+4n*       7+4n*       b         REP OUTS = Output String       1 1 1 1 0 0 1 0       0 1 1 0 1 1 1 1       ***       12+5n*       6+5n'/<br>26+5n**       b       s/n         REPE SCAS = Scan String (Find non-AL/AX/EAX)       1 1 1 1 0 0 1 1       1 0 1 0 1 1 1 w       5+8n*       5+8n*       b         REPNE SCAS = Scan String (Find AL/AX/EAX)       1 1 1 1 0 0 1 0       1 0 1 0 1 1 1 w       5+8n*       5+8n*       b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | REPE CMPS = Compare String (Find non-match)  | 1 1 1 1 0 0 1 1 1 0 1 0 0 1 1 w             | 5+9n**           | 5+9n**             | ъ                | h                                       |
| Internet indexing       Internet indexing       Internet indexing       Internet indexing         REP LODS = Load String       Internet indexing       Internet indexing       Second Sec                                                                                | REPNE CMPS = Compare String (Find match)     | 1 1 1 1 0 0 1 0 1 0 1 0 0 1 1 w             | 5+9n**           | 5+9n**             | b                | h                                       |
| REP LODS = Load String       1 1 1 1 0 0 1 0 1 0 1 0 1 0 1 1 0 1 0 0 1 0 0       5+6n*       5+6n*       b         REP MOVS = Move String       1 1 1 1 0 0 1 0 1 0 1 0 1 0 1 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | REP INS = Input String                       | 1 1 1 1 0 0 1 0 0 1 1 0 1 1 0 w ····        | 13+6n*           |                    | 6                | s/t, h, m                               |
| REP OUTS = Output String                1 1 1 0 0 1 0 0 1 1 0 1 1 1 w                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | REP LODS = Load String                       | 1 1 1 1 0 0 1 0 1 0 1 0 1 1 0 w             | 5+6n*            | 1                  | ъ                | h                                       |
| REPE SCAS = Scan String (Find non-AL/AX/EAX)       1 1 1 1 0 0 1 0 1 0 1 0 1 0 1 1 1 0 0 1 1 1 0 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 0 1 0 1 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                       | REP MOVS = Move String                       | 1 1 1 1 0 0 1 0 1 0 1 0 0 1 0 w             | 7+4n*            | 7+4n*              | b                | h                                       |
| REPE SCAS = Scan String (Find non-AL/AX/EAX)         1 1 1 1 0 0 1 1         1 0 1 0 1 1 1 w         5 + 8n*         5 + 8n*         b           REPNE SCAS = Scan String (Find AL/AX/EAX)         1 1 1 1 0 0 1 0         1 0 1 0 1 1 1 w         5 + 8n*         5 + 8n*         b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | REP OUTS = Output String                     | 1 1 1 1 0 0 1 0 0 1 1 0 1 1 1 w             | 12+5n*           |                    | ь                | s/t, h, m                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | REPE SCAS = Scan String (Find non-AL/AX/EAX) | 1 1 1 1 0 0 1 1 1 0 1 0 1 1 1 w             | 5+8n*            |                    | ь                | h                                       |
| REP STOS = Store String         1 1 1 1 0 0 1 0 1 0 1 0 1 0 1 0 1 w         5+5n*         5+5n*         b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | REPNE SCAS = Scan String (Find AL/AX/EAX)    | 1 1 1 1 0 0 1 0 1 0 1 0 1 1 1 w             | 5+8n*            | 5+8n*              | ь                | h                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | REP STOS = Store String                      | 1 1 1 1 0 0 1 0 1 0 1 0 1 0 1 w             | 5+5n*            | 5+5n*              | ь                | h                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                              |                                             |                  |                    |                  |                                         |

"If CPL≤IOPL "If CPL>IOPL

\*\*\*Clock count shown applies if I/O permission allows I/O to the port in Virtual 8086 Mode. If I/O bit map denies permission Exception 13 fault occurs; refer to clock counts for INT3 instruction.

|                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                               |                                                  | Count                                                                      | No                                               | tes                                                                                                          |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|--------------------------------------------------|----------------------------------------------------------------------------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------|
| Instruction                                                                                                                                                                                                                                                                                                                                                                                                          | Format                                                                        | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode                                    | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode                                                                      |
| BIT MANIPULATION                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                               | occo mode                                        | mode                                                                       | occo mode                                        | mode                                                                                                         |
| BSF=Scan Bit Forward                                                                                                                                                                                                                                                                                                                                                                                                 | 0 0 0 0 1 1 1 1 1 0 1 1 1 1 0 0 mod reg r/m (1)                               | 10+3n*                                           | 10+3n*                                                                     | ь                                                | h                                                                                                            |
| BSR=Scan Bit Reverse                                                                                                                                                                                                                                                                                                                                                                                                 | 0 0 0 0 1 1 1 1 1 0 1 1 1 0 1 mod reg r/m                                     | 10+3n*                                           | 10+3n*                                                                     | ь                                                | h                                                                                                            |
| BT = Test Bit                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                               |                                                  |                                                                            |                                                  |                                                                                                              |
| Register/Memory, Immediate                                                                                                                                                                                                                                                                                                                                                                                           | 0 0 0 0 1 1 1 1 1 0 1 1 1 0 1 0 mod 1 0 0 r/m (1)                             | 3/6*                                             | 3/6*                                                                       | b                                                | h                                                                                                            |
| Register/Memory, Register                                                                                                                                                                                                                                                                                                                                                                                            | 0 0 0 0 1 1 1 1 1 0 1 0 0 0 1 1 mod reg r/m                                   | 3/12*                                            | 3/12*                                                                      | b                                                | h                                                                                                            |
| BTC = Test Bit and Complement                                                                                                                                                                                                                                                                                                                                                                                        |                                                                               |                                                  |                                                                            |                                                  |                                                                                                              |
| Register/Memory, Immediate                                                                                                                                                                                                                                                                                                                                                                                           | 0 0 0 0 1 1 1 1 1 0 1 1 1 0 1 0 mod 1 1 1 r/m (1)                             | 6/8*                                             | 6/8 <b>*</b>                                                               | b                                                | h                                                                                                            |
| Register/Memory, Register                                                                                                                                                                                                                                                                                                                                                                                            | 0 0 0 0 1 1 1 1 1 0 1 1 1 0 1 1 mod reg r/m                                   | 6/13*                                            | 6/13 <b>*</b>                                                              | b                                                | h                                                                                                            |
| BTR = Test Bit and Reset                                                                                                                                                                                                                                                                                                                                                                                             |                                                                               |                                                  |                                                                            |                                                  |                                                                                                              |
| Register/Memory, Immediate                                                                                                                                                                                                                                                                                                                                                                                           | 0 0 0 0 1 1 1 1 1 0 1 1 1 0 1 0 mod 1 1 0 r/m (1)                             | 6/8*                                             | 6/8*                                                                       | b                                                | h                                                                                                            |
| Register/Memory, Register                                                                                                                                                                                                                                                                                                                                                                                            | 0 0 0 0 1 1 1 1 1 0 1 1 0 0 1 1 mod reg r/m                                   | 6/13*                                            | 6/13 <b>*</b>                                                              | b                                                | h                                                                                                            |
| BTS = Test Bit and Set                                                                                                                                                                                                                                                                                                                                                                                               |                                                                               |                                                  |                                                                            |                                                  |                                                                                                              |
| Register/Memory, Immediate                                                                                                                                                                                                                                                                                                                                                                                           | 0 0 0 0 1 i 1 i 1 0 1 1 1 0 1 0 mod 1 0 1 r/m (1)                             | 6/8*                                             | 6/8*                                                                       | b                                                | h                                                                                                            |
| Register/Memory, Register                                                                                                                                                                                                                                                                                                                                                                                            | 0 0 0 0 1 1 1 1 1 0 1 0 1 0 1 1 mod reg r/m                                   | 6/13*                                            | 6/13*                                                                      | b                                                | h                                                                                                            |
| CONTROL TRANSFER                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                               |                                                  |                                                                            |                                                  |                                                                                                              |
| CALL = Call                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                               |                                                  |                                                                            |                                                  |                                                                                                              |
| Direct Within Segment                                                                                                                                                                                                                                                                                                                                                                                                | 1 1 1 0 1 0 0 0 full displacement                                             | 7+m*                                             | 9 + m*                                                                     | b                                                | r                                                                                                            |
| Register/Memory<br>Indirect Within Segment                                                                                                                                                                                                                                                                                                                                                                           | 1 1 1 1 1 1 1 1 mod 0 1 0 r/m                                                 | 7 + m*/<br>10 + m*                               | 9+m*/<br>12+m*                                                             | b                                                | h, r                                                                                                         |
| Direct Intersegment                                                                                                                                                                                                                                                                                                                                                                                                  | 1 0 0 1 1 0 1 0 unsigned full offset, selector                                | 17 + m*                                          | 42 + m*                                                                    | b                                                | j, k, r                                                                                                      |
| Protected Mode Only (Direct Intersegment)<br>Via Call Gate to Same Privilege Level<br>Via Call Gate to Different Privilege Level<br>From 80286 Task to 80286 TSS<br>From 80286 Task to 80286 TSS<br>From 80286 Task to Virtual 8086 Task (A<br>From Am386SXL CPU Task to 80286 TS<br>From Am386SXL CPU Task to Am386S<br>From Am386SXL CPU Task to Virtual 80                                                        | x Parameters)<br>S<br>m386SXL CPU TSS)<br>S<br>L CPU TSS                      |                                                  | 64 + m<br>98 + m<br>106 + 8x + m<br>285<br>310<br>229<br>285<br>392<br>309 |                                                  | h, j, k, r<br>h, j, k, r |
| Indirect Intersegment                                                                                                                                                                                                                                                                                                                                                                                                | 1 1 1 1 1 1 1 1 mod 0 1 1 r/m                                                 | 30 + m                                           | 46 + m                                                                     | b                                                | h, j, k, r                                                                                                   |
| Protected Mode Only (Indirect Intersegment)<br>Via Call Gate to Same Privilege Level<br>Via Call Gate to Different Privilege Level<br>Via Call Gate to Different Privilege Level<br>From 80286 Task to 80286 TSS<br>From 80286 Task to Am386SXL CPU TS<br>From 80286 Task to Virtual 8086 Task (A<br>From Am386SXL CPU Task to 80286 TS<br>From Am386SXL CPU Task to Am386S)<br>From Am386SXL CPU Task to Virtual 80 | (No Parameters)<br>(x Parameters)<br>S<br>m386SXL CPU TSS)<br>S<br>:L CPU TSS |                                                  | 68 + m<br>102 + m<br>110 + 8x + m<br>399                                   |                                                  | h, j, k, r<br>h, j, k, r |

\* If CPL ≤ IOPL \*\* If CPL > IOPL (1) Immediate 8-bit data

|                                                                                                                                                                                                                                                                                                                                |                                                                                                                 | Clock                                            | Count                                   | No                                               | tes                                                                                                          |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|--------------------------------------------------|-----------------------------------------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------|
| Instruction                                                                                                                                                                                                                                                                                                                    | Format                                                                                                          | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode                                                                      |
| CONTROL TRANSFER (continued)                                                                                                                                                                                                                                                                                                   | ₩/, (1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999 |                                                  |                                         |                                                  |                                                                                                              |
| JMP = Unconditional Jump                                                                                                                                                                                                                                                                                                       |                                                                                                                 |                                                  |                                         |                                                  |                                                                                                              |
| Short                                                                                                                                                                                                                                                                                                                          | 1 1 1 0 1 0 1 1 8-bit displacement                                                                              | 7 + m                                            | 7+m                                     |                                                  | r                                                                                                            |
| Direct within Segment                                                                                                                                                                                                                                                                                                          | 1 1 0 1 0 0 0 1 full displacement                                                                               | 7+m                                              | 7 + m                                   |                                                  | r                                                                                                            |
| Register/Memory<br>Indirect Within Segment                                                                                                                                                                                                                                                                                     | 1 1 1 1 1 1 1 1 mod 1 0 0 r/m                                                                                   | 9+m/<br>14+m                                     | 9+m/<br>14+m                            | b                                                | h, r                                                                                                         |
| Direct Intersegment                                                                                                                                                                                                                                                                                                            | 1 1 1 0 1 0 1 0 unsigned full offset, selector                                                                  | 16+m                                             | 31 + m                                  |                                                  | j, k, r                                                                                                      |
| Protected Mode Only (Direct Intersegment)<br>Via Call Gate to Same Privilege Level<br>From 80286 Task to 80286 TSS<br>From 80286 Task to Am386SXL CPU TSS<br>From 80286 Task to Virtual 8086 Task (Am<br>From Am386SXL CPU Task to 80286 TSS<br>From Am386SXL CPU Task to Am386SXL<br>From Am386SXL CPU Task to Virtual 8086   | CPUTSS                                                                                                          | 17+m                                             | 53 + m<br>395<br>31 + m                 | Þ                                                | h, j, k, r<br>h, j, k, r |
| Indirect Intersegment                                                                                                                                                                                                                                                                                                          | 1 1 1 1 1 1 1 1 mod 1 0 1 r/m                                                                                   |                                                  | 0,1,11                                  | 5                                                | .,,,,,,,,                                                                                                    |
| Protected Mode Only (Indirect Intersegment)<br>Via Call Gate to Same Privilege Level<br>From 80286 Task to 80286 TSS<br>From 80286 Task to Am386SXL CPU TSS<br>From 80286 Task to Virtual 8086 Task (Am<br>From Am386SXL CPU Task to 80286 TSS<br>From Am386SXL CPU Task to Am386SXL<br>From Am386SXL CPU Task to Virtual 8086 | CPU TSS                                                                                                         |                                                  | 49 + m<br>328                           |                                                  | h, j, k, r<br>h, j, k, r               |
| RET = Return from Call                                                                                                                                                                                                                                                                                                         |                                                                                                                 | [                                                | 12+m                                    | ь                                                | g, h, r                                                                                                      |
| Within Segment                                                                                                                                                                                                                                                                                                                 | 1 1 0 0 0 0 1 1                                                                                                 |                                                  | 12+m                                    | ь                                                | g, h, r                                                                                                      |
| Within Segment Adding Immediate to SP                                                                                                                                                                                                                                                                                          | 1 1 0 0 0 0 1 0 16-bit displacement                                                                             |                                                  | 36 + m                                  | b                                                | g, h, j, k, r                                                                                                |
| Intersegment                                                                                                                                                                                                                                                                                                                   |                                                                                                                 |                                                  | 36+m                                    | b                                                | g, h, j, k, r                                                                                                |
| Intersegment Adding Immediate to SP                                                                                                                                                                                                                                                                                            | 1 1 0 0 1 0 1 0 16-bit displacement                                                                             |                                                  |                                         | -                                                | 91 / 1 J / 1 / 2                                                                                             |
| Protected Mode Only (RET): to Different Privile<br>Intersegment<br>Intersegment Adding Immediate to SP<br>CONDITIONAL JUMPS (Note: Times are Jun                                                                                                                                                                               | ge Level                                                                                                        |                                                  | 72<br>72                                |                                                  | h, j, k, r<br>h, j, k, r                                                                                     |
| JO = Jump on Overflow                                                                                                                                                                                                                                                                                                          |                                                                                                                 | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                                                                                            |
| 8-bit Displacement                                                                                                                                                                                                                                                                                                             |                                                                                                                 |                                                  | 7 + m or 3                              |                                                  | r                                                                                                            |
| Full Displacement                                                                                                                                                                                                                                                                                                              | 0 1 1 1 0 0 0 0 8-bit displacement                                                                              |                                                  |                                         |                                                  |                                                                                                              |
| JNO = Jump on Not Overflow                                                                                                                                                                                                                                                                                                     | 0 0 0 0 1 1 1 1 1 0 0 0 0 0 0 0 0 full displacement                                                             | 7+m or 3                                         | 7 + m or 3                              |                                                  | r                                                                                                            |
| 8-bit Displacement                                                                                                                                                                                                                                                                                                             |                                                                                                                 |                                                  |                                         |                                                  |                                                                                                              |
| Full Displacement                                                                                                                                                                                                                                                                                                              | 0 1 1 1 0 0 0 1 8-bit displacement                                                                              | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                                                                                            |
|                                                                                                                                                                                                                                                                                                                                | 0 0 0 0 1 1 1 1 1 0 0 0 0 0 0 1 full displacement                                                               | 1                                                |                                         |                                                  |                                                                                                              |

\* If CPL≤IOPL \*\* If CPL>IOPL

|                                  |                                                   | Clock                                            | Count                                   | Not                                              | es                                      |
|----------------------------------|---------------------------------------------------|--------------------------------------------------|-----------------------------------------|--------------------------------------------------|-----------------------------------------|
| Instruction                      | Format                                            | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode |
| CONDITIONAL JUMPS (continue      | d)                                                |                                                  |                                         |                                                  |                                         |
| JB/JNAE = Jump on Below/Not A    |                                                   |                                                  |                                         |                                                  |                                         |
| 8-bit Displacement               | 0 1 1 1 0 0 1 0 8-bit displacement                | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| Full Displacement                | 0 0 0 0 1 1 1 1 1 0 0 0 0 0 1 0 full displacement | 7 + m or 3                                       | 7+m or 3                                |                                                  | r                                       |
| JNB/JAE = Jump on Not Below/A    |                                                   |                                                  |                                         |                                                  |                                         |
| 8-bit Displacement               | 0 1 1 1 0 0 1 1 8-bit displacement                | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| Full Displacement                | 0 0 0 0 1 1 1 1 1 0 0 0 0 0 1 1 full displacement | 7 + m or 3                                       | 7 + m or 3                              |                                                  | ,<br>r                                  |
| JE/JZ = Jump on Equal/Zero       |                                                   |                                                  |                                         |                                                  |                                         |
| 8-bit Displacement               | 0 1 1 1 0 1 0 0 8-bit displacement                | 7 + m or 3                                       | 7 + m or 3                              |                                                  | l r                                     |
| Full Displacement                |                                                   | 7 + m or 3                                       | 7+m or 3                                |                                                  |                                         |
| JNE/JNZ = Jump on Not Equal/N    |                                                   | / +111 07 0                                      | 7 411 01 0                              |                                                  | ,                                       |
| 8-bit Displacement               | F                                                 | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| Full Displacement                |                                                   | 7+m or 3                                         | 7+m or 3                                |                                                  |                                         |
|                                  | 0 0 0 0 1 1 1 1 1 0 0 0 0 1 0 1 full displacement | 7 + 11 01 3                                      | 7+11013                                 |                                                  |                                         |
| JBE/JNA = Jump on Below or Eq    |                                                   |                                                  |                                         |                                                  |                                         |
| 8-bit Displacement               | 0 1 1 1 0 1 1 0 8-bit displacement                | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| Full Displacement                | 0 0 0 0 1 1 1 1 1 0 0 0 0 1 1 0 full displacement | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| JNBE/JA = Jump on Not Below o    |                                                   |                                                  |                                         |                                                  |                                         |
| 8-bit Displacement               | 0 1 1 1 0 1 1 1 8-bit displacement                | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| Full Displacement                | 0 0 0 0 1 1 1 1 1 0 0 0 0 1 1 1 full displacement | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| JS = Jump on Sign                |                                                   |                                                  |                                         |                                                  |                                         |
| 8-bit Displacement               | 0 1 1 1 1 0 0 0 8-bit displacement                | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| Full Displacement                | 0 0 0 0 1 1 1 1 1 0 0 0 1 0 0 0 full displacement | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| JNS = Jump on Not Sign           |                                                   |                                                  |                                         |                                                  |                                         |
| 8-bit Displacement               | 0 1 1 1 1 0 0 1 8-bit displacement                | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| Full Displacement                | 0 0 0 0 1 1 1 1 1 0 0 0 1 0 0 1 full displacement | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| JP/JPE = Jump on Parity/Parity E | Iven                                              |                                                  |                                         |                                                  |                                         |
| 8-bit Displacement               | 0 1 1 1 1 0 1 0 8-bit displacement                | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| Full Displacement                | 0 0 0 0 1 1 1 1 1 0 0 0 1 0 1 0 full displacement | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| JNP/JPO = Jump on Not Parity/P   | arity Odd                                         |                                                  |                                         |                                                  |                                         |
| 8-bit Displacement               | 0 1 1 1 1 0 1 1 8-bit displacement                | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| Full Displacement                | 0 0 0 0 1 1 1 1 1 0 0 0 1 0 1 1 full displacement | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
|                                  |                                                   |                                                  |                                         |                                                  |                                         |
|                                  |                                                   | 1                                                | 1                                       | 1                                                | 1                                       |

|                                       |                                                   | Clock Count                                      |                                         | Not                                              | <b>8</b> 5                              |
|---------------------------------------|---------------------------------------------------|--------------------------------------------------|-----------------------------------------|--------------------------------------------------|-----------------------------------------|
| Instruction                           | Format                                            | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode |
| CONDITIONAL JUMPS (continued)         |                                                   |                                                  |                                         |                                                  |                                         |
| JL/JNGE = Jump on Less/Not Greater or | Equal                                             |                                                  |                                         |                                                  |                                         |
| 8-bit Displacement                    | 0 1 1 1 1 1 0 0 8-bit displacement                | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| Full Displacement                     | 0 0 0 0 1 1 1 1 1 0 0 0 1 1 0 0 full displacement | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| JNL/JGE = Jump on Net Less/Greater or | Equal                                             |                                                  |                                         |                                                  |                                         |
| 8-bit Displacement                    | 0 1 1 1 1 0 1 8-bit displacement                  | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| Full Displacement                     | 0 0 0 0 1 1 1 1 1 0 0 0 1 1 0 1 full displacement | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| JLE/JNG = Jump on Less or Equal/Not G | reater                                            |                                                  |                                         |                                                  |                                         |
| 8-bit Displacement                    | 0 1 1 1 1 1 0 8-bit displacement                  | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| Full Displacement                     | 0 0 0 0 1 1 1 1 1 0 0 0 1 1 1 0 full displacement | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| JNLE/JG = Jump on Not Less or Equal/G | reator                                            |                                                  |                                         |                                                  |                                         |
| 8-bit Displacement                    | 0 1 1 1 1 1 1 1 8-bit displacement                | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| Full Displacement                     | 0 0 0 0 1 1 1 1 1 0 0 0 1 1 1 1 full displacement | 7 + m or 3                                       | 7 + m or 3                              |                                                  | r                                       |
| JCXZ=Jump on CX Zero*                 | 1 1 1 0 0 0 1 1 8-bit displacement                | 9+m or 5                                         | 9+m or 5                                |                                                  | r                                       |
| JECXZ = Jump on ECX Zero              | 1 1 1 0 0 0 1 1 8-bit displacement                | 9+m or 5                                         | 9 + m or 5                              |                                                  | r                                       |
| LOOP = Loop CX Times                  | 1 1 1 0 0 0 1 0 8-bit displacement                | 11+m                                             | 11+m                                    |                                                  | r                                       |
| LOOPZ/LOOPE = Loop with Zero/Equal    | 1 1 1 0 0 0 0 1 8-bit displacement                | 11+m                                             | 11+m                                    |                                                  | r                                       |
| LOOPNZ/LOOPNE = Loop while Not Zero   | 1 1 1 0 0 0 0 0 8-bit displacement                | 11 + m                                           | 11+m                                    |                                                  | r                                       |
| CONDITIONAL BYTE SET (Note: Times A   | tre Register/Memory)                              |                                                  |                                         |                                                  |                                         |
| SETO = Set Byte on Overflow           |                                                   |                                                  |                                         |                                                  |                                         |
| To Register/Memory                    | 0 0 0 0 1 1 1 1 1 0 0 1 0 0 0 0 mod 0 0 0 r/m     | 4/5*                                             | 4/5*                                    |                                                  | h                                       |
| SETNO≖Set Byte on Not Overflow        |                                                   |                                                  |                                         |                                                  |                                         |
| To Register/Memory                    | 0 0 0 0 1 1 1 1 1 0 0 1 0 0 0 1 mod 0 0 0 r/m     | 4/5*                                             | 4/5*                                    |                                                  | h                                       |
| SETB/SETNAE = Set Byte on Below/Not J | Above or Equal                                    |                                                  |                                         |                                                  |                                         |
| To Register/Memory                    | 0 0 0 0 1 1 1 1 1 0 0 1 0 0 1 0 mod 0 0 0 r/m     | 4/5*                                             | 4/5°                                    |                                                  | h                                       |
| SETNB = Set Byte on Not Below/Above o | r Equal                                           |                                                  |                                         |                                                  |                                         |
| To Register/Memory                    | 0 0 0 0 1 1 1 1 1 0 0 1 0 0 1 1 mod 0 0 0 r/m     | 4/5*                                             | 4/5*                                    |                                                  | h                                       |
| SETE/SETZ = Set Byte on Equal/Zero    |                                                   |                                                  |                                         |                                                  |                                         |
| To Register/Memory                    | 0 0 0 0 1 1 1 1 1 0 0 1 0 1 0 0 mod 0 0 0 r/m     | 4/5*                                             | 4/5*                                    |                                                  | h                                       |
| SETNE/SETNZ = Set Byte on Not Equal/N | ot Zero                                           |                                                  |                                         |                                                  |                                         |
| To Register/Memory                    | 0 0 0 0 1 1 1 1 1 0 0 1 0 1 0 1 0 mod 0 0 0 r/m   | 4/5*                                             | 4/5*                                    |                                                  | h                                       |
|                                       |                                                   |                                                  |                                         |                                                  |                                         |

\* Address Size Prefix differentiates JCXZ from JECXZ

|                                          |                                                  |                                                  | Clock Count                             |                                                  | les                                     |
|------------------------------------------|--------------------------------------------------|--------------------------------------------------|-----------------------------------------|--------------------------------------------------|-----------------------------------------|
| Instruction                              | Format                                           | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode |
| CONDITIONAL BYTE SET (continued)         |                                                  |                                                  |                                         |                                                  |                                         |
| SETBE/SETNA = Set Byte on Below or Equ   | al/Not Above                                     |                                                  |                                         |                                                  |                                         |
| To Register/Memory                       | 0 0 0 0 1 1 1 1 1 0 0 1 0 1 1 0 mod 0 0 0 r/m    | 4/5*                                             | 4/5*                                    |                                                  | h                                       |
| SETNBE/SETA = Set Byte on Not Below or   | Equal/Above                                      |                                                  |                                         |                                                  |                                         |
| To Register/Memory                       | 0 0 0 0 1 1 1 1 1 0 0 1 0 1 1 1 mod 0 0 0 r/m    | 4/5*                                             | 4/5*                                    |                                                  | h                                       |
| SETS = Set Byte on Sign                  |                                                  |                                                  |                                         |                                                  |                                         |
| To Register/Memory                       | 0 0 0 0 1 1 1 1 1 0 0 1 1 0 0 0 mod 0 0 0 r/m    | 4/5*                                             | 4/5*                                    |                                                  | h                                       |
| SETNS = Set Byte on Not Sign             |                                                  |                                                  |                                         |                                                  |                                         |
| To Register/Memory                       | 00001111110011001 mod 000 r/m                    | 4/5*                                             | 4/5*                                    |                                                  | h                                       |
| SETP/SETPE = Set Byte on Parity/Parity E |                                                  |                                                  |                                         |                                                  |                                         |
| To Register/Memory                       | 0 0 0 0 1 1 1 1 1 0 0 1 1 0 1 0 mod 0 0 0 r/m    | 4/5*                                             | 4/5*                                    |                                                  | h                                       |
| SETNP/SETPO = Set Byte on Not Parity/Pa  |                                                  |                                                  |                                         |                                                  |                                         |
| To Register/Memory                       | 0 0 0 0 1 1 1 1 1 0 0 1 1 0 1 1 mod 0 0 0 r/m    | 4/5*                                             | 4/5*                                    |                                                  | h                                       |
| SETL/SETNGE = Set Byte on Less/Not Gre   |                                                  |                                                  |                                         |                                                  |                                         |
| To Register/Memory                       | · · · · · · · · · · · · · · · · · · ·            | 4/5*                                             | 4/5*                                    |                                                  | h                                       |
| SETNL/SETGE = Set Byte on Not Less/Gre   |                                                  | 4/3                                              | 4/5                                     |                                                  |                                         |
| -                                        | ·                                                | 4/5*                                             | 4/5*                                    |                                                  |                                         |
| To Register/Memory                       | 0 0 0 0 1 1 1 1 0 1 1 1 1 0 1 mod 0 0 0 r/m      | 4/5                                              | 4/5                                     |                                                  | h                                       |
| SETLE/SETNG = Set Byte on Less or Equa   |                                                  |                                                  |                                         |                                                  |                                         |
| To Register/Memory                       | 0 0 0 0 1 1 1 1 1 0 0 1 1 1 1 0 mod 0 0 0 r/m    | 4/5*                                             | 4/5*                                    |                                                  | h                                       |
| SETNLE/SETG = Set Byte on Not Less or I  |                                                  |                                                  |                                         |                                                  |                                         |
| To Register/Memory                       | 0 0 0 0 1 1 1 1 1 0 0 1 1 1 1 1 mod 0 0 0 r/m    | 4/5*                                             | 4/5*                                    |                                                  | h                                       |
| ENTER = Enter Procedure<br>L = 0         | 1 1 0 0 1 0 0 0 16-bit displacement, 8-bit level | 10                                               | 10                                      | ь                                                | h                                       |
| L=1                                      |                                                  | 14                                               | 14                                      | b                                                | h                                       |
| L > 1<br>LEAVE = Leave Procedure         |                                                  | 17+8 (n-1)                                       | 17+8 (n-1)                              | b                                                | h                                       |
| INTERRUPT INSTRUCTIONS                   | 1 1 0 0 1 0 0 1                                  | 4                                                | 4                                       | b                                                | h                                       |
| INT = Interrupt:                         |                                                  |                                                  |                                         |                                                  |                                         |
| Type Specified                           |                                                  |                                                  |                                         |                                                  |                                         |
| Туре 3                                   | 1 1 0 0 1 1 0 1 type                             | 37                                               |                                         | b                                                |                                         |
| INTO = Interrupt 4 if Overflow Flag Set  | 1 1 0 0 1 1 0 0                                  | 33                                               |                                         | b                                                |                                         |
| If OF = 1                                | 1 1 0 0 1 1 1 0                                  | 05                                               |                                         |                                                  |                                         |
| If OF =0                                 |                                                  | 35<br>3                                          | 3                                       | b,e<br>b,e                                       |                                         |
|                                          |                                                  |                                                  |                                         |                                                  |                                         |

<sup>\*</sup> If CPL≤IOPL \*\* If CPL>IOPL

|                                                          |                                          | Clock                                            | Count                                   | Not                                              | les                                     |
|----------------------------------------------------------|------------------------------------------|--------------------------------------------------|-----------------------------------------|--------------------------------------------------|-----------------------------------------|
| nstruction                                               | Format                                   | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode |
| NTERRUPT INSTRUCTIONS (continue                          | ad)                                      |                                                  |                                         |                                                  |                                         |
| NT = Interrupt:                                          |                                          |                                                  |                                         |                                                  |                                         |
| ype Specified                                            |                                          |                                                  |                                         |                                                  |                                         |
| уре 3                                                    |                                          |                                                  |                                         |                                                  |                                         |
| Bound=Interrupt 5 if Detected Value (<br>If Out of Range | Dut of Range 0 1 1 0 0 0 1 0 mod reg r/m | 44                                               |                                         | b, e                                             | e,g,h,j,k,i                             |
| If In Range                                              |                                          | 10                                               | 10                                      | b,e                                              | e,g,h,j,k,i                             |
| Protected Mode Only (INT)                                |                                          |                                                  |                                         |                                                  |                                         |
| INT: Type Specified                                      |                                          |                                                  |                                         |                                                  |                                         |
| Via Interrupt or Trap Gate to Same P                     | rivilege Level                           |                                                  |                                         | 1                                                |                                         |
| Via Interrupt or Trap Gate to Differen                   | -                                        |                                                  | 71                                      | 1                                                | g,j,k,r                                 |
| From 80286 Task to 80286 TSS via                         |                                          |                                                  | 111                                     |                                                  | g, j, k, r                              |
| From 80286 Task to Am386SXL CPL                          |                                          |                                                  | 438                                     |                                                  | g,j,k,r                                 |
| From 80286 Task to Virtual 8086 Mo                       |                                          |                                                  | 465                                     |                                                  | g, j, k, r                              |
| From Am386SXL CPU Task to 8028                           |                                          |                                                  | 382                                     |                                                  | g, j, k, r                              |
| From Am386SXL CPU Task to Am38                           |                                          |                                                  | 440                                     | 1                                                | g,j,k,r                                 |
| From Am386SXL CPU Task to Virtua                         |                                          | 1                                                | 467<br>384                              | 1                                                | g,j,k,r<br>g,j,k,r                      |
| From Virtual 8086 Mode to 80286 TS                       |                                          |                                                  | 445                                     |                                                  |                                         |
| From Virtual 8086 Mode to Am386S)                        |                                          | 1                                                | 445                                     |                                                  | g, j, k, r                              |
| From Virtual 8086 Mode to Privilege                      | Level 0 via Trap Gate or Interrupt Gate  |                                                  | 275                                     |                                                  | g,j,k,r<br>g,j,k,r                      |
| INT: Type 3                                              |                                          |                                                  |                                         |                                                  |                                         |
| Via Interrupt or Trap Gate to Same P                     | rivilege Level                           |                                                  |                                         |                                                  |                                         |
| Via Interrupt or Trap Gate to Differen                   | •                                        |                                                  | 71                                      |                                                  | g, j, k, r                              |
| From 80286 Task to 80286 TSS via                         |                                          |                                                  | 111                                     |                                                  | g, j, k, r                              |
| From 80286 Task to Am386SXL CPU                          |                                          |                                                  | 382                                     |                                                  | g,j,k,r                                 |
| From 80286 Task to Virtual 8086 Mo                       |                                          | ļ                                                | 409                                     |                                                  | g, j, k, r                              |
| From Am386SXL CPU Task to 8028                           |                                          |                                                  | 326                                     |                                                  | g, j, k, r                              |
| From Am386SXL CPU Task to Am38                           |                                          |                                                  | 384                                     |                                                  | g, j, k, r                              |
| From Am386SXL CPU Task to Virtua                         |                                          |                                                  | 411                                     | ļ                                                | g, j, k, r                              |
| From Virtual 8086 Mode to 80286 TS                       | S via Task Gate                          |                                                  | 328                                     |                                                  | g, j, k, r                              |
| From Virtual 8086 Mode to Am386S)                        | (L CPU TSS via Task Gate                 |                                                  | 389                                     |                                                  | g, j, k, r                              |
| From Virtual 8086 Mode to Privilege                      | Level 0 via Trap Gate or Interrupt Gate  |                                                  | 416<br>223                              |                                                  | g, j, k, r<br>g, j, k, r                |
| INTO                                                     |                                          |                                                  |                                         |                                                  |                                         |
| Via Interrupt or Trap Gate to Same P                     | -                                        |                                                  |                                         |                                                  |                                         |
| Via Interrupt or Trap Gate to Differen                   | -                                        | 1                                                | 71                                      | 1                                                | g, j, k, r                              |
| From 80286 Task to 80286 TSS via                         |                                          |                                                  | 111                                     | 1                                                | g, j, k, r                              |
| From 80286 Task to Am386SXL CPU                          |                                          |                                                  | 384                                     |                                                  | g, j, k, r                              |
| From 80286 Task to Virtual 8086 Mo                       |                                          |                                                  | 411                                     |                                                  | g, j, k, r                              |
| From Am386SXL CPU Task to 8028                           |                                          |                                                  | 328                                     | 1                                                | g, j, k, r                              |
| From Am386SXL CPU Task to Am38                           |                                          |                                                  | Am386DX<br>413                          |                                                  | g,j,k,r                                 |
| From Am386SXL CPU Task to Virtua                         |                                          |                                                  | 329                                     |                                                  | g,j,k,r                                 |
| From Virtual 8086 Mode to 80286 TS                       |                                          |                                                  | 329<br>391                              |                                                  | g,j,k,r                                 |
| From Virtual 8086 Mode to Am386S)                        |                                          |                                                  | 418                                     |                                                  | g, j, k, r<br>g, j, k, r                |
| From Virtual 8086 Mode to Privilege                      | Level 0 via Trap Gate or Interrupt Gate  |                                                  | 223                                     |                                                  | g, j, k, r                              |
| BOUND                                                    |                                          |                                                  |                                         |                                                  |                                         |
| Via Interrupt or Trap Gate to Same P                     | -                                        |                                                  |                                         | ]                                                |                                         |
| Via interrupt or Trap Gate to Differen                   |                                          |                                                  | 71                                      | 1                                                | g, j, k, r                              |
| From 80286 Task to 80286 TSS via                         |                                          |                                                  | 111                                     |                                                  | g,j,k,r                                 |
| From 80286 Task to Am386SXL CPU                          | JISS via Task Gate                       |                                                  | 358<br>388                              | 1                                                | g, j, k, r                              |
|                                                          |                                          | 1                                                | 300                                     |                                                  | g, j, k, r                              |

|                                                                            |                                                           | Clock                                            | Count                                   | No                                               | les                                     |
|----------------------------------------------------------------------------|-----------------------------------------------------------|--------------------------------------------------|-----------------------------------------|--------------------------------------------------|-----------------------------------------|
| Instruction                                                                | Format                                                    | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode |
| INTERRUPT INSTRUCTIONS (continue                                           | id)                                                       |                                                  |                                         |                                                  |                                         |
| BOUND (continued)                                                          |                                                           |                                                  |                                         |                                                  |                                         |
| From 80286 Task to Virtual 8086 Mod                                        | de via Task Gate                                          |                                                  | 335                                     |                                                  | g, j, k, r                              |
| From Am386SXL CPU Task to 80286                                            |                                                           |                                                  | 368                                     |                                                  | g, j, k, r                              |
| From Am386SXL CPU Task to Am38                                             |                                                           |                                                  | 398                                     |                                                  | g, j, k, r                              |
| From Am386SXL CPU Task to Virtua<br>From Virtual 8086 Mode to 80286 TS     |                                                           |                                                  | 347<br>368                              |                                                  | g,j,k,r                                 |
| From Virtual 8086 Mode to 80286 TS                                         |                                                           |                                                  | 398                                     |                                                  | g,j,k,r<br>g,j,k,r                      |
|                                                                            | evel 0 via Trap Gate or Interrupt Gate                    |                                                  | 223                                     |                                                  | g, j, k, r<br>g, j, k, r                |
| INTERRUPT RETURN                                                           |                                                           |                                                  |                                         |                                                  |                                         |
| IRET = Interrupt Return                                                    | 1 1 0 0 1 1 1 1                                           | 24                                               |                                         |                                                  | g,h,j,k,r                               |
| Protected Mode Only (IRET)                                                 |                                                           |                                                  |                                         |                                                  |                                         |
| Via Interrupt or Trap Gate to Same Pr                                      | rivilege Level (within Task)                              |                                                  | 42                                      | 1                                                | g,h,j,k,r                               |
| Via Interrupt or Trap Gate to Different                                    | Privilege Level (within Task)                             |                                                  | 86                                      |                                                  | g,h,j,k,r                               |
| From 80286 Task to 80286 TSS                                               | 1700                                                      |                                                  | 285                                     |                                                  | h, j, k, r                              |
| From 80286 Task to Am386SXL CPU                                            |                                                           |                                                  | 318<br>267                              |                                                  | h, j, k, r                              |
| From 80286 Task to Virtual 8086 Tas<br>From 80286 Task to Virtual 8086 Mod |                                                           |                                                  | 113                                     |                                                  | h, j, k, r<br>h. j. k. r                |
| From Am386SXL CPU Task to Virtua                                           |                                                           |                                                  | 324                                     |                                                  | h, j, k, r                              |
| From Am386SXL CPU Task to 80286                                            |                                                           |                                                  | 328                                     |                                                  | h, j, k, r                              |
| From Am386SXL CPU Task to Am38                                             | 6SXL CPU TSS                                              |                                                  | 377                                     |                                                  | h, j, k, r                              |
| From Am386SXL CPU Task to Virtua                                           | l 8086 Mode (within Task)                                 |                                                  | 113                                     |                                                  | h, j, k, r                              |
| PROCESSOR CONTROL                                                          |                                                           |                                                  |                                         |                                                  |                                         |
| HLT = Hait                                                                 | 1 1 1 1 0 1 0 0                                           | 5                                                | 5                                       |                                                  | ł                                       |
| MOV = Move To and From Control/Deb                                         | ug/Test Registers                                         |                                                  |                                         |                                                  |                                         |
| CR0/CR2/CR3 from Register                                                  | 0 0 0 0 1 1 1 1 0 0 1 0 0 1 0 1 1 eee reg                 | 10/4/5                                           | 10/4/5                                  |                                                  | 1                                       |
| Register from CR3-CR0                                                      | 0 0 0 0 1 1 1 1 0 0 1 0 0 0 0 0 1 1 eee reg               | 5                                                | 6                                       |                                                  | 1                                       |
| DR3-DR0 from Register                                                      | 0 0 0 0 1 1 1 1 0 0 1 0 0 0 1 1 1 1 eee reg               | 22                                               | 22                                      |                                                  | 1                                       |
| DR7-DR6 from Register                                                      | 0 0 0 0 1 1 1 1 0 0 1 0 0 0 1 1 1 1 eee reg               | 16                                               | 16                                      |                                                  | 1                                       |
| Register from DR7-DR6                                                      | 0 0 0 0 1 1 1 1 0 0 1 0 0 0 0 1 1 1 eee reg               | 14                                               | 14                                      |                                                  | 1                                       |
| Register from DR3-DR0                                                      | 0 0 0 0 1 1 1 1 0 0 1 0 0 0 0 1 1 1 eee reg               | 22                                               | 22                                      |                                                  | 1                                       |
| TR7-TR6 from Register                                                      | 0 0 0 0 1 1 1 1 0 0 1 0 0 1 1 0 1 1 eee reg               | 12                                               | 12                                      |                                                  | 1                                       |
| Register from TR7–TR6                                                      | 0 0 0 0 1 1 1 1 0 0 1 0 0 1 0 0 1 1 eee reg               | 12                                               | 12                                      |                                                  | 1                                       |
| NOP = No Operation                                                         | 1001000                                                   | 3                                                | 3                                       |                                                  |                                         |
| WAIT = Wait until BUSY pin is negated                                      | 10011011                                                  | 6                                                | 6                                       |                                                  |                                         |
| PROCESSOR EXTENSION INSTRUCTI                                              | IONS                                                      | See 387SXL                                       |                                         |                                                  |                                         |
| Processor Extension Escape                                                 | 1 1 0 1 1 T T T mod L L L r/m                             | Datasheet<br>for clock                           |                                         |                                                  | h                                       |
| PREFIX BYTES                                                               | TTT and LLL bits are op-code information for coprocessor. | counts                                           |                                         |                                                  |                                         |
| Address Size Prefix                                                        | 01100111                                                  | 0                                                | 0                                       |                                                  |                                         |
|                                                                            |                                                           |                                                  |                                         |                                                  |                                         |

|                                            |                                               | Clock                                            | Count                                   |                                                  | tes                                     |
|--------------------------------------------|-----------------------------------------------|--------------------------------------------------|-----------------------------------------|--------------------------------------------------|-----------------------------------------|
| Instruction                                | Format                                        | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode |
| PREFIX BYTES (continued)                   |                                               |                                                  |                                         |                                                  |                                         |
| LOCK = Bus Lock Prefix                     | 1 1 1 1 0 0 0 0                               | 0                                                | 0                                       |                                                  | m                                       |
| Operand Size Prefix                        | 0 1 1 0 0 1 1 0                               | 0                                                | 0                                       |                                                  |                                         |
| Segment Override Prefix                    |                                               |                                                  |                                         |                                                  |                                         |
| CS                                         | 00101110                                      | 0                                                | 0                                       |                                                  |                                         |
| DS                                         | 0 0 1 1 1 1 1 0                               | 0                                                | o                                       |                                                  |                                         |
| ES                                         | 00100110                                      | 0                                                | o                                       |                                                  |                                         |
| FS                                         | 01100100                                      | 0                                                | 0                                       |                                                  |                                         |
| GS                                         | 01100101                                      | 0                                                | 0                                       |                                                  |                                         |
| SS                                         | 00110110                                      | 0                                                | 0                                       |                                                  |                                         |
| PROTECTION CONTROL                         |                                               |                                                  |                                         |                                                  |                                         |
| ARPL = Adjust Requested Privilege Leve     | 1                                             |                                                  |                                         |                                                  |                                         |
| From Register/Memory                       | 0 1 1 0 0 0 1 1 mod reg r/m                   | N/A                                              | 20/21**                                 | a                                                | h                                       |
| LAR = Load Access Rights                   |                                               |                                                  |                                         |                                                  |                                         |
| From Register/Memory                       | 0 0 0 0 1 1 1 1 0 0 0 0 0 0 1 0 mod reg r/m   | N/A                                              | 15/16*                                  | a                                                | g, h, j, p                              |
| LGDT = Load Global Descriptor              |                                               |                                                  |                                         |                                                  |                                         |
| Table Register                             | 0 0 0 0 1 1 1 1 0 0 0 0 0 0 0 1 mod 0 1 0 r/m | 11*                                              | 11*                                     | b, c                                             | h, l                                    |
| LIDT = Load Interrupt Descriptor           |                                               |                                                  |                                         |                                                  |                                         |
| Table Register                             | 0 0 0 0 1 1 1 1 0 0 0 0 0 0 0 1 mod 0 1 1 r/m | 11*                                              | 11*                                     | b, c                                             | h, l                                    |
| LLDT = Load Local Descriptor               |                                               |                                                  |                                         |                                                  |                                         |
| Table Regiser to Register/Memory           | 0 0 0 0 1 1 1 1 0 0 0 0 0 0 0 0 mod 0 1 0 r/m | N/A                                              | 20/24*                                  | a                                                | g, h, j, l                              |
| LMSW = Load Machine Status Word            |                                               |                                                  |                                         |                                                  |                                         |
| From Register/Memory                       | 0 0 0 0 1 1 1 1 0 0 0 0 0 0 0 1 mod 1 1 0 r/m | 10/13                                            | 10/13 <b>*</b>                          | b, c                                             | h, I                                    |
| LSL = Load Segment Limit                   |                                               |                                                  |                                         |                                                  |                                         |
| From Register/Memory                       | 0 0 0 0 1 1 1 1 0 0 0 0 0 0 1 1 mod reg r/m   |                                                  |                                         |                                                  |                                         |
| Byte-Granular Limit<br>Page-Granular Limit |                                               | N/A<br>N/A                                       | 20/21*<br>25/26*                        | a<br>a                                           | g, h, j, p<br>g, h, j, p                |
| LTR = Load Task Register                   |                                               |                                                  |                                         |                                                  | 3 <i>"</i> , F                          |
| From Register/Memory                       | 0 0 0 0 1 1 1 1 0 0 0 0 0 0 0 0 mod 0 0 1 r/m | N/A                                              | 23/27*                                  | a                                                | g, h, j, l                              |
| SGDT = Store Global Descriptor             |                                               |                                                  |                                         |                                                  |                                         |
| Table Register                             | 0 0 0 0 1 1 1 1 0 0 0 0 0 0 0 1 mod 0 0 0 r/m | 9.                                               | 9*                                      | b, c                                             | h                                       |
| SIDT = Store Interrupt Descriptor          |                                               |                                                  |                                         |                                                  |                                         |
| Table Register                             | 0 0 0 0 1 1 1 1 0 0 0 0 0 0 0 1 mod 0 0 1 r/m | 9*                                               | 9*                                      | b, c                                             | h                                       |
|                                            |                                               | 1                                                |                                         | 1                                                |                                         |

\* If CPL≤IOPL \*\* If CPL>IOPL

|                                         |                                                 | Clock                                            | Count                                   | Not                                              | tes                                     |
|-----------------------------------------|-------------------------------------------------|--------------------------------------------------|-----------------------------------------|--------------------------------------------------|-----------------------------------------|
| Instruction                             | Format                                          | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode | Real<br>Address<br>Mode/<br>Virtual<br>8086 Mode | Protected<br>Virtual<br>Address<br>Mode |
| PROTECTION CONTROL (continued)          |                                                 |                                                  |                                         |                                                  |                                         |
| SLDT = Store Local Descriptor Table Reg | jister                                          |                                                  |                                         |                                                  |                                         |
| To Register/Memory                      | 0 0 0 0 1 1 1 1 0 0 0 0 0 0 0 0 mod 0 0 0 r/m   | N/A                                              | 2/2*                                    | a                                                | h                                       |
| SMSW = Store Machine Status Word        | 0 0 0 0 1 1 1 1 0 0 0 0 0 0 0 1 mod 1 0 0 r/m   | 2/2*                                             | 2/2*                                    | b, c                                             | h, l                                    |
| STR = Store Task Register               |                                                 |                                                  |                                         |                                                  |                                         |
| To Register/Memory                      | 0 0 0 0 1 1 1 1 0 0 0 0 0 0 0 0 0 mod 0 0 1 r/m | N/A                                              | 2/2*                                    | а                                                | h                                       |
| VERR = Verify Read Access               |                                                 |                                                  |                                         |                                                  |                                         |
| Register/Memory                         | 0 0 0 0 1 1 1 1 0 0 0 0 0 0 0 0 mod 1 0 0 r/m   | N/A                                              | 10/11*                                  | а                                                | g, h, j, p                              |
| VERW = Verify Write Access              | 00001111 0000000 mod 101 r/m                    | N/A                                              | 15/16*                                  | a                                                | g, h, j, p                              |
| • If CPL≤IOPL •• If CPL>IOPL            |                                                 |                                                  |                                         |                                                  |                                         |

#### Instruction Notes for Instruction Set Summary

#### Notes a through c apply to Real Address Mode only:

- a. This is a Protected Mode instruction. Attempted execution in Real Mode will result in Exception 6 (invalid op-code).
- b. Exception 13 fault (general protection) will occur in Real Mode if an operand reference is made that partially or fully extends beyond the maximum CS, DS, ES, FS, or GS limit (FFFFH). Exception 12 fault (stack segment limit violation or not present) will occur in Real Mode if an operand reference is made that partially or fully extends beyond the maximum SS limit.
- c. This instruction may be executed in Real Mode. In Real Mode, its purpose is primarily to initialize the CPU for Protected Mode.

#### Notes d through g apply to Real Address Mode and Protected Virtual Address Mode:

d. The Am386SXL CPU uses an early-out multiply algorithm. The actual number of clocks depends on the position of the most significant bit in the operand (multiplier).

Clock counts given are minimum to maximum. To calculate actual clocks use the following formula:

Actual Clock = if m < > 0, then max ( $[log_2 |m|]$ , 3) + b clocks; = if m = 0, then 3 + b clocks

In this formula, m is the multiplier, and

- b = 9 for register to register;
- b = 12 for memory to register;
- b = 10 for register with immediate to register;
- b = 11 for memory with immediate to register.
- e. An exception may occur, depending on the value of the operand.
- f. LOCK is automatically asserted, regardless of the presence or absence of the LOCK prefix.
- g. LOCK is asserted during descriptor table accesses.

#### Notes h through r apply to Protected Virtual Address Mode only:

- h. Exception 13 fault will occur if the memory operand in CS, DS, ES, FS, or GS cannot be used due to either a segment limit violation or an access rights violation. If a stack limit is violated, an Exception 12 occurs.
- For segment load operations, the CPL, RPL, and DPL must agree with the privilege rules to avoid an Exception 13 fault. The segment's descriptor must indicate "present" or Exception 11 (CS, DS, ES, FS, GS not present). If the SS register is loaded and a stack segment not present is detected, an Exception 12 occurs.
- j. All segment descriptor accesses in the GDT or LDT made by this instruction will automatically assert LOCK to maintain descriptor integrity in multiprocessor systems.
- k. JMP, CALL, INT, RET, and IRET instructions referring to another code segment will cause an Exception 13, if an applicable privilege rule is violated.
- I. An Exception 13 fault occurs if CPL is greater than 0 (0 is the most privileged level).
- m. An Exception 13 fault occurs if CPL is greater than IOPL.
- n. The IF bit of the flag register is not updated if CPL is greater than IOPL. The IOPL and VM fields of the flag register are updated only if CPL = 0.
- o. The PE bit of the MSW (CR0) cannot be reset by this instruction. Use MOV into CR0 if desiring to reset the PE bit.
- p. Any violation of privilege rules as applied to the selector operand does not cause a protection exception; rather, the zero flag is cleared.
- q. If the coprocessor's memory operand violates a segment limit or segment access rights, an Exception 13 fault will occur before the ESC instruction is executed. An Exception 12 fault will occur if the stack limit is violated by the operand's starting address.
- r. The destination of a JMP, CALL, INT, RET, or IRET must be in the defined limit of a code segment or an Exception 13 fault will occur.
- s/t. The instruction will execute in s clocks if CPL ≤ IOPL. If CPL > IOPL, the instruction will take t clock.

### Instruction Encoding

#### Overview

All instruction encodings are subsets of the general instruction format shown in the Am386SXL Instruction Set Clock Count Summary (pages 1-406 thru 1-420). Instructions consist of one or two primary op-code bytes, possibly an address specifier consisting of the mod r/m byte and scaled index byte, a displacement if required, and an immediate data field if required.

Within the primary op-code(s), smaller encoding fields may be defined. These fields vary according to the class of operation. The fields define such information as direction of the operation, size of the displacements, register encoding, or sign extension.

Almost all instructions referring to an operand in memory have an addressing mode byte following the primary op-code byte(s). This byte (mod r/m) specifies the address mode to be used. Certain encodings of the mod r/m byte indicate a second addressing byte (scale-index-base byte) follows the mod r/m byte to fully specify the addressing mode.

Addressing modes can include a displacement immediately following the mod r/m byte, or scaled index byte. If a displacement is present, the possible sizes are 8, 16, or 32 bits.

If the instruction specifies an immediate operand, the immediate operand follows any displacement bytes. The immediate operand, if specified, is always the last field of the instruction.

Figure 56 illustrates several of the fields that can appear in an instruction, such as the mod field and the r/m field,

but Figure 56 does not show all fields. Several smaller fields also appear in certain instructions, sometimes within the op-code bytes themselves. Table 22 is a complete list of all fields appearing in the Instruction Set. Further ahead, following Table 22, are detailed tables for each field.

#### 32-Bit Extensions of the Instruction Set

With the Am386SXL CPU, the 8086/80186/80286 Instruction Set is extended in two orthogonal directions: 32-bit forms of all 16-bit instructions are added to support the 32-bit data types; and, 32-bit addressing modes are made available for all instructions referencing memory. This orthogonal instruction set extension is accomplished having a Default (D) bit in the code segment descriptor, and by having 2 prefixes to the instruction set.

Whether the instruction defaults to operations of 16 bits or 32 bits depends on the setting of the D bit in the code segment descriptor, which gives the default length (either 32 bits or 16 bits) for both operands and effective addresses, when executing that code segment. In the Real Address Mode or Virtual 8086 Mode, no code segment descriptors are used, but a D value of 0 is assumed internally by the Am386SXL CPU when operating in those modes (for 16-bit default sizes compatible with the 8086/80C186/80286).

Two prefixes, the Operand Size Prefix and the Effective Address Size Prefix, allow overriding individually the Default selection of operand size and effective address size. These prefixes may precede any op-code bytes and affect only the instruction they precede. If necessary, one or both of the prefixes may be placed

| Field Name | Description                                                                         | Number of Bits       |
|------------|-------------------------------------------------------------------------------------|----------------------|
| w          | Specifies if data is byte or full size (full size is either 16 or 32 bits)          | 1                    |
| d          | Specifies direction of data operation                                               | 1                    |
| s          | Specifies if an immediate data field must be sign-extended                          | 1                    |
| reg        | General Register Specifier                                                          | 3                    |
| mod r/m    | Address Mode Specifier (effective address can be a General Register)                | 2 for mod; 3 for r/n |
| SS         | Scale Factor for Scaled Index Address Mode                                          | 2                    |
| index      | General Register to be used as Index Register                                       | 3                    |
| base       | General Register to be used as Base Register                                        | 3                    |
| sreg2      | Segment Register Specifier for CS, SS, DS, and ES                                   | 2                    |
| sreg3      | Segment Register Specifier for CS, SS, DS, ES, FS, and GS                           | 3                    |
| tttn       | For Conditional Instructions, specifies a condition asserted or a condition negated | 4                    |

Table 22 Fields within Instructions

Note: Table 21 shows encoding of individual instructions.



before the op-code bytes. The presence of the Operand Size Prefix and the Effective Address Prefix will toggle the operand size or the effective address size, respectively, to the value opposite from the Default setting. For example, if the default operand size is for 32-bit data operations, then presence of the Operand Size Prefix toggles the instruction to 16-bit data operation. As another example, if the default effective address size is 16 bits, presence of the Effective Address Size prefix toggles the instruction to use 32-bit effective address computations.

These 32-bit extensions are available in all modes, including the Real Address Mode and the Virtual 8086 Mode. In these modes the default is always 16 bits, so prefixes are needed to specify 32-bit operands or addresses. For instructions with more than one prefix, the order of prefixes is unimportant.

Unless specified otherwise, instructions with 8-bit and 16-bit operands do not affect the contents of the high-order of the extended registers.

### **Encoding of Instruction Fields**

Within the instruction are several fields indicating register selection, addressing mode and so on. The exact encodings of these fields are defined immediately ahead.

### Encoding of Operand Length (w) Field

For any given instruction performing a data operation, the instruction is executing as a 32-bit operation or a 16-bit operation. Within the constraints of the operation size, the w field encodes the operand size as either one byte or the full operation size, as shown in the table below.

| w Field | Operand Size<br>During 16-Bit<br>Data Operations | Operand Size<br>During 32-Bit<br>Data Operations |
|---------|--------------------------------------------------|--------------------------------------------------|
| 0       | 8 Bits                                           | 8 Bits                                           |
| 1       | 16 Bits                                          | 32 Bits                                          |

### Encoding of the General Register (reg) Field

The general register is specified by the reg field, which may appear in the primary op-code bytes, or as the reg field of the mod r/m byte, or as the r/m field of the mod r/m byte.

#### Encoding of reg Field When w Field is not Present in Instruction

| reg Field | Register Selected<br>During 16-Bit<br>Data Operations | Register Selected<br>During 32-Bit<br>Data Operations |
|-----------|-------------------------------------------------------|-------------------------------------------------------|
| 000       | AX                                                    | EAX                                                   |
| 001       | СХ                                                    | ECX                                                   |
| 010       | DX                                                    | EDX                                                   |
| 011       | BX                                                    | EBX                                                   |
| 100       | SP                                                    | ESP                                                   |
| 101       | BP                                                    | EBP                                                   |
| 101       | SI                                                    | ESI                                                   |
| 101       | DI                                                    | EDI                                                   |

#### Encoding of reg Field When w Field is Present in Instruction

|     | Register Specified by<br>During 16-Bit Data Op |              |
|-----|------------------------------------------------|--------------|
|     | Function of w Field                            |              |
| reg | (when w = 0)                                   | (when w = 1) |
| 000 | AL                                             | AX           |
| 001 | CL                                             | сх           |
| 010 | DL                                             | DX           |
| 011 | BL                                             | BX           |
| 100 | AH                                             | SP           |
| 101 | СН                                             | BP           |
| 110 | DH                                             | SI           |
| 111 | ВН                                             | DI           |

|     | Register Specified by<br>During 32-Bit Data Op |              |  |
|-----|------------------------------------------------|--------------|--|
|     | Function of w Field                            |              |  |
| reg | (when w = 0)                                   | (when w = 1) |  |
| 000 | AL                                             | EAX          |  |
| 001 | CL                                             | ECX          |  |
| 010 | DL                                             | EDX          |  |
| 011 | BL                                             | EBX          |  |
| 100 | AH                                             | ESP          |  |
| 101 | СН                                             | EBP          |  |
| 110 | DH                                             | ESI          |  |
| 111 | BH                                             | EDI          |  |

### Encoding of the Segment Register (sreg) Field

The sreg field in certain instructions is a 2-bit field, allowing one of the four 80286 segment registers to be specified. The sreg field in other instructions is a 3-bit field, allowing the Am386SXL CPU FS and GS segment registers to be specified.

### 2-Bit sreg2 Field

| 2-Bit sreg2 Field | Segment Register Selected |
|-------------------|---------------------------|
| 00                | ES                        |
| 01                | CS                        |
| 10                | SS                        |
| 11                | DS                        |

### 3-Bit sreg3 Field

| 3-Bit sreg3 Field | Segment Register Selected |
|-------------------|---------------------------|
| 000               | ES                        |
| 001               | CS                        |
| 010               | SS                        |
| 011               | DS                        |
| 100               | FS                        |
| 101               | GS                        |
| 110               | do not use                |
| 111               | do not use                |

#### Encoding of Address Mode

Except for special instructions, such as PUSH or POP, where the addressing mode is predetermined, the addressing mode for the current instruction is specified by addressing bytes following the primary op-code. The primary addressing byte is the mod r/m byte, and a second byte of addressing information, the s-i-b (scale-index-base) byte, can be specified.

The s-i-b byte is specified when using 32-bit addressing mode, the mod r/m byte has r/m = 100, and mod = 00, 01, or 10. When the s-i-b byte is present, the 32-bit addressing mode is a function of the mod, ss, index, and base fields.

The primary addressing byte, the mod r/m byte, also contains three bits (shown as TTT in Figure 56)

sometimes used as an extension of the primary opcode. The three bits, however, may also be used as a register field (reg).

When calculating an effective address, either 16-bit addressing or 32-bit addressing is used. 16-bit addressing uses 16-bit address components to calculate the effective address, while 32-bit addressing uses 32-bit address components to calculate the effective address. When 16-bit addressing is used, the mod r/m byte is interpreted as a 16-bit addressing mode specifier. When 32-bit addressing is used, the mod r/m byte is interpreted as a 32-bit addressing mode specifier.

Tables on the following pages define all encodings of all 16-bit addressing modes and 32-bit addressing modes.

| mod r/m | Effective Address |
|---------|-------------------|
| 00 000  | DS:[BX + SI]      |
| 00 001  | DS:[BX + DI]      |
| 00 010  | SS:[BP + SI]      |
| 00 011  | DS:[BP + DI]      |
| 00 100  | DS:[SI]           |
| 00 101  | DS:[DI]           |
| 00 110  | DS:d16            |
| 00 111  | DS:[BX]           |
|         |                   |
| 01 000  | DS:[BX + SI + d8] |
| 01 001  | DS:[BX + DI + d8] |
| 01 010  | SS:[BP + SI + d8] |
| 01 011  | SS:[BP + DI + d8] |
| 01 100  | DS:[SI + d8]      |
| 01 101  | DS:[DI + d8]      |
| 01 110  | SS:[BP + d8]      |
| 01 111  | DS:[BX + d8]      |

Encoding of 16-Bit Address Mode with mod r/m Byte

| mod r/m | Effective Address  |
|---------|--------------------|
| 10 000  | DS:[BX + SI + d16] |
| 10 001  | DS:[BX + DI + d16] |
| 10 010  | SS:[BP + SI + d16] |
| 10 011  | SS:[BP+SI+d16]     |
| 10 100  | DS:[SI + d16]      |
| 10 101  | DS:[DI + d16]      |
| 10 110  | SS:[BP + d16]      |
| 10 111  | DS:[BX + d16]      |
|         |                    |
| 11 000  | Register—See Below |
| 11 001  | Register—See Below |
| 11 010  | Register—See Below |
| 11 011  | Register—See Below |
| 11 100  | Register—See Below |
| 11 101  | RegisterSee Below  |
| 11 110  | Register—See Below |
| 11 111  | Register—See Below |

| Register Specified by r/m<br>During 16-Bit Data Operations |              |                     |  |
|------------------------------------------------------------|--------------|---------------------|--|
|                                                            | Function     | Function of w Field |  |
| mod r/m                                                    | (when w = 0) | (when w = 1)        |  |
| 11 000                                                     | AL           | AX                  |  |
| 11 001                                                     | CL           | CX CX               |  |
| 11 010                                                     | DL           | DX                  |  |
| 11 011                                                     | BL           | BX                  |  |
| 11 100                                                     | AH           | SP                  |  |
| 11 101                                                     | СН           | BP                  |  |
| 11 110                                                     | DH           | SI                  |  |
| 11 111                                                     | ВН           | DI                  |  |

| Register Specified by r/m<br>During 32-Bit Data Operations |                     |              |
|------------------------------------------------------------|---------------------|--------------|
|                                                            | Function of w Field |              |
| mod r/m                                                    | (when w = 0)        | (when w = 1) |
| 11 000                                                     | AL                  | EAX          |
| 11 001                                                     | CL                  | ECX          |
| 11 010                                                     | DL                  | EDX          |
| 11 011                                                     | BL                  | EBX          |
| 11 100                                                     | AH                  | ESP          |
| 11 101                                                     | СН                  | EBP          |
| 11 110                                                     | DH                  | ESI          |
| 11 111                                                     | BH                  | EDI          |

## Encoding of 32-Bit Address Mode with mod r/m Byte (no s-i-b byte present)

| mod r/m | Effective Address |   |
|---------|-------------------|---|
| 00 000  | DS:[EAX]          |   |
| 00 001  | DS:[ECX]          |   |
| 00 010  | DS:[EDX]          |   |
| 00 011  | DS:[EBX]          |   |
| 00 100  | s-i-b is present  |   |
| 00 101  | DS:d32            |   |
| 00 110  | DS:[ESI]          |   |
| 00 111  | DS:[EDI]          |   |
|         |                   |   |
| 01 000  | DS:[EAX + d8]     | 1 |
| 01 001  | DS:[ECX + d8]     |   |
| 01 010  | DS:[EDX + d8]     |   |
| 01 011  | DS:[EBX + d8]     |   |
| 01 100  | s-i-b is present  |   |
| 01 101  | SS:[EBP + d8]     |   |
| 01 110  | DS:[ESI + d8]     | 1 |
| 01 111  | DS:[EDI + d8]     |   |

| mod r/m | Effective Address  |
|---------|--------------------|
| 10 000  | DS:[EAX + d32]     |
| 10 001  | DS:[ECX + d32]     |
| 10 010  | DS:[EDX + d32]     |
| 10 011  | DS:[EBX + d32]     |
| 10 100  | s-i-b is present   |
| 10 101  | SS:[EBP + d32]     |
| 10 110  | DS:[ESI + d32]     |
| 10 111  | DS:[EDI + d32]     |
|         |                    |
| 11 000  | Register—See Below |
| 11 001  | Register—See Below |
| 11 010  | Register—See Below |
| 11 011  | Register—See Below |
| 11 100  | Register—See Below |
| 11 101  | Register—See Below |
| 11 110  | Register—See Below |
| 11 111  | Register—See Below |

| Register Specified by reg or r/m<br>During 16-Bit Data Operations |              |                     |  |
|-------------------------------------------------------------------|--------------|---------------------|--|
|                                                                   | Function     | Function of w Field |  |
| mod r/m                                                           | (when w = 0) | (when w = 1)        |  |
| 11 000                                                            | AL           | AX                  |  |
| 11 001                                                            | CL           | СХ                  |  |
| 11 010                                                            | DL           | DX                  |  |
| 11 011                                                            | BL           | BX                  |  |
| 11 100                                                            | AH           | SP                  |  |
| 11 101                                                            | СН           | BP                  |  |
| 11 110                                                            | DH           | SI                  |  |
| 11 111                                                            | BH           | DI                  |  |

| Register Specified by reg or r/m<br>During 32-Bit Data Operations |                     |              |
|-------------------------------------------------------------------|---------------------|--------------|
|                                                                   | Function of w Field |              |
| mod r/m                                                           | (when w = 0)        | (when w = 1) |
| 11 000                                                            | AL                  | EAX          |
| 11 001                                                            | CL                  | ECX          |
| 11 010                                                            | DL                  | EDX          |
| 11 011                                                            | BL                  | EBX          |
| 11 100                                                            | AH                  | ESP          |
| 11 101                                                            | СН                  | EBP          |
| 11 110                                                            | DH                  | ESI          |
| 11 111                                                            | BH                  | EDI          |



| mod base | Effective Address               |
|----------|---------------------------------|
| 00 000   | DS:[EAX + (scaled index)]       |
| 00 001   | DS:[ECX + (scaled index)]       |
| 00 010   | DS:[EDX + (scaled index)]       |
| 00 011   | DS:[EBX + (scaled index)]       |
| 00 100   | SS:[ESP + (scaled index)]       |
| 00 101   | DS:[d32 + (scaled index)]       |
| 00 110   | DS:[ESI + (scaled index)]       |
| 00 111   | DS:[EDI + (scaled index)]       |
|          |                                 |
| 01 000   | DS:[EAX + (scaled index) + d8]  |
| 01 001   | DS:[ECX + (scaled index) + d8]  |
| 01 010   | DS:[EDX + (scaled index) + d8]  |
| 01 011   | DS:[EBX + (scaled index) + d8]  |
| 01 100   | SS:[ESP + (scaled index) + d8]  |
| 01 101   | SS:[EBP + (scaled index) + d8]  |
| 01 110   | DS:[ESI + (scaled index) + d8]  |
| 01 111   | DS:[EDI + (scaled index) + d8]  |
|          |                                 |
| 10 000   | DS:[EAX + (scaled index) + d32] |
| 10 001   | DS:[ECX + (scaled index) + d32] |
| 10 010   | DS:[EDX + (scaled index) + d32] |
| 10 011   | DS:[EBX + (scaled index) + d32] |
| 10 100   | SS:[ESP + (scaled index) + d32] |
| 10 101   | SS:[EBP + (scaled index) + d32] |
| 10 110   | DS:[ESI + (scaled index) + d32] |
| 10 111   | DS:[EDI + (scaled index) + d32] |

#### Encoding of 32-Bit Address Mode (mod r/m byte and s-i-b byte present):

| Note: Mod field in mod r/m byte; ss | index, and base fields in s-i-b byte |
|-------------------------------------|--------------------------------------|
|-------------------------------------|--------------------------------------|

| SS | Scale Factor |
|----|--------------|
| 00 | x1           |
| 01 | x2           |
| 10 | x4           |
| 11 | x8           |

| Index | Index Register          |
|-------|-------------------------|
| 000   | EAX                     |
| 001   | ECX                     |
| 010   | EDX                     |
| 011   | EBX                     |
| 100   | no index reg (see note) |
| 101   | EBP                     |
| 110   | ESI                     |
| 111   | EDI                     |

Note: When index field is 100, indicating no index register, then ss field must equal 00. If index is 100 and ss does not equal 00, the effective address is undefined.

## Encoding of Operation Direction (d) Field

In many two-operand instructions, the d field is present to indicate which operand is considered the source and which is the destination.

| d | Direction of Operation                                                                                                              |
|---|-------------------------------------------------------------------------------------------------------------------------------------|
| 0 | Register/Memory ← Register<br>reg Field indicates Source Operand;<br>mod r/m or mod ss index base indicates Destination<br>Operand. |
| 1 | Register ⇐ Register/Memory<br>reg Field indicates Destination Operand;<br>mod r/m or mod ss index base indicates Source<br>Operand. |

## Encoding of Sign-Extend (s) Field

The s field occurs primarily to instructions with immediate data fields. The s field has an effect only if the size of the immediate data is 8 bits and is being placed in a 16-bit or 32-bit destination.

| s | Effect on<br>Immediate Data8                                | Effect on<br>Immediate Data 16 32 |
|---|-------------------------------------------------------------|-----------------------------------|
| 0 | None                                                        | None                              |
| 1 | Sign-Extended Data8 to Fill<br>16-Bit or 32-Bit Destination | None                              |

## Encoding of Conditional Test (tttn) Field

For the conditional instructions (conditional jumps and set on condition), tttn is encoded with n indicating to use the condition (n = 0), or its negation (n = 1), and ttt giving the condition to test.

| Mnemonic | Condition                           | tttn |
|----------|-------------------------------------|------|
| 0        | Overflow                            | 0000 |
| NO       | No Overflow                         | 0001 |
| B/NAE    | Below/Not Above or Equal            | 0010 |
| NB/AE    | Not Below/Above or Equal            | 0011 |
| E/Z      | Equal/Zero                          | 0100 |
| NE/NZ    | Not Equal/Not Zero                  | 0101 |
| BE/NA    | Below or Equal/Not Above            | 0110 |
| NBE/A    | Not Below or Equal/Above            | 0111 |
| S        | Sign                                | 1000 |
| NS       | Not Sign                            | 1001 |
| P/PE     | Parity/Parity Even                  | 1010 |
| NP/PO    | No Parity/Parity Odd                | 1011 |
| L/NGE    | Less Than/Not Greater or Equal      | 1100 |
| NL/GE    | Not Less Than/Greater or Equal      | 1101 |
| LE/NG    | Less Than or Equal/Not Greater Than | 1110 |
| NLE/G    | Not Less Than or Equal/Greater Than | 1111 |

# Encoding of Control or Debug or Test Register (eee) Field

For the loading and storing of the Control, Debug, and Test registers.

#### When Interpreted as Control Register Field

| eee Code                      | Reg Name |
|-------------------------------|----------|
| 000                           | CR0      |
| 010                           | CR2      |
| 011                           | CR3      |
| Do not use any other encoding |          |

#### When Interpreted as Debug Register Field

| eee Code                      | Reg Name |  |  |  |  |
|-------------------------------|----------|--|--|--|--|
| 000                           | DR0      |  |  |  |  |
| 001                           | DR1      |  |  |  |  |
| 010                           | DR2      |  |  |  |  |
| 011                           | DR3      |  |  |  |  |
| 110                           | DR6      |  |  |  |  |
| 111                           | DR7      |  |  |  |  |
| Do not use any other encoding |          |  |  |  |  |

#### When Interpreted as Test Register Field

| eee Code   | Reg Name                      |  |  |  |  |  |  |
|------------|-------------------------------|--|--|--|--|--|--|
| 110        | TR6                           |  |  |  |  |  |  |
| 111        | TR7                           |  |  |  |  |  |  |
| Do not use | Do not use any other encoding |  |  |  |  |  |  |

# Am386™DXLV

High-Performance, Low-Voltage, 32-Bit Microprocessor

## DISTINCTIVE CHARACTERISTICS

- Operating voltage range 3.0 V to 5.5 V—Ideal for portable PC applications
  - -25 MHz operating frequency for 3.0 V to 5.5 V, 33 MHz operating frequency for 4.5 V to 5.5 V
  - -2X improvement in battery life over existing 5 V desians
  - -Wide range of chipsets and other logic available for 3 V systems with support for Standby Mode operation
  - -True static design for long battery life
  - ---Power consumption 85% lower than Intel i386DX, 65% lower than Am386DXL processor
  - -Performance on demand (0 to 33 MHz)
- SMM (System Management Mode) for system and power management
  - -SMI (System Management Interrupt) for power management independent of processor operating mode and operating system
  - ---SMI coupled with I/O instruction break feature provides transparent power off and auto resume of peripherals which may not be "power aware"

-SMI is non-maskable and has higher priority than NMI

Advanced Micro

Devices

- -Automatic save and restore of the microprocessor state
- -Wide range of chipsets supporting SMM available to allow product differentiation
- Ideal for desktop PCs
  - -Lower heat dissipation due to lower operating voltage allows elimination of fan
- "Float" input to facilitate system debug and test
- Compatible with 386DX systems and software
- Supports 387DX-compatible math coprocessors
- 132-pin PQFP package with optional protective ring for better lead coplanarity
- AMD® advanced 0.8 micron CMOS technology



## GENERAL DESCRIPTION

The Am386DXLV microprocessor is a low-voltage, true static implementation of the Intel i386DX microprocessor. The operating voltage range is 3.0 V to 5.5 V. The low-voltage operation makes it ideal for both desktop and battery-powered portable personal computers. For desktop PCs, low heat dissipation allows the system designers to remove or reduce the size and cost of the system cooling fan. The Am386DXLV microprocessor operates at a maximum speed of 25 MHz from 3.0 to 5.5 V and at a maximum speed of 33 MHz from 4.5 to 5.5 V.

The Am386DXLV microprocessor's lower operating voltage and true static design enables longer battery life and/or lower weight for portable applications. At 25 MHz, this device has 80% lower operating lcc than the Intel i386DX. Lowering typical operating voltage from 5.0 V to 3.3 V doubles the battery life. Standby Mode allows the Am386DXLV microprocessor to be clocked down to 0 MHz (DC) and retain full register contents. In Standby Mode, typical current draw is 0.01 mA,

a greater than 1000X reduction in power consumption versus the Intel i386DX or Intel i386SX.

The Am386DXLV processor is available in a small footprint 132-pin Plastic Quad Flat Pack (PQFP) package. This surface-mount package is 40% smaller than a PGA package, allowing smaller lower-cost board designs without the need for a socket.

Additionally, the Am386DXLV processors comes with SMM for system and power management. SMI is a nonmaskable, higher priority interrupt than NMI and has its own code space (1 Mb). SMI can be coupled with the I/O instruction break feature to implement transparent power management of peripherals. SMM can be used by system designers to implement system and power management code independent of the operating system or the Processor Mode.

The Am386DXLV processor incorporates a float pin that places all outputs in a three-state mode to facilitate board test and debug.



15021B-001

## FUNCTIONAL DESCRIPTION

## **Benefits of Lower Operating Voltage**

The Am386DXLV microprocessor has an operating voltage range of 3.0 V to 5.5 V. Low voltage allows for lower operating power consumption, longer battery life, and/or smaller batteries for notebook applications.

Because power is proportional to the square of voltage, reduction of the supply voltage from 5.0 V to 3.3 V reduces power consumption by 56%. This directly translates to a doubling of battery life for portable applications. Lower power consumption can also be used to reduce the size and weight of the battery. Thus, 3 V designs facilitate a reduction in the form factor. For desktop PCs, low power consumption means elimination of the cooling fan, thus reducing the size and noise of the PC.

A lower operating voltage results in a reduction of I/O voltage swings. This reduces noise generation providing a less hostile environment for board design. It also reduces electromagnetic radiation noise making it easier to obtain FCC approval.

#### SMM–System Management Mode

The Am386DXLV processor has a new System Management Mode (SMM) for system and power management. This mode consists of two features: System Management Interrupt (SMI) and I/O instruction break.

#### SMI–System Management Interrupt

SMI is implemented through the use of special bus interface pins. This interrupt method can be used to perform system management functions such as power management independent of Processor Operating Mode (Real, Protected, or Virtual 86 Modes).

SMI can also be invoked in software. This allows system software to communicate with SMI power management code. In addition, an instruction called UMOV allows data transfers between SMI and normal system memory spaces.

Activating the <u>SMI</u> pin invokes a sequence which saves the operating state of the processor into a separate SMM memory space, independent of the main system memory. After the state is saved, the processor is forced into Real Mode and begins execution at address FFFFFFF0h where a far jump to the SMM code is executed. This Real Mode code can perform its system management function and then resume execution of the normal system software by executing a special opcode sequence which will reload the saved processor state and continue execution in the main system memory space. See Figure 1 for a general flowchart of an SMM operation.



#### CPU Interface—Pin Functions

The CPU interface for SMM consists of three pins dedicated to the SMI function. One pin, <u>SMI</u>, is the new interrupt input. The other two pins, <u>SMIADS</u> and <u>SMIRDY</u>, provide the control signals necessary for the separate SMI Mode memory space.

#### SMM Operation

The execution of a System Management Interrupt has four distinct phases: the initiation of the interrupt via  $\overline{SMI}$ , a processor state save, execution of the SMM interrupt code, and a processor state restore (to resume normal operation).

## 

A System Management Interrupt is initiated by the driving of an active Low pulse on the SMI pin of at least four CLK2 periods. This pulse period will ensure recognition of the interrupt. The CPU will drive the SMI pin active after the completion of the current operation (active bus cycle, instruction execution, or both). The active drive of the pin by the CPU will be released at the end of the interrupt routine, following the last register read of the saved state.

An SMI cannot be masked off by the CPU, and it will always be recognized by the CPU, regardless of operating mode. This includes the Real, Protected, and Virtual 8086 Modes of the processor.

While the CPU is in SMI Mode, a bus hold request via the HOLD pin will be granted. The HLDA pin will go active after bus release and the SMIADS pin will float along with the other pins that normally float during a bus hold cycle.

## **Processor State Save**

The first set of SMM bus transfer cycles after the CPU's recognition of an active SMI will be the processor saving its state to an external RAM array in a separate address space from main system memory. This is accomplished by using the SMIADS and SMIRDY pins for initiation and termination of bus cycles, instead of the ADS and READY pins. The 32-bit addresses to which the CPU saves its state are 60000H–600C8h and 60100h–60124h. These are fixed address locations for each register saved.

The value of  $\overline{BS16}$  and  $\overline{NA}$  will be ignored during the state save, only full 32-bit, non-pipelined cycles are generated for the state save cycles. In a zero wait state memory implementation, it will take approximately 630 CLK2 cycles to complete the save state operation. There are 61 data transfer cycles.

## SMI Code Execution

After the processor state is saved to the separate SMM memory space, the execution of the SMI interrupt routine code begins. The processor enters Real Mode, sets most of the register values to "reset" values (those values normally seen after a CPU reset), and begins fetching code from address FFFFFF0h in the separate SMM memory space. Normally, the first thing the interrupt routine code will do is a FAR JUMP to the Real Mode entry point for the SMI interrupt routine, which is also in SMM memory space.

Any Real Mode interrupt routine code can be executed, with the obvious exception of normal interrupt routines (which are deferred). The SMM code can be located anywhere within the 1 Mb Real Mode address space, except where the processor state is saved. I/O cycles, as a result of the IN, OUT, INS, and OUTS instructions, will go to the normal address space, utilizing the normal ADS and READY bus interface signals. This facilitates power management code manipulating system hardware registers as needed through the standard I/O subsystem; a separate I/O space does not need to be implemented.

#### Processor State Restore (Resuming Normal Execution)

Returning to normal code execution in the main system memory, including restoring the Processor Operating Mode, is accomplished by executing a special code sequence. This code invokes a restore CPU state operation which reloads the CPU registers from the saved data in the RAM controlled by SMIADS and SMIRDY.

The ES:EDI register pair must point to physical address 60000h. Then the special opcode sequence 0Fh 07h should be executed to start the restore state operation. After completion of the restore state operation, the SMI pin will be deactivated by the CPU and normal code execution will continue at the point that it left off before the SMI occurred.

In a zero wait state memory implementation, it will take approximately 574 CLK2 cycles to complete the restore state operation. There are 61 data transfer cycles.

## Software Features

There are several features of the SMI function that provide support for special operations during the execution of the system's software. These features involve the execution of reserved opcodes to induce specific SMI related operations.

#### Software SMI Generation

Besides hardware initiation of the System Management Interrupt via the  $\overline{SMI}$  pin, there is also a software induced SMI mechanism. Generating a soft  $\overline{SMI}$  involves setting a control bit in Debug Register 7 (DR7) and executing a reserved opcode (0F1H).

The functional sequence of the software-based SMI is identical to the hardware-based SMI with the exception that the SMI pin is not initially driven active by an external source. Upon execution of a soft SMI opcode, the SMI pin is driven active (Low) by the processor before the save state operation begins.

## Memory Transfers to Main System Memory

While executing an SMI routine, the interrupt code can initiate memory data reads and writes to the main system memory using the normal ADS and READY pins. This is accomplished by using reserved opcodes that are special forms of the MOV instruction (called UMOV). The UMOV opcodes can move byte, word, or doubleword register operands to or from main system memory. Multiple data transfers using the normal ADS and READY pins will occur if the operands are misaligned relative to the effective address used. The UMOV opcodes are 0F10h, 0F11h, 0F12h, and 0F13h.

The UMOV instruction can use any of the 386 addressing modes, as specified in the ModR/M byte of the opcode. Note that the 16- and 32-bit versions are the same opcodes with the exception of the 066h operand size prefix. The  $\overline{BS16}$  line is recognized during the normal memory space data transfer(s) initiated by these instructions.

## I/O Instruction Break

The Am386DXLV processor has an I/O instruction break feature that allows the system logic to implement I/O trapping for peripheral devices. To enable the I/O instruction break feature, IIBEN must first be asserted active Low. On detecting an I/O instruction, the processor will prevent the execution unit from executing further instructions until READY is driven active Low by the system. Once READY is driven active, the execution unit will either immediately respond to any active interrupt request or continue executing instructions following the I/O instruction that caused the break.

The I/O instruction break feature can be used to allow system logic to implement I/O trapping for peripheral devices. On sensing an I/O instruction, the system can drive the SMI (or NMI or INTR) active before driving READY active. This ensures that the SMI service routine is executed immediately following the I/O instruction that caused the break. (If the I/O instruction break feature is not enabled via IIBEN, several instructions after the I/O instruction that caused the break will execute before the SMI service routine is executed.) The SMI service routine can access the peripheral for which SMI was asserted and modify its state.

The SMI service routine will normally return to the instruction following the I/O instruction that caused the break. By modifying the saved state instruction pointer, the routine can choose to return to the I/O instruction that caused the break and re-execute that instruction. The default is to return to the following instruction (except for REP I/O strings). To re-execute the I/O instruction that caused the break. the SMI service routine must copy the I/O instruction pointer over the default pointer. This feature is particularly useful when an application program requests an access to a peripheral that has been powered down. The SMI service routine can restore power to the peripheral and initiate a re-execution sequence transparent to the application program. This re-execution feature should only be used if the SMI is in response to an I/O trap with IIBEN active.

Note that the I/O instruction break feature is not enabled for memory mapped I/O devices or for 80387 bus cycles even if IIBEN is active.

#### I/O Instruction Break Timing

The I/O Instruction Break feature requires that  $\overline{SMI}$  be sampled active (Low) by the processor at least three CLK2 edges before the CLK2 edge that ends the I/O cycle with an active READY signal. This timing applies for both pipelined and non-pipelined cycles. If this timing constraint is not met, the next instruction may be executed by the internal execution unit prior to entering SMI Mode, but the  $\overline{SMI}$  will be recognized eventually.

Depending on the state of the prefetch queue at the time that  $\overline{SMI}$  is asserted, instruction fetch cycles may occur on the normal  $\overline{ADS}$  interface before the SMI save state process begins with the assertion of  $\overline{SMIADS}$ . However, this fetched code will not be executed.

## True Static Operation

The Am386DXLV microprocessor incorporates a true static design. Unlike dynamic circuit design, the Am386DXLV device eliminates the minimum operating frequency restriction. It may be clocked from its maximum speed of 33 MHz all the way down to 0 MHz (DC). System designers can use this feature to design true 32-bit battery-powered portable PCs with long battery life.

## Standby Mode

This true static design allows for a Standby Mode. At any of its operating speeds (33 MHz to 0 MHz), the Am386DXLV microprocessor will retain its state (i.e., the contents of all of its registers). By shutting off the clock completely, the device enters Standby Mode. Since power consumption is a function of clock frequency, operating power consumption is reduced as the frequency is lowered. In Standby Mode, typical current draw is reduced to less than 0.01 mA at DC.

Not only does this feature save battery life, but it also simplifies the design of power-conscious notebook computers in the following ways.

- 1. Eliminates the need for software in BIOS to save and restore the contents of registers.
- Allows simpler circuitry to control stopping of the clock since the system does not need to know what state the processor is in.

## Lower Operating Icc

True static design also allows lower operating lcc when operating at any speed. See the following graph for typical current at operating speeds.



## Performance on Demand

The Am386DXLV microprocessor retains its state at any speed from 0 MHz (DC) to its maximum operating speed. With this feature, system designers may vary the operating speed of the system to extend the battery life in portable systems.

For example, the system could operate at low speeds during inactivity or polling operations. However, upon

interrupt, the system clock can be increased up to its maximum speed. After a user-defined time-out period, the system can be returned to a low (or a 0 MHz) operating speed without losing its state. This design maximizes battery life while achieving optimal performance.

## CONNECTION DIAGRAMS 132-Lead Plastic Quad Flat Pack (PQFP) Package



150228-002

Note: Pin 1 is marked for orientation.

# PQFP Pin Designations (Functional Grouping)

| Pin<br>Name | Pin<br>No. | Pin<br>Name | Pin<br>No. | Pin<br>Name | Pin<br>No. | Pin<br>Name     | Pin<br>No. | Pin<br>Name     | Pin<br>No. | Pin<br>Name     | Pin<br>No. |
|-------------|------------|-------------|------------|-------------|------------|-----------------|------------|-----------------|------------|-----------------|------------|
| A2          | 67         | A24         | 96         | D6          | 13         | D28             | 112        | V <sub>cc</sub> | 16         | V <sub>ss</sub> | 51         |
| A3          | 68         | A25         | 97         | D7          | 12         | D29             | 109        |                 | 22         |                 | 55         |
| A4          | 69         | A26         | 98         | D8          | 9          | D30             | 108        |                 | 34         |                 | 57         |
| A5          | 70         | A27         | 100        | D9          | 7          | D31             | 107        |                 | 49         |                 | 64         |
| A6          | 71         | A28         | 101        | D10         | 6          | D/C             | 41         |                 | 56         |                 | 65         |
| A7          | 72         | A29         | 102        | D11         | 5          | ERROR           | 47         |                 | 73         |                 | 66         |
| A8          | 74         | A30         | 103        | D12         | 4          | FLT             | 54         |                 | 85         |                 | 80         |
| A9          | 75         | A31         | 104        | D13         | 3          | HLDA            | 8          |                 | 99         |                 | 83         |
| A10         | 76         | ADS         | 27         | D14         | 131        | HOLD            | 28         |                 | 106        |                 | 90         |
| A11         | 77         | BE0         | 31         | D15         | 130        | IIBEN           | 58         |                 | 110        |                 | 91         |
| A12         | 78         | BE1         | 32         | D16         | 129        | INTR            | 53         |                 | 117        |                 | 92         |
| A13         | 79         | BE2         | 33         | D17         | 128        | LOCK            | 42         |                 | 123        |                 | 105        |
| A14         | 81         | BE3         | 38         | D18         | 126        | M/IO            | 40         |                 | 127        |                 | 111        |
| A15         | 82         | BS16        | 29         | D19         | 125        | NA              | 30         | V <sub>ss</sub> | 1          |                 | 114        |
| A16         | 84         | BUSY        | 46         | D20         | 124        | NMI             | 52         |                 | 10         |                 | 122        |
| A17         | 86         | CLK2        | 24         | D21         | 121        | PEREQ           | 50         |                 | 11         |                 | 132        |
| A18         | 87         | D0          | 20         | D22         | 120        | READY           | 26         |                 | 21         | W/R             | 43         |
| A19         | 88         | D1          | 19         | D23         | 119        | RESET           | 45         |                 | 23         | NC              | 39         |
| A20         | 89         | D2          | 18         | D24         | 118        | SMI             | 59         |                 | 25         |                 | 60         |
| A21         | 93         | D3          | 17         | D25         | 116        | SMIADS          | 37         |                 | 35         |                 | 61         |
| A22         | 94         | D4          | 15         | D26         | 115        | SMIRDY          | 36         |                 | 44         |                 | 62         |
| A23         | 95         | D5          | 14         | D27         | 113        | V <sub>cc</sub> | 2          |                 | 48         |                 | 63         |

# PQFP Pin Designations (Sorted by Pin No.)

| Pin<br>No. | Pin<br>Name     |
|------------|-----------------|------------|-----------------|------------|-----------------|------------|-----------------|------------|-----------------|------------|-----------------|
| 1          | V <sub>ss</sub> | 23         | V <sub>ss</sub> | 45         | RESET           | 67         | A2              | 89         | A20             | 111        | V <sub>ss</sub> |
| 2          | V <sub>cc</sub> | 24         | CLK2            | 46         | BUSY            | 68         | A3              | 90         | V <sub>ss</sub> | 112        | D28             |
| 3          | D13             | 25         | V <sub>ss</sub> | 47         | ERROR           | 69         | A4              | 91         | V <sub>ss</sub> | 113        | D27             |
| 4          | D12             | 26         | READY           | 48         | V <sub>ss</sub> | 70         | A5              | 92         | V <sub>ss</sub> | 114        | VSS             |
| 5          | D11             | 27         | ADS             | 49         | V <sub>cc</sub> | 71         | A6              | 93         | A21             | 115        | D26             |
| 6          | D10             | 28         | HOLD            | 50         | PEREQ           | 72         | A7              | 94         | A22             | 116        | D25             |
| 7          | D9              | 29         | BS16            | 51         | V <sub>ss</sub> | 73         | $V_{cc}$        | 95         | A23             | 117        | V <sub>cc</sub> |
| 8          | HLDA            | 30         | NA              | 52         | NMI             | 74         | A8              | 96         | A24             | 118        | D24             |
| 9          | D8              | 31         | BE0             | 53         | INTR            | 75         | A9              | 97         | A25             | 119        | D23             |
| 10         | V <sub>ss</sub> | 32         | BE1             | 54         | FLT             | 76         | A10             | 98         | A26             | 120        | D22             |
| 11         | V <sub>ss</sub> | 33         | BE2             | 55         | V <sub>ss</sub> | 77         | A11             | 99         | V <sub>cc</sub> | 121        | D21             |
| 12         | D7              | 34         | V <sub>cc</sub> | 56         | V <sub>cc</sub> | 78         | A12             | 100        | A27             | 122        | V <sub>ss</sub> |
| 13         | D6              | 35         | V <sub>ss</sub> | 57         | V <sub>ss</sub> | 79         | A13             | 101        | A28             | 123        | V <sub>cc</sub> |
| 14         | A5              | 36         | SMIRDY          | 58         | IIBEN           | 80         | Vss             | 102        | A29             | 124        | D20             |
| 15         | D4              | 37         | SMIADS          | 59         | SMI             | 81         | A14             | 103        | A30             | 125        | D19             |
| 16         | V <sub>cc</sub> | 38         | BE3             | 60         | NC              | 82         | A15             | 104        | A31             | 126        | D18             |
| 17         | D3              | 39         | NC              | 61         | NC              | 83         | V <sub>ss</sub> | 105        | V <sub>ss</sub> | 127        | V <sub>cc</sub> |
| 18         | D2              | 40         | M/IO            | 62         | NC              | 84         | A16             | 106        | V <sub>cc</sub> | 128        | D17             |
| 19         | D1              | 41         | D/C             | 63         | NC              | 85         | $V_{cc}$        | 107        | D31             | 129        | D16             |
| 20         | D0              | 42         | LOCK            | 64         | V <sub>ss</sub> | 86         | A17             | 108        | D30             | 130        | D15             |
| 21         | V <sub>ss</sub> | 43         | W/R             | 65         | V <sub>ss</sub> | 87         | A18             | 109        | D29             | 131        | D14             |
| 22         | V <sub>cc</sub> | 44         | V <sub>ss</sub> | 66         | V <sub>ss</sub> | 88         | A19             | 110        | V <sub>cc</sub> | 132        | V <sub>ss</sub> |

## **ORDERING INFORMATION**

## **Standard Products**

AMD standard products are available in several packages and operating ranges. The order number (Valid Combination) is formed by a combination of the elements below.



| Valid Combinations |           |                     |  |  |  |  |
|--------------------|-----------|---------------------|--|--|--|--|
| NG                 | 80386DXLV | -25<br>-25F<br>-25S |  |  |  |  |

#### Valid Combinations

Valid Combinations lists configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations and to check on newly released combinations.



15021B-003

#### A31-A2

#### Address Bus (Outputs)

Outputs physical memory or port I/O addresses.

## ADS

#### Address Status (Active Low; Output)

Indicates that a valid bus cycle definition and address  $(W/\overline{R}, D/\overline{C}, M/\overline{IO}, \overline{BE3}-\overline{BE0}, \text{ and } A31-A2)$  are being driven at the Am386DXLV microprocessor pins.

## BE3-BE0

#### Byte Enable (Active Low; Outputs)

Indicates which data bytes of the data bus take part in a bus cycle.

#### **BS16**

#### Bus Size 16 (Active Low; Input)

Allows direct connection of 32-bit and 16-bit data buses. BS16 has an internal pullup resistor.

#### BUSY

#### Busy (Active Low; Input)

Signals a busy condition from a processor extension. BUSY has an internal pullup resistor.

#### CLK2

#### Clock (Input)

Provides the fundamental timing for the Am386DXLV microprocessor.

#### D31-D0

#### Data Bus (Inputs/Outputs)

Inputs data during memory, I/O, and interrupt acknowledge read cycles and outputs data during memory and I/O write cycles.

#### D/C

#### Data/Control (Output)

A bus cycle definition pin that distinguishes data cycles, either memory or I/O, from control cycles (which are interrupt acknowledge, halt, and instruction fetching).

#### ERROR

#### Error (Active Low; Input)

Signals an error condition from a processor extension. ERROR has an internal pullup resistor.

## FLT

#### Float (Active Low; Input)

An input signal which forces all bi-directional and output signals, including HLDA, to the three-state condition. FLT has an internal pullup resistor.

#### HLDA

#### Bus Hold Acknowledge (Active High; Output)

Indicates that the Am386DXLV microprocessor has surrendered control of its local bus to another bus master.

#### HOLD

#### Bus Hold Request (Active High; Input)

Allows another bus master to request control of the local bus.

## IIBEN

#### I/O Instruction Break Enable (Active Low; Input)

Enables the I/O instruction break feature. IIBEN has an internal pullup resistor.

## INTR

#### Interrupt Request (Active High; Input)

A maskable input that signals the Am386DXLV microprocessor to suspend execution of the current program and execute an interrupt acknowledge function.

## LOCK

#### Bus Lock (Active Low; Output)

A bus cycle definition pin that indicates that other system bus masters are denied access to the system bus while it is active.

## M/IO

#### Memory I/O (Output)

A bus cycle definition pin that distinguishes memory cycles from input/output cycles.

## NA

#### Next Address (Active Low; Input)

Used to request address pipelining.

## NC

#### No Connect

Should always remain unconnected. Connection of an NC pin may cause the processor to malfunction or be incompatible with future steppings of the Am386DXLV microprocessor.

#### NMI

#### Non-Maskable Interrupt Request (Active High; Input)

A non-maskable input that signals the Am386DXLV microprocessor to suspend execution of the current program and execute an interrupt acknowledge function.

#### PEREQ

#### Processor Extension Request (Active High; Input)

Indicates that the processor extension has data to be transferred by the Am386DXLV microprocessor. PEREQ has an internal pulldown resistor.

#### READY

#### Bus Ready (Active Low; Input)

Terminates the bus cycle.

#### RESET

#### Reset (Active High; Input)

Suspends any operation in progress and places the Am386DXLV microprocessor in a known reset state.

#### SMI

# System Management Interrupt (Active Low; Input/Output)

A non-maskable interrupt pin which signals the Am386DXLV microprocessor to suspend execution and enter System Management Mode. SMI has an internal pullup resistor.



## 

# SMI Address Status (Active Low, Three-State; Output)

Indicates that a valid bus cycle definition and address (W/R, D/C, M/IO, BE3-BE0, and A31-A2) are being driven at the Am386DXLV microprocessor pins while in System Management Mode.

#### SMIRDY

## SMI Ready (Active Low; Input)

This input terminates the current bus cycle to the SMM address space in the same manner the READY pin does for the Normal Mode address space. SMIRDY has an internal pullup resistor.

#### Vcc

## System Power (Active High; Input)

Provides the DC supply input.

#### Vss

## System Ground (Input)

Provides 0-V connection from which all inputs and outputs are measured.

## W/R

#### Write/Read (Output)

A bus cycle definition pin that distinguishes write cycles from read cycles.

## **ABSOLUTE MAXIMUM RATINGS**

Stresses above those listed may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to ABSOLUTE MAXIMUM RATINGS for extended periods may affect device reliability.

## **OPERATING RANGES**

Voltage on Other Pins ..... -0.5 V to Vcc +0.5 V Supply Voltage with Respect to Vss . . -0.5 V to +7 V

Operating ranges define those limits between which the functionality of the device is guaranteed.

## DC CHARACTERISTICS over COMMERCIAL Operating Ranges

 $V_{CC} = 3.0 V$  to 3.6 V;  $T_{CASE} = 0^{\circ}C$  to  $+100^{\circ}C$ 

|                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                            | Preli                                                                  | minary                     | 7                |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|------------------------------------------------------------------------|----------------------------|------------------|
| Symbol            | Parameter<br>Description                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Notes                                                                      | Min                                                                    | Max                        | Unit             |
| V <sub>IL</sub>   | Input Low Voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                               | (Note 1)                                                                   | -0.3                                                                   | 0.8                        | V                |
| V <sub>IH</sub>   | Input High Voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                            | 2.0                                                                    | V <sub>cc</sub> + 0.3      | V                |
| V <sub>ILC</sub>  | CLK2 Input Low Voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                          | (Note 1)                                                                   | -0.3                                                                   | 0.8                        | V                |
| V <sub>IHC</sub>  | CLK2 Input High Voltage<br>25 MHz                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                            | V <sub>cc</sub> -0.6                                                   | V <sub>cc</sub> + 0.3      | v                |
| V <sub>ol</sub>   | Output Low Voltage<br>$I_{oL} = 0.5 \text{ mA: } A31-A2, D31-D0$<br>$I_{oL} = 0.5 \text{ mA: } \overline{BE3-BE0}, W/\overline{R}, D/\overline{C},$<br>$M/\overline{IO}, \overline{LOCK}, \overline{ADS}, \overline{SMIADS}, HLDA$<br>$I_{oL} = 2 \text{ mA: } A31-A2, D31-D0$<br>$I_{oL} = 2.5 \text{ mA: } \overline{BE3-BE0}, W/\overline{R}, D/\overline{C},$<br>$M/\overline{IO}, \overline{LOCK}, \overline{ADS}, \overline{SMIADS}, HLDA$                                | (Note 5)                                                                   |                                                                        | 0.2<br>0.2<br>0.45<br>0.45 | V<br>V<br>V<br>V |
| V <sub>oH</sub>   | Output High Voltage<br>$I_{OH} = 0.1 \text{ mA: }A31-A2, D31-D0$<br>$I_{OH} = 0.1 \text{ mA: }\overline{BE3}-\overline{BE0},$<br>$W/\overline{R}, D/\overline{C}, M/\overline{IO}, \overline{LOCK},$<br>$\overline{ADS}, \overline{SMIADS}, HLDA$<br>$I_{OH} = 0.5 \text{ mA: }A31-A2, D31-D0$<br>$I_{OH} = 0.5 \text{ mA: }\overline{BE3}-\overline{BE0},$<br>$W/\overline{R}, D/\overline{C}, M/\overline{IO}, \overline{LOCK},$<br>$\overline{ADS}, \overline{SMIADS}, HLDA$ | (Note 5)                                                                   | $V_{cc} - 0.2$<br>$V_{cc} - 0.2$<br>$V_{cc} - 0.45$<br>$V_{cc} - 0.45$ |                            | v<br>v<br>v<br>v |
| l <sub>u</sub>    | Input Leakage Current<br>(All pins except BS16, PEREQ, IIBEN<br>BUSY, FLT, ERROR, SMI, and SMIRDY)                                                                                                                                                                                                                                                                                                                                                                              | $0 V \leq V_{\rm IN} \leq V_{\rm cc}$                                      |                                                                        | ±15                        | μΑ               |
| l <sub>in</sub>   | Input Leakage Current<br>(PEREQ Pin)                                                                                                                                                                                                                                                                                                                                                                                                                                            | V <sub>IH</sub> =V <sub>cc</sub> -0.1 V<br>V <sub>IH</sub> =2.4 V (Note 2) |                                                                        | 300<br>200                 | μA               |
| I <sub>IL</sub>   | Input Leakage Current<br>(BS16, BUSY, FLT, ERROR, SMI, IIBEN,<br>and SMIRDY)                                                                                                                                                                                                                                                                                                                                                                                                    | $V_{IL} = 0.1 V$<br>$V_{IL} = 0.45 V$ (Note 3)                             |                                                                        | 300<br>200                 | μA               |
| I <sub>LO</sub>   | Output Leakage Current                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0.1 V≤V <sub>out</sub> ≤V <sub>cc</sub>                                    |                                                                        | ±15                        | μA               |
| l <sub>cc</sub>   | Supply Current<br>CLK2 = 40 MHz: Oper. Freq. 20 MHz<br>CLK2 = 50 MHz: Oper. Freq. 25 MHz                                                                                                                                                                                                                                                                                                                                                                                        | I <sub>cc</sub> Тур = 80<br>I <sub>cc</sub> Тур = 95                       |                                                                        | 110<br>135                 | mA<br>mA         |
| I <sub>CCSB</sub> | Standby Current                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | I <sub>ccsb</sub> Typ = 10                                                 |                                                                        | 150                        | μA               |
| C <sub>IN</sub>   | Input or I/O Capacitance                                                                                                                                                                                                                                                                                                                                                                                                                                                        | F <sub>c</sub> =1 MHz (Note 4)                                             |                                                                        | 10                         | pF               |
| Cour              | Output Capacitance                                                                                                                                                                                                                                                                                                                                                                                                                                                              | F <sub>c</sub> =1 MHz (Note 4)                                             |                                                                        | 12                         | pF               |
| C <sub>CLK</sub>  | CLK2 Capacitance                                                                                                                                                                                                                                                                                                                                                                                                                                                                | F <sub>c</sub> =1 MHz (Note 4)                                             |                                                                        | 20                         | pF               |

Notes: 1. The Min value, -0.3, is not 100% tested.

PEREQ input has an internal pulldown resistor.
 BS16, BUSY, FLT, ERROR, SMI, SMIRDY, and IIBEN inputs each have an internal pullup resistor.

4. Not 100% tested.

5. Outputs are CMOS and will pull rail to rail if the load is not resistive.



# 

#### PRELIMINARY

## ABSOLUTE MAXIMUM RATINGS

Storage Temperature ..... -65°C to +150°C Ambient Temperature Under Bias . . -65°C to +125°C

Stresses above those listed may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to ABSOLUTE MAXIMUM RATINGS for extended periods may affect device reliability.

## OPERATING RANGES

Voltage on Other Pins ..... –0.5 V to V∞ +0.5 V Supply Voltage with Respect

Operating ranges define those limits between which the functionality of the device is guaranteed.

## DC CHARACTERISTICS over COMMERCIAL Operating Ranges

Vcc = 3.6 V to 5.5 V; Tcase = 0°C to +100°C

|                   |                                                                                                                                                                |                                             | Prelir                       | ninary                                         | ]              |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|------------------------------|------------------------------------------------|----------------|
| Symbol            | Parameter<br>Description                                                                                                                                       | Notes                                       | Min                          | Max                                            | Unit           |
| V <sub>IL</sub>   | Input Low Voltage                                                                                                                                              | (Note 1)                                    | -0.3                         | 0.8                                            | V              |
| V <sub>IH</sub>   | Input High Voltage                                                                                                                                             |                                             | 2.0                          | V <sub>cc</sub> + 0.3                          | v              |
| V <sub>ILC</sub>  | CLK2 Input Low Voltage                                                                                                                                         | (Note 1)                                    | -0.3                         | 0.8                                            | V              |
| V <sub>IHC</sub>  | CLK2 Input High Voltage<br>20 MHz<br>25, 33 MHz                                                                                                                |                                             | V <sub>cc</sub> – 0.8<br>3.7 | V <sub>cc</sub> + 0.3<br>V <sub>cc</sub> + 0.3 | v<br>v         |
| V <sub>oL</sub>   | Output Low Voltage<br>I <sub>oL</sub> = 4 mA: A31–A2, D31–D0<br>I <sub>oL</sub> = 5 mA: BE3–BE0, W/R,<br>D/C, M/IO, LOCK, ADS, SMIADS,<br>HLDA                 | (Note 5)                                    |                              | 0.45<br>0.45                                   | v<br>v         |
| V <sub>он</sub>   | Output High Voltage<br>I <sub>он</sub> = 1 mA: A31–A2, D31–D0<br>I <sub>он</sub> = 0.9 mA: <u>ВЕ3–ВЕ0,</u><br><u>W/R, D/C, M/Ю, LOCK,</u><br>ADS, SMIADS, HLDA | (Note 5)                                    | 2.4<br>2.4                   |                                                | v<br>v         |
| l <sub>u</sub>    | Input Leakage Current<br>(All pins except BS16, PEREQ,<br>IIBEN, BUSY, FLT, SMI, SMIRDY,<br>and ERROR)                                                         | 0 V≤V <sub>IN</sub> ≤V <sub>cc</sub>        |                              | ±15                                            | μA             |
| l <sub>im</sub>   | Input Leakage Current<br>(PEREQ Pin)                                                                                                                           | V <sub>⊮</sub> =2.4 V<br>(Note 2)           |                              | 200                                            | μА             |
| l <sub>i.</sub>   | Input Leakage Current<br>(BS16, BUSY, FLT, SMI, SMIRDY,<br>IIBEN, and ERROR)                                                                                   | V <sub>iL</sub> = 0.45<br>(Note 3)          |                              | -400                                           | μA             |
| l <sub>lo</sub>   | Output Leakage Current                                                                                                                                         | 0.45 V ≤ V <sub>out</sub> ≤ V <sub>cc</sub> |                              | ±15                                            | μA             |
| Ι <sub>cc</sub>   | Supply Current<br>CLK2 = 40 MHz: Oper. Freq. 20 MHz<br>CLK2 = 50 MHz: Oper. Freq. 25 MHz<br>CLK2 = 66 MHz: Oper. Freq. 33 MHz                                  | $l_{cc}$ Typ = 210                          |                              | 200<br>250<br>330                              | mA<br>mA<br>mA |
| I <sub>CCSB</sub> | Standby Current                                                                                                                                                | I <sub>ccss</sub> Typ=0.02 mA               |                              | 150                                            | μΑ             |
|                   | Input or I/O Capacitance                                                                                                                                       | F <sub>c</sub> =1 MHz (Note 4)              |                              | 10                                             | pF             |
| Cour              | Output Capacitance                                                                                                                                             | F <sub>c</sub> = 1 MHz (Note 4)             |                              | 12                                             | pF             |
| C <sub>cl.k</sub> | CLK2 Capacitance                                                                                                                                               | F <sub>c</sub> =1 MHz (Note 4)              |                              | 20                                             | pF             |

Notes: 1. The Min value, -0.3, is not 100% tested.

PEREQ input has an internal pulldown resistor.
 BS16, BUSY, FLT, ERROR, SMI, SMIRDY, and IIBEN inputs each have an internal pullup resistor.

4. Not 100% tested.

5. Outputs are CMOS and will pull rail to rail if the load is not resistive.

## SWITCHING CHARACTERISTICS

The switching characteristics consist of output delays, input setup requirements, and input hold requirements. All characteristics are relative to the CLK2 rising edge crossing the 2.0 V level.

Switching characteristic measurement is defined by Figure 2. Inputs must be driven to the voltage levels indicated by this diagram. Am386DXLV CPU output delays are specified with minimum and maximum limits measured as shown. The minimum Am386DXLV microprocessor delay times are hold times provided to external circuitry. Am386DXLV microprocessor input setup and hold time are specified as minimums, defining the smallest acceptable sampling window. Within the sampling window, a synchronous input signal must be stable for correct Am386DXLV microprocessor operation.

Outputs W/R, D/C, M/IO, LOCK, BE3–BE0, ADS, A31–A2, HLDA, and SMIADS only change at the beginning of phase one. D31–D0 (write cycles) only change at the beginning of phase two. The READY, HOLD, BUSY, ERROR, PEREQ, FLT, D31–D0, and SMIRDY (read cycles) inputs are sampled at the beginning of phase one. The NA, BS16, INTR, NMI, and SMI inputs are sampled at the beginning of phase two.



Note: Input waveforms have tr  $\leq$  2.0 ns from 0.8 V to 2.0 V.

15021B-071

#### Figure 2. Drive Levels and Measurement Points

## SWITCHING CHARACTERISTICS over operating range at 33 MHz

Vcc = 4.5 V to 5.5 V; Tcase = 0°C to +100°C

|     |                                    |                                 | Prelim         | inary | 1                                                                                                              |      |
|-----|------------------------------------|---------------------------------|----------------|-------|----------------------------------------------------------------------------------------------------------------|------|
| No. | Parameter<br>Description           | Notes                           | Ref<br>Figures | Min   | Max                                                                                                            | Unit |
|     | Operating Frequency                | Half of CLK2 Freq               |                | 0     | 33.3                                                                                                           | MHz  |
| 1   | CLK2 Period                        |                                 | 4              | 15.0  |                                                                                                                | ns   |
| 2a  | CLK2 High Time                     | at 2 V                          | 4              | 6.25  |                                                                                                                | ns   |
| 2b  | CLK2 High Time                     | at 3.7 V                        | 4              | 4.5   |                                                                                                                | ns   |
| 3a  | CLK2 Low Time                      | at 2 V                          | 4              | 6.25  |                                                                                                                | ns   |
| 3b  | CLK2 Low Time                      | at 0.8 V                        | 4              | 4.5   |                                                                                                                | ns   |
| 4   | CLK2 Fall Time                     | 3.7 V to 0.8 V<br>(Note 3)      | 4              |       | 4                                                                                                              | ns   |
| 5   | CLK2 Rise Time                     | 0.8 V to 3.7 V<br>(Note 3)      | 4              |       | 4                                                                                                              | ns   |
| 6   | A31–A2 Valid Delay                 | С <sub>L</sub> = 50 pF          | 3, 6           | 4     | 15                                                                                                             | ns   |
| 7   | A31-A2 Float Delay                 | (Note 1)                        | 10             | 4     | 20                                                                                                             | ns   |
| 8   | BE3-BE0, LOCK Valid Delay          | C <sub>L</sub> = 50 pF          | 3, 6           | 4     | 15                                                                                                             | ns   |
| 9   | BE3-BE0, LOCK Float Delay          | (Note 1)                        | 10             | 4     | 20                                                                                                             | ns   |
| 10  | W/R, M/IO, D/C Valid Delay         | $C_{L} = 50 \text{ pF}$         | 3, 6           | 4     | 15                                                                                                             | ns   |
| 10a | ADS Valid Delay                    | C <sub>L</sub> = 50 pF          | 2, 6           | 4     | 14.5                                                                                                           | ns   |
| 10s | SMIADS Valid Delay                 | C <sub>L</sub> =50 pF           | 2,6            | 4     | 23                                                                                                             | ns   |
| 11  | W/R, M/IO, D/C, ADS Float Delay    | (Note 1)                        | 10             | 4     | 20                                                                                                             | ns   |
| 11s | SMIADS Float Delay                 | (Note 1)                        | 10             | 4     | 20                                                                                                             | ns   |
| 12  | D31-D0 Write Data Valid Delay      | C <sub>L</sub> = 50 pF (Note 4) | 6, 7, 9        | 7     | 24                                                                                                             | ns   |
| 12a | D31D0 Write Data Hold Time         | $C_{L} = 50 \text{ pF}$         | 3, 8           | 2     |                                                                                                                | ns   |
| 13  | D31-D0 Float Delay                 | (Note 1)                        | 10             | 4     | 17                                                                                                             | ns   |
| 14  | HLDA Valid Delay                   | C <sub>L</sub> = 50 pF          | 3, 10          | 4     | 20                                                                                                             | ns   |
| 15  | NA Setup Time                      |                                 | 5              | 5     |                                                                                                                | ns   |
| 16  | NA Hold Time                       |                                 | 5              | 2     | ali na mangangan sa mangangan sa mangangan sa mangan sa mangan sa mangan sa mangan sa mangan sa mangan sa mang | ns   |
| 17  | BS16 Setup Time                    |                                 | 5              | 5     |                                                                                                                | ns   |
| 18  | BS16 Hold Time                     |                                 | 5              | 2     | WWW. Contraction of the second se | ns   |
| 19  | READY Setup Time                   |                                 | 5              | 7     |                                                                                                                | ns   |
| 19s | SMIRDY Setup Time                  |                                 | 5              | 7     |                                                                                                                | ns   |
| 20  | READY Hold Time                    |                                 | 5              | 4     |                                                                                                                | ns   |
| 20s | SMIRDY Hold Time                   |                                 | 5              | 4     |                                                                                                                | ns   |
| 21  | D31–D0 Read Setup Time             |                                 | 5              | 5     | ****                                                                                                           | ns   |
| 22  | D31–D0 Read Hold Time              |                                 | 5              | 3     |                                                                                                                | ns   |
| 23  | HOLD Setup Time                    |                                 | 5              | 11    |                                                                                                                | ns   |
| 24  | HOLD Hold Time                     |                                 | 5              | 2     |                                                                                                                | ns   |
| 25  | RESET Setup Time                   |                                 | 11             | 5     |                                                                                                                | ns   |
| 26  | RESET Hold Time                    |                                 | 11             | 2     |                                                                                                                | ns   |
| 27  | NMI, INTR Setup Time               | (Note 2)                        | 5              | 5     |                                                                                                                | ns   |
| 27s | SMI Setup Time                     |                                 | 5              | 5     |                                                                                                                | ns   |
| 28  | NMI, INTR Hold Time                | (Note 2)                        | 5              | 5     | *******                                                                                                        | ns   |
| 28s | SMI Hold Time                      |                                 | 5              | 5     |                                                                                                                | ns   |
| 29  | PEREQ, ERROR, BUSY, FLT Setup Time | (Note 2)                        | 5              | 5     |                                                                                                                | ns   |
| 30  | PEREQ, ERROR, BUSY, FLT Hold Time  | (Note 2)                        | 5              | 4     |                                                                                                                | ns   |

Notes: 1. Float condition occurs when maximum output current becomes less than Ito in magnitude. Float delay is not 100% tested. 2. These inputs are allowed to be asynchronous to CLK2. The setup and hold specifications are given for testing purposes, to assure recognition within a specific CLK2 period.

Rise and fall times are not tested.
 Min time not 100% tested.



## SWITCHING CHARACTERISTICS over operating range at 25 MHz

Vcc = 3.0 V to 5.5 V; Tcase = 0°C to +100°C

|     |                                       | [                                      | Prelin         | ninary | 7   |      |
|-----|---------------------------------------|----------------------------------------|----------------|--------|-----|------|
| No. | Parameter<br>Description              | Notes                                  | Ref<br>Figures | Min    | Max | Unit |
|     | Operating Frequency                   | Half of CLK2 Freq                      |                | 0      | 25  | MHz  |
| 1   | CLK2 Period                           |                                        | 4              | 20     |     | ns   |
| 2a  | CLK2 High Time                        | at 2 V                                 | 4              | 7      |     | ns   |
| 2b  | CLK2 High Time                        | at 3.7 V                               | 4              | 4      |     | ns   |
| 3a  | CLK2 Low Time                         | at 2 V                                 | 4              | 7      |     | ns   |
| 3b  | CLK2 Low Time                         | at 0.8 V                               | 4              | 5      |     | ns   |
| 4   | CLK2 Fall Time                        | 3.7 V to 0.8 V<br>(Note 3)             | 4              |        | 7   | ns   |
| 5   | CLK2 Rise Time                        | 0.8 V to 3.7 V<br>(Note 3)             | 4              |        | 7   | ns   |
| 6   | A31–A2 Valid Delay                    | C <sub>L</sub> =50 pF                  | 3, 6           | 4      | 21  | ns   |
| 7   | A31-A2 Float Delay                    | (Note 1)                               | 10             | 4      | 30  | ns   |
| 8   | BE3-BE0 Valid Delay                   | C <sub>L</sub> = 50 pF                 | 3, 6           | 4      | 24  | ns   |
| 8a  | LOCK Valid Delay                      | C <sub>L</sub> = 50 pF                 | 3, 6           | 4      | 21  | ns   |
| 9   | BE3-BE0, LOCK Float Delay             | (Note 1)                               | 10             | 4      | 30  | ns   |
| 10  | W/R, M/IO, D/C, ADS Valid Delay       | C <sub>L</sub> =50 pF                  | 3, 6           | 4      | 21  | ns   |
| 10s | SMIADS Valid Delay                    | C <sub>L</sub> =50pF                   | 3,6            | 4      | 25  | ns   |
| 11  | W/R, M/IO, D/C, ADS Float Delay       | (Note 1)                               | 10             | 4      | 30  | ns   |
| 11s | SMIADS Float Delay                    | (Note 1)                               | 10             | 4      | 30  | ns   |
| 12  | D31–D0 Write Data Valid Delay         | C <sub>L</sub> = 50 pF                 | 6, 7, 9        | 7      | 27  | ns   |
| 12a | D31-D0 Write Data Hold Time           | C <sub>L</sub> =50 pF                  | 3, 8           | 2      |     | ns   |
| 13  | D31–D0 Float Delay                    | (Note 1)                               | 10             | 4      | 22  | ns   |
| 14  | HLDA Valid Delay                      | C <sub>L</sub> =50 pF                  | 3, 10          | 4      | 22  | ns   |
| 15  | NA Setup Time                         |                                        | 5              | 7      |     | ns   |
| 16  | NA Hold Time                          |                                        | 5              | 3      |     | ns   |
| 17  | BS16 Setup Time                       |                                        | 5              | 7      |     | ns   |
| 18  | BS16 Hold Time                        |                                        | 5              | 3      |     | ns   |
| 19  | READY Setup Time                      |                                        | 5              | 9      |     | ns   |
| 19s | SMIRDY Setup Time                     |                                        | 5              | 9      |     | ns   |
| 20  | READY Hold Time                       |                                        | 5              | 4      |     | ns   |
| 20s | SMIRDY Hold Time                      |                                        | 5              | 4      |     | ns   |
| 21  | D31–D0 Read Setup Time                |                                        | 5              | 7      | 1   | ns   |
| 22  | D31–D0 Read Hold Time                 |                                        | 5              | 5      | 1   | ns   |
| 23  | HOLD Setup Time                       |                                        | 5              | 15     |     | ns   |
| 24  | HOLD Hold Time                        |                                        | 5              | 3      | 1   | ns   |
| 25  | RESET Setup Time                      |                                        | 11             | 10     | 1   | ns   |
| 26  | RESET Hold Time                       |                                        | 11             | 3      | 1   | ns   |
| 27  | NMI, INTR Setup Time                  | (Note 2)                               | 5              | 6      |     | ns   |
| 27s | SMI Setup Time                        | ····· ································ | 5              | 6      | t   | ns   |
| 28  | NMI, INTR Hold Time                   | (Note 2)                               | 5              | 6      |     | ns   |
| 28s | SMI Hold Time                         |                                        | 5              | 6      | 1   | ns   |
| 29  | PEREQ, ERROR, BUSY, FLT<br>Setup Time | (Note 2)                               | 5              | 6      |     | ns   |
| 30  | PEREQ, ERROR, BUSY, FLT<br>Hold Time  | (Note 2)                               | 5              | 5      |     | ns   |

Notes: 1. Float condition occurs when maximum output current becomes less than I<sub>LO</sub> magnitude. Float delay is not 100% tested.
2. These inputs are allowed to be asynchronous to CLK2. The setup and hold specifications are given for testing purposes, to assure recognition within a specific CLK2 period.
3. Rise and fall times are not tested.



## SWITCHING CHARACTERISTICS (continued)



CL includes all parasitic capacitances.

Figure 3. AC Test Load





Figure 4. CLK2 Timing

15021B-073

## SWITCHING WAVEFORMS



Figure 6. Output Valid Delay Timing

15021B-075

AMD





Am386DXLV Microprocessor







The second internal processor phase following RESET High-to-Low transition (provided t25 and t26 are met) is  $\phi_2$ . 15021B–084

#### Figure 11. RESET Setup and Hold Timing and Internal Phase

AMD



Note: This graph will not be linear outside of the C<sub>L</sub> range shown.

15021B-079





Note: This graph will not be linear outside of the CL range shown.

15021B-080

#### Figure 13. Typical Output Valid Delay Versus Load Capacitance at Maximum Operating Temperature (CL = 75 pF)

Am386DXLV Microprocessor

Figure 15. Typical Output Rise Time Versus Load Capacitance at Maximum Operating Temperature

Note: This graph will not be linear outside of the CL range shown.

15021B-081





Note: This graph will not be linear outside of the CL range shown.









# Am386<sup>TM</sup>SXLV High-Performance, Low-Voltage, 32-Bit Microprocessor with 16-Bit Data Bus

- Operating range 3.0 V to 5.5 V—Ideal for notebook PC designs
  - —2X improvement in battery life over existing 5 V designs
  - Wide range of chipsets and other logic available for 3 V systems with support for Standby Mode operation
  - -True static design for long battery life
  - Power consumption 75% lower than Intel i386SX, 65% lower than Am386SXL microprocessor
  - -Performance on demand (0 to 25 MHz)
- System Management Mode (SMM) for system and power management
  - —System Management Interrupt (SMI) for power management independent of processor operating mode and operating system

—SMI coupled with I/O instruction break feature provides transparent power off and auto resume of peripherals which may not be "power aware"

Advanced Micro

Devices

- ---SMI is non-maskable and has higher priority than NMI
- -Automatic save and restore of the microprocessor state
- ---Wide range of chipsets supporting SMM available to allow product differentiation
- Lower heat dissipation facilitates elimination of the cooling fan in desktop PCs
- "Float" Input to facilitate system debug and test
- Compatible with 386SX systems and software
- Supports 387SX-compatible math coprocessors
- 100-pin PQFP package with optional protective ring for better lead coplanarity
- AMD® advanced 0.8 micron CMOS technology

Typical Power Consumption



Publication # 16305 Rev. B Amendment /0 issue Date: October 1991

1-450

## **GENERAL DESCRIPTION**

The Am386SXLV microprocessor is a low-voltage, true static implementation of the Intel i386SX microprocessor. With the operating range of 3.0 V to 5.5 V, it is ideal for both desktop and battery-powered notebook personal computers. For desktop PCs, this device offers lower heat dissipation, allowing system designers to remove or reduce the size and cost of the cooling fan.

The Am386SXLV microprocessor's lower operating voltage and true static design enables longer battery life and/or lower weight for notebook applications. At 20 MHz, this device has 60% lower operating loc than the Intel i386SX. Lowering typical operating voltage from 5.0 V to 3.3 V enables battery life to increase by a factor of two. Standby Mode allows the Am386SXLV microprocessor to be clocked down to 0 MHz (DC) and retain full register contents. In Standby Mode, typical current draw is less than 0.01 mA, a greater than 1000X reduction in power consumption versus the Intel i386SX.

The Am386SXLV microprocessor is available in a small footprint 100-pin Plastic Quad Flat Pack (PQFP) package. This package may be shipped in an optional protective ring for better lead protection during shipping.

Additionally, the Am386SXLV microprocessor comes with System Management Mode (SMM) for system and power management. SMI (System Management Interrupt) is a non-maskable, higher priority interrupt than NMI and has its own code space (1 Mb). SMI can be coupled with the I/O instruction break feature to implement transparent power management of peripherals. SMM can be used by system designers to implement system and power management code independent of the operating system or the Processor Mode.

The Am386SXLV microprocessor incorporates a float pin that places all outputs in a three-state mode to facilitate board test and debug.



## FUNCTIONAL DESCRIPTION

## Benefits of Lower Operating Voltage

The Am386SXLV microprocessor has an operating voltage range of 3.0 V to 5.5 V. Low voltage allows for lower operating power consumption, longer battery life, and/or smaller batteries for notebook applications.

Because power is proportional to the square of voltage. reduction of the supply voltage from 5.0 V to 3.3 V reduces power consumption by 56%. This directly translates to a doubling of battery life for portable applications. Lower power consumption can also be used to reduce the size and weight of the battery. Thus, 3.3 V designs facilitate a reduction in the form factor. For desktop PCs, low power consumption means elimination of the cooling fan, thus reducing the size and noise of the PC.

A lower operating voltage results in a reduction of I/O voltage swings. This reduces noise generation providing a less hostile environment for board design. It also reduces electromagnetic radiation noise making it easier to obtain FCC approval.

## SMM—System Management Mode

The Am386SXLV microprocessor has a new System Management Mode (SMM) for system and power management. This mode consists of two features: System Management Interrupt (SMI) and I/O instruction break.

## SMI—System Management Interrupt

SMI is implemented through the use of special bus interface pins. This interrupt method can be used to perform system management functions such as power management independent of Processor Operating Mode (Real, Protected, or Virtual 86 modes).

SMI can also be invoked in software. This allows system software to communicate with SMI power management code. In addition, an instruction called UMOV allows data transfers between SMI and normal system memory spaces.

Activating the SMI pin invokes a sequence that saves the operating state of the processor into a separate SMM memory space, independent of the main system memory. After the state is saved, the processor is forced into Real Mode and begins execution at address FFFFF0h in the SMM memory space where a far jump to the SMM code is executed. This Real Mode code can perform its system management function and then resume execution of the normal system software by executing a special opcode sequence which will reload the saved processor state and continue execution in the main system memory space. See Figure 1 for a general flowchart of an SMM operation.

## CPU Interface—Pin Functions

The CPU interface for SMM consists of three pins dedicated to the SMI function. One pin, SMI, is the new interrupt input. The other two pins, SMIADS and SMIRDY, provide the control signals necessary for the separate SMM mode memory space.

## **Description of SMM Operation**

The execution of a System Management Interrupt has four distinct phases: the initiation of the interrupt via SMI, a processor state save, execution of the SMM interrupt code, and a processor state restore (to resume normal operation).



Figure 1. SMM Flow

## Interrupt Initiation

A System Management Interrupt is initiated by the driving of an active Low pulse on the SMI pin of at least four CLK2 periods. This pulse period will ensure recognition of the interrupt. The CPU will drive the SMI pin active after the completion of the current operation (active bus cycle, instruction execution, or both). The active drive of the pin by the CPU will be released at the end of the interrupt routine following the last register read of the saved state.

While the CPU is in SMM, a bus hold request via the HOLD pin **will be granted.** The HLDA pin will go active after bus release and the SMIADS pin will float along with the other pins that normally float during a bus hold cycle.

#### **Processor State Save**

The first set of SMM bus transfer cycles after the CPU's recognition of an active SMI will be the processor saving its state to an external RAM array in a separate address space from main system memory. This is accomplished by using the  $\overline{SMIADS}$  and  $\overline{SMIRDY}$  pins for initiation and termination of bus cycles, instead of the  $\overline{ADS}$  and  $\overline{READY}$  pins. The 32-bit addresses to which the CPU saves its state are 60000h–600CAh and 60100h–60126h. These are fixed address locations for each register saved.

The value of NA will be ignored during the state save. Only full 16-bit, non-pipelined cycles are generated for the state save cycles. There are 114 data transfer cycles

## SMI Code Execution

After the processor state is saved to the separate SMM memory space, the execution of the SMI interrupt routine code begins. The processor enters Real Mode, sets most of the register values to "reset" values (those values normally seen after a CPU reset), and begins fetching code from address FFFFF0h in the separate SMM memory space. Normally, the first thing the interrupt routine code will do is a FAR JUMP to the Real Mode entry point for the SMI interrupt routine, which is also in SMM memory space.

Any Real Mode interrupt routine code can be executed, with the obvious exception of normal interrupt routines (which are deferred). The SMM code can be located anywhere within the 1-Mb Real Mode address space, except for where the processor state is saved. I/O cycles, as a result of the IN, OUT, INS, and OUTS instructions, will go to the normal address space, utilizing the normal ADS and READY bus interface signals. This facilitates power management code manipulating system hardware registers as needed through the standard I/O subsystem; a separate I/O space does not need to be implemented.

#### Processor State Restore (Resuming Normal Execution)

Returning to normal code execution in the main system memory, including restoring the Processor Operating Mode, is accomplished by executing a special code sequence. This code invokes a restore CPU state operation which reloads the CPU registers from the saved data in the RAM controlled by SMIADS and SMIRDY.

The ES:EDI register pair must point to physical address 60000h. Then the special opcode sequence 0Fh 07h should be executed to start the restore state operation. After completion of the restore state operation, the SMI pin will be deactivated by the CPU and normal code execution will continue at the point it left off before the SMI occurred. There are 114 data transfer cycles in the restore operation.

## **Software Features**

There are several features of the SMI function that provide support for special operations during the execution of the system's software. These features involve the execution of reserved opcodes to induce specific SMI related operations.

#### Software SMI Generation

Besides hardware initiation of the System Management Interrupt via the  $\overline{SMI}$  pin, there is also a software induced SMI mechanism. Generating a soft SMI involves setting a control bit in Debug Register 7 (DR7) and executing a reserved opcode (0F1H).

The functional sequence of the software based SMI is identical to the hardware based SMI with the exception that the  $\overline{SMI}$  pin is not initially driven active by an external source. Upon execution of a soft SMI opcode, the  $\overline{SMI}$  pin is driven active (Low) by the processor before the save state operation begins.

## Memory Transfers to Main System Memory

While executing an SMI routine, the interrupt code can initiate memory data reads and writes to the main system memory using the normal  $\overline{\text{ADS}}$  and  $\overline{\text{READY}}$  pins. This is accomplished by using reserved opcodes that are special forms of the MOV instruction (called UMOV). The UMOV opcodes can move byte, word, or double word register operands to or from main system memory. Multiple data transfers using the normal  $\overline{\text{ADS}}$  and  $\overline{\text{READY}}$  pins will occur if the operands are misaligned relative to the effective address used. The UMOV opcodes are 0F10h, 0F11h, 0F12h, and 0F13h.

## I/O Instruction Break

The Am386SXLV microprocessor has an I/O instruction break feature that allows the system logic to implement I/O trapping for peripheral devices. To enable the I/O Instruction break feature, IIBEN must first be asserted active Low. On detecting an I/O instruction, the processor will prevent the execution unit from executing further instructions until READY is driven active Low by the system. Once READY is driven active, the execution unit will either immediately respond to any active interrupt request or continue executing instructions following the I/O instruction that caused the break.

The I/O instruction break feature can be used to allow system logic to implement I/O trapping for peripheral devices. On sensing an I/O instruction, the system can drive the  $\overline{SMI}$  pin active before driving  $\overline{READY}$  active. This ensures that the SMI service routine is executed immediately following the I/O instruction that caused the break. (If the I/O instruction break feature is not enabled via  $\overline{IIBEN}$ , several instructions could execute before the SMI service routine is executed.)

The SMI service routine can access the peripheral for which SMI was asserted and modify its state. The SMI service routine will normally return to the instruction following the I/O instruction that caused the break. By modifying the saved state instruction pointer, the routine can choose to return to the I/O instruction that caused the break and re-execute that instruction. The default is to return to the following instruction (except for REP I/O string instruction). To re-execute the I/O instruction that caused the break, the SMI service routine must copy the I/O instruction pointer over the default pointer. This feature is particularly useful when an application program requests an access to a peripheral that has been powered down. The SMI service routine can restore power to the peripheral and initiate a re-execution sequence transparent to the application program. This re-execution feature should only be used if the SMI is in response to an I/O trap with IIBEN active. Note that the I/O instruction break feature is not enabled for memory mapped I/O devices or for coprocessor bus cycles even if **IIBEN** is active.

#### I/O Instruction Break Timing

The I/O Instruction Break feature requires that  $\overline{SMI}$  be sampled active (Low) by the processor at least three

CLK2 edges before the CLK2 edge that ends the I/O cycle with an active READY signal. This timing applies for both pipelined and non-pipelined cycles. If this timing constraint is not met, the next instruction may be executed by the internal execution unit prior to entering SMI Mode, but the SMI will be recognized eventually.

## **True Static Operation**

The Am386SXLV microprocessor incorporates a true static design. Unlike dynamic circuit design, the Am386SXLV device eliminates the minimum operating frequency restriction. It may be clocked from its maximum speed of 25 MHz all the way down to 0 MHz (DC). System designers can use this feature to design battery-powered notebook PCs with long battery life.

## **Standby Mode**

This true static design allows for a Standby Mode. At any operating speed (25 MHz to 0 MHz), the Am386SXLV microprocessor will retain its state (i.e., the contents of all of its registers). By shutting off the clock completely, the device enters Standby Mode. Since power consumption is proportional to clock frequency, operating power consumption is reduced as the frequency is lowered. In Standby Mode, typical current draw is reduced to less than 0.01 mA. Not only does this feature save battery life, but it also simplifies the design of power-conscious notebook computers in the following ways.

- 1. Eliminates the need for software in BIOS to save and restore the contents of registers
- Allows simpler circuitry to control stopping of the clock (since) the system does not need to know what state the processor is in

## Lower Operating Icc

True static design also allows lower operating Icc when operating at any speed. See the following graph for typical current at operating speeds.



## Performance on Demand

The Am386SXLV microprocessor retains its state at any speed from 0 MHz (DC) to its maximum operating speed. With this feature, system designers may vary the operating speed of the system to extend the battery life in notebook systems.

For example, the system could operate at low speeds during inactivity or polling operations. However, upon interrupt, the system clock can be increased up to its maximum speed. After a user-defined time-out period, the system can be returned to a low (or a 0 MHz) operating speed without losing its state. This design maximizes battery life while achieving optimal performance.

# CONNECTION DIAGRAM

**Top View** 





Notes: Pin 1 is marked for orientation. N/C = Not connected.

# PIN DESIGNATION TABLES (Sorted by Pin Name)

| Addı     | ress    | Da       | ita     | Cor      | ntrol   | NC      | V <sub>cc</sub> | V <sub>ss</sub> |
|----------|---------|----------|---------|----------|---------|---------|-----------------|-----------------|
| Pin Name | Pin No. | Pin Name | Pin No. | Pin Name | Pin No. | Pin No. | Pin No.         | Pin No.         |
| A1       | 18      | D0       | 1       | ADS      | 16      | 20      | 8               | 2               |
| A2       | 51      | D1       | 100     | BHE      | 19      | 27      | 9               | 5               |
| A3       | 52      | D2       | 99      | BLE      | 17      | 44      | 10              | 11              |
| A4       | 53      | D3       | 96      | BUSY     | 34      | 45      | 21              | 12              |
| A5       | 54      | D4       | 95      | CLK2     | 15      | 46      | 32              | 13              |
| A6       | 55      | D5       | 94      | D/C      | 24      | 47      | 39              | 14              |
| A7       | 56      | D6       | 93      | ERROR    | 36      |         | 42              | 22              |
| A8       | 58      | D7       | 92      | FLT      | 28      |         | 48              | 35              |
| A9       | 59      | D8       | 90      | HLDA     | 3       |         | 57              | 41              |
| A10      | 60      | D9       | 89      | HOLD     | 4       |         | 69              | 49              |
| A11      | 61      | D10      | 88      | TIBEN    | 29      |         | 71              | 50              |
| A12      | 62      | D11      | 87      | INTR     | 40      |         | 84              | 63              |
| A13      | 64      | D12      | 86      | LOCK     | 26      |         | 91              | 67              |
| A14      | 65      | D13      | 83      | M/IO     | 23      |         | 97              | 68              |
| A15      | 66      | D14      | 82      | NA       | 6       |         |                 | 77              |
| A16      | 70      | D15      | 81      | NMI      | 38      |         |                 | 78              |
| A17      | 72      |          |         | PEREQ    | 37      |         |                 | 85              |
| A19      | 73      |          |         | READY    | 7       |         |                 | 98              |
| A20      | 75      |          |         | RESET    | 33      |         |                 |                 |
| A21      | 76      |          |         | SMI      | 43      |         |                 |                 |
| A22      | 79      |          |         | SMIADS   | 31      |         |                 |                 |
| A23      | 80      |          |         | SMIRDY   | 30      |         |                 |                 |
|          |         |          |         | W/R      | 25      |         |                 |                 |

# PIN DESIGNATION TABLES (Sorted by Pin Number)

| Pin No. | Pin Name        |
|---------|-----------------|---------|-----------------|---------|-----------------|---------|-----------------|---------|-----------------|
| 1       | D0              | 21      | V <sub>cc</sub> | 41      | V <sub>ss</sub> | 61      | A11             | 81      | D15             |
| 2       | V <sub>ss</sub> | 22      | V <sub>ss</sub> | 42      | V <sub>cc</sub> | 62      | A12             | 82      | D14             |
| 3       | HLDA            | 23      | M/ĪŌ            | 43      | SMI             | 63      | V <sub>ss</sub> | 83      | D13             |
| 4       | HOLD            | 24      | D/C             | 44      | NC              | 64      | A13             | 84      | V <sub>cc</sub> |
| 5       | V <sub>ss</sub> | 25      | W∕R             | 45      | NC              | 65      | A14             | 85      | V <sub>ss</sub> |
| 6       | NA              | 26      | LOCK            | 46      | NC              | 66      | A15             | 86      | D12             |
| 7       | READY           | 27      | NC              | 47      | NC              | 67      | V <sub>ss</sub> | 87      | D11             |
| 8       | V <sub>cc</sub> | 28      | FLT             | 48      | V <sub>cc</sub> | 68      | V <sub>ss</sub> | 88      | D10             |
| 9       | V <sub>cc</sub> | 29      | IIBEN           | 49      | V <sub>ss</sub> | 69      | V <sub>cc</sub> | 89      | D9              |
| 10      | V <sub>cc</sub> | 30      | SMIRDY          | 50      | V <sub>ss</sub> | 70      | A16             | 90      | D8              |
| 11      | V <sub>ss</sub> | 31      | SMIADS          | 51      | A2              | 71      | V <sub>cc</sub> | 91      | V <sub>cc</sub> |
| 12      | V <sub>ss</sub> | 32      | V <sub>cc</sub> | 52      | A3              | 72      | A17             | 92      | D7              |
| 13      | V <sub>ss</sub> | 33      | RESET           | 53      | A4              | 73      | A18             | 93      | D6              |
| 14      | V <sub>ss</sub> | 34      | BUSY            | 54      | A5              | 74      | A19             | 94      | D5              |
| 15      | CLK2            | 35      | V <sub>ss</sub> | 55      | A6              | 75      | A20             | 95      | D4              |
| 16      | ADS             | 36      | ERROR           | 56      | A7              | 76      | A21             | 96      | D3              |
| 17      | BLE             | 37      | PEREQ           | 57      | V <sub>cc</sub> | 77      | V <sub>ss</sub> | 97      | V <sub>cc</sub> |
| 18      | A1              | 38      | NMI             | 58      | A8              | 78      | Vss             | 98      | V <sub>ss</sub> |
| 19      | BHE             | 39      | V <sub>cc</sub> | 59      | A9              | 79      | A22             | 99      | D2              |
| 20      | NC              | 40      | INTR            | 60      | A10             | 80      | A23             | 100     | D1              |

## ORDERING INFORMATION Standard Products

AMD standard products are available in several packages and operating ranges. The order number (Valid Combination) is formed by a combination of the elements below.



NG = 100-Pin Plastic Quad Flat Pack (PQ100, PQB100)

| Valid Combinations |           |              |  |  |  |
|--------------------|-----------|--------------|--|--|--|
|                    |           | 25<br>20     |  |  |  |
| NG                 | 80386SXLV | 25F<br>20F   |  |  |  |
|                    |           | -25S<br>-20S |  |  |  |

#### Valid Combinations

Valid Combinations lists configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations and to check on newly released combinations.

AMD

## LOGIC SYMBOL



### PIN DESCRIPTIONS

### A23–A1 Address Bus (Outputs)

Outputs physical memory or port I/O addresses.

### ADS

### Address Status (Active Low; Output)

Indicates that a valid bus cycle definition and address  $(W/\overline{R}, D/\overline{C}, M/\overline{IO}, \overline{BHE}, \overline{BLE}, and A23-A1)$  are being driven at the Am386SXLV microprocessor pins.

### BHE, BLE

### Byte Enables (Active Low; Outputs)

Indicate which data bytes of the data bus take part in a bus cycle.

### BUSY

### Busy (Active Low; Input)

Signals a busy condition from a processor extension. BUSY has an internal pullup resistor.

### CLK2

### CLK2 (Input)

Provides the fundamental timing for the Am386SXLV microprocessor.

### D15-D0

### Data Bus (Inputs/Outputs)

Inputs data during memory, I/O, and interrupt acknowledge read cycles; outputs data during memory and I/O write cycles.

### D/C

### Data/Control (Output)

A bus cycle definition pin that distinguishes data cycles, either memory or I/O, from control cycles which are: interrupt acknowledge, halt, and code fetch.

### ERROR

### Error (Active Low; Input)

Signals an error condition from a processor extension. ERROR has an internal pullup resistor.

### FLT

### Float (Active Low; Input)

An input which forces all bi-directional and output signals, including HLDA, to the three-state condition. FLT has an internal pullup resistor. The pin, if not used, should be disconnected.

### HLDA

### Bus Hold Acknowledge (Active High; Output)

Output indicates that the Am386SXLV microprocessor has surrendered control of its logical bus to another bus master.

### HOLD

### Bus Hold Request (Active High; Input)

Input allows another bus master to request control of the local bus.

### IIBEN

### I/O Instruction Break Enable (Active Low; Input)

Enables the I/O instruction break feature. IIBEN has an internal pullup resistor.

### INTR

### Interrupt Request (Active High; Input)

A maskable input that signals the Am386SXLV microprocessor to suspend execution of the current program and execute an interrupt acknowledge function.

### LOCK

### Bus Lock (Active Low; Output)

A bus cycle definition pin that indicates that other system bus masters are not to gain control of the system bus while it is active.

### M/ĪŌ

### Memory/IO (Output)

A bus cycle definition pin that distinguishes memory cycles from input/output cycles.

### NA

### Next Address (Active Low; Input)

Used to request address pipelining.

### NC

### No Connect

Should always be left unconnected. Connection of a NC pin may cause the processor to malfunction or be incompatible with future steppings of the Am386SXLV microprocessor.

### NMI

# Non-Maskable Interrupt Request (Active High; Input)

A non-maskable input that signals the Am386SXLV microprocessor to suspend execution of the current program and execute an interrupt acknowledge function.

### PEREQ

### Processor Extension Request (Active High; Input)

Indicates that the processor has data to be transferred by the Am386SXLV microprocessor. PEREQ has an internal pulldown resistor.

### READY

### **Bus Ready (Active Low; Input)**

Terminates the bus cycle.

### RESET

### Reset (Active High; Input)

Suspends any operation in progress and places the Am386SXLV microprocessor in a known reset state.

### SMI

### System Management Interrupt (Active Low; I/O)

A non-maskable interrupt pin which signals the Am386SXLV microprocessor to suspend execution and enter System Management Mode. SMI has an internal pullup resistor.

### SMIADS

# SMI Address Status (Active Low Three-State; Output)

When active, this pin indicates that a valid bus cycle definition and address (W/R D/ $\overline{C}$ , M/ $\overline{IO}$ ,  $\overline{BHE}$ ,  $\overline{BLE}$ , and A23–A1) are being driven at the Am386SXLV microprocessor pins while in the System Management Mode.

### SMIRDY

### SMI Ready (Active Low; Input)

This input terminates the current bus cycle to the <u>SMM</u> Mode address space in the same manner as the <u>READY</u> pin does for the normal mode address space. <u>SMIRDY</u> has an internal pullup resistor.

### $V_{cc}$

### System Power (Active High; Input)

Provides the DC supply input.

### $V_{ss}$

### System Ground (Input)

Provides the 0-V connection from which all inputs and outputs are measured.

### W/R

### Write/Read (Output)

A bus cycle definition pin that distinguishes write cycles from read cycles.

### ABSOLUTE MAXIMUM RATINGS

Stresses above those listed may cause permanent damage to the device. Functionality at or above these limits is not implied. Exposure to ABSOLUTE MAXI-MUM RATING conditions for extended periods of time may affect device reliability.

### **OPERATING RANGES**

Supply Voltage with respect to Vss . . -0.5 V to +7.0 V Voltage on Other Pins . . . . . . -0.5 V to V<sub>∞</sub> +0.5 V

Operating ranges define those limits between which the functionality of the device is guaranteed.

### DC CHARACTERISTICS over COMMERCIAL operating ranges

Vcc = 3.0 V to 3.6 V; Tcase = 0°C to +100°C

|                   |                                                                                                                               |                                                                                  | Prelin                                                                   | ninary                     |                          |  |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|--------------------------------------------------------------------------|----------------------------|--------------------------|--|
| Symbol            | Parameter Description                                                                                                         | Notes                                                                            | Min                                                                      | Max                        | Unit                     |  |
| V <sub>IL</sub>   | Input Low Voltage                                                                                                             | (Note 1)                                                                         | -0.3                                                                     | +0.8                       | V                        |  |
| V <sub>IH</sub>   | Input High Voltage                                                                                                            |                                                                                  | 2.0                                                                      | V <sub>cc</sub> +0.3       | V                        |  |
| V <sub>ILC</sub>  | CLK2 Input Low Voltage                                                                                                        | (Note 1)                                                                         | -0.3                                                                     | +0.8                       | V                        |  |
| V <sub>IHC</sub>  | CLK2 Input High Voltage 16, 20 MHz                                                                                            |                                                                                  | $V_{cc}$ -0.6                                                            | V <sub>cc</sub> +0.3       | V                        |  |
| V <sub>oL</sub>   | $\begin{array}{llllllllllllllllllllllllllllllllllll$                                                                          | (Note 5)                                                                         |                                                                          | 0.2<br>0.2<br>0.45<br>0.45 | v<br>v<br>v              |  |
| V <sub>он</sub>   | $\begin{array}{llllllllllllllllllllllllllllllllllll$                                                                          | (Note 5)                                                                         | $V_{cc}^{-} 0.2 \\ V_{cc}^{-} 0.2 \\ V_{cc}^{-} 0.45 \\ V_{cc}^{-} 0.45$ |                            | V<br>V<br>V<br>V         |  |
| lu                | Input Leakage Current (All pins except<br>PEREQ, BUSY, ERROR, SMI, SMIRDY, FLT,<br>IIBEN)                                     | $0 V \le V_{iN} \le V_{cc}$                                                      |                                                                          | ±15                        | μA                       |  |
| l <sub>in</sub>   | Input Leakage Current<br>(PEREQ pin)                                                                                          | V <sub>IH</sub> = V <sub>cc</sub> –0.1 V<br>V <sub>IH</sub> = 2.4 V (Note 2)     |                                                                          | 300<br>200                 | μ <b>Α</b><br>μ <b>Α</b> |  |
| l <sub>iL</sub>   | Input Leakage Current<br>(BUSY, ERROR, SMI, SMIRDY, FLT, IIBEN )                                                              | V <sub>IL</sub> = 0.1 V<br>V <sub>IL</sub> = 0.45 V (Note 3)                     |                                                                          | -300<br>-200               | μ <b>Α</b><br>μΑ         |  |
| I <sub>LO</sub>   | Output Leakage Current                                                                                                        | 0.1 V ≤ V <sub>out</sub> ≤ V <sub>cc</sub>                                       |                                                                          | ±15                        | μA                       |  |
| I <sub>cc</sub>   | Supply Current<br>CLK2 = 32 MHz: Oper. Freq. 16 MHz<br>CLK2 = 40 MHz: Oper. Freq. 20 MHz<br>CLK2 = 50 MHz: Oper. Freq. 25 MHz | I <sub>cc</sub> Typ = 65<br>I <sub>cc</sub> Typ = 80<br>I <sub>cc</sub> Typ = 95 |                                                                          | 95<br>110<br>125           | mA<br>mA<br>mA           |  |
| I <sub>ccsb</sub> | Standby Current                                                                                                               | I <sub>ссsв</sub> Тур=10                                                         |                                                                          | 150                        | μA                       |  |
| C <sub>IN</sub>   | Input or I/O Capacitance                                                                                                      | F <sub>c</sub> = 1 MHz (Note 4)                                                  |                                                                          | 10                         | pF                       |  |
| C <sub>OUT</sub>  | Output Capacitance                                                                                                            | F <sub>c</sub> = 1 MHz (Note 4)                                                  |                                                                          | 12                         | pF                       |  |
| С <sub>ськ</sub>  | CLK2 Capacitance                                                                                                              | F <sub>c</sub> = 1 MHz (Note 4)                                                  |                                                                          | 20                         | pF                       |  |

Notes: 1. The min value, -0.3, is not 100% tested.

2. PEREQ input has an internal pulldown resistor.

3. BUSY, ERROR, FLT, SMI, IIBEN, and SMIRDY inputs each have an internal pullup resistor.

4. Not 100% tested.

5. Outputs are CMOS and will pull rail to rail if the load is not resistive.

### ABSOLUTE MAXIMUM RATINGS

Stresses above those listed may cause permanent damage to the device. Functionality at or above these limits is not implied. Exposure to ABSOLUTE MAXI-MUM RATING conditions for extended periods of time may affect device reliability.

### **OPERATING RANGES**

Supply Voltage with respect to Vss  $\ldots$  -0.5 V to +7 V Voltage on Other Pins  $\ldots$   $\ldots$  -0.5 V to V\_{\infty} +0.5 V

Operating ranges define those limits between which the functionality of the device is guaranteed.

### DC CHARACTERISTICS over COMMERCIAL operating ranges

 $V_{CC} = 3.6 V$  to 5.5 V;  $T_{CASE} = 0^{\circ}C$  to  $+100^{\circ}C$ 

|                   |                                                                                                                                             |                                                                                               | Prelir                                                       | ninary               |                |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|--------------------------------------------------------------|----------------------|----------------|
| Symbol            | Parameter Description                                                                                                                       | Notes                                                                                         | Min                                                          | Max                  | Unit           |
| V <sub>IL</sub>   | Input Low Voltage                                                                                                                           | (Note 1)                                                                                      | -0.3                                                         | +0.8                 | V              |
| V <sub>IH</sub>   | Input High Voltage                                                                                                                          |                                                                                               | 2.0                                                          | V <sub>cc</sub> +0.3 | V              |
| VILC              | CLK2 Input Low Voltage                                                                                                                      | (Note 1)                                                                                      | -0.3                                                         | +0.8                 | V              |
| VIHC              | CLK2 Input High Voltage                                                                                                                     |                                                                                               | $V_{cc} - 0.8$                                               | V <sub>cc</sub> +0.3 | V              |
| V <sub>ol</sub>   | Output Low Voltage<br>I <sub>oL</sub> = 4 mA: A23–A1, D15–D0<br>I <sub>oL</sub> = 5 mA: BHE, BLE, W/R, D/C, M/O,<br>LOCK, ADS, SMIADS, HLDA | (Note 5)                                                                                      |                                                              | 0.45<br>0.45         | v<br>v         |
| V <sub>он</sub>   | $\begin{array}{llllllllllllllllllllllllllllllllllll$                                                                                        | (Note 5)                                                                                      | 2.4<br>V <sub>cc</sub> - 0.5<br>2.4<br>V <sub>cc</sub> - 0.5 |                      | v<br>v<br>v    |
| l <sub>u</sub>    | Input Leakage Current (All pins except<br>PEREQ, BUSY, ERROR, SMI, SMIRDY, FLT,<br>and IIBEN )                                              | $0 \text{ V} \leq \text{V}_{\text{IN}} \leq \text{V}_{\text{CC}}$                             |                                                              | ±15                  | μA             |
| l <sub>in</sub>   | Input Leakage Current (PEREQ pin)                                                                                                           | V <sub>IH</sub> = 2.4 V (Note 2)                                                              |                                                              | 200                  | μ <b>A</b>     |
| l <sub>iL</sub>   | Input Leakage Current (BUSY, ERROR, SMI,<br>SMIRDY, FLT, IIBEN)                                                                             | V <sub>IL</sub> = 0.45 V (Note 3)                                                             |                                                              | -400                 | μA             |
| I <sub>LO</sub>   | Output Leakage Current                                                                                                                      | $0.45 \text{ V} \leq \text{V}_{\text{out}} \leq \text{V}_{\text{cc}}$                         |                                                              | ±15                  | μ <b>A</b>     |
| I <sub>cc</sub>   | Supply Current<br>CLK2 = 32 MHz: Oper. Freq. 16 MHz<br>CLK2 = 40 MHz: Oper. Freq. 20 MHz<br>CLK2 = 50 MHz: Oper. Freq. 25 MHz               | $V_{cc} = 5.5 V \\ I_{cc} Typ = 135 \\ I_{cc} Typ = 165 \\ I_{cc} Typ = 210 \\ \end{bmatrix}$ |                                                              | 160<br>200<br>250    | mA<br>mA<br>mA |
| I <sub>CCSB</sub> | Standby Current                                                                                                                             | I <sub>ccsв</sub> Тур = 0.02 mA                                                               |                                                              | 0.15                 | mA             |
| C <sub>IN</sub>   | Input or I/O Capacitance                                                                                                                    | F <sub>c</sub> = 1 MHz (Note 4)                                                               |                                                              | 10                   | pF             |
| Cout              | Output Capacitance                                                                                                                          | F <sub>c</sub> = 1 MHz (Note 4)                                                               |                                                              | 12                   | pF             |
| C <sub>clk</sub>  | CLK2 Capacitance                                                                                                                            | F <sub>c</sub> = 1 MHz (Note 4)                                                               |                                                              | 20                   | pF             |

Notes: 1. The min value, -0.3, is not 100% tested.

2. PEREQ input has an internal pulldown resistor.

3. BUSY, ERROR, FLT, SMI, IIBEN, and SMIRDY inputs each have an internal pullup resistor.

4. Not 100% tested.

5. Outputs are CMOS and will pull rail to rail if the load is not resistive.



### SWITCHING CHARACTERISTICS

The switching characteristics given consist of output delays, input setup requirements, and input hold requirements. All switching characteristics are relative to the CLK2 rising edge crossing the 2.0 V level.

Switching characteristic measurement is defined by Figure 2. Inputs must be driven to the voltage levels indicated by Figure 2 when switching characteristics are measured. Output delays are specified with minimum and maximum limits measured, as shown. The minimum delay times are hold times provided to external circuitry. Input setup and hold times are specified as minimums, defining the smallest acceptable sampling window. Within the sampling window, a synchronous input signal must be stable for correct operation.

Outputs ADS, W/R, D/C, M/IO, LOCK, BHE, BLE, SMIADS, A23–A1, and HLDA only change at the beginning of phase one. D15–D0 (write cycles) only change at the beginning of phase two. The READY, HOLD, BUSY, SMIRDY, ERROR, PEREQ, FLT, and D15–D0 (read cycles) inputs are sampled at the beginning of phase one. The NA, INTR, NMI, and SMI inputs are sampled at the beginning of phase two.



Figure 2. Drive Levels and Measurement Points for Switching Characteristics



### SWITCHING CHARACTERISTICS over operating ranges at 25 MHz

 $V_{cc} = 3.0 \text{ V} - 5.5 \text{ V}$ ;  $T_{case} = 0^{\circ}\text{C}$  to  $100^{\circ}\text{C}$ 

|        |                                    |                                            |                 | Prelimina | ry       |      |
|--------|------------------------------------|--------------------------------------------|-----------------|-----------|----------|------|
| Symbol | Parameter Description              | Notes                                      | Ref.<br>Figures | Min       | Мах      | Unit |
|        | Operating Frequency                | Half CLK2 freq.                            |                 | 0         | 25       | MHz  |
| 1      | CLK2 Period                        |                                            | 3               | 20        |          | ns   |
| 2a     | CLK2 High Time                     | at 2 V                                     | 3               | 7         |          | ns   |
| 2b     | CLK2 High Time                     | at (V <sub>cc</sub> −0.8 V)                | 3               | 4         |          | ns   |
| 3a     | CLK2 Low Time                      | at 2 V                                     | 3               | 7         |          | ns   |
| 3b     | CLK2 Low Time                      | at 0.8 V                                   | 3               | 5         |          | ns   |
| 4      | CLK2 Fall Time                     | (V <sub>cc</sub> -0.8 V) to 0.8 V (Note 3) | 3               |           | 7        | ns   |
| 5      | CLK2 Rise Time                     | 0.8 V to (V <sub>cc</sub> -0.8 V) (Note 3) | 3               |           | 7        | ns   |
| 6      | A23–A1 Valid Delay                 | C <sub>L</sub> = 50 pF                     | 6               | 4         | 17       | ns   |
| 7      | A23-A1 Float Delay                 | (Note 1)                                   | 10              | 4         | 30       | ns   |
| 8      | BHE, BLE, LOCK Valid Delay         | C <sub>L</sub> = 50 pF                     | 6               | 4         | 17       | ns   |
| 9      | BHE, BLE, LOCK Float Delay         | (Note 1)                                   | 10              | 4         | 30       | ns   |
| 10     | M/IO, D/C, W/R, ADS Valid Delay    | C <sub>L</sub> = 50 pF                     | 6               | 4         | 17       | ns   |
| 10s    | SMIADS Valid Delay                 | C <sub>L</sub> = 50 pF                     | 6               | 4         | 25       | ns   |
| 11     | W/R, M/IO, D/C, ADS Float Delay    | (Note 1)                                   | 10              | 4         | 30       | ns   |
| 11s    | SMIADS Float Delay                 | (Note 1)                                   | 10              | 4         | 30       | ns   |
| 12     | D15-D0 Write Data Valid Delay      | C <sub>L</sub> = 50 pF                     | 6, 7, 9         | 7         | 23       | ns   |
| 12a    | D15-D0 Write Data Hold Time        | $C_{L} = 50  pF$                           | 8               | 2         |          | ns   |
| 13     | D15–D0 Write Data Float Delay      | (Note 1)                                   | 10              | 4         | 22       | ns   |
| 14     | HLDA Valid Delay                   | $C_{L} = 50  pF$                           | 6               | 4         | 22       | ns   |
| 15     | NA Setup Time                      |                                            | 5               | 5         | 1        | ns   |
| 16     | NA Hold Time                       |                                            | 5               | 3         |          | ns   |
| 19     | READY Setup Time                   | · · · · · · · · · · · · · · · · · · ·      | 5               | 9         |          | ns   |
| 19s    | SMIRDY Setup Time                  |                                            | 5               | 9         |          | ns   |
| 20     | READY Hold Time                    |                                            | 5               | 4         |          | ns   |
| 20s    | SMIRDY Hold Time                   |                                            | 5               | 4         |          | ns   |
| 21     | D15–D0 Read Data Setup Time        |                                            | 5               | 7         |          | ns   |
| 22     | D15-D0 Read Data Hold Time         |                                            | 5               | 5         |          | ns   |
| 23     | HOLD Setup Time                    |                                            | 5               | 9         | 1        | ns   |
| 24     | HOLD Hold Time                     |                                            | 5               | 3         |          | ns   |
| 25     | RESET Setup Time                   |                                            | 11              | 8         |          | ns   |
| 26     | RESET Hold Time                    |                                            | 11              | 3         |          | ns   |
| 27     | NMI, INTR Setup Time               | (Note 2)                                   | 5               | 6         | <u> </u> | ns   |
| 27s    | SMI Setup Time                     | (Note 2)                                   | 5               | 6         |          | ns   |
| 28     | NMI, INTR Hold Time                | (Note 2)                                   | 5               | 6         | <u> </u> | ns   |
| 28s    | SMI Hold Time                      | (Note 2)                                   | 5               | 6         | <u> </u> | ns   |
| 29     | PEREQ, ERROR, BUSY, FLT Setup Time | (Note 2)                                   | 5               | 6         | <u> </u> | ns   |
| 30     | PEREQ, ERROR, BUSY, FLT Hold Time  | (Note 2)                                   | 5               | 5         |          | ns   |

Notes: 1. Float condition occurs when maximum output current becomes less than ILO in magnitude. Float delay is not 100% tested.

2. These inputs are allowed to be asynchronous to CLK2. The setup and hold specifications are given for testing purposes, to assure recognition within a specific CLK2 period.

3. These are not tested. They are guaranteed by design characterization.

### SWITCHING CHARACTERISTICS over operating ranges at 20 MHz

 $V_{cc} = 3.0 \text{ V}$  to 5.5 V;  $T_{case} = 0^{\circ}\text{C}$  to 100°C

|        |                                    | Concernance of the local division of the loc | Prelimina | у               |     |     |      |
|--------|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----------------|-----|-----|------|
| Symbol | Parameter Description              | Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           | Ref.<br>Figures | Min | Max | Unit |
|        | Operating Frequency                | Half CLK2 freq.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           |                 | 0   | 20  | MHz  |
| 1      | CLK2 Period                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           | 3               | 25  |     | ns   |
| 2a     | CLK2 High Time                     | at 2 V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |           | 3               | 8   |     | ns   |
| 2b     | CLK2 High Time                     | at (V <sub>cc</sub> -0.8 V)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |           | 3               | 5   |     | ns   |
| За     | CLK2 Low Time                      | at 2 V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |           | 3               | 8   |     | ns   |
| Зb     | CLK2 Low Time                      | at 0.8 V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |           | 3               | 6   |     | ns   |
| 4      | CLK2 Fall Time                     | (V <sub>cc</sub> -0.8 V) to 0.8 V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | (Note 3)  | 3               |     | 8   | ns   |
| 5      | CLK2 Rise Time                     | 0.8 V to (V <sub>cc</sub> -0.8 V)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | (Note 3)  | 3               |     | 8   | ns   |
| 6      | A23–A1 Valid Delay                 | C <sub>L</sub> = 120 pF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | (Note 4)  | 6               | 4   | 30  | ns   |
| 7      | A23-A1 Float Delay                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | (Note 1)  | 10              | 4   | 32  | ns   |
| 8      | BHE, BLE, LOCK Valid Delay         | С <sub>L</sub> = 75 рF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | (Note 4)  | 6               | 4   | 30  | ns   |
| 9      | BHE, BLE, LOCK Float Delay         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | (Note 1)  | 10              | 4   | 32  | ns   |
| 10a    | M/IO, D/C Valid Delay              | C <sub>L</sub> = 75 pF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | (Note 4)  | 6               | 4   | 28  | ns   |
| 10b    | W/R, ADS Valid Delay               | C <sub>L</sub> = 75 pF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | (Note 4)  | 6               | 4   | 26  | ns   |
| 10s    | SMIADS Valid Delay                 | C <sub>L</sub> = 75 pF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | (Note 4)  | 6               | 4   | 26  | ns   |
| 11     | W/R, M/IO, D/C, ADS Float Delay    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | (Note 1)  | 10              | 6   | 30  | ns   |
| 11s    | SMIADS Float Delay                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | (Note 1)  | 10              | 4   | 30  | ns   |
| 12     | D15-D0 Write Data Valid Delay      | C <sub>L</sub> = 120 pF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | (Note 4)  | 6, 7, 9         | 4   | 38  | ns   |
| 13     | D15-D0 Write Data Float Delay      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | (Note 1)  | 10              | 4   | 27  | ns   |
| 14     | HLDA Valid Delay                   | C <sub>1</sub> = 75 pF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | (Note 4)  | 6               | 4   | 28  | ns   |
| 15     | NA Setup Time                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           | 5               | 5   |     | ns   |
| 16     | NA Hold Time                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           | 5               | 12  |     | ns   |
| 19     | READY Setup Time                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           | 5               | 12  |     | ns   |
| 19s    | SMIRDY Setup Time                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           | 5               | 12  |     | ns   |
| 20     | READY Hold Time                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           | 5               | 4   |     | ns   |
| 20s    | SMIRDY Hold Tme                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           | 5               | 4   |     | ns   |
| 21     | D15–D0 Read Data Setup Time        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           | 5               | 9   |     | ns   |
| 22     | D15-D0 Read Data Hold Time         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           | 5               | 6   |     | ns   |
| 23     | HOLD Setup Time                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           | 5               | 17  |     | ns   |
| 24     | HOLD Hold Time                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           | 5               | 5   |     | ns   |
| 25     | RESET Setup Time                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           | 11              | 12  |     | ns   |
| 26     | RESET Hold Time                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           | 11              | 4   |     | ns   |
| 27     | NMI, INTR Setup Time               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | (Note 2)  | 5               | 16  |     | ns   |
| 27s    | SMI Setup Time                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | (Note 2)  | 5               | 16  |     | ns   |
| 28     | NMI, INTR Hold Time                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | (Note 2)  | 5               | 16  |     | ns   |
| 28s    | SMI Hold Time                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | (Note 2)  | 5               | 16  |     | ns   |
| 29     | PEREQ, ERROR, BUSY, FLT Setup Time |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | (Note 2)  | 5               | 14  |     | ns   |
| 30     | PEREQ, ERROR, BUSY, FLT Hold Time  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | (Note 2)  | 5               | 5   |     | ns   |

Notes: 1. Float condition occurs when maximum output current becomes less than I<sub>LO</sub> in magnitude. Float delay is not 100% tested.
 These inputs are allowed to be asynchronous to CLK2. The setup and hold specifications are given for testing purposes, to assure recognition within a specific CLK2 period.

3. These are not tested. They are guaranteed by design characterization.

 Tested with C<sub>L</sub> set at 50 pF and derated to support the indicated distributed capacitive load. See Figures 12–14 for the capacitive derating curve.

### SWITCHING CHARACTERISTICS (continued)



15022B-031





15022B-032



### SWITCHING WAVEFORMS



15022B-033

Figure 5. Input Setup and Hold Timing



15022B-034





Figure 9. Write Data Valid Delay Timing (20 MHz)

### SWITCHING WAVEFORMS (continued)



Figure 10. Output Float Delay and HLDA Valid Delay Timing



15022B-036

Figure 11. RESET Setup and Hold Timing and Internal Phase





Figure 13. Typical Output Valid Delay Versus Load Capacitance at Maximum Operating Temperature (C, = 75 pF)



Figure 14. Typical Output Valid Delay Versus Load Capacitance at Maximum Operating Temperature (CL = 50 pF) Figure 15. Typical Output Rise Time Versus Load Capacitance at Maximum Operating Temperature

Am386<sup>TM</sup>DX High-Performance 32-Bit Microprocessor

### DISTINCTIVE CHARACTERISTICS

- Compatible with 386DX systems and software
- 40-, 33-, 25-, and 20-MHz clock speeds
- 32-bit microprocessor for personal computers and embedded systems
- 32-bit address and data bus for high performance
  - -4-Gb physical address space

--64-tb virtual address space --4-Gb maximum segment size

- Supports 387DX-compatible math coprocessor
- AMD advanced 0.8 micron CMOS technology
- 132-lead ceramic PGA package or optional
   132-lead plastic quad flat pack (PQFP) package

**GENERAL DESCRIPTION** 

The Am386DX microprocessor is a compatible implementation of the Intel i386DX. It is engineered to meet strict requirements for compatibility. It is compatible with 386DX-based hardware, and is in fact a plug-in replacement for the Intel i386DX. It is also compatible with operating systems written for the 386 and the wide variety of commercially available software applications.

The Am386DX device is an advanced 32-bit microprocessor designed for applications needing very high performance. This device offers a 21% increase in performance from 33 to 40 MHz. The 32-bit registers and data paths support 32-bit addresses and data types. The processor addresses up to 4 Gb of physical memory and 64 tb of virtual memory. The integrated memory management and protection architecture allow high-performance execution of operating systems including DOS, Windows, OS/2, and UNIX.

The device is manufactured using the AMD advanced 0.8 micron CMOS process and is packaged in a standard 132-lead ceramic pin grid array (PGA) package. Additionally, the Am386DX microprocessor will be available in a small footprint 132-pin plastic quad flat pack (PQFP) package. This surface-mount package is 40% smaller than PGA allowing smaller, lower cost board designs without the need for a socket.

### **BLOCK DIAGRAM**



\*Float feature available in Rev. C0 and later, PQFP only.

### INTRODUCTION

AMD is proud to provide the Am386DX microprocessor at a time when the personal computer market requires alternatives. Alternate source manufacturers traditionally increase availability, add features, and broaden the market. AMD has focused significant engineering resources to bring you these benefits.

AMD's track record with the 80286 shows that we were first to raise the performance of the 80286 from 8 MHz to 10, 12, and 16 MHz. We were first to offer new packaging technology with a smaller, lower cost PLCC. Today, over 90% of all 80286s sold use PLCC packaging. AMD is committed to similar advances with the Am386DX microprocessor.

Another member of the family is the Am386DXL microprocessor. This device offers several enhancements including operating speeds up to 40 MHz, true static compatibility, and a small footprint cost-saving PQFP package. The Am386DXL microprocessor provides higher speeds and lower heat dissipation for desktop PCs, allowing the use of a smaller, or even, no cooling fan. For portables, its true static design allows for longer battery life with low power consumption and standby mode. (See Am386DXL CPU Data Sheet for more information—order #15484.)

AMD has engineered the Am386DX microprocessor to insure compatibility with the installed base of hardware and software for 386-based personal computers. The Am386DX microprocessor is your solution to meet the demand for high-performance, 32-bit personal computers.

### CONNECTION DIAGRAMS 132-Lead Ceramic Pin Grid Array (PGA) Package

| CFI | iii Gi          | iu ,                 | 4110                 | y (                         | гu              | A)                   | ra              | ina                  | ye              |                      |                 |                             |                      |                      |                      |     |
|-----|-----------------|----------------------|----------------------|-----------------------------|-----------------|----------------------|-----------------|----------------------|-----------------|----------------------|-----------------|-----------------------------|----------------------|----------------------|----------------------|-----|
|     |                 |                      |                      |                             |                 |                      |                 | ide                  |                 |                      | -               |                             | •                    |                      |                      |     |
|     | P               | N                    | M                    | L                           | К               |                      | н               | G                    |                 |                      | E               | D                           | c                    | <u>В</u>             | ^                    |     |
| 1   | A30             | O<br>A27             | O<br>A26             | O<br>A23                    | <b>O</b><br>A21 | <b>O</b><br>A20      | 0<br>A17        | O<br>A16             |                 | )<br>15              | <b>O</b><br>A14 | <b>O</b><br>A11             | <b>O</b><br>A8       | О<br><sub>Vss</sub>  | 0 `<br>v             | 1   |
| 2   | 0               | 0                    | 0                    | 0                           | 0               | 0                    | 0               | 0                    | C               | 2                    | 0               | 0                           | 0                    | 0                    | Ő                    | 2   |
| 3   | V <sub>cc</sub> | A31<br>O             | A29<br>O             | A24<br>O                    | A22<br>0        | V <sub>ss</sub><br>O | A18<br>O        | v<br>0               |                 | ss<br>D              | A13<br>O        | A10<br>O                    | A7<br><b>O</b>       | А5<br>О              | V <sub>ss</sub><br>O | 3   |
| 3   | D30             | $V_{\text{ss}}$      | V <sub>cc</sub>      | A28                         |                 | Vss                  | A19             | Vcc                  |                 |                      | A12             | A9                          | A6                   | A4                   | A3                   |     |
| 4   | 0<br>D29        | О<br>V <sub>сс</sub> | 0<br>V <sub>ss</sub> |                             |                 |                      |                 |                      |                 |                      |                 |                             | <b>O</b><br>A2       | O<br>NC              | O<br>NC              | 4   |
| 5   | 0               | 0                    | 0                    |                             |                 |                      |                 |                      |                 |                      |                 |                             | 0                    | 0                    | 0                    | 5   |
| 6   | 0               | D27<br><b>O</b>      | D31<br><b>O</b>      |                             |                 |                      |                 |                      |                 |                      |                 |                             | V<br>O               | V <sub>ss</sub><br>O | v<br>O               | 6   |
| 7   | V <sub>ss</sub> | D25<br><b>O</b>      | D28<br><b>O</b>      |                             |                 |                      |                 |                      |                 |                      |                 |                             | NC<br>O              | NC<br>O              | v <sub>ss</sub><br>O | 7   |
|     | D24             | $V_{cc}$             | V <sub>cc</sub>      |                             |                 |                      |                 |                      |                 |                      |                 |                             | NC                   | INTR                 | $V_{cc}$             |     |
| 8   |                 | <b>O</b><br>D23      | O<br>V <sub>ss</sub> |                             |                 |                      |                 |                      |                 |                      |                 | P                           | OPEREQ               | O<br>NMI             | o<br>Errof           | 8   |
| 9   | 0               | <b>O</b><br>D21      | <b>Ö</b><br>D20      |                             |                 |                      |                 |                      |                 |                      |                 | R                           | O                    | O                    | O<br>Var             | 9   |
| 10  | 0               | 0                    | 0                    |                             |                 |                      |                 |                      |                 |                      |                 |                             | 0                    | 0                    | Õ                    | 10  |
|     | D19             | D17<br><b>O</b>      | V <sub>ss</sub><br>O |                             |                 |                      |                 |                      |                 |                      |                 |                             | OCK                  | ₩/Ŕ<br>0             | V<br>0               |     |
| 11  |                 | D16                  | D15                  |                             |                 |                      |                 |                      |                 |                      |                 |                             | Vss                  | Vss                  | D/C                  | 11  |
| 12  | 0<br>D14        | <b>O</b><br>D12      | <b>O</b><br>D10      | <b>O</b><br>V <sub>cc</sub> | <b>O</b><br>D7  | 0<br>V <sub>ss</sub> | <b>O</b><br>D0  | 0<br>Vcc             |                 | <b>)</b><br>.к2      | O<br>BEO        | <b>O</b><br>V <sub>cc</sub> | О<br>V <sub>сс</sub> | O<br>NC              | <b>О</b><br>м/Ю      | 12  |
| 13  | 0               | 0                    | 0                    | 0                           | 0               | 0                    | 0               | 0                    | C               | C                    | 0               | 0                           | 0                    | 0                    | 0                    | 13  |
| 14  | D13             | 0                    | V <sub>cc</sub><br>O | D8<br><b>O</b>              | D5<br><b>O</b>  | V <sub>ss</sub><br>O | 0               | READ                 |                 | с<br>Э               | NC<br>O         |                             | BET                  | BE2<br>O             | BE3<br>O             | 14  |
|     | Vss             | D9                   | HLDA                 | D6                          | D4              | D3                   | D2              | Vcc                  | V               | <b>SS</b>            | ADS I           | HOLD                        | BS16                 | $V_{\rm ss}$         | Vcc                  |     |
|     | P               | N                    | м                    | L                           | к               | J                    | н               | G                    |                 | =                    | Е               | D                           | С                    | в                    | A                    |     |
|     |                 |                      |                      | -                           |                 |                      |                 | ide \                |                 |                      |                 |                             |                      |                      | -                    |     |
|     | $\hat{}$        | B                    |                      |                             |                 | E                    | F               | G                    | <u>н</u>        |                      | <u>к</u>        | <u> </u>                    | <u>M</u>             | N                    | - <sup>P</sup>       |     |
| 1   |                 | O<br>V <sub>ss</sub> | O<br>8A              |                             |                 | <b>O</b><br>\14      | <b>O</b><br>A15 | O<br>A16             | 0<br>A17        |                      | 0<br>A21        | <b>O</b><br>A23             | <b>O</b><br>A26      | O<br>A27             | <b>O</b><br>A30      | ] 1 |
| 2   | O<br>Vss        | <b>O</b><br>A5       | 0<br>A7              | -                           |                 | 0                    | O<br>Vss        | О<br><sub>Vcc</sub>  | <b>O</b><br>A18 | 0<br>V <sub>ss</sub> | 0<br>A22        | <b>O</b><br>A24             | <b>O</b><br>A29      | <b>O</b><br>A31      | О<br>V <sub>сс</sub> | 2   |
| 3   | 0               | õ                    | õ                    |                             |                 | 0                    | O               | Ö                    | 0               | 0                    | 0               | 0                           | 0                    | 0                    | O<br>O               | з   |
|     | A3              | A4                   | A6                   |                             | 9 4             | 12                   | Vss             | $V_{cc}$             | A19             | Vss                  | A25             | A28                         |                      | Vss                  | D30                  |     |
| 4   | O<br>NC         | O<br>NC              | 0<br>A2              |                             |                 |                      |                 |                      |                 |                      |                 | ]                           | O<br>Vss             | О<br><sub>Vcc</sub>  | <b>O</b><br>D29      | 4   |
| 5   | 0<br>V          | 0<br>V <sub>ss</sub> | 0<br>V               |                             | ]               |                      |                 |                      |                 |                      |                 |                             | <b>O</b><br>D31      | <b>O</b><br>D27      | <b>O</b><br>D26      | 5   |
| 6   | 0               | 0                    | 0                    |                             |                 |                      |                 |                      |                 |                      |                 |                             | 0                    | 0                    | 0                    | 6   |
| 7   |                 | NC<br>O              |                      |                             |                 |                      |                 |                      |                 |                      |                 |                             | D28<br><b>O</b>      | D25                  | V <sub>ss</sub><br>O | 7   |
| 8   | V <sub>cc</sub> | INTR                 | NC                   | ;                           |                 |                      | Ν               | letal L              | id              |                      |                 |                             | V <sub>cc</sub>      | Vcc                  | D24                  |     |
|     | O               |                      |                      | EQ                          |                 |                      |                 |                      |                 |                      |                 |                             | O<br>V <sub>ss</sub> | O<br>D23             |                      | 8   |
| 9   |                 | O<br>BUSY            | O<br>RES             |                             |                 |                      |                 |                      |                 |                      |                 |                             | <b>O</b><br>D20      | <b>O</b><br>D21      | <b>O</b><br>D22      | 9   |
| 10  | 0               | 0                    | 0                    |                             |                 |                      |                 |                      |                 |                      |                 |                             | 0                    | 0                    | 0                    | 10  |
| 11  | V∞<br>O         | W/R                  |                      |                             |                 |                      |                 |                      |                 |                      |                 |                             | V <sub>ss</sub><br>O | D17                  | D19<br><b>O</b>      | 11  |
|     | D/₹             | $V_{ss}$             | Vse                  | 5                           | L               |                      |                 |                      | _               | _                    |                 | -                           | D15                  | D16                  | D18                  |     |
| 12  | о<br>м/іС       |                      | 0<br>Vc              | -                           |                 |                      | O<br>CLK2       | О<br>V <sub>сс</sub> | 0<br>D0         |                      | <b>O</b><br>D7  | 0<br>V                      | <b>O</b><br>D10      | <b>O</b><br>D12      | <b>O</b><br>D14      | 12  |
| 13  | O<br>BE3        | O<br>BE2             | O<br>BE              | C                           |                 | 0                    | 0               |                      | 0               | 0                    | 0               | 0                           | 0                    | 0                    | 0                    | 13  |
| 14  | O BE3           | 0<br>0               | O                    |                             |                 | 0                    | O P             |                      | 0               | V <sub>ss</sub>      | 05              | D8<br><b>O</b>              | v<br>0               | 0                    | D13<br><b>O</b>      | 14  |
|     | V <sub>cc</sub> | Vss                  |                      | 5 HO                        |                 | DS                   | V <sub>ss</sub> | Vcc                  | D2              | D3                   | D4              | D6                          | HLDA                 | D9                   | Vss                  | )   |
|     | Α               | В                    | С                    | 0                           | )               | E                    | F               | G                    | н               | J                    | к               | L                           | м                    | Ν                    | Р                    |     |

Am386DX Microprocessor

| Pin Pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Pin Pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Pin Pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Pin Pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Pin Pin                                                | Pin Pin                                                                                                                                                                                                                                                                                                                         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Name No.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Name No.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Name No.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Name No.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Name No.                                               | Name No.                                                                                                                                                                                                                                                                                                                        |
| Alime         NO.           A2         C4           A3         A3           A4         B3           A5         B2           A6         C3           A7         C2           A8         C1           A9         D3           A10         D2           A11         D1           A12         E3           A13         E2           A14         E1           A15         F1           A16         G1           A17         H1           A18         H2           A19         H3           A20         J1           A21         K1           A22         K2           A23         L1 | Name         No.           A24         L2           A25         K3           A26         M1           A27         N1           A28         L3           A29         M2           A30         P1           A31         N2           AD5         E14           BE0         E12           BE1         C13           BE2         B13           BS16         C14           BUSY         B9           CLK2         F12           D0         H12           D1         H13           D2         H14           D3         J14           D4         K14           D5         K13 | Name         No.           D6         L14           D7         K12           D8         L13           D9         N14           D10         M12           D11         N13           D12         N12           D13         P13           D14         P12           D15         M11           D16         N11           D17         N10           D18         P11           D19         P10           D20         M9           D21         N9           D22         P9           D23         N8           D24         P7           D25         N6           D26         P5           D27         N5 | Name         No.           D28         M6           D29         P4           D30         P3           D31         M5           D/C         A11           ERROR         A8           HLDA         M14           HOLD         D14           INTR         B7           LOCK         C10           M/IO         A12           NA         D13           NMI         B8           PEREQ         C8           RESET         C9           V <sub>cc</sub> A1           A5         A7           A10         A14           C5         C5 | $\begin{array}{c c c c c c c c c c c c c c c c c c c $ | Vame         No.           V <sub>ss</sub> F2           F3         F14           J2         J3           J12         J13           M4         M8           M10         N3           P6         P14           W/R         B10           NC         A4           B6         B12           C6         C7           E13         F13 |

ē,

### PGA Pin Designations (Sorted by Pin No.)

| Pin | Pin             | Pin | Pin         | Pin | Pin                                                                                                                                                                                                                               | Pin | Pin             | Pin | Pin             | Pin | Pin             |
|-----|-----------------|-----|-------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----------------|-----|-----------------|-----|-----------------|
| No. | Name            | No. | Name        | No. | Name                                                                                                                                                                                                                              | No. | Name            | No. | Name            | No. | Name            |
|     |                 |     |             |     | Pin           A9           V68           NA           HOLD           A14           A13           A12           BE0           NC           ADS           A15           Vss           CLK2           NC           Vss           A16 |     |                 |     |                 |     |                 |
| B4  | NC              | C12 | V <u>cc</u> | G2  |                                                                                                                                                                                                                                   | K13 | D4              | N2  | A31             | P10 | D19             |
| B5  | V <sub>ss</sub> | C13 | BE1         | G3  |                                                                                                                                                                                                                                   | L1  | A23             | N3  | V <sub>ss</sub> | P11 | D18             |
| B6  | NC              | C14 | BS16        | G12 |                                                                                                                                                                                                                                   | L2  | A24             | N4  | V <sub>cc</sub> | P12 | D14             |
| B7  | INTR            | D1  | A11         | G13 |                                                                                                                                                                                                                                   | L3  | A28             | N5  | D27             | P13 | D13             |
| B8  | NMI             | D2  | A10         | G14 |                                                                                                                                                                                                                                   | L12 | V <sub>cc</sub> | N6  | D25             | P14 | V <sub>ss</sub> |

### CONNECTION DIAGRAMS (continued) 132-Lead Plastic Quad Flat Pack (PQFP) Package



15022B--002

AMD

Notes: Pin 1 is marked for orientation. \*Float feature available in Rev. C0 and later, PQFP only.





150228-002

ģ

Notes: Pin 1 is marked for orientation.

\*Float feature available in Rev. C0 and later, PQFP only.

| Pin<br>Name | Pin<br>No. | Pin<br>Name | Pin<br>No. | Pin<br>Name | Pin<br>No. | Pin<br>Name     | Pin<br>No. | Pin<br>Name     | Pin<br>No. | Pin<br>Name     | Pin<br>No. |
|-------------|------------|-------------|------------|-------------|------------|-----------------|------------|-----------------|------------|-----------------|------------|
| A2          | 67         | A24         | 96         | D6          | 13         | D28             | 112        | V <sub>cc</sub> | 56         | V <sub>ss</sub> | 64         |
| A3          | 68         | A25         | 97         | D7          | 12         | D29             | 109        |                 | 58         |                 | 65         |
| A4          | 69         | A26         | 98         | D8          | 9          | D30             | 108        |                 | 73         |                 | 66         |
| A5          | 70         | A27         | 100        | D9          | 7          | D31             | 107        |                 | 85         |                 | 80         |
| A6          | 71         | A28         | 101        | D10         | 6          | D/C             | 41         |                 | 99         |                 | 83         |
| A7          | 72         | A29         | 102        | D11         | 5          | ERROR           | 47         |                 | 106        |                 | 90         |
| A8          | 74         | A30         | 103        | D12         | 4          | HLDA            | 8          |                 | 110        |                 | 91         |
| A9          | 75         | A31         | 104        | D13         | 3          | HOLD            | 28         |                 | 117        |                 | 92         |
| A10         | 76         | ADS         | 27         | D14         | 131        | INTR            | 53         |                 | 123        | 3               | 105        |
| A11         | 77         | BEO         | 31         | D15         | 130        | LOCK            | 42         |                 | 127        |                 | 111        |
| A12         | 78         | BE1         | 32         | D16         | 129        | M/IO            | 40         | V <sub>ss</sub> | 1          |                 | 114        |
| A13         | 79         | BE2         | 33         | D17         | 128        | NA              | 30         |                 | 10         | 1               | 122        |
| A14         | 81         | BE3         | 38         | D18         | 126        | NMI             | 52         |                 | 11         |                 | 132        |
| A15         | 82         | <b>BS16</b> | 29         | D19         | 125        | PEREQ           | 50         |                 | 21         | W/R             | 43         |
| A16         | 84         | BUSY        | 46         | D20         | 124        | READY           | 26         |                 | 23         | NC              | 36         |
| A17         | 86         | CLK2        | 24         | D21         | 121        | RESET           | 45         |                 | 25         |                 | 37         |
| A18         | 87         | D0          | 20         | D22         | 120        | V <sub>cc</sub> | 2          |                 | 35         |                 | 39         |
| A19         | 88         | D1          | 19         | D23         | 119        |                 | 16         |                 | 44         | 1               | 59         |
| A20         | 89         | D2          | 18         | D24         | 118        |                 | 22         |                 | 48         | J               | 60         |
| A21         | 93         | D3          | 17         | D25         | 116        | 1               | 34         |                 | 51         |                 | 61         |
| A22         | 94         | D4          | 15         | D26         | 115        |                 | 49         |                 | 55         |                 | 62         |
| A23         | 95         | D5          | 14         | D27         | 113        | FLT*            | 54         |                 | 57         |                 | 63         |
|             |            |             |            |             |            |                 |            |                 |            |                 |            |

### PQFP Pin Designation (Functional Grouping)

### PQFP Pin Designation (Sorted by Pin No.)

| Pin<br>No. | Pin<br>Name     | Pin<br>No. | Pin<br>Name           | Pin<br>No. | Pin<br>Name     | Pin<br>No. | Pin<br>Name     | Pin<br>No. | Pin<br>Name     | Pin<br>No. | Pin<br>Name     |
|------------|-----------------|------------|-----------------------|------------|-----------------|------------|-----------------|------------|-----------------|------------|-----------------|
| 1          | V <sub>ss</sub> | 23         | V <sub>ss</sub> ·     | 45         | RESET           | 67         | A2              | 89         | A20             | 111        | V <sub>ss</sub> |
| 2          | $V_{cc}$        | 24         | CLK2                  | 46         | BUSY            | 68         | A3              | 90         | V <sub>ss</sub> | 112        | D28             |
| 3          | D13             | 25         | Vss                   | 47         | ERROR           | 69         | A4              | 91         | V <sub>ss</sub> | 113        | D27             |
| 4          | D12             | 26         | READY                 | 48         | V <sub>ss</sub> | 70         | A5              | 92         | V <sub>ss</sub> | 114        | VSS             |
| 5          | D11             | 27         | ADS                   | 49         | V <sub>cc</sub> | 71         | A6              | 93         | A21             | 115        | D26             |
| 6          | D10             | 28         | HOLD                  | 50         | PEREQ           | 72         | A7              | 94         | A22             | 116        | D25             |
| 7          | D9              | 29         | <b>BS16</b>           | 51         | V <sub>ss</sub> | 73         | V <sub>cc</sub> | 95         | A23             | 117        | V <sub>cc</sub> |
| 8          | HLDA            | 30         | NA                    | 52         | NMI             | 74         | A8              | 96         | A24             | 118        | D24             |
| 9          | D8              | 31         | BE0                   | 53         | INTR            | 75         | A9              | 97         | A25             | 119        | D23             |
| 10         | V <sub>ss</sub> | 32         | BE1                   | 54         | FLT ·           | 76         | A10             | 98         | A26             | 120        | D22             |
| 11         | V <sub>ss</sub> | 33         | BE2                   | 55         | V <sub>ss</sub> | 77         | A11             | 99         | V <sub>cc</sub> | 121        | D21             |
| 12         | D7              | 34         | V <sub>cc</sub>       | 56         | V <sub>cc</sub> | 78         | A12             | 100        | A27             | 122        | V <sub>ss</sub> |
| 13         | D6              | 35         | V <sub>ss</sub><br>NC | 57         | V <sub>ss</sub> | 79         | A13             | 101        | A28             | 123        | V <sub>cc</sub> |
| 14         | A5              | 36         |                       | 58         | V <sub>cc</sub> | 80         | V <sub>ss</sub> | 102        | A29             | 124        | D20             |
| 15         | D4              | 37         | NC                    | 59         | NC              | 81         | A14             | 103        | A30             | 125        | D19             |
| 16         | V <sub>cc</sub> | 38         | BE3                   | 60         | NC              | 82         | A15             | 104        | A31             | 126        | D18             |
| 17         | D3              | 39         | NC                    | 61         | NC              | 83         | V <sub>ss</sub> | 105        | V <sub>ss</sub> | 127        | V <sub>cc</sub> |
| 18         | D2              | 40         | M/IO                  | 62         | NC              | 84         | A16             | 106        | V <sub>cc</sub> | 128        | D17             |
| 19         | D1              | 41         | D/C                   | 63         | NC              | 85         | V <sub>cc</sub> | 107        | D31             | 129        | D16             |
| 20         | D0              | 42         | LOCK                  | 64         | V <sub>ss</sub> | 86         | A17             | 108        | D30             | 130        | D15             |
| 21         | V <sub>ss</sub> | 43         | W/R                   | 65         | V <sub>ss</sub> | 87         | A18             | 109        | D29             | 131        | D14             |
| 22         | $V_{cc}$        | 44         | V <sub>ss</sub>       | 66         | V <sub>ss</sub> | 88         | A19             | 110        | V <sub>cc</sub> | 132        | V <sub>ss</sub> |
|            |                 |            |                       |            |                 |            |                 |            |                 |            |                 |

\*Float feature available in Rev. C0 and later, PQFP only.

# 



\*Float feature available in Rev. C0 and later, PQFP only.

15021B-003

ŝ

### **ORDERING INFORMATION**

### **Standard Products**

AMD standard products are available in several packages and operating ranges. The order number (Valid Combination) is formed by a combination of the elements below.



A = 132-Lead Pin Grid Array (CGX 132) NG = 132-Lead Plastic Quad Flat Pack (PQ132, PQB132)

|    | Valid Combinations |                                                      |  |  |  |  |  |  |  |
|----|--------------------|------------------------------------------------------|--|--|--|--|--|--|--|
| A  | 80386DX            | 40<br>33<br>25<br>20                                 |  |  |  |  |  |  |  |
| NG | 80386DX            | -40F, -40S<br>-33F, -33S<br>-25F, -25S<br>-20F, -20S |  |  |  |  |  |  |  |

### Valid Combinations

Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations and to check on newly released combinations.

### **PIN DESCRIPTION**

### A31-A2

### Address Bus (Outputs)

Outputs physical memory or port I/O addresses.

### ADS

### Address Status (Active Low; Output)

Indicates that a valid bus cycle definition and address (W/R, D/C, M/IO, BE0, BE1, BE2, BE3, and A31–A2) are being driven at the Am386DX microprocessor pins.

### BE3-BE0

### Byte Enables (Active Low; Outputs)

Indicate which data bytes of the data bus take part in a bus cycle.

### **BS16**

### Bus Size 16 (Active Low; Input)

Allows direct connection of 32-bit and 16-bit data buses.

### BUSY

### Busy (Active Low; Input)

Signals a busy condition from a processor extension.

### CLK2

### Clock (Input)

Provides the fundamental timing for the Am386DX microprocessor.

### D31-D0

### Data Bus (Inputs/Outputs)

Inputs data during memory, I/O, and interrupt acknowledge read cycles and outputs data during memory and I/O write cycles.

### D/C

### Data/Control (Output)

A bus cycle definition pin that distinguishes data cycles, either memory or I/O from control cycles which are: interrupt acknowledge, halt, and instruction fetching.

### ERROR

### Error (Active Low; Input)

Signals an error condition from a processor extension.

### FLT\*

### Float (Active Low; Input)

An input signal which forces all bi-directional and output signals, including HLDA, to the three-state condition.

FLT has an internal pull-up resistor, and if it is not used it should be unconnected.

### HLDA

### Bus Hold Acknowledge (Active High; Output)

Indicates that the Am386DX microprocessor surrendered control of its local bus to another bus master.

### HOLD

### Bus Hold Request (Active High; Input)

Allows another bus master to request control of the local bus.

### INTR

### Interrupt Request (Active High; Input)

A maskable input that signals the Am386DX microprocessor to suspend execution of the current program and execute an interrupt acknowledge function.

### LOCK

### Bus Lock (Active Low; Output)

A bus cycle definition pin that indicates that other system bus masters are denied access to the system bus while it is active.

### M/IO

### Memory I/O (Output)

A bus cycle definition pin that distinguishes memory cycles from input/output cycles.

### NA

### Next Address (Active Low; Input)

Used to request address pipelining.

### NC

### No Connect

Should always remain unconnected. Connection of a NC pin may cause the processor to malfunction or be incompatible with future steppings of the Am386DX microprocessor.

### NMI

# Non-Maskable Interrupt Request (Active High; Input)

A non-maskable input that signals the Am386DX microprocessor to suspend execution of the current program and execute an interrupt acknowledge function.

### PEREQ

### Processor Extension Request (Active High; Input)

Indicates that the processor extension has data to be transferred by the Am386DX microprocessor.

### READY

### Bus Ready (Active Low; Input)

Terminates the bus cycle.

### RESET

### Reset (Active High; Input)

Suspends any operation in progress and places the Am386DX microprocessor in a known reset state.

### Vcc

### System Power (Active High; Input)

Provides the +5 V nominal DC supply input.

### Vss

### System Ground (Input)

System ground provides 0 V connection from which all inputs and outputs are measured.

### W/R

### Write/Read (Output)

A bus cycle definition pin that distinguishes write cycles from read cycles.

\*Float feature available in Rev. C0 and later, PQFP only.

### **ABSOLUTE MAXIMUM RATINGS**

 Storage Temperature
 -65°C to +150°C

 Ambient Temperature Under Bias
 -65°C to +125°C

 Supply Voltage with Respect
 0.5 V to +7 V

 to Vss
 -0.5 V to +7 V

 Voltage on Other Pins
 -0.5 V to Vcc +0.5 V

Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to Absolute Maximum Ratings for extended periods may affect device reliability.

### DC CHARACTERISTICS over COMMERCIAL operating ranges

 $V_{CC} = 5 V \pm 5\%$ ;  $T_{CASE} = 0^{\circ}C$  to  $+85^{\circ}C$  (PGA)  $V_{CC} = 5 V \pm 10\%$ ;  $T_{CASE} = 0^{\circ}C$  to  $+100^{\circ}C$  (PQFP)

| Symbol           | Parameter<br>Description                                                                                                                                       | Notes                                                                                                            | Min                         | Max                                            | Unit                 |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|-----------------------------|------------------------------------------------|----------------------|
| V <sub>IL</sub>  | Input Low Voltage                                                                                                                                              | (Note 1)                                                                                                         | -0.3                        | 0.8                                            | V                    |
| V <sub>IH</sub>  | Input High Voltage                                                                                                                                             |                                                                                                                  | 2.0                         | V <sub>cc</sub> + 0.3                          | V                    |
| V <sub>ILC</sub> | CLK2 Input Low Voltage                                                                                                                                         | (Note 1)                                                                                                         | -0.3                        | 0.8                                            | V                    |
| V <sub>IHC</sub> | CLK2 Input High Voltage<br>20 MHz<br>25, 33, and 40 MHz                                                                                                        |                                                                                                                  | V <sub>cc</sub> -0.8<br>3.7 | V <sub>cc</sub> + 0.3<br>V <sub>cc</sub> + 0.3 | v<br>v               |
| V <sub>oL</sub>  | Output Low Voltage<br>I <sub>oL</sub> = 4 mA: A31–A2, D31–D0<br>I <sub>oL</sub> = 5 mA: BE3–BE0, W/R,<br>D/C, M/IO, LOCK, ADS,<br>HLDA                         |                                                                                                                  |                             | 0.45<br>0.45                                   | v<br>v               |
| V <sub>oH</sub>  | Output High Voltage<br>I <sub>он</sub> = 1 mA: A31–A2, D31–D0<br>I <sub>он</sub> = 0.9 mA: <u>BE3–BE0,</u><br>W/R, D/C, M/Ю, <u>LOCK,</u><br><u>ADS</u> , HLDA |                                                                                                                  | 2.4<br>2.4                  |                                                | v<br>v               |
| l <sub>u</sub>   | Input Leakage Current<br>(All pins except BS16, PEREQ,<br>BUSY, FLT*, and ERROR)                                                                               | $0 V \leq V_{\rm IN} \leq V_{\rm CC}$                                                                            |                             | ±15                                            | μA                   |
| l <sub>in</sub>  | Input Leakage Current<br>(PEREQ Pin)                                                                                                                           | V <sub>IH</sub> = 2.4 V<br>(Note 2)                                                                              |                             | 200                                            | μA                   |
| I <u>n</u>       | Input Leakage Current<br>(BS16, BUSY, FLT*, and ERROR)                                                                                                         | V <sub>IL</sub> = 0.45<br>(Note 3)                                                                               |                             | -400                                           | μΑ                   |
| I <sub>LO</sub>  | Output Leakage Current                                                                                                                                         | 0.45 V ≤ V <sub>out</sub> ≤ V <sub>cc</sub>                                                                      |                             | ±15                                            | μA                   |
| l <sub>cc</sub>  | Supply Current<br>CLK2 = 40 MHz: with -20<br>CLK2 = 50 MHz: with -25<br>CLK2 = 66 MHz: with -33<br>CLK2 = 80 MHz: with -40                                     | l <sub>cc</sub> Typ = 350<br>l <sub>cc</sub> Typ = 375<br>l <sub>cc</sub> Typ = 400<br>l <sub>cc</sub> Typ = 400 |                             | 500<br>550<br>550<br>550                       | mA<br>mA<br>mA<br>mA |
| C <sub>IN</sub>  | Input or I/O Capacitance                                                                                                                                       | $F_c = 1$ MHz (Note 4)                                                                                           |                             | 10                                             | pF                   |
| C <sub>out</sub> | Output Capacitance                                                                                                                                             | F <sub>c</sub> =1 MHz (Note 4)                                                                                   |                             | 12                                             | pF                   |
| C <sub>CLK</sub> | CLK2 Capacitance                                                                                                                                               | F <sub>c</sub> = 1 MHz (Note 4)                                                                                  |                             | 20                                             | pF                   |

Notes: 1. The Min value, -0.3, is not 100% tested.

2. PEREQ input has an internal pulldown resistor.

3. BS16, BUSY, FLT\*, and ERROR inputs each have an internal pullup resistor.

4. Not 100% tested.

\*Float feature available in Rev. Co and later, PQFP only.

 $V_{CC} = 5 V \pm 5\%$ ;  $T_{CASE} = 0^{\circ}C$  to  $+85^{\circ}C$ 

| No. | Parameter<br>Description        | Notes                           | Ref<br>Figure | 40 MHz<br>Min | 40 MHz<br>Max | Unit |
|-----|---------------------------------|---------------------------------|---------------|---------------|---------------|------|
|     | Operating Frequency             | Half of CLK2 Freq               |               | 8             | 40            | MHz  |
| 1   | CLK2 Period                     |                                 | 3             | 12.5          | 62.5          | ns   |
| 2a  | CLK2 High Time                  | at 2 V                          | 3             | 5             |               | ns   |
| 2b  | CLK2 High Time                  | at 3.7 V                        | 3             | 3.25          |               | ns   |
| 3a  | CLK2 Low Time                   | at 2 V                          | 3             | 5             | 1             | ns   |
| 3b  | CLK2 Low Time                   | at 0.8 V                        | 3             | 3.25          |               | ns   |
| 4   | CLK2 Fall Time                  | 3.7 V to 0.8 V<br>(Note 3)      | 3             |               | 4             | ns   |
| 5   | CLK2 Rise Time                  | 0.8 V to 3.7 V<br>(Note 3)      | 3             |               | 4             | ns   |
| 6   | A31–A2 Valid Delay              | C <sub>L</sub> = 50 pF          | 2, 5, 13      | 4             | 13            | ns   |
| 7   | A31–A2 Float Delay              | (Note 1)                        | 13            | 4             | 20            | ns   |
| 8   | BE3–BE0, LOCK Valid Delay       | C <sub>L</sub> =50 pF           | 2, 5, 13      | 4             | 13            | ns   |
| 9   | BE3-BE0, LOCK Float Delay       | (Note 1)                        | 13            | 4             | 20            | ns   |
| 10  | W/R, M/IO, D/C Valid Delay      | C <sub>L</sub> = 50 pF          | 2, 5, 13      | 4             | 13            | ns   |
| 10a | ADS Valid Delay                 | C <sub>L</sub> = 50 pF          | 2, 5, 13      | 4             | 13            | ns   |
| 11  | W/R, M/IO, D/C, ADS Float Delay | (Note 1)                        | 13            | 4             | 20            | ns   |
| 12  | D31–D0 Write Data Valid Delay   | C <sub>L</sub> = 50 pF (Note 4) | 2, 6, 13      | 7             | 18            | ns   |
| 12a | D31–D0 Write Data Hold Time     | C <sub>L</sub> =50 pF           | 2, 7          | 2             |               | ns   |
| 13  | D31–D0 Float Delay              | (Note 1)                        | 13            | 4             | 17            | ns   |
| 14  | HLDA Valid Delay                | C <sub>L</sub> =50 pF           | 2, 13         | 4             | 17            | ns   |
| 15  | NA Setup Time                   |                                 | 4             | 5             |               | ns   |
| 16  | NA Hold Time                    |                                 | 4             | 2             |               | ns   |
| 17  | BS16 Setup Time                 |                                 | 4             | 5             |               | ns   |
| 18  | BS16 Hold Time                  |                                 | 4             | 2             | T             | ns   |
| 19  | READY Setup Time                |                                 | 4             | 7             |               | ns   |
| 20  | READY Hold Time                 |                                 | 4             | 4             |               | ns   |
| 21  | D31–D0 Read Setup Time          |                                 | 4             | 4             |               | ns   |
| 22  | D31–D0 Read Hold Time           |                                 | 4             | 3             |               | ns   |
| 23  | HOLD Setup Time                 |                                 | 4             | 4             |               | ns   |
| 24  | HOLD Hold Time                  |                                 | 4             | 2             |               | ns   |
| 25  | RESET Setup Time                |                                 | 14            | 4             |               | ns   |
| 26  | RESET Hold Time                 |                                 | 14            | 2             |               | ns   |
| 27  | NMI, INTR Setup Time            | (Note 2)                        | 14            | 5             |               | ns   |
| 28  | NMI, INTR Hold Time             | (Note 2)                        | 14            | 5             |               | ns   |
| 29  | PEREQ, ERROR, BUSY Setup Time   | (Note 2)                        | 4             | 5             |               | ns   |
| 30  | PEREQ, ERROR, BUSY Hold Time    | (Note 2)                        | 4             | 4             |               | ns   |

Notes: 1. Float condition occurs when maximum output current becomes less than I<sub>Lo</sub> in magnitude. Float delay is not 100% tested. 2. These inputs are allowed to be asynchronous to CLK2. The setup and hold specifications are given for testing purposes, to assure

recognition within a specific clock period.

3. Rise and fall times are not tested.

4. Min time not 100% tested.

 $V_{CC} = 5 V \pm 5\%$ ;  $T_{CASE} = 0^{\circ}C$  to  $+85^{\circ}C$ 

| No. | Parameter<br>Description        | Notes                          | Ref<br>Figures | 33 MHz<br>Min | 33 MHz<br>Max | Unit |
|-----|---------------------------------|--------------------------------|----------------|---------------|---------------|------|
|     | Operating Frequency             | Half of CLK2 Freq              |                | 8             | 33.3          | MHz  |
| 1   | CLK2 Period                     |                                | 3              | 15.0          | 62.5          | ns   |
| 2a  | CLK2 High Time                  | at 2 V                         | 3              | 6.25          |               | ns   |
| 2b  | CLK2 High Time                  | at 3.7 V                       | 3              | 4.5           |               | ns   |
| 3a  | CLK2 Low Time                   | at 2 V                         | 3              | 6.25          |               | ns   |
| 3b  | CLK2 Low Time                   | at 0.8 V                       | 3              | 4.5           |               | ns   |
| 4   | CLK2 Fall Time                  | 3.7 V to 0.8 V<br>(Note 3)     | 3              |               | 4             | ns   |
| 5   | CLK2 Rise Time                  | 0.8 V to 3.7 V<br>(Note 3)     | 3              |               | 4             | ns   |
| 6   | A31–A2 Valid Delay              | C <sub>L</sub> = 50 pF         | 2, 5, 13       | 4             | 15            | ns   |
| 7   | A31–A2 Float Delay              | (Note 1)                       | 13             | 4             | 20            | ns   |
| 8   | BE3-BE0, LOCK Valid Delay       | C <sub>L</sub> = 50 pF         | 2, 5, 13       | 4             | 15            | ns   |
| 9   | BE3-BE0, LOCK Float Delay       | (Note 1)                       | 13             | 4             | 20            | ns   |
| 10  | W/R, M/IO, D/C Valid Delay      | C <sub>L</sub> =50 pF          | 2, 5, 13       | 4             | 15            | ns   |
| 10a | ADS Valid Delay                 | С <sub>L</sub> = 50 pF         | 2, 5, 13       | 4             | 14.5          | ns   |
| 11  | W/R, M/IO, D/C, ADS Float Delay | (Note 1)                       | 13             | 4             | 20            | ns   |
| 12  | D31–D0 Write Data Valid Delay   | C <sub>L</sub> =50 pF (Note 4) | 2, 6, 13       | 7             | 24            | ns   |
| 12a | D31-D0 Write Data Hold Time     | C <sub>L</sub> =50 pF          | 2, 7           | 2             |               | ns   |
| 13  | D31–D0 Float Delay              | (Note 1)                       | 13             | 4             | 17            | ns   |
| 14  | HLDA Valid Delay                | С <sub>L</sub> =50 рF          | 2, 13          | 4             | 20            | ns   |
| 15  | NA Setup Time                   |                                | 4              | 5             |               | ns   |
| 16  | NA Hold Time                    |                                | 4              | 2             |               | ns   |
| 17  | BS16 Setup Time                 |                                | 4              | 5             |               | ns   |
| 18  | BS16 Hold Time                  |                                | 4              | 2             |               | ns   |
| 19  | READY Setup Time                |                                | 4              | 7             |               | ns   |
| 20  | READY Hold Time                 |                                | 4              | 4             |               | ns   |
| 21  | D31-D0 Read Setup Time          |                                | 4              | 5             |               | ns   |
| 22  | D31-D0 Read Hold Time           |                                | 4              | 3             |               | ns   |
| 23  | HOLD Setup Time                 |                                | 4              | 11            |               | ns   |
| 24  | HOLD Hold Time                  |                                | 4              | 2             |               | ns   |
| 25  | RESET Setup Time                |                                | 14             | 5             |               | ns   |
| 26  | RESET Hold Time                 |                                | 14             | 2             |               | ns   |
| 27  | NMI, INTR Setup Time            | (Note 2)                       | 4              | 5             |               | ns   |
| 28  | NMI, INTR Hold Time             | (Note 2)                       | 4              | 5             |               | ns   |
| 29  | PEREQ, ERROR, BUSY Setup Time   | (Note 2)                       | 4              | 5             |               | ns   |
| 30  | PEREQ, ERROR, BUSY Hold Time    | (Note 2)                       | 4              | 4             |               | ns   |

Notes: 1. Float condition occurs when maximum output current becomes less than I<sub>LO</sub> in magnitude. Float delay is not 100% tested.
2. These inputs are allowed to be asynchronous to CLK2. The setup and hold specifications are given for testing purposes, to assure recognition within a specific CLK2 period.
3. Rise and fall times are not tested.
4. Min time not 100% tested.

 $V_{CC} = 5 V \pm 5\%$ ;  $T_{CASE} = 0^{\circ}C$  to  $+85^{\circ}C$  (PGA)

 $V_{cc} = 5 V \pm 10\%$ ;  $T_{cASE} = 0^{\circ}C$  to  $\pm 100^{\circ}C$  (PQFP)

| No. | Parameter<br>Description               | Notes                      | Ref<br>Figures | 25 MHz<br>Min | 25 MHz<br>Max | Unit |
|-----|----------------------------------------|----------------------------|----------------|---------------|---------------|------|
|     | Operating Frequency                    | Half of CLK2 Freq          |                | 4             | 25            | MHz  |
| 1   | CLK2 Period                            |                            | 3              | 20            | 125           | ns   |
| 2a  | CLK2 High Time                         | at 2 V                     | 3              | 7             |               | ns   |
| 2b  | CLK2 High Time                         | at 3.7 V                   | 3              | 4             |               | ns   |
| 3a  | CLK2 Low Time                          | at 2 V                     | 3              | 7             |               | ns   |
| 3b  | CLK2 Low Time                          | at 0.8 V                   | 3              | 5             |               | ns   |
| 4   | CLK2 Fall Time                         | 3.7 V to 0.8 V<br>(Note 3) | <sup>.</sup> 3 |               | 7             | ns   |
| 5   | CLK2 Rise Time                         | 0.8 V to 3.7 V<br>(Note 3) | 3              |               | 7             | ns   |
| 6   | A31–A2 Valid Delay                     | С <sub>L</sub> =50 рF      | 2, 5, 13       | 4             | 21            | ns   |
| 7   | A31-A2 Float Delay                     | (Note 1)                   | 13             | 4             | 30            | ns   |
| 8   | BE3-BE0 Valid Delay                    | С <sub>L</sub> =50 рF      | 2, 5, 13       | 4             | 24            | ns   |
| 8a  | LOCK Valid Delay                       | CL=50 pF                   | 2, 5, 13       | 4             | 21            | ns   |
| 9   | BE3-BE0, LOCK Float Delay              | (Note 1)                   | 13             | 4             | 30            | ns   |
| 10  | W/R, M/IO, D/C, ADS<br>Valid Delay     | С <sub>L</sub> =50 рF      | 2, 5, 13       | 4             | 21            | ns   |
| 11  | W/R, M/IO, D/C, ADS<br>Float Delay     | (Note 1)                   | 13             | 4             | 30            | ns   |
| 12  | D31–D0 Write Data Valid Delay          | C <sub>L</sub> =50 pF      | 2, 6, 13       | 7             | 27            | ns   |
| 12a | D31-D0 Write Data Hold Time            | C <sub>L</sub> =50 pF      | 2, 7           | 2             |               | ns   |
| 13  | D31–D0 Float Delay                     | (Note 1)                   | 13             | 4             | 22            | ns   |
| 14  | HLDA Valid Delay                       | C <sub>L</sub> =50 pF      | 2, 13          | 4             | 22            | ns   |
| 15  | NA Setup Time                          |                            | 4              | 7             |               | ns   |
| 16  | NA Hold Time                           |                            | 4              | 3             |               | ns   |
| 17  | BS16 Setup Time                        |                            | 4              | 7             |               | ns   |
| 18  | BS16 Hold Time                         |                            | 4              | 3             |               | ns   |
| 19  | READY Setup Time                       |                            | 4              | 9             |               | ns   |
| 20  | READY Hold Time                        |                            | 4              | 4             |               | ns   |
| 21  | D31–D0 Read Setup Time                 |                            | 4              | 7             |               | ns   |
| 22  | D31-D0 Read Hold Time                  |                            | 4              | 5             |               | ns   |
| 23  | HOLD Setup Time                        |                            | 4              | 15            |               | ns   |
| 24  | HOLD Hold Time                         |                            | 4              | 3             |               | ns   |
| 25  | RESET Setup Time                       |                            | 14             | 10            |               | ns   |
| 26  | RESET Hold Time                        |                            | 14             | 3             |               | ns   |
| 27  | NMI, INTR Setup Time                   | (Note 2)                   | 4              | 6             |               | ns   |
| 28  | NMI, INTR Hold Time                    | (Note 2)                   | 4              | 6             |               | ns   |
| 29  | PEREQ, ERROR, BUSY, FLT*<br>Setup Time | (Note 2)                   | 4              | 6             |               | ns   |
| 30  | PEREQ, ERROR, BUSY, FLT*<br>Hold Time  | (Note 2)                   | 4              | 5             |               | ns   |

Notes: 1. Float condition occurs when maximum output current becomes less than I<sub>LO</sub> magnitude. Float delay is not 100% tested.
 2. These inputs are allowed to be asynchronous to CLK2. The setup and hold specifications are given for testing purposes, to assure recognition within a specific CLK2 period.
 3. Rise and fall times are not tested.
 \*Float feature available in Rev C0 and later, PQFP only.

 $V_{CC} = 5 V \pm 5\%$ ;  $T_{CASE} = 0^{\circ}C$  to  $+85^{\circ}C$  (PGA)  $V_{CC} = 5 V \pm 10\%$ ;  $T_{CASE} = 0^{\circ}C$  to  $+100^{\circ}C$  (PQFP)

| No. | Parameter<br>Description               | Notes                                         | Ref<br>Figures | 20 MHz<br>Min | 20 MHz<br>Max | Unit |
|-----|----------------------------------------|-----------------------------------------------|----------------|---------------|---------------|------|
|     | Operating Frequency                    | Half of CLK2 Freq                             |                | 4             | 20            | MHz  |
| 1   | CLK2 Period                            |                                               | 3              | 25            | 125           | ns   |
| 2a  | CLK2 High Time                         | at 2 V                                        | 3              | 8             |               | ns   |
| 2b  | CLK2 High Time                         | at (V <sub>cc</sub> –0.8 V)                   | 3              | 5             |               | ns   |
| 3a  | CLK2 Low Time                          | at 2 V                                        | 3              | 8             |               | ns   |
| 3b  | CLK2 Low Time                          | at 0.8 V                                      | 3              | 6             |               | ns   |
| 4   | CLK2 Fall Time                         | (V <sub>cc</sub> -0.8 V) to 0.8 V<br>(Note 3) | 3              |               | 8             | ns   |
| 5   | CLK2 Rise Time                         | 0.8 V to (V <sub>cc</sub> -0.8 V)<br>(Note 3) | 3              |               | 8             | ns   |
| 6   | A31–A2 Valid Delay                     | C <sub>L</sub> = 120 pF                       | 2, 5, 13       | 4             | 30            | ns   |
| 7   | A31–A2 Float Delay                     | (Note 1)                                      | 13             | 4             | 32            | ns   |
| 8   | BE3-BEO, LOCK Valid Delay              | С <sub>L</sub> = 75 pF                        | 2, 5, 13       | 4             | 30            | ns   |
| 9   | BE3–BE0, LOCK<br>Float Delay           | (Note 1)                                      | 13             | 4             | 32            | ns   |
| 10  | W/R, M/IO, D/C, ADS<br>Valid Delay     | С <sub>ь</sub> = 75 рF                        | 2, 5, 13       | 4             | 28            | ns   |
| 11  | W/R, M/IO, D/C, ADS<br>Float Delay     | (Note 1)                                      | 13             | 4             | 30            | ns   |
| 12  | D31–D0 Write Data Valid Delay          | C <sub>L</sub> = 120 pF                       | 2, 8, 13       | 4             | 38            | ns   |
| 13  | D31–D0 Float Delay                     | (Note 1)                                      | 13             | 4             | 27            | ns   |
| 14  | HLDA Valid Delay                       | C <sub>L</sub> = 75 pF                        | 2, 13          | 6             | 28            | ns   |
| 15  | NA Setup Time                          |                                               | 4              | 9             |               | ns   |
| 16  | NA Hold Time                           |                                               | 4              | 14            |               | ns   |
| 17  | BS16 Setup Time                        |                                               | 4              | 13            |               | ns   |
| 18  | BS16 Hold Time                         |                                               | 4              | 21            |               | ns   |
| 19  | READY Setup Time                       |                                               | 4              | 12            |               | ns   |
| 20  | READY Hold Time                        |                                               | 4              | 4             |               | ns   |
| 21  | D31–D0 Read Setup Time                 |                                               | 4              | 11            |               | ns   |
| 22  | D31-D0 Read Hold Time                  |                                               | 4              | 6             |               | ns   |
| 23  | HOLD Setup Time                        |                                               | 4              | 17            |               | ns   |
| 24  | HOLD Hold Time                         |                                               | 4              | 5             |               | ns   |
| 25  | RESET Setup Time                       |                                               | 14             | 12            |               | ns   |
| 26  | RESET Hold Time                        |                                               | 14             | 4             |               | ns   |
| 27  | NMI, INTR Setup Time                   | (Note 2)                                      | 4              | 16            |               | ns   |
| 28  | NMI, INTR Hold Time                    | (Note 2)                                      | 4              | 16            |               | ns   |
| 29  | PEREQ, ERROR, BUSY, FLT*<br>Setup Time | (Note 2)                                      | 4              | 14            |               | ns   |
| 30  | PEREQ, ERROR, BUSY, FLT*<br>Hold Time  | (Note 2)                                      | 4              | 5             |               | ns   |

Notes: 1. Float condition occurs when maximum output current becomes less than ILO magnitude. Float delay is not 100% tested.

2. These inputs are allowed to be asynchronous to CLK2. The setup and hold specifications are given for testing purposes, to assure recognition within a specific CLK2 period. 3. Rise and fall times are not tested.

\*Float feature available in Rev. C0 and later, PQFP only.

### SWITCHING WAVEFORMS

The switching characteristics consist of output delays, input setup requirements, and input hold requirements. All characteristics are relative to the CLK2 rising edge crossing the 2.0 V level.

Switching characteristic measurement is defined in Figure 1. Inputs must be driven to the voltage levels indicated by this diagram. Am386DX microprocessor output delays are specified with minimum and maximum limits, measured as shown. The minimum Am386DX microprocessor delay times are hold times provided to external circuitry. Am386DX microprocessor input setup and hold time are specified as minimums, defining the smallest acceptable sampling window. Within the sampling window, a synchronous input signal must be stable for correct Am386DX microprocessor operation. Outputs  $\overline{\text{ADS}}$ ,  $W/\overline{\text{R}}$ ,  $D/\overline{\text{C}}$ ,  $M/\overline{\text{IO}}$ ,  $\overline{\text{LOCK}}$ ,  $\overline{\text{BE3-BE0}}$ , A31–A2, and HLDA only change at the beginning of phase one. D31–D0 (write cycles) only change at the beginning of phase two. The READY, HOLD,  $\overline{\text{BUSY}}$ ,  $\overline{\text{ERROR}}$ , PEREQ,  $\overline{\text{FLT}}^*$ , and D31–D0 (read cycles) inputs are sampled at the beginning of phase one. The NA, BS16, INTR, and NMI inputs are sampled at the beginning of phase two.

15021B-071



Note: Input waveforms have tr  $\leq$  2.0 ns from 0.8 V to 2.0 V. \*Float feature available in Rev. Co and later, PQFP only.

### Figure 1. Drive Levels and Measurement Points



CL includes all parasitic capacitances.

Figure 2. AC Test Loads

15021B-072



Figure 3. CLK2 Timing

15021B-073

# 



\*Float feature available in Rev. C0 and later, PQFP only.

### Figure 4. Input Setup and Hold Timing

15021B-074

with the



### Figure 5. Output Valid Delay Timing

15021B--075



15021B-078

Figure 8. Write Data Valid Delay Timing (20 MHz)



Note: This graph will not be linear outside of the  $C_L$  range shown.

15021B-079



Figure 9. Typical Output Valid Delay Versus Load Capacitance at Maximum Operating Temperature ( $C_L$  =120 pF)

15021B-080

Note: This graph will not be linear outside of the CL range shown.

Figure 10. Typical Output Valid Delay Versus Load Capacitance at Maximum Operating Temperature (CL = 75 pF)



nom + 9

nom + 6

nom + 3

Output Valid Delay (ns)

Note: This graph will not be linear outside of the  $\mathsf{C}_\mathsf{L}$  range shown.



150



Note: This graph will not be linear outside of the  $\mathsf{C}_\mathsf{L}$  range shown.



Am386DX Microprocessor

15021B-082

15021B-081





The second internal processor phase following RESET High-to-Low transition (provided t25 and t26 are met) is \$\phi2\$.

15021B-084

É

### Figure 14. RESET Setup and Hold Timing and Internal Phase

# Am386™SX

# High-Performance, 32-Bit Microprocessor with 16-Bit Data Bus

### DISTINCTIVE CHARACTERISTICS

- Compatible with 386SX systems and software
- 25- and 20-MHz operating speeds
- Pin-for-pin replacement of the Intel i386SX
- Supports 387SX-compatible math coprocessors

100-lead PQFP package with optional protective ring for better lead coplanarity

Advanced

Micro

Devices

- 24-bit address bus, 16-bit data bus
- Advanced 0.8 micron CMOS technology

### **GENERAL DESCRIPTION**

The Am386SX microprocessor is a compatible implementation of the Intel i386SX. It is engineered to meet strict requirements for compatibility. It is compatible with hardware designed for 386SX systems and is, in fact, a pin-for-pin replacement of the Intel i386SX. It is also compatible with operating systems written for the 386 and the wide variety of commercially available software applications.

The Am386SX microprocessor is a 32-bit CPU with a 16-bit external data bus, and a 24-bit external address

bus. It provides the performance and compatibility benefits of the 386 architecture with the cost savings associated with 16-bit hardware. This device offers a 25% increase in performance from 20 to 25 MHz.

The device is manufactured using the AMD® advanced 0.8 micron CMOS process. It is packaged in a 100-pin plastic quad flat pack (PQFP). This package may be shipped in an optional protective ring for better lead protection during manufacturing.



\*Float feature is available in Rev. B0 and later.



# **Top View**

АМГ



15022P 002

ń

Notes: NC = No Connect

Pin 1 is marked for orientation.

\*Float feature is available in Rev. B0 and later.

#### V<sub>cc</sub> Vss Address Data Control NC Pin Name Pin No. Pin Name Pin No. Pin Name Pin No. Pin No. Pin No. Pin No. ADS 16 20 8 2 A1 18 D0 1 BHE A2 51 D1 100 19 27 9 5 A3 BLE 52 D2 99 17 29 10 11 A4 53 BUSY D3 96 34 30 21 12 A5 54 D4 CLK2 15 95 31 32 13 A6 55 D/C 24 D5 94 43 39 14 Α7 56 ERROR 36 D6 93 44 42 22 **A**8 58 FLT\* 28 D7 92 45 48 35 Α9 59 HLDA 3 D8 90 46 57 41 A10 60 HOLD 4 D9 89 47 69 49 A11 61 INTR 40 D10 88 71 50 A12 62 LOCK 26 D11 87 84 63 A13 64 M/ĪO 23 D12 86 A14 65 91 67 NA 6 D13 83 A15 66 97 68 NMI 38 D14 82 70 A16 PEREQ 37 77 D15 81 72 A17 78 READY 7 A18 73 85 RESET 33 74 A19 W/R 25 98 75 A20 76 A21 A22 79 A23 80

# **PIN DESIGNATIONS (Sorted by Pin Name)**

# PIN DESIGNATIONS (Sorted by Pin Number)

| Pin No. | Pin Name        |
|---------|-----------------|---------|-----------------|---------|-----------------|---------|-----------------|---------|-----------------|
| 1       | D0              | 21      | V <sub>cc</sub> | 41      | V <sub>ss</sub> | 61      | A11             | 81      | D15             |
| 2       | V <sub>ss</sub> | 22      | V <sub>ss</sub> | 42      | V <sub>cc</sub> | 62      | A12             | 82      | D14             |
| 3       | HLDA            | 23      | M/IO            | 43      | NC              | 63      | V <sub>ss</sub> | 83      | D13             |
| 4       | HOLD            | 24      | D/C             | 44      | NC              | 64      | A13             | 84      | V <sub>cc</sub> |
| 5       | V <sub>ss</sub> | 25      | W/R             | 45      | NC              | 65      | A14             | 85      | V <sub>ss</sub> |
| 6       | NA              | 26      | LOCK            | 46      | NC              | 66      | A15             | 86      | D12             |
| 7       | READY           | 27      | NC              | 47      | NC              | 67      | V <sub>ss</sub> | 87      | D11             |
| 8       | V <sub>cc</sub> | 28      | FLT*            | 48      | V <sub>cc</sub> | 68      | V <sub>ss</sub> | 88      | D10             |
| 9       | V <sub>cc</sub> | 29      | NC              | 49      | V <sub>ss</sub> | 69      | V <sub>cc</sub> | 89      | D9              |
| 10      | V <sub>cc</sub> | 30      | NC              | 50      | V <sub>ss</sub> | 70      | A16             | 90      | D8              |
| 11      | V <sub>ss</sub> | 31      | NC              | 51      | A2              | 71      | V <sub>cc</sub> | 91      | V <sub>cc</sub> |
| 12      | V <sub>ss</sub> | 32      | V <sub>cc</sub> | 52      | A3              | 72      | A17             | 92      | D7              |
| 13      | V <sub>ss</sub> | 33      | RESET           | 53      | A4              | 73      | A18             | 93      | D6              |
| 14      | V <sub>ss</sub> | 34      | BUSY            | 54      | A5              | 74      | A19             | 94      | D5              |
| 15      | CLK2            | 35      | V <sub>ss</sub> | 55      | A6              | 75      | A20             | 95      | D4              |
| 16      | ADS             | 36      | ERROR           | 56      | A7              | 76      | A21             | 96      | D3              |
| 17      | BLE             | 37      | PEREQ           | 57      | V <sub>cc</sub> | 77      | V <sub>ss</sub> | 97      | V <sub>cc</sub> |
| 18      | A1              | 38      | NMI             | 58      | A8              | 78      | V <sub>ss</sub> | 98      | V <sub>ss</sub> |
| 19      | BHE             | 39      | V <sub>cc</sub> | 59      | A9              | 79      | A22             | 99      | D2              |
| 20      | NC              | 40      | INTR            | 60      | A10             | 80      | A23             | 100     | D1              |

\*Float feature is available in Rev. B0 and later.



\*Float feature is available in Rev. B0 and later.

15022B-003

Ş

1000



# **ORDERING INFORMATION**

# **Standard Products**

AMD standard products are available in several packages and operating ranges. The order number (Valid Combination) is formed by a combination of the elements below.



| NC | a = 100-Pl | n Plastic | Quad | Flat | Раск | (PQ1 | 00, F | QB. | 100 |
|----|------------|-----------|------|------|------|------|-------|-----|-----|
|    |            |           |      |      |      |      |       |     |     |

|    | Valid Combinations |                       |  |  |  |  |
|----|--------------------|-----------------------|--|--|--|--|
|    |                    | 25<br>20<br>16*       |  |  |  |  |
| NG | 80386SX            | –25F<br>–20F<br>–16F* |  |  |  |  |
|    |                    | –25S<br>–20S<br>–16S* |  |  |  |  |

\*Contact AMD for 16-MHz availability.

#### Valid Combinations

Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations and to check on newly released combinations.

# **PIN DESCRIPTION**

# A23-A1

# Address Bus (Outputs)

Outputs physical memory or port I/O addresses.

# ADS

# Address Status ( Active Low; Output)

Indicates that a valid bus cycle definition and address (W/ $\overline{R}$ , D/ $\overline{C}$ , M/ $\overline{IO}$ , BHE, BLE, and A23–A1) are being driven at the Am386SX microprocessor pins.

# BHE, BLE

# Byte Enables (Active Low; Outputs)

Indicate which data bytes of the data bus take part in a bus cycle.

# BUSY

# Busy (Active Low; Input)

Signals a busy condition from a processor extension.

# CLK2

# CLK2 (Input)

Provides the fundamental timing for the Am386SX microprocessor.

# D15-D0

## Data Bus (Inputs/Outputs)

Inputs data during memory, I/O, and interrupt acknowledge read cycles; outputs data during memory and I/O write cycles.

# $D/\overline{C}$

# Data/Control (Output)

A bus cycle definition pin that distinguishes data cycles, either memory or I/O, from control cycles which are: interrupt acknowledge, halt, and code fetch.

# ERROR

# Error (Active Low; Input)

Signals an error condition from a processor extension.

# FLT\*

# Float (Active Low; Input)

An input which forces all bi-directional and output signals, including HLDA, to the three-state condition.

# HLDA

# Bus Hold Acknowledge (Active High; Output)

Output indicates that the Am386SX microprocessor has surrendered control of its logical bus to another bus master.

# HOLD

# Bus Hold Request (Active High; Input)

Input allows another bus master to request control of the local bus.

# INTR

# Interrupt Request (Active High; Input)

A maskable input that signals the Am386SX microprocessor to suspend execution of the current program and execute an interrupt acknowledge function.

# LOCK

# Bus Lock (Active Low; Output)

A bus cycle definition pin that indicates that other system bus masters are not to gain control of the system bus while it is active.

# M/IO

# Memory/IO (Output)

A bus cycle definition pin that distinguishes memory cycles from input/output cycles.

# NA

# Next Address (Active Low; Input)

Used to request address pipelining.

# NC

# No Connect

Should always be left unconnected. Connection of a NC pin may cause the processor to malfunction, or be incompatible with future steppings of the Am386SX microprocessor.

# NMI

# Non-Maskable Interrupt Request (Actve High; Input)

A non-maskable input that signals the Am386SX microprocessor to suspend execution of the current program and execute an interrupt acknowledge function.

# PEREQ

# Processor Extension Request (Active High; Input)

Indicates that the processor has data to be transferred by the Am386SX microprocessor.

# READY

# Bus Ready (Active Low; Input)

Terminates the bus cycle.

# RESET

# Reset (Active High; Input)

Suspends any operation in progress and places the Am386SX microprocessor in a known reset state.

# $V_{cc}$

# System Power (Active High; Input)

Provides the +5 V nominal DC supply input.

# $V_{ss}$

# System Ground (Input)

Provides the 0 V connection from which all inputs and outputs are measured.

# W/R

# Write/Read (Output)

A bus cycle definition pin that distinguishes write cycles from read cycles.

\*Float feature is available in Rev. B0 and later.

# **ABSOLUTE MAXIMUM RATINGS**

Ambient Temperature under bias .....-65 to 125°C Storage Temperature .....-65 to 150°C

Stresses above those listed may cause permanent damage to the device. Exposure to absolute maximum rating conditions for extended periods of time may affect device reliability.

# **OPERATING RANGES**

Supply Voltage with respect to V<sub>ss</sub> . . . . -0.5 V to 7 V Voltage on other pins . . . . . . -0.5 V to (V<sub>cc</sub> + 0.5)V

Operating ranges define those limits between which the functionality of the device is guaranteed.

# DC CHARACTERISTICS over COMMERCIAL operating ranges

 $V_{cc} = 5 V \pm 10\%$ ;  $T_{case} = 0^{\circ}C$  to  $100^{\circ}C$ 

| Symbol           | Parameter Description                                                                                                                             | Notes                                                                                                    | Min                                                                       | Мах                  | Unit           |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|----------------------|----------------|
| V <sub>IL</sub>  | Input Low Voltage                                                                                                                                 |                                                                                                          | -0.3                                                                      | +0.8                 | ۷              |
| V <sub>IH</sub>  | Input High Voltage                                                                                                                                |                                                                                                          | 2.0                                                                       | V <sub>cc</sub> +0.3 | v              |
| VILC             | CLK2 Input Low Voltage                                                                                                                            |                                                                                                          | -0.3                                                                      | +0.8                 | v              |
| VIHC             | CLK2 Input High Voltage                                                                                                                           |                                                                                                          | V <sub>cc</sub> -0.8                                                      | V <sub>cc</sub> +0.3 | v              |
| V <sub>ol</sub>  | Output Low Voltage<br>$I_{oL} = 4 \text{ mA:}$ A23–A1, D15–D0<br>$I_{oL} = 5 \text{ mA:}$ BHE, BLE, W/R,<br><u>D/C</u> , M/IO, LOCK,<br>ADS, HLDA |                                                                                                          |                                                                           | 0.45<br>0.45         | v<br>v         |
| V <sub>он</sub>  | $\begin{array}{llllllllllllllllllllllllllllllllllll$                                                                                              |                                                                                                          | $\begin{array}{c} 2.4 \\ V_{cc} - 0.5 \\ 2.4 \\ V_{cc} - 0.5 \end{array}$ |                      | v<br>v<br>v    |
| lu               | Input Leakage Current<br>(for all pins except PEREQ,<br>BUSY, FLT*, and ERROR)                                                                    | $0 V \leq V_{iN} \leq V_{cc}$                                                                            |                                                                           | ±15                  | μA             |
| l <sub>in</sub>  | Input Leakage Current<br>(PEREQ pin)                                                                                                              | V <sub>IH</sub> = 2.4 V (1)                                                                              |                                                                           | 200                  | μA             |
| I <sub>IL</sub>  | Input Leakage Current<br>(BUSY, ERROR, and FLT* pins)                                                                                             | V <sub>IL</sub> = 0.45 V (2)                                                                             |                                                                           | -400                 | μA             |
| I <sub>LO</sub>  | Output Leakage Current                                                                                                                            | 0.45 V ≤ V <sub>ουτ</sub> ≤ V <sub>cc</sub>                                                              |                                                                           | ±15                  | μA             |
| I <sub>cc</sub>  | Supply Current<br>CLK2 = 32 MHz: with –16**<br>CLK2 = 40 MHz: with –20<br>CLK2 = 50 MHz: with –25                                                 | l <sub>cc</sub> Typ = 175 mA (3)<br>l <sub>cc</sub> Typ = 200 mA (3)<br>l <sub>cc</sub> Typ = 225 mA (3) |                                                                           | 275<br>305<br>335    | mA<br>mA<br>mA |
| C <sub>IN</sub>  | Input Capacitance                                                                                                                                 | F <sub>c</sub> = 1 MHz (4)                                                                               |                                                                           | 10                   | pF             |
| Cout             | Output or I/O Capacitance                                                                                                                         | F <sub>c</sub> = 1 MHz (4)                                                                               |                                                                           | 12                   | pF             |
| C <sub>CLK</sub> | CLK2 Capacitance                                                                                                                                  | $F_{c} = 1 \text{ MHz} (4)$                                                                              |                                                                           | 20                   | pF             |

Notes: Tested at the minimum operating frequency of the part. \*Float feature is available in Rev. B0 and later. 1. PEREQ input has an internal pull-down resistor.

 BUSY, FLT\*, and ERROR inputs each have an internal pull-up resistor.

 I<sub>cc</sub> Max measurement at worst case frequency, V<sub>cc</sub>, and temperature, outputs unloaded.

4. Not 100% tested.

# SWITCHING CHARACTERISTICS

The switching characteristics given consist of output delays, input setup requirements, and input hold requirements. All switching characteristics are relative to the CLK2 rising edge crossing the 2.0 V level.

Switching characteristic measurement is defined by Figure 1. Inputs must be driven to the voltage levels indicated by Figure 1 when switching characteristics are measured. Output delays are specified with minimum and maximum limits measured, as shown. The minimum delay times are hold times provided to external circuitry. Input setup and hold times are specified as minimums, defining the smallest acceptable sampling window. Within the sampling window, a synchronous input signal must be stable for correct operation.

Outputs ADS, W/R, D/C, M/IO, LOCK, BHE, BLE, A23–A1, and HLDA only change at the beginning of phase one. D15–D0 (write cycles) only change at the beginning of phase two. The READY, HOLD, BUSY, ERROR, PEREQ, FLT\*, and D15–D0 (read cycles) inputs are sampled at the beginning of phase one. The NA, INTR, and NMI inputs are sampled at the beginning of phase two.



\*Float feature is available in Rev. B0 and later.

Figure 1. Drive Levels and Measurement Points for Switching Characteristics

# SWITCHING CHARACTERISTICS over operating ranges

Switching Characteristics at 25 MHz:  $V_{cc} = 5 V \pm 10\%$ ;  $T_{case} = 0^{\circ}C$  to  $100^{\circ}C$ 

| Symbol  | Parameter Description               | Notes                                      | Ref.<br>Figure | Min | Max | Unit |
|---------|-------------------------------------|--------------------------------------------|----------------|-----|-----|------|
|         | Operating Frequency                 | Half CLK2 freg.                            |                | 2   | 25  | MHz  |
| 1       | CLK2 Period                         | ······                                     | 2              | 20  | 250 | ns   |
| -<br>2a | CLK2 High Time                      | at 2 V                                     | 2              | 7   |     | ns   |
| <br>2b  | CLK2 High Time                      | at (V <sub>cc</sub> -0.8 V)                | 2              | 4   |     | ns   |
| <br>3a  | CLK2 Low Time                       | at 2 V                                     | 2              | 7   |     | ns   |
| 3b      | CLK2 Low Time                       | at 0.8 V                                   | 2              | 5   |     | ns   |
| 4       | CLK2 Fall Time                      | (V <sub>cc</sub> -0.8 V) to 0.8 V (Note 3) | 2              |     | 7   | ns   |
| 5       | CLK2 Rise Time                      | 0.8 V to (V <sub>cc</sub> -0.8 V) (Note 3) | 2              |     | 7   | ns   |
| 6       | A23–A1 Valid Delay                  | C <sub>L</sub> = 50 pF                     | 5              | 4   | 17  | ns   |
| 7       | A23-A1 Float Delay                  | (Note 1)                                   | 9              | 4   | 30  | ns   |
| 8       | BHE, BLE, LOCK Valid Delay          | C <sub>L</sub> = 50 pF                     | 5              | 4   | 17  | ns   |
| 9       | BHE, BLE, LOCK Float Delay          | (Note 1)                                   | 9              | 4   | 30  | ns   |
| 10      | M/IO, D/C, W/R, ADS Valid Delay     | C <sub>L</sub> = 50 pF                     | 5              | 4   | 17  | ns   |
| 11      | W/R, M/IO, D/C, ADS Float Delay     | (Note 1)                                   | 9              | 4   | 30  | ns   |
| 12      | D15–D0 Write Data Valid Delay       | C <sub>L</sub> = 50 pF                     | 5              | 7   | 23  | ns   |
| 12a     | D15-D0 Write Data Hold Time         | $C_{L} = 50  \text{pF}$                    |                | 2   |     | ns   |
| 13      | D15–D0 Write Data Float Delay       | (Note 1)                                   | 9              | 4   | 22  | ns   |
| 14      | HLDA Valid Delay                    | C <sub>L</sub> = 50 pF                     | 5              | 4   | 22  | ns   |
| 15      | NA Setup Time                       |                                            | 4              | 5   |     | ns   |
| 16      | NA Hold Time                        |                                            | 4              | 3   |     | ns   |
| 19      | READY Setup Time                    |                                            | 4              | 9   |     | ns   |
| 20      | READY Hold Time                     |                                            | 4              | 4   |     | ns   |
| 21      | D15-D0 Read Data Setup Time         |                                            | 4              | 7   |     | ns   |
| 22      | D15–D0 Read Data Hold Time          |                                            | 4              | 5   |     | ns   |
| 23      | HOLD Setup Time                     |                                            | 4              | 9   |     | ns   |
| 24      | HOLD Hold Time                      |                                            | 4              | 3   |     | ns   |
| 25      | RESET Setup Time                    |                                            | 10             | 8   |     | ns   |
| 26      | RESET Hold Time                     |                                            | 10             | 3   |     | ns   |
| 27      | NMI, INTR Setup Time                | (Note 2)                                   | 4              | 6   |     | ns   |
| 28      | NMI, INTR Hold Time                 | (Note 2)                                   | 4              | 6   |     | ns   |
| 29      | PEREQ, ERROR, BUSY, FLT* Setup Time | (Note 2)                                   | 4              | 6   |     | ns   |
| 30      | PEREQ, ERROR, BUSY, FLT* Hold Time  | (Note 2)                                   | 4              | 5   |     | ns   |

Notes: \*Float feature is available in Rev. B0 and later.

1. Float condition occurs when maximum output current becomes less than ILO in magnitude. Float delay is not 100% tested.

2. These inputs are allowed to be asynchronous to CLK2. The setup and hold specifications are given for testing purposes, to assure recognition within a specific CLK2 period.

3. These are not tested. They are guaranteed by design characterization.

# SWITCHING CHARACTERISTICS over operating ranges (continued)

Switching Characteristics at 20 MHz:  $V_{cc} = 5 V \pm 10\%$ ;  $T_{case} = 0^{\circ}C$  to  $100^{\circ}C$ 

| Symbol | Parameter Description               | Notes                             |          | Ref.<br>Figure | Min | Max | Unit |
|--------|-------------------------------------|-----------------------------------|----------|----------------|-----|-----|------|
|        | Operating Frequency                 | Half CLK2 freq.                   |          |                | 2   | 20  | MHz  |
| 1      | CLK2 Period                         |                                   |          | 2              | 25  | 250 | ns   |
| 2a     | CLK2 High Time                      | at 2 V                            |          | 2              | 8   |     | ns   |
| 2b     | CLK2 High Time                      | at (V <sub>cc</sub> -0.8 V)       |          | 2              | 5   |     | ns   |
| 3a     | CLK2 Low Time                       | at 2 V                            |          | 2              | 8   |     | ns   |
| 3b     | CLK2 Low Time                       | at 0.8 V                          |          | 2              | 6   |     | ns   |
| 4      | CLK2 Fall Time                      | (V <sub>cc</sub> -0.8 V) to 0.8 V | (Note 3) | 2              |     | 8   | ns   |
| 5      | CLK2 Rise Time                      | 0.8 V to (V <sub>cc</sub> -0.8 V) | (Note 3) | 2              |     | 8   | ns   |
| 6      | A23–A1 Valid Delay                  | C <sub>L</sub> = 120 pF           | (Note 4) | 9              | 4   | 30  | ns   |
| 7      | A23-A1 Float Delay                  |                                   | (Note 1) | 9              | 4   | 32  | ns   |
| 8      | BHE, BLE, LOCK Valid Delay          | С <sub>L</sub> = 75 рF            | (Note 4) | 5              | 4   | 30  | ns   |
| 9      | BHE, BLE, LOCK Float Delay          |                                   | (Note 1) | 9              | 4   | 32  | ns   |
| 10a    | M/IO, D/C Valid Delay               | С <sub>L</sub> = 75 рF            | (Note 4) | 5              | 4   | 28  | ns   |
| 10b    | W/R, ADS Valid Delay                | C <sub>L</sub> = 75 pF            | (Note 4) | 5              | 4   | 26  | ns   |
| 11     | W/R, M/IO, D/C, ADS Float Delay     |                                   | (Note 1) | 9              | 6   | 30  | ns   |
| 12     | D15–D0 Write Data Valid Delay       | C <sub>L</sub> = 120 pF           | (Note 4) | 5              | 4   | 38  | ns   |
| 13     | D15–D0 Write Data Float Delay       |                                   | (Note 1) | 9              | 4   | 27  | ns   |
| 14     | HLDA Valid Delay                    | С <sub>L</sub> = 75 рF            | (Note 4) | 5              | 4   | 28  | ns   |
| 15     | NA Setup Time                       |                                   |          | 4              | 5   |     | ns   |
| 16     | NA Hold Time                        |                                   |          | . 4            | 12  |     | ns   |
| 19     | READY Setup Time                    |                                   |          | 4              | 12  |     | ns   |
| 20     | READY Hold Time                     |                                   |          | 4              | 4   |     | ns   |
| 21     | D15–D0 Read Data Setup Time         |                                   | ******   | 4              | 9   |     | ns   |
| 22     | D15-D0 Read Data Hold Time          |                                   |          | 4              | 6   |     | ns   |
| 23     | HOLD Setup Time                     |                                   |          | 4              | 17  |     | ns   |
| 24     | HOLD Hold Time                      |                                   |          | 4              | 5   |     | ns   |
| 25     | RESET Setup Time                    |                                   |          | 10             | 12  |     | ns   |
| 26     | RESET Hold Time                     |                                   |          | 10             | 4   |     | ns   |
| 27     | NMI, INTR Setup Time                |                                   | (Note 2) | 4              | 16  |     | ns   |
| 28     | NMI, INTR Hold Time                 |                                   | (Note 2) | 4              | 16  | 1   | ns   |
| 29     | PEREQ, ERROR, BUSY, FLT* Setup Time |                                   | (Note 2) | 4              | 14  |     | ns   |
| 30     | PEREQ, ERROR, BUSY, FLT* Hold Time  |                                   | (Note 2) | 4              | 5   | 1   | ns   |

Notes: \*Float feature is available in Rev. B0 and later.

1. Float condition occurs when maximum output current becomes less than  $I_{LO}$  in magnitude. Float delay is not 100% tested.

2. These inputs are allowed to be asynchronous to CLK2. The setup and hold specifications are given for testing purposes, to assure recognition within a specific CLK2 period.

3. These are not tested. They are guaranteed by design characterization.

Tested with C<sub>L</sub> set at 50 pF and derated to support the indicated distributed capacitive load. See Figures 11–14 for the capacitive derating curve.

| SWITCHING CHARACTERISTICS over operating ranges (continued)                                        |
|----------------------------------------------------------------------------------------------------|
| Switching Characteristics at 16 MHz**: V <sub>cc</sub> = 5 V±10%; T <sub>case</sub> = 0°C to 100°C |

| Symbol | Parameter Description               | Notes                             |          | Ref.<br>Figure | Min | Max | Unit |
|--------|-------------------------------------|-----------------------------------|----------|----------------|-----|-----|------|
|        | Operating Frequency                 | Half CLK2 freq.                   |          |                | 2   | 16  | MHz  |
| 1      | CLK2 Period                         |                                   |          | 2              | 31  | 250 | ns   |
| 2a     | CLK2 High Time                      | at 2 V                            |          | 2              | 9   |     | ns   |
| 2b     | CLK2 High Time                      | at (V <sub>cc</sub> -0.8 V)       |          | 2              | 5   |     | ns   |
| 3a     | CLK2 Low Time                       | at 2 V                            |          | 2              | 9   |     | ns   |
| Зb     | CLK2 Low Time                       | at 0.8 V                          |          | 2              | 7   |     | ns   |
| 4      | CLK2 Fall Time                      | (V <sub>cc</sub> -0.8 V) to 0.8 V | (Note 3) | 2              |     | 8   | ns   |
| 5      | CLK2 Rise Time                      | 0.8 V to (V <sub>cc</sub> -0.8 V) | (Note 3) | 2              |     | 8   | ns   |
| 6      | A23–A1 Valid Delay                  | C <sub>L</sub> = 120 pF           | (Note 4) | 5              | 4   | 36  | ns   |
| 7      | A23-A1 Float Delay                  |                                   | (Note 1) | 9              | 4   | 40  | ns   |
| 8      | BHE, BLE, LOCK Valid Delay          | C <sub>L</sub> = 75 pF            | (Note 4) | 5              | 4   | 36  | ns   |
| 9      | BHE, BLE, LOCK Float Delay          |                                   | (Note 1) | 9              | 4   | 40  | ns   |
| 10     | W/R, M/IO, D/C, ADS Valid Delay     | С <sub>L</sub> = 75 рF            | (Note 4) | 5              | 4   | 33  | ns   |
| 11     | W/R, M/IO, D/C, ADS Float Delay     |                                   | (Note 1) | 9              | 6   | 35  | ns   |
| 12     | D15–D0 Write Data Valid Delay       | C <sub>L</sub> = 120 pF           | (Note 4) | 5              | 4   | 40  | ns   |
| 13     | D15–D0 Write Data Float Delay       |                                   | (Note 1) | 9              | 4   | 35  | ns   |
| 14     | HLDA Valid Delay                    | С <sub>L</sub> = 75 рF            | (Note 4) | 5              | 4   | 33  | ns   |
| 15     | NA Setup Time                       |                                   |          | 4              | 5   |     | ns   |
| 16     | NA Hold Time                        |                                   |          | 4              | 21  |     | ns   |
| 19     | READY Setup Time                    |                                   |          | 4              | 19  |     | ns   |
| 20     | READY Hold Time                     |                                   |          | 4              | 4   |     | ns   |
| 21     | D15–D0 Read Data Setup Time         |                                   |          | 4              | 9   |     | ns   |
| 22     | D15–D0 Read Data Hold Time          |                                   |          | 4              | 6   |     | ns   |
| 23     | HOLD Setup Time                     |                                   |          | 4              | 26  |     | ns   |
| 24     | HOLD Hold Time                      |                                   |          | 4              | 5   |     | ns   |
| 25     | RESET Setup Time                    |                                   |          | 10             | 13  |     | ns   |
| 26     | RESET Hold Time                     |                                   |          | 10             | 4   |     | ns   |
| 27     | NMI, INTR Setup Time                |                                   | (Note 2) | 4              | 16  |     | ns   |
| 28     | NMI, INTR Hold Time                 |                                   | (Note 2) | 4              | 16  |     | ns   |
| 29     | PEREQ, ERROR, BUSY, FLT* Setup Time |                                   | (Note 2) | 4              | 16  |     | ns   |
| 30     | PEREQ, ERROR, BUSY, FLT* Hold Time  |                                   | (Note 2) | 4              | 5   |     | ns   |

Notes: \*Float feature is available in Rev. B0 and later.

\*\*Contact AMD for 16-MHz availability.

1. Float condition occurs when maximum output current becomes less than ILO in magnitude. Float delay is not 100% tested.

2. These inputs are allowed to be asynchronous to CLK2. The setup and hold specifications are given for testing purposes, to assure recognition within a specific CLK2 period.

3. These are not tested. They are guaranteed by design characterization.

4. Tested with CL set at 50 pF and derated to support the indicated distributed capacitive load. See Figures 11–14 for the capacitive derating curve.









15022B-032

キャントでは、第二日

ĝ

Figure 3. AC Test Circuit

# SWITCHING WAVEFORMS



\*Float feature is available in Rev. B0 and later.







15022B-034





+ 40°C\* dogu 6 esto filiñoa o

Ś

district.

Figure 8. Write Data Valid Delay Timing (20 MHz)

# SWITCHING WAVEFORMS (continued)



Figure 9. Output Float Delay and HLDA Valid Delay Timing



15022B-036

Figure 10. RESET Setup and Hold Timing and Internal Phase



15022B-037







Note: This graph will not be linear outside of the CL range shown.







# **AMD** 80C287<sup>™</sup>

# 80-Bit CMOS Math Coprocessor

# **DISTINCTIVE CHARACTERISTICS**

- High-performance CMOS process vields 10-MHz and 12-MHz speed grades
- Available in space-saving 44-pin PLCC as well as 40-pin DIP
- 80-bit numeric accelerator for 80C286- and 80286-based systems
- Compatible with IEEE floating-point standard 754
- Static CMOS design does not require a minimum clock rate, resulting in significantly lower power dissipation
- Performs single-, double-, and extendedprecision floating-point, as well as word, short. and long integer and 18-digit BCD conversions
- Adds trigonometric, logarithmic, exponential, and arithmetic instructions to the 80C286 instruction set

# **GENERAL DESCRIPTION**

The AMD 80C287 math coprocessor is implemented in AMD's advanced static CMOS process that allows for significantly higher speeds at a much lower power dissipation than traditional NMOS versions or standard CMOS. The AMD 80C287 math coprocessor is a highperformance arithmetic processor that expands the 80C286 instruction set with floating-point instructions

conversions. The floating-point operations comply with the IEEE Standard 754. The device is available in 10and 12-MHz speed grades and is provided in 44-pin PLCC and 40-pin DIP packages. When coupled with the 80C286, the AMD 80C287 math coprocessor provides a complete solution for high-performance numeric

#### Bus Interface Unit Numeric Execution Unit Instruction Address Operand Address Exponent Control Word D Status a Word t 16 Shifter Tag Word Data a B Instruction Arithmetic u Unit 16 Addressf Unit f Controle 64 r 16 S Register Stack 80 Bits 11671A-001

# Publication: 11671 Rev. D Amendment /0

**BLOCK DIAGRAM** 

# including transcendentals, and integer and BCD processing applications.



# **CONNECTION DIAGRAM**



Note: N/C pins should not be connected. Pin 1 is marked for orientation.

# PIN DESCRIPTION

#### BUSY

#### Busy Status (Output; Active Low)

A Low level indicates that the AMD 80C287 math coprocessor is currently executing a command.

#### CKM

#### **Clock Mode Signal (Input)**

When CKM is High, the CLK is used directly. When CKM is Low, CLK is divided by three. This input must be either High or Low 20-CLK cycles before RESET goes Low.

#### CLK

#### Clock (Input)

Provides timing for AMD 80C287 math coprocessor operations.

# CMD1, CMD0

#### Command Lines (Inputs)

 $CMD_1$  and  $CMD_0$ , along with select inputs, allow the CPU to direct the AMD 80C287 math coprocessor operations. These inputs are timed relative to the read and write strobes.

#### D15-D0

#### Data (Inputs/Outputs)

Bi-directional data bus. These inputs are timed relative to the read and write strobes.

#### ERROR

#### Error Status (Output; Active Low)

Reflects the error summary status bit of the status word. A Low level indicates that an unmasked exception condition exists.

11671A-002

#### NPRD

#### Numeric Processor Read (Input; Active Low)

A Low level enables transfer of data from the AMD 80C287 math coprocessor. This input may be asynchronous to the AMD 80C287 clock.

#### NPS1, NPS2

#### Numeric Processor Selects (Inputs)

Indicates the CPU is transferring data to and from the AMD 80C287 math coprocessor. Asserting both signals (NPS1 Low and NPS2 High) enables the AMD 80C287 math coprocessor to transfer floating-point data or instructions. No data transfers involving the AMD 80C287 math coprocessor will occur unless the AMD 80C287 math coprocessor is selected via NPS1 and NPS2. These inputs are timed relative to the read and write strobes.

#### NPWR

#### Numeric Processor Write (Input; Active Low)

A Low level enables transfer of data to the AMD 80C287 math coprocessor. This input may be asynchronous to the AMD 80C287 clock.

# PEACK

# Processor Extension Acknowledge (Input; Active Low)

A Low level indicates that the request signal (PEREQ) has been recognized. PEACK causes the request (PEREQ) to be withdrawn when no more transfers are required. PEACK may be asynchronous to the AMD 80C287 clock.

#### PEREQ

#### Processor Extension Request (Output)

A High level indicates that the AMD 80C287 math coprocessor is ready to transfer data. PEREQ will be disabled upon assertion of PEACK or upon actual data transfer, whichever occurs first, when no more transfers are required.

#### RESET System Reset (input)

Reset causes the AMD 80C287 math coprocessor to immediately terminate its present activity and enter a dormant state. Reset must be High for more than four CLK cycles. For proper initialization the High-Low transition must occur no sooner than 50  $\mu s$  after  $V_{CC}$  and CLK meet their DC and AC specifications.

V<sub>ss</sub> System Ground (Input)

Both pins must be connected to ground.

# **ORDERING INFORMATION**

#### **Commodity Products**

AMD products are available in several packages and operating ranges. The order number (Valid Combination) is formed by a combination of the elements below.



| Valid C | combination   |
|---------|---------------|
|         | AMD 80C287-12 |
| N, P    | AMD 80C287-10 |

#### Valid Combination

Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations and to check on newly released valid combinations.

# SIMPLIFIED FUNCTIONAL DESCRIPTION

The AMD 80C287 math coprocessor is internally divided into two basic processing units; the numeric execution unit, and the bus interface unit as shown in the block diagram. The numeric execution unit performs numeric instructions. The bus interface unit receives and decodes instructions, executes processor control instructions, and requests operands transfers to and from memory. The 80C286 may execute non-numeric instruction concurrently with numeric instruction executed on the AMD 80C287 math coprocessor. Synchronization and error recognition occurs when the next numeric instruction is decoded by the 80C286.

## **The Numeric Execution Unit**

The numeric execution data path is 80 bits wide. All operands are converted to the internal 80-bit format before use. These instructions include arithmetic, transcendental, constant, and data transfer instructions.

## The Bus Interface Unit

The bus interface unit decodes the ESC instruction executed by the 80C286. The signal BUSY is activated for the 80C286/AMD 80C287 synchronization and the signal ERROR is activated for error detection. BUSY is activated when an instruction is transferred and deactivated when the instruction completes. ERROR will be asserted if an error has occurred when BUSY is deactivated.

The signals PEREQ, PEACK, NPRD, NPWR, NPS1, CMD0, CMD1, and NPS2 control data transfers between the AMD 80C287 math coprocessor and the 80C286. The 80C286 performs the actual data transfer with memory.

#### **The Register Stack**

The register stack contains eight 80-bit data registers, organized as a push down stack. Operations are performed on the stack top, between the stack top and another register, or between the stack top and memory.

#### System Configuration with 80C286

A simplified block diagram of the AMD 80C287 interface to a 80C286 CPU is shown in Figure 1. The AMD 80C287 math coprocessor can operate concurrently with the host CPU. The signals PEREQ, PEACK, BUSY, NPRD, NPWR, CMD0, and CMD1 allow the AMD 80C287 math coprocessor to receive instructions and data from the 80C286. Detection of errors are indicated to the CPU by asserting the signal ERROR. The address decode logic, bus control and timing logic are shown in this implementation using AMD PAL<sup>®</sup> devices but may also be accomplished using standard chip sets.

The AMD 80C287 math coprocessor operates either directly from the CPU clock or with a dedicated clock. The AMD 80C287 math coprocessor functions at two-thirds the frequency of the 80C286 when operating with the CPU clock (i.e., for a 16-MHz 80C286, the 32-MHz clock is divided down to 10.6 MHz).



Figure 1. The 80C286/AMD 80C287 Simplified System Configuration

11671A-003

# **ELECTRICAL AND SWITCHING CHARACTERISTICS**

# **Absolute Maximum Ratings**

| Storage Temperature65 to +150° C                       |
|--------------------------------------------------------|
| Ambient Temperature Under Bias55 to +125° C            |
| Supply Voltage to Ground Potential                     |
| Continuous1.0 to +7.0 V                                |
| DC Voltage Applied to Outputs                          |
| for High Output State0.3 V to + V <sub>cc</sub> +0.3 V |
| DC Input Voltage0.3 to V <sub>cc</sub> +0.3 V          |
| DC Output Current, into Low Outputs                    |
| DC Input Current10 to +10 mA                           |
| Power Dissipation (Max.)0.5 W                          |
|                                                        |

Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to absolute maximum ratings for extended periods may affect devices reliability.

# **Operating Ranges**

| Commercial (C) Devices                 |                |
|----------------------------------------|----------------|
| Temperature, Ambient (T <sub>A</sub> ) | 0 to +70°C     |
| (also meets 0 to 100°C Case T          |                |
| for laptop requirements)               |                |
| Supply Voltage (V <sub>cc</sub> )      | +4.5 to +5.5 V |

Operating ranges define those limits between which the functionality of the device is guaranteed.

DC CHARACTERISTICS over operating range unless otherwise specified (for APL Products, Group A, Subgroups 1, 2, 3 are tested unless otherwise noted).

| Parameter<br>Symbol | Parameter<br>Description                                  | Test                                                                           | Test Conditions                            |            | Max                     | Unit   |
|---------------------|-----------------------------------------------------------|--------------------------------------------------------------------------------|--------------------------------------------|------------|-------------------------|--------|
| V <sub>on</sub>     | Output High Voltage                                       | V <sub>cc</sub> = Min.<br>V <sub>IN</sub> = V <sub>IL</sub> or V <sub>IH</sub> | l <sub>он</sub> = -0.4 mA                  | 2.4        |                         | v      |
| Vol                 | Output Low Voltage                                        | V <sub>cc</sub> = Min.<br>V <sub>IN</sub> = V <sub>IL</sub> or V <sub>IH</sub> | l <sub>oL</sub> = 3 mA                     |            | 0.45                    |        |
| V <sub>IH</sub>     | Guaranteed Input Logical<br>High Voltage (see note below) |                                                                                |                                            | 2.0        | V <sub>cc</sub><br>+0.5 | V      |
| V <sub>IL</sub>     | Guaranteed Input Logical<br>Low Voltage (see note below)  |                                                                                |                                            | -0.5       | 0.8                     | V      |
| V <sub>IHC</sub>    | Clock Input High Voltage<br>CKM = 1                       |                                                                                |                                            | 2.0        | V <sub>cc</sub><br>+1.0 | v      |
|                     | СКМ = 0                                                   |                                                                                |                                            | 3.8        | V <sub>cc</sub><br>+1.0 | v      |
| V <sub>ILC</sub>    | Clock Input Low Voltage                                   |                                                                                |                                            | 0.5<br>0.5 | 0.8<br>0.6              | v<br>v |
| IJ                  | Input Leakage Current                                     | $0 V \le V_{iN} \le V_{cc}$                                                    |                                            |            | ±10                     | μA     |
| I <sub>ozH</sub>    | Off-State (High Impedance)<br>Output Current              | V <sub>cc</sub> = Max, V <sub>o</sub> = 2.4                                    | ŧ V                                        |            | 10                      | μA     |
| l <sub>ozt</sub>    | Off-State (High Impedance)<br>Output Current              | V <sub>cc</sub> = Max, V <sub>o</sub> = 0.4                                    | 45 V                                       |            | -10                     | μA     |
| I <sub>CCD</sub>    | Power Supply Current, Operating                           | V <sub>cc</sub> = Max<br>Outputs Unloaded                                      |                                            | 10 mA      | + 5 mA/I                | MHz    |
| I <sub>ccs</sub>    | Power Supply Current, Static                              | $V_{cc} = Max, V_{iN} - V_{ci}$                                                | <sub>c</sub> or GND, I <sub>o</sub> = 0 μA |            | 20 mA                   |        |

Note: These input levels provide zero-noise immunity and should only be statically tested in a noise-free environment (not functionally tested).

#### AMD 80C287-10 AMD 80C287-12 No. **Parameter Description** Min Max Min Max Unit Clock Period 1 CKM = 1100 80 ns CKM = 032 26 ns 2 **Clock Low Time** CKM = 145 35 ns CKM = 011 9 ns **Clock High Time** 3 CKM = 128 22 ns CKM = 0 11 9 ns **Clock Rise Time** 4 10 8 ns **Clock Fall Time** 10 8 5 ns Data Setup to NPWR Inactive 6 75 75 ns Data Hold from NPWR Inactive 7 18 10 ns NPWR, NPRD Active Time 70 90 8 ns 9 Command Valid Setup Time 0 0 ns PEREQ Active to NPRD Active 10 100 80 ns PEACK Active Time 11 60 50 ns PEACK Inactive Time 12 200 160 ns PEACK Inactive to NPRD, NPWR Inactive 32 13 40 ns NPRD, NPWR Inactive to PEACK Active 14 -30 -30 ns 15 **Command Valid Hold Time** 22 18 ns PEACK Active Setup to NPRD, NPWR 16 30 40 ns NPRD, NPWR to CLK Setup 17 53 40 ns 18 NPRD, NPWR CLK Hold 37 29 ns 19 **RESET to CLK Setup** 20 20 ns 20 RESET from CLK Hold 20 20 ns NPRD Inactive to Data Float 21 21 17 ns NPRD Active to Data Valid 22 60 50 ns 23 **ERROR** Active to **BUSY** Inactive 100 100 ns NPWR, Active to BUSY Active 100 24 80 ns PEACK Active to PEREQ Inactive 25 100 80 ns NPRD, NPWR Active to PEREQ Inactive 100 26 80 ns Command Inactive Time 27 Write to Write 75 60 ns Read to Read 75 60 ns Write to Read 75 60 ns Read to Write 75 60 ns Data Hold from Time NPRD Inactive 28 3 1 ns

# SWITCHING CHARACTERISTICS over commercial operating range

# SWITCHING WAVEFORMS

#### AC Drive and Measurement Points—CLK Input



11959A-004

#### AC Setup, Hold and Delay Time Measurement-General



AC Test Loading on Outputs



11959A-005

#### Read Timing from AMD 80C287 Math Coprocessor



11959A-007

#### Write Timing from AMD 80C287 Math Coprocessor



# Data Channel Timing (Initiated by AMD 80C287 Math Coprocessor)



11959A-009





NOTE: Reset, NPWR, NPRD are inputs asynchronous to CLK. Timing requirements above are given for testing purposes only, to assure recognition at a specific CLK edge.

# CLK, NPRD, NPWR TIMING (CKM = 1)



11959A-012

# CLK, RESET TIMING (CKM = 0)



NOTE: Reset must meet timing shown to guarantee known phase of internal + 3 circuit.

11959A-013

CLK, NPRD, NPWR TIMING (CKM = 0)



11959A-014

# AMD 80EC287<sup>™</sup>

# Enhanced 80-Bit CMOS Math Coprocessor

# DISTINCTIVE CHARACTERISTICS

- Pin compatible and functionally equivalent to the Intel 80287
- High-performance CMOS process vields 10-, and 12-MHz speed grades
- Enhanced sleep feature automatically shuts off the internal clock when no instruction is executing, reducing power consumption. This feature is transparent to the user
- Available in space-saving 44-pin PLCC as well as 40-pin DIP
- 80-bit numeric accelerator for 80C286- and 80286-based systems

# **GENERAL DESCRIPTION**

The AMD 80EC287 processor is implemented in AMD's advanced static CMOS process that allows for significantly higher speeds at a much lower power dissipation than traditional NMOS versions or standard CMOS. The AMD 80EC287 processor is a highperformance arithmetic processor that expands the 80C286 instruction set with floating-point instructions including transcendentals, and integer and BCD conversions. The AMD 80EC287 processor is functionally equivalent to the Intel 80287 and AMD 80C287 math coprocessor plus adds a low-power sleep

#### **BLOCK DIAGRAM**

- Compatible with IEEE floating point Standard 754
- Static CMOS design does not require a minimum clock rate, resulting in significantly lower power dissipation
- Performs single-, double-, and extendedprecision floating point, as well as word, short, and long integer and 18-digit BCD conversions
- Adds trigonometric, logarithmic, exponential, and arithmetic instructions to the 80C286 instruction set

feature for battery powered applications. This enhanced AMD 80EC287 processor can be a direct replacement for an AMD 80C287 processor. The sleep feature is an automatic inherent feature of the device and thus requires no external entry. The floating point operations comply with the IEEE Standard 754. The device is available in 10- and 12-MHz speed grades and is provided in 44-pin PLCC and 40-pin DIP packages. When coupled with the 80C286, the AMD 80EC287 processor provides a complete solution for highperformance numeric processing applications.



11959-002A

# **CONNECTION DIAGRAMS**



Notes: N/C pins should not be conntected. Pin 1 is marked for orientation

# **PIN DESCRIPTION**

#### BUSY

#### **Busy Status (Output; Active Low)**

A Low level indicates that the AMD 80EC287 math coprocessor is currently executing a command.

#### СКМ

#### **Clock Mode Signal (Input)**

When CKM is High, the CLK is used directly. When CKM is Low, CLK is divided by three. This input must be either High or Low 20-CLK cycles before RESET goes Low.

#### CLK

#### Clock (Input)

Provides timing for AMD 80EC287 math coprocessor operations.

#### CMD1, CMD0 Command Lines (Inputs)

CMD1 and CMD0, along with select inputs, allow the CPU to direct the AMD 80EC287 math coprocessor operations. These inputs are timed relative to the read and write strobes.

#### D15-D0

#### Data (Inputs/Outputs)

Bi-directional data bus. These inputs are timed relative to the read and write strobes.

#### ERROR

#### Error Status (Output; Active Low)

Reflects the error summary status bit of the status word. A Low level indicates that an unmasked exception condition exists.

#### NPRD

#### Numeric Processor Read (Input; Active Low)

A Low level enables transfer of data from the AMD 80EC287 math coprocessor. This input may be asyn-chronous to the AMD 80EC287 clock.

#### NPS1, NPS2

#### Numeric Processor Selects (Inputs)

Indicates the CPU is transferring data to and from the AMD 80EC287 math coprocessor. Asserting both signals (NPS1 Low and NPS2 High) enables the AMD 80EC287 math coprocessor to transfer floating-point data or instructions. No data transfers involving the AMD 80EC287 math coprocessor will occur unless the AMD 80EC287 math coprocessor is selected via NPS1 and NPS2. These inputs are timed relative to the read and write strobes.

#### NPWR

#### Numeric Processor Write (Input; Active Low)

A Low level enables transfer of data to the AMD 80EC287 math coprocessor. This input may be asynchronous to the AMD 80EC287 clock.

#### PEACK Processor Extension Acknowledge

#### (Input; Active Low)

A Low level indicates that the request signal (PEREQ) has been recognized. PEACK causes the request (PEREQ) to be withdrawn when no more transfers are required. PEACK may be asynchronous to the AMD 80EC287 clock.

#### PEREQ

#### **Processor Extension Request (Output)**

A High level indicates that the AMD 80EC287 math coprocessor is ready to transfer data. PEREQ will be disabled upon assertion of PEACK or upon actual data transfer, whichever occurs first, when no more transfers are required.

Valid Combination

N. P

AMD 80EC287-12

AMD 80EC287-10

# RESET System Reset (Input)

Reset causes the AMD 80EC287 math coprocessor to immediately terminate its present activity and enter a dormant state. Reset must be High for more than four CLK cycles. For proper initialization the High-Low transition must occur no sooner than 50  $\mu s$  after V<sub>CC</sub> and CLK meet their DC and AC specifications.

v<sub>cc</sub> +5 V Supply (Input)

#### V<sub>ss</sub> System Ground (Input)

Both pins must be connected to ground.

# **ORDERING INFORMATION**

## **Commodity Products**

AMD products are available in several packages and operating ranges. The order number (Valid Combination) is formed by a combination of the elements below.



#### Valid Combination

Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations and to check on newly released valid combinations.

# SIMPLIFIED FUNCTIONAL DESCRIPTION

The AMD 80EC287 numeric processor is internally divided into two basic processing units: the numeric execution unit, and the bus interface unit as shown in the block diagram. The numeric execution unit performs numeric instructions. The bus interface unit receives and decodes instructions, executes processor control instructions, and requests operands transfers to and from memory. The 80C286 may execute non-numeric instruction concurrently with numeric instruction executed on the AMD 80EC287 processor. Synchronization and error recognition occurs when the next numeric instruction is decoded by the 80C286.

# The Numeric Execution Unit

The numeric execution data path is 80-bits wide. All operands are converted to the internal 80-bit format before use. These instructions include arithmetic, transcendental, constant, and data transfer instructions.

## The Bus Interface Unit

The Bus Interface Unit decodes the ESC instruction executed by the 80C286. The signal  $\overline{\text{BUSY}}$  is activated for AMD 80C286/80EC287 processor synchronization and the signal  $\overline{\text{ERROR}}$  is activated for error detection. BUSY is activated when an instruction is transferred and deactivated when the instruction completes.  $\overline{\text{ERROR}}$  will be asserted if an error has occurred when BUSY is deactivated.

The signals PEREQ, PEACK, NPRD, NPWR, NPS1, CMD0, CMD1, and NPS2 control data transfers between the AMD 80EC287 processor and the 80C286. The 80C286 performs the actual data transfer with memory.

## The Register Stack

The register stack contains eight 80-bit data registers, organized as a push down stack. Operations are performed on the stack top, between the stack top and another register, or between the stack top and memory.

# System Configuration with 80C286

A simplified block diagram of the AMD 80EC287 processor interface to a 80C286 CPU is shown in Figure 1. The AMD 80EC287 processor can operate concurrently with the host CPU. The signals PEREQ, PEACK, BUSY, NPRD, NPWR, CMD0, and CMD1 allow the AMD 80EC287 processor to receive instructions and data from the 80C286. Detection of errors are indicated to the CPU by asserting the signal ERROR. The address decode logic, bus control and timing logic is shown in this implementation using AMD PAL® devices but may also be accomplished using standard chip sets.

The AMD 80EC287 processor operates either directly from the CPU clock or with a dedicated clock. The AMD 80EC287 processor functions at two-thirds the frequency of the 80C286 when operating with the CPU clock (i.e., for a 16-MHz 80C286, the 32-MHz clock is divided down to 10.6 MHz).

# **Sleep Feature**

The AMD 80EC287 processor clock runs only while an instruction is executing. The internal clock shuts itself off when no instruction is executing, thus reducing power consumption. This feature is completely transparent to the user and requires no external circuitry or design interface.



# Figure 1. AMD 80C286/80EC287 Simplified System Configuration

11959-003A

影

# **ABSOLUTE MAXIMUM RATINGS**

| Storage Temperature                 | 65°C to +150° C                    |
|-------------------------------------|------------------------------------|
| Ambient Temperature Under Bias      | 55°C to +125° C                    |
| Supply Voltage to Ground Potential  |                                    |
| Continuous                          | 1.0 to +7.0 V                      |
| DC Voltage Applied to Outputs       |                                    |
| for High Output State               | -0.3 V to + V <sub>cc</sub> +0.3 V |
| DC Input Voltage                    | 0.3 to V <sub>cc</sub> +0.3 V      |
| DC Output Current, into Low Outputs |                                    |
| DC Input Current                    |                                    |
| Power Dissipation (Max)             | 0.5 W                              |

Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to absolute maximum ratings for extended periods may affect devices reliability.

# **OPERATING RANGES**

| Commercial (C) Devices                 |                                  |
|----------------------------------------|----------------------------------|
| Temperature, Ambient (T <sub>A</sub> ) | 0°C to +70°C                     |
| (also meets 0 to 100°C Case T          | emperature (T <sub>c</sub> ) for |
| laptop requirements)                   |                                  |
| Supply Voltage (V <sub>CC</sub> )      | + 4.5 to +5.5 V                  |

Operating ranges define those limits between which the functionality of the device is guaranteed.

# DC CHARACTERISTICS over COMMERCIAL operating range unless otherwise specified

| Parameter<br>Symbol |                                                   |                                                                               | Conditions                | Min              | Max                          | Unit   |  |
|---------------------|---------------------------------------------------|-------------------------------------------------------------------------------|---------------------------|------------------|------------------------------|--------|--|
| V <sub>OH</sub>     | Output High Voltage                               | V <sub>CC</sub> = Min<br>V <sub>IN</sub> = V <sub>IL</sub> or V <sub>IH</sub> | I <sub>OH</sub> = -0.4 mA | 2.4              |                              | v      |  |
| V <sub>OL</sub>     | Output Low Voltage                                | V <sub>CC</sub> = Min<br>V <sub>IN</sub> = V <sub>IL</sub> or V <sub>IH</sub> | I <sub>OL</sub> = 3 mA    |                  | 0.45                         |        |  |
| V <sub>IH</sub>     | Guaranteed Input Logical<br>High Voltage (Note 1) |                                                                               |                           | 2.0              | V <sub>cc</sub><br>+0.5      | V      |  |
| V <sub>IL</sub>     | Guaranteed Input Logical<br>Low Voltage (Note 1)  |                                                                               |                           | 0.5              | 0.8                          | v      |  |
| V <sub>IHC</sub>    | Clock Input High Voltage<br>CKM = 1               |                                                                               |                           | 2.0              | V <sub>cc</sub><br>+1.0      | v      |  |
|                     | CKM = 0                                           |                                                                               |                           | 3.8              | V <sub>cc</sub><br>+1.0      | v      |  |
| V <sub>ILC</sub>    | Clock Input Low Voltage<br>CKM = 1<br>CKM = 0     |                                                                               |                           | 0.5<br>0.5       | 0.8<br>0.6                   | v<br>v |  |
| I <sub>LI</sub>     | Input Leakage Current                             | $0 V \le V_{IN} \le V_{CC}$                                                   |                           |                  | ±10                          | μA     |  |
| I <sub>ozh</sub>    | Off-State (High Impedance)<br>Output Current      | $V_{\rm CC}$ = Max, $V_{\rm o}$ = 2.4 V                                       |                           |                  | 10                           | μA     |  |
| l <sub>ozl</sub>    | Off-State (High Impedance)<br>Output Current      | V <sub>CC</sub> = Max, V <sub>o</sub> = 0.45 V                                |                           |                  | -10                          | μA     |  |
| I <sub>ccs</sub>    | Power Supply Current,<br>Static                   | $V_{cc} = Max, V_{IN} - V_{cc} \text{ or GND, } I_{o} = 0 \ \mu A$            |                           | 20 mA            |                              |        |  |
| I <sub>CCD</sub>    | Supply Current, operating                         | V <sub>cc</sub> = Max<br>Outputs Unloaded                                     |                           | 10 m             | 10 mA + 5 mA/MHz<br>(Note 2) |        |  |
| Icc <sub>sм</sub>   | Power Supply Current, Sleep Mode                  | V <sub>cc</sub> = Max Outputs                                                 | 10 m                      | 10 mA + 1 mA/MHz |                              |        |  |

Notes: 1. These input levels provide zero-noise immunity and should only be statically tested in a noise-free environment (not functionally tested).

2. This reduces to  $\mathrm{I}_{\mathrm{CCSM}}$  when no instruction is executing, reducing overall power consumption.



# SWITCHING CHARACTERISTICS over COMMERCIAL operating range

|      |                       |                 | AMD 80 | EC287-10 | AMD 80 | EC287-12  |      |  |
|------|-----------------------|-----------------|--------|----------|--------|-----------|------|--|
| No.  | Parameter Description | Test Conditions | Min    | Max      | Min    | Max       | Unit |  |
| 1    | Clock Period          |                 | 1      |          |        |           |      |  |
| t    | CKM = 1               |                 | 100    |          | 80     |           | ns   |  |
|      | CKM = 0               |                 | 32     |          | 26     |           | ns   |  |
| 2    | Clock LowTime         |                 |        |          |        |           |      |  |
| 2    | CKM = 1               |                 | 45     |          | 35     | 11        | ns   |  |
|      |                       |                 | 11     |          | 9      |           | ns   |  |
|      |                       |                 |        |          |        |           |      |  |
| 3    | Clock High Time       |                 |        |          |        |           |      |  |
|      | CKM = 1               |                 | 28     |          | 22     |           | ns   |  |
|      | CKM = 0               |                 | 11     |          | 9      |           | ns   |  |
| 4    | Clock Rise Time       |                 |        | 10       |        | 8         | ns   |  |
| 5    | Clock Fall Time       |                 |        | 10       |        | 8         | ns   |  |
| 6    | Data Setup to         |                 |        |          |        |           |      |  |
| -    | NPWR Inactive         |                 | 75     |          | 75     |           | ns   |  |
| 7    | Data Hold from        |                 |        |          |        |           |      |  |
| '    | NPWR Inactive         |                 | 18     |          | 10     |           |      |  |
|      |                       |                 | 10     |          | 10     |           | ns   |  |
| 8    | NPWR, NPRD            |                 |        |          |        |           |      |  |
|      | Active Time           |                 | 90     | }        | 70     |           | ns   |  |
| 9    | Command Valid         |                 |        |          |        |           |      |  |
|      | Setup Time            |                 | 0      | 1        | 0      |           | ns   |  |
| 10   | PEREQ Active to       |                 |        |          |        | <u>  </u> |      |  |
|      | NPRD Active           |                 | 100    |          | 80     |           | ns   |  |
| 11   | PEACK Active Time     |                 | 60     |          | 50     |           | ns   |  |
|      |                       |                 |        |          |        |           |      |  |
| 12   | PEACK Inactive Time   |                 | 200    |          | 160    |           | ns   |  |
| 13   | PEACK Inactive to     |                 |        |          |        |           |      |  |
|      | NPRD, NPWR Inactive   |                 | 40     |          | 32     |           | ns   |  |
| 14   | NPRD, NPWR Inactive   |                 |        |          |        |           |      |  |
| ••   | to PEACK Active       |                 | -30    |          | -30    |           | ns   |  |
| 15   | Command Valid         |                 |        |          |        |           |      |  |
| 15   | Hold Time             |                 | 22     |          | 18     |           |      |  |
|      |                       |                 |        |          | 10     |           | ns   |  |
| 16   | PEACK Active Setup    |                 |        |          |        |           |      |  |
|      | to NPRD, NPWR         |                 | 40     |          | 30     |           | ns   |  |
| 17   | NPRD, NPWR to         |                 |        |          |        |           |      |  |
|      | CLK Setup             |                 | 53     |          | 40     |           | ns   |  |
| 18   | NPRD, NPWR CLK Hold   |                 | 37     |          | 29     |           | ns   |  |
| 19   | RESET to CLK Setup    |                 | 20     |          | 20     | +         |      |  |
|      |                       |                 |        |          |        |           | ns   |  |
| 20   | RESET from CLK Hold   |                 | 20     |          | 20     |           | ns   |  |
| 21   | NPRD Inactive to      |                 |        |          |        |           |      |  |
|      | Data Float            |                 |        | 21       |        | 17        | ns   |  |
| 22   | NPRD Active to        |                 |        |          |        |           |      |  |
|      | Data Valid            |                 |        | 60       |        | 50        | ns   |  |
|      | ERROR Active to       |                 |        |          |        |           |      |  |
|      | BUSY Inactive         |                 | 100    |          | 100    |           | ns   |  |
| 24   | NPWR, Active to       |                 |        |          |        |           |      |  |
|      | BUSY Active           |                 |        | 100      |        | 80        | ns   |  |
| 25   | PEACK Active to       |                 |        | +        |        | +         |      |  |
|      | PEREQ Inactive        |                 |        | 100      |        | 80        | ns   |  |
| 26 N | NPRD, NPWR Active to  | ł               |        | 100      |        |           | 115  |  |
|      |                       |                 |        | 100      |        | 80        |      |  |
|      | PEREQ Inactive        |                 |        | 100      |        | 80        | ns   |  |
| 27   | Command Inactive Time |                 |        |          |        |           |      |  |
|      | Write to Write        |                 | 75     |          | 60     |           | ns   |  |
|      | Read to Read          |                 | 75     |          | 60     |           | ns   |  |
|      | Write to Read         |                 | 75     | 1        | 60     |           | ns   |  |
|      | Read to Write         |                 | 75     |          | 60     |           | ns   |  |
| 28   | Data Hold from Time   |                 |        |          |        | +         |      |  |
|      | NPRD Inactive         | 1               | 3      | 1        | 1      | 1         | F    |  |

# SWITCHING WAVEFORMS







AC Setup, Hold and Delay Time Measurement—General



AC Test Loading on Outputs

11959-004

# SWITCHING WAVEFORMS (continued)



Read Timing from AMD 80EC287 Processor



Write Timing from AMD 80EC287 Processor

11959-005

# SWITCHING WAVEFORMS (continued)



Data Channel Timing (Initiated by AMD 80EC287 Processor)

11959-006A



**Error Output Timing** 



CLK, Reset Timing (CKM = 1)

11959-007

Note: Reset, NPWR, NPRD are inputs asynchronous to CLK. Timing requirements above are given for testing purposes only to assure recognition at a specific CLK edge.

# SWITCHING WAVEFORMS (continued)







## CLK, RESET Timing (CKM = 0)

Note: Reset must meet timing shown to guarantee known phase of internal + 3 circuit.



11959-008A

CLK, NPRD, NPWR Timing (CKM = 0)

# **Chapter 2**

**General Information** 

4

# CHAPTER 2 General Information

| Thermal Characteristics  | . 2-3 |
|--------------------------|-------|
| TapePak Application Note | . 2-4 |
| Physical Dimensions      | 2-11  |
| Support Literature       | 2-23  |

#### **Personal Computer Microprocessors**

| Device      | Package                    | Process              | Area<br>(KSq Mils)   | Power <sup>1, 2</sup><br>(mW) | θja³<br>(°C/W) | θjc³<br>(°C/W) |
|-------------|----------------------------|----------------------|----------------------|-------------------------------|----------------|----------------|
| Am386DX     | PGA132                     | CMOS                 | 74.0                 | 2750                          | 21             | 2              |
| Am386SX     | PQ100<br>PQB100            | CMOS<br>CMOS         | 74.0<br>74.0         | 1250<br>1250                  | 45             | 11             |
| Am386DXL    | PGA132<br>PQ132<br>PQB132  | CMOS<br>CMOS<br>CMOS | 74.0<br>74.0<br>74.0 | 2000<br>2000<br>2000          | 21<br>40       | 2<br>10        |
| Am386SXL    | PQ100<br>PQB100            | CMOS<br>CMOS         | 74.0<br>74.0         | 1250<br>1250                  | 45<br>45       | 11<br>11       |
| Am386DXLV   | PQ132<br>PQB132            | CMOS<br>CMOS         | 74.0<br>74.0         | 446<br>446                    | 41<br>41       | 9<br>9         |
| Am386SXLV   | PQ100<br>PQB100            | CMOS<br>CMOS         | 74.0<br>74.0         | 413<br>413                    | 45<br>45       | 11<br>11       |
| Am286ZX/LX  | PQ216                      | CMOS                 | 247.0                | 1625                          | 25             |                |
| 80286       | CA2068<br>CGX068           | NMOS<br>NMOS         | 8.0<br>98.0          | 3000<br>3000                  | 31<br>37       | 8<br>2         |
| 30C286      | CA2068<br>PL 068           | CMOS<br>CMOS         | 101.4<br>101.4       | 1980<br>1980                  | 38<br>33       | 4              |
| 30L286      | PL 068                     | NMOS                 | 98.0                 | 2250                          | 34             |                |
| 3086        | CD 040<br>PD 040<br>CL 040 | NMOS<br>NMOS<br>NMOS | 52.9<br>52.9<br>52.9 | 1700<br>1700<br>1700          | 32<br>44<br>47 | 7              |
| 3088        | CD 040<br>PD 040<br>CL 040 | NMOS<br>NMOS<br>NMOS | 36.1<br>36.1<br>36.1 | 1700<br>1700<br>1700          | 34<br>44<br>47 | 7              |
| AMD 80C287  | CD 040<br>PL 044<br>PD 040 | CMOS<br>CMOS<br>CMOS | 82.5<br>82.5<br>82.5 | 600<br>600<br>600             | 30<br>40<br>38 | 5              |
| AMD 80EC287 | CD 040<br>PL 044<br>PD 040 | CMOS<br>CMOS<br>CMOS | 82.5<br>82.5<br>82.5 | 600<br>600<br>600             | 30<br>40<br>38 | 5              |

# THERMAL CHARACTERISTICS

1. Power is the highest  $I_{cc}$  over the temperature times the nominal power supply voltage.

2. Power measured at highest possible clock frequency. Power for Am386DXLV and Am386SXLV microprocessors are at 3.3 V nominal supply voltage.

3. θja and θjc values were estimated by extrapolating measured data. Values are to be considered as typical for the device.

## **HIGH DENSITY PACKAGING**

Manufacturing demands for higher board density and more cost effective systems, along with advances in micron and sub-micron technology, have made integrated circuits smaller, denser, and more complex. Consequently, more input/output (I/O) connections are required in the IC package than can be accommodated in traditional Dual-In-Line (DIP) and Plastic Leaded Chip Carrier (PLCC) packages.

AMD, in keeping pace with the increased complexity of ICs, has developed a family of fine pitch Plastic Quad Flat Pack (PQFP) packages; a reliable, highdensity, low-cost, plastic package for high-lead count applications.

To facilitate the handling and testing of the fine pitch leads and preserve their formation and mechanical integrity, AMD has adopted the industry standard TapePak® package configuration and has applied it to all high pin count PQFP packages.

# The TapePak Format

TapePak is a plastic ring formed around the perimeter of the PQFP's coplanar leads. It is molded at the same time as the package body, securing the lead frame in place and providing mechanical stability and lead protection during the manufacturing process. This configuration offers significant benefits, helping meet the challenges for testability and board assembly automation. With TapePak, board yields are increased by improved lead coplanarity, reduction in bent leads, and superior ESD protection.

# **TAPEPAK CONFIGURATION BENEFITS**

## Testability

The TapePak configuration provides extensions to the package leads, spanning them out to the perimeter of the TapePak ring. Using these as electrical contact points in test and burn-in operations preserves the actual package leads, virtually eliminating lead coplanarity and bent lead problems. Components remain in the TapePak format up to the point of board assembly. Chart number 1, based on actual data from a 60 piece sample, compares AMD's TapePak PQFP flow to that of another company's trimmed PQFP flow. AMD's lead coplanarity falls well within the industry standard specifications of 4.0 mil with a tight standard deviation. Comparatively the competition's coplanarity is higher, resulting in a 15% yield loss.



#### **Personal Computer Microprocessors**

The TapePak lead extensions are standardized at an outside lead-pitch of 0.65 mm, which is compatible with existing automatic test equipment. With this standardization, only two socket sizes are required for AMD's entire family of TapePak PQFPs: a 36 mm ring size and a 46 mm size.

# Standardized Socket Tooling

AMD has taken a leadership role, working with major socket manufacturers, to develop a TapePak compatible family of industry-standard test and burn-in sockets.

The socket is designed with an open-top, eliminating lid clearance problems during automated burn-in board loading. Curved socket leads provide the spring pressure necessary to hold the package in place, and the serrated edges of the socket leads scrub the package test-points, removing any oxidation and facilitating good electric contact. Having the test contact points along the perimeter of the ring eliminates the need for expensive pogo pins. The socket contacts splay the narrower package lead-pitch out to three rows of pins to allow connection to a through-hole pattern on the board.

# Surface Mount Compatibility

The TapePak design offers all the benefits of surfacemount technology. With only the addition of a trimand-form station, TapePak is fully compatible with existing high-speed, high-precision surface mount equipment. Trim-and-form equipment is readily available to excise the package, form the leads, and present it to a pick-and-place head for placement onto the circuit board. (For a list of pick-and-place equipment suppliers with TapePak trim-and form capability and available suppliers of trim-and-form feeders contact your local AMD sales representative). The trim-and-form specification can be based on the AMD standard 1.6 mm lead length, 1.95 mm lead length or any other specification desired. AMD's PQFP trim-and-form standards are outlined in Table 1.

Trim-and-form feeders are available for a variety of TapePak packaging methods, including coin stack tubes, flat tubes, or AMMO-Pak formats. In coin stack tubes, the PQFP/TapePak packages are stacked vertically, in flat tubes the parts are laid end -to-end. AMMO-Pak presents the parts to the trim-and-form station in the form of a taped belt, without a tube. The device quantities per carrier type and box are presented in Table 2.

Multi-tube, random access trim-and-form systems can be programmed to process several different leadcount packages within a ring size. And, with only minor modifications, automatic gravity-fed PLCC test handlers and markers can be made compatible with TapePak parts in flat tubes.

| Package<br>Type  | Lead<br>Count | Package<br>Stand-Off<br>(Nominal) | Lead<br>Length<br>(Nominal) | Coplanarity          | Bent<br>Leads        |
|------------------|---------------|-----------------------------------|-----------------------------|----------------------|----------------------|
| JEDEC<br>Metric  | 48-144        | 0.35 mm<br>(0.0138")              | 1.6 mm<br>(0.0630")         | 0.10 mm<br>(0.004")  | 0.076 mm<br>(0.003") |
|                  | 1681          | 0.35 mm<br>(0.0138")              | 1.6 mm<br>(0.0630")         | 0.10 mm<br>(0.004")  | 0.076 mm<br>(0.003") |
|                  | 2161          | 0.35 mm<br>(0.0138")              | 1.6 mm<br>(0.0630")         | 0.076 mm<br>(0.003") | 0.076 mm<br>(0.003") |
| JEDEC<br>English | 100 & 132     | 0.0130"<br>(0.76 mm)              | 0.065"<br>(1.65 mm)         | 0.004"<br>(0.10 mm)  | 0.003"<br>(0.076 mm) |

## Table 1. PQFP Trim-and-Form Standards

Note 1: Not yet JEDEC registered.

| Table 2. Device Quantities Per Carrier Type and Box |                 |                             |                        |                                  |                    |
|-----------------------------------------------------|-----------------|-----------------------------|------------------------|----------------------------------|--------------------|
| Package<br>Format                                   | Carrier<br>Type | Pkg. Pin<br>Count           | Devices Per<br>Carrier | Carriers<br>per Box <sup>1</sup> | Devices<br>per Box |
| TapePak                                             | Flat Tubes      | 36 mm ring<br>44 mm ring    | 12<br>10               | 10<br>12                         | 1202<br>1202       |
|                                                     | Coin Tubes      | 36 mm ring<br>46 mm ring    | 60                     | 3                                | 180                |
|                                                     |                 | 48 pin<br>80 pin<br>100 pin | 66                     |                                  | 330                |
| Trimmed                                             | Trays           | 100 pin                     | 55                     |                                  | 275                |
| and Formed                                          | -               | 120 pin                     | 24                     | 63                               | 120                |
|                                                     |                 | 132 pin<br>144 pin          | 36                     |                                  | 180                |
|                                                     |                 | 168 pin<br>216 pin          | 24                     |                                  | 120                |

Notes: 1. In all cases, PQFPs are dry packed and sealed in a dry pack bag.

2. These represent 2K box quantities. There is double this quantity in a 4K box.

3. The top tray is empty, serving as a cover.

## Improved Performance

TapePak enables very high-density ICs to be packed smaller; one third the size of a comparable plastic chip carrier and one tenth of a molded DIP. This allows board sizing to be significantly reduced, typically 50% to 80% over standard PLCC and DIP layouts. Additionally, electrical performance improves because the shorter leads to the die reduce lead capacitance, inductance, and propagation delays. Thermal characteristics are also enhanced through the use of highly conductive, copper leadframe material.

# DRY PACK PROTECTION

When high pin-count PQFPs are soldered directly to a board using conventional methods, such as vapor phase of infrared reflow, there is a risk of moisture-induced package cracking. These process expose the package body to very rapid rise to high temperatures. As a result, the moisture in the package vaporizes and can crack the package as it escapes.

AMD has conducted extensive studies to show that the risk of moisture-induced package cracking does not exist until the moisture level in the package exceeds 0.10% by weight. Moisture in the package will increase or decrease with respect to the relative humidity (RH) of the environment in which it is present. Dry packing the product protects it from environmental moisture and keeps the package moisture level well within the safety zone.

Dry packing is accomplished by oven baking the product for 24 hours at 125°C to remove all package moisture. The baked packages are sealed under a partial vacuum in a moisture barrier bag with desiccant and a humidity indicator card. The bag interior remains at  $\leq$  30% RH for at least a year from the date of the dry pack seal (noted on the dry pack seal label on the bag). After a year, the product only needs to be re-baked *if* the RH level in the bag is > 30%, as evidenced by the humidity indicator card. Should re-baking be necessary, a lower temperature oven bake can be done—192 hours at 40°C and  $\leq$  5 RH—if parts remain in tubes or low-temp trays. Otherwise, parts must be removed from these containers and put in metal tubes prior to the 24 hour bake at 125°C.

AMD recommends that the parts be soldered onto boards within 72 hours of breaking the dry pack seal, given a typical factory environment of 20° to 30°C and 50% to 70% RH.

# **TapePak and TAB**

In addition to the adoption of the TapePak configuration, AMD is developing tape-automated bonding (TAB) for very high-lead count devices requiring finer pitch I/O connections (0.1 to 0.5 mm). Bond pads on the die are directly connected to copper foil traces on a polyimidefilmed polymer tape. The polyimid film holds the individual traces in place, allowing lead-pitch to be very small. The copper traces are then bonded directly to the leadframe, as in the PQFP, or to a board. This combination of TAB and TapePak provides the highest density plastic package available in the market today.

# Standardization

TapePak was registered with the Joint Electronic Device Engineering Council (JEDEC) in 1987, for mechanical standardization. AMD is participating in the JEDEC and Electronic Industries Association of Japan (EIAJ) packaging committees to promote the TapePak configuration as an industry standard.

AMD is adopting the TapePak configuration for the entire family of fine pitch (0.8 mm or less) PQFPs. AMD offers both metric and English dimensioned PQFP packages from 48 to 216 leads. As TAB is implemented, higher density PQFPs will be introduced in TapePak.

Additional information on TapePak and TAB can be obtained through your local AMD sales representative.

| PQFP | Area | Sizes i | n TapePak |
|------|------|---------|-----------|
|------|------|---------|-----------|

|                      | Area S        | ize          | Package Lead Pitch |              |  |
|----------------------|---------------|--------------|--------------------|--------------|--|
| Pin Count            | Body Package  | TapePak Ring | Inside Ring        | Outside Ring |  |
| 48 Pin               |               |              | 0.8 mm             |              |  |
| 80 Pin               | 14 × 20 mm    | 36 × 36 mm   | 0.8 mm             | 0.65 mm      |  |
| 100 Pin              |               |              | 0.65 mm            |              |  |
| 100 Pin <sup>2</sup> | 750 × 750 mil |              | 25 mil             |              |  |
| 120 Pin              | 28 × 28 mm    |              | 0.8 mm             | 0.65 mm      |  |
| 132 Pin <sup>2</sup> | 950 × 950 mil | 46 × 46 mm   | 25 mil             | ]            |  |
| 168 Pin <sup>3</sup> | 28 × 28 mm    |              | 0.65 mm            |              |  |
| 216 Pin <sup>3</sup> |               |              | 0.5 mm             | 1            |  |

Notes: 1. These PQFP packages are JEDEC metric version unless otherwise noted.

2. This PQFP package is the JEDEC English package version, which has corner bumpers.

3. These PQFP packages are not yet JEDEC registered.

É



## PQFP in the TapePak Format



The TapePak lead extensions are used for contact points in test and burn-in socket tooling, virtually eliminating lead coplanarity problems.

# **PHOTOS (continued)**



TapePak is compatible with existing pick-and-place machines with the simple addition of a trim-and-form station to excise the package and form the leads.



Am386 microprocessor in a 132-pin PQFP package.



TapePak enables very high-density ICs to be packaged smaller. (To left, clockwise: 48-pin plastic DIP, 84-pin PLCC, 80-pin PQFP.)

# PHYSICAL DIMENSIONS







Ę

**Physical Dimensions** 



PL 044

06752F BV 8 6/9/91 c dc

.025 .045 R

.800 REF

.890

.930

22



.985 .995

.

06753K AN 7 12/5/89 CD

.090 .130

.165

.180

## Personal Computer Microprocessors





AMD

ť,









15679F BX 43 10/29/91 SG

#### Personal Computer Microprocessors

PQB 100



AMD

CGX 132



Bottom View (Pins Facing Up)

Side View

15304C BP 36 4/30/91 CD

.105

.195

.080

e



ŝ



PQB 132 (measured in inches)





PQJ 216 (measured in millimeters)

TOP VIEW



14830G BX 45 10/29/91 SG

PQR 216 (measured in millmeters)



# SUPPORT LITERATURE

## **Am386 Family Literature**

#### Am386 Family-Better 32-Bit Microprocessors (#15946)

OEM-targeted brochure detailing all the Am386 Family features and benefits. Includes application benchmark comparisons of performance and battery life between the Am386 and Intel 386 processors and a complete AMD versus Intel feature comparison chart.

#### Am386 Family—Choosing the Best 386-Based Computer (#16269)

An end-user-targeted brochure containing an overview of the Am386 Family with performance and battery life benchmark comparisons to the Intel 386 processors.

#### 40 MHz Am386DX Microprocessor Performance Summary (#16219)

Shows the performance comparison of a 40 MHz 386 PC, 33 MHz PC, and a 20 MHz 486SX PC using both application benchmarks and industry standard DOS benchmark software. Window applications include PageMaker 4.0, Excel 3.0, and Corel Draw 2.0. DOS benchmarks include Power Meter MIPs, Dhrystones, Norton SI, BYTE, PC Magazine, and PC Week tests.

#### 25 MHz Am386SX Microprocessor Performance Summary (#16411)

Shows the performance comparison of two 25 MHz 386 PCs using the AMD Am386SX-25 microprocessor and two 20 MHz 386SX PCs using the Intel i386SX-20. Both application benchmarks and industry standard DOS benchmarks are used.

#### Am386 Microprocessor Family Demo Diskette (#16274)

Graphically shows the benefits of value-added Am386 microprocessors. Emphasizes the upward growth of the 386 market, high performance and low power of the AMD Am386 Family, and complete Intel compatibility.

#### 40-MHz Am386 Microprocessor Design Kit (#15689)

A turnkey development kit speeds to market and reduces design time of your 40 MHz Am386DX/DXL microprocessorbased computers. The kit contains complete design documentation from AMD and chip-set manufacturers to phase the 40-MHz PC into production.

#### Am386DXL Notebook Design Kit (#15911)

A low-power notebook design demonstrating advanced power-management techniques for maximizing battery life. This 32-bit evaluation kit is a true 32-bit Am386DXL microprocessor motherboard.

#### Am386SXL Notebook Design Kit (#15910)

A small-form-factor, medium-performance, non-cache, Am386SXL microprocessor-based motherboard design. This low-power design demonstrates advanced power-management techniques maximizing PC battery life.

#### "486SX vs. Am386-40-The 486 Falls Short" (#15964)

Am386 Family article reprint from BYTE Magazine, June 1991.

#### "Having the Marketing Gurus Gone to Far?" (#15965)

Am386 Family article reprint from Microprocessor Report.

## 80286/AMD 80C287 Literature

#### 80C286/AMD 80C287 Programmers Reference Manual (#14554)

Includes an introduction to the 80C286 and AMD 80C287 math coprocessor features, operations, and architectures, including detailed information on memory segmentation, registers, addressing modes, and the 80C286 instruction set. This manual is aimed at system programmers and focuses on the advanced architectural features of the 80C286 when in protected mode.

## AMD 80C287 Demonstration/Games Disk (1#4709)

A PC/AT diskette to aid evaluation of the AMD 80C287 math coprocessor. The disk contains benchmark performance data, fractals, and games.

#### Fusion286 Catalog (#13052)

Provides information on AMD and third party support tools that speed your 80286 microprocessor-based product to market. Includes products from over 20 expert suppliers of personal computer solutions, including hardware/software development tools, system support products, and manufacturing support tools.

#### AMD 80C287 Coprocessor Performance Benchmarks Application Note (#12640)

Benchmark analysis of the AMD 80C287 math coprocessor running PC Magazine floating-point benchmarks, HLBENCH floating-point benchmarks, and Whetstones benchmark.

#### Battery Life Benefits of the AMD 80EC287 Math Coprocessor Application Note (#12911)

Battery life testing benchmark comparison of the AMD 80EC287 math coprocessor vs the Intel 80C287A using the Zenith Supersport/286 laptop computer.

#### Am286ZX/LX Literature

#### Am286ZX and Am286LX Integrated Microprocessor Brochure (#15382)

An overview of the Am286ZX integrated microprocessor. Includes a description of AMD's Mercury/286ZLX demonstration board.

#### Am286ZX/LX Technical Manual (#15620)

Includes an introduction to the Am286ZX integrated microprocessor's features, operations, and architecture. It also includes standard peripheral, system control logic, and AT support logic details as well as bus, BIOS, and system configurations.

#### Mercury/286ZLX Development Kit (#15343)

A turnkey development kit to reduce design time and make Am286LX integrated microprocessor product evaluation and software development easier. The kit contains complete design documentation to help you access methodology and performance, and to phase the Am286LX microprocessor into production.

## "Destination Laptop" (#15775)

Am286ZX article reporting from BTYE Magazine, February 1991.

#### "AMD 286ZX Combines 286 and PC System Logic (#15391)

Am286ZX article reprint from Microprocessor Report, October 3, 1990.

#### "The One-Chip PC Makes Building Systems a Snap" (#15385)

Am286ZX article reprint from Electronic Design, September 27, 1990.

## Sales Offices

| North America         | an an       |                                                                                  |
|-----------------------|-------------|----------------------------------------------------------------------------------|
|                       |             |                                                                                  |
|                       |             |                                                                                  |
| CALIFORNIA,           |             |                                                                                  |
|                       |             | (213) 645-1524                                                                   |
| Newport Beach         |             | (714) 752-6262                                                                   |
| Sacramento(Rosevi     | lie)        |                                                                                  |
|                       |             |                                                                                  |
|                       |             |                                                                                  |
| CANADA, Ontario,      |             |                                                                                  |
|                       |             | (613) 592-0060                                                                   |
|                       |             |                                                                                  |
|                       |             | (303) 741-2900                                                                   |
|                       |             | (203) 264-7800                                                                   |
| FLORIDA,              |             | (912) 520 0071                                                                   |
|                       |             | (813) 530-9971<br>(305) 776-2001                                                 |
| Orlando (Longwood     | )           |                                                                                  |
|                       |             | (404) 449-7920                                                                   |
|                       |             |                                                                                  |
| ILLINOIS.             |             |                                                                                  |
| Chicago (Itasca)      |             | (708) 773-4422                                                                   |
| Naperville            |             |                                                                                  |
|                       |             |                                                                                  |
|                       |             |                                                                                  |
| NEW JERSEY,           |             |                                                                                  |
| Cherry Hill           |             |                                                                                  |
|                       |             |                                                                                  |
| NEW YORK,             |             |                                                                                  |
|                       |             | (315) 457-5400                                                                   |
|                       |             | (914) 279-8323                                                                   |
|                       | ••••••      | (716) 425-8050                                                                   |
| NORTH CAROLINA        |             |                                                                                  |
|                       |             | (704) 455-1010                                                                   |
|                       | ••••••      | (919) 878-8111                                                                   |
| OHIO,                 | illo        |                                                                                  |
|                       |             | (513) 439-0268                                                                   |
| •                     |             | (503) 245-0080                                                                   |
| PENNSYLVANIA          |             |                                                                                  |
| TEXAS.                |             |                                                                                  |
| Austin                |             | (512) 346-7830                                                                   |
|                       |             | (214) 934-9099                                                                   |
|                       |             | (713) 376-8084<br>(801) 264-2900                                                 |
|                       |             | (801) 264-2900                                                                   |
| International _       |             |                                                                                  |
| BELGIUM, Antwerpen .  | TEL         | (03) 248 43 00<br>(03) 248 46 42<br>(1) 49-75-10-10<br>(1) 49-75-10-13<br>263282 |
| EDANCE Davia          | FAX         | (03) 248 46 42                                                                   |
| FRANCE, Paris         | I EL<br>FAY | (1) 49-75-10-10                                                                  |
|                       | TLX         |                                                                                  |
| GERMANY,              |             |                                                                                  |
| Bad Homburg           | TEL         |                                                                                  |
| München               | TEL         | (49) 6172-24061<br>(49) 6172-23195<br>(089) 4114-0                               |
|                       | FAX         |                                                                                  |
| HONG KONG             | <u>TLX</u>  |                                                                                  |
| HONG KONG,<br>Wanchai | IEL         |                                                                                  |
|                       |             |                                                                                  |
| ITALY, Milano         | TEL         |                                                                                  |
|                       | FAV         | (02) 3533241                                                                     |
|                       | TI X        |                                                                                  |
| JAPAN,                |             |                                                                                  |
| Atsuai                | <u>TEL</u>  | (0462) 29-8460                                                                   |
| Kanagawa              | FAX         |                                                                                  |
| nanayawa              | FAX         |                                                                                  |
|                       |             |                                                                                  |

| International (Co | ntinued)   |                                                     |
|-------------------|------------|-----------------------------------------------------|
| Tokvo             |            | (03) 3346-7550                                      |
|                   |            |                                                     |
|                   | TIY        |                                                     |
| Osaka             | TEL        |                                                     |
|                   | FAX        | (06) 243-3253                                       |
| KOREA, Seoul      | <u>TEL</u> |                                                     |
|                   | FAX        |                                                     |
| LATIN AMERICA,    | TEI        |                                                     |
| FL Lauderdale     |            | (305) 484-8800                                      |
|                   | TIX        |                                                     |
| NORWAY, Oslo area | TEL        |                                                     |
| (Hövik)           | FAX        |                                                     |
|                   | TLX        |                                                     |
| SINGAPORE         | TEL        |                                                     |
|                   | FAX        |                                                     |
| OWEDEN            | TLX        |                                                     |
| SWEDEN,           | TEI        | (08) 08 61 80                                       |
| (Prommo)          |            |                                                     |
| TAIWAN Tainei     | TEI        | (08) 98 09 06<br>(886) 2-7213393<br>(886) 2-7723422 |
|                   | FAX        | (886) 2-7723422                                     |
|                   |            |                                                     |
| Manchester area   | TEL        |                                                     |
| (Warrington)      | FAX        |                                                     |
|                   | TLX        |                                                     |
|                   | <u>TEL</u> | (0483) 740440                                       |
| (Woking)          |            | (0483) 756196                                       |
|                   | ILA        |                                                     |

## North American Representatives\_\_\_\_\_

| CANADA                                                  | •        |
|---------------------------------------------------------|----------|
| Burnaby, B.C DAVETEK MARKETING                          | 0        |
| Kanata, Ontario - VITEL ELECTRONICS                     | ō        |
| Mississauga, Ontario - VITEL ELECTRONICS. (416) 676-972 | 0        |
| Lachine, Quebec - VITEL ELECTRONICS (514) 636-595       | 1        |
| ILLINOIS                                                |          |
| Skokie - INDUSTRIAL REPRESTATIVES, INC (708) 967-843    | 0        |
| INDIANA                                                 |          |
| Huntington - ELECTRONIC MARKETING                       |          |
| CONSULTANTS, INC                                        | С        |
| Indianapolis - ELECTRONIC MARKETING                     |          |
| CONSULTANTS, INC                                        | С        |
| IOWA                                                    |          |
| LORENZ SALES                                            | 3        |
| KANSAS                                                  |          |
| Merriam - LORENZ SALES(913) 469-131                     | 2        |
| Wichita - LORENZ SALES                                  | С        |
| KENTUCKY                                                |          |
| ELECTRONIC MARKETING<br>CONSULTANTS, INC(317) 921-345   | _        |
| CONSULTANTS, INC                                        | 2        |
| MICHIGAN                                                | _        |
| Birmingham - MIKE RAICK ASSOCIATES (313) 644-504        | 2        |
| Holland – COM-TEK SALES, INC                            | 2        |
| Novi - COM-TEK SALES, INC                               | 7        |
| MINNESOTA<br>Mel Foster Tech. Sales, Inc                | ~        |
|                                                         | J        |
| MISSOURI<br>LORENZ SALES(314) 997-455                   | _        |
| NEBRASKA                                                | 5        |
| LORENZ SALES                                            | <u>_</u> |
| NEW MEXICO                                              | ,        |
| THORSON DESERT STATES                                   | 2        |
| NEW YORK                                                | 2        |
| East Syracuse - NYCOM, INC                              | 2        |
| Woodbury - COMPONENT                                    | '        |
| CONSULTANTS, INC(516) 364-8020                          | n        |
| OHIO                                                    |          |
| Centerville - DOLFUSS ROOT & CO                         | 6        |
| Columbus - DOLFUSS ROOT & CO                            | 4        |
| Westlake – DOLFUSS ROOT & CO                            | ō.       |
| OREGON                                                  |          |
| ELECTRA TECHNICAL SALES, INC                            | 4        |
| PENNSYLVANIA                                            |          |
| RUSSELL F. CLARK CO., INC                               | 0        |
| PUERTO RICO                                             | -        |
| COMP REP ASSOC, INC                                     | 0        |
| WASHINGTON                                              |          |
| ELECTRA TECHNICAL SALES                                 | 2        |
| WISCONSIN                                               |          |
| Brookfield-INDUSTRIAL                                   |          |
| REPRESTATIVES, INC                                      | 3        |
|                                                         |          |

Advanced Micro Devices reserves the right to make changes in its product without notice in order to improve design or performance characteristics. The performance characteristics listed in this document are guaranteed by specific tests, guard banding, design and other practices common to the industry. For specific testing details, contact your local AMD sales representative. The company assumes no responsibility for the use of any circuits described herein.

コ

Advanced Micro Devices, Inc. 901 Thompson Place, P.O. Box 3453, Sunnyvale, CA 94088, USA Tel: (408) 732-2400 • TWX: 910-339-9280 • TELEX: 34-6306 • TOLL FREE: (800) 538-6450 APPLICATIONS HOTLINE & LITERATURE ORDERING • TOLL FREE: (800) 222-9323 • (408) 749-5703 © 1991 Advanced Micro Devices, Inc. 10/24/91 Printed in USA



# ADVANCED MICRO

DEVICES, INC. 901 Thompson Place P.O. Box 3453 Sunnyvale California 94088-3453 (408) 732-2400 TWX: 910-339-9280 TELEX: 34-6306 TOLL-FREE (800) 538-8450

APPLICATIONS HOTLINE & LITERATURE ORDERING (800) 222-9323 (408) 749-5703



Printed in USA CUS-44K-11/91-0 11339B