## Am386® SE # High-Performance, Low-Power, 32-Bit Embedded Microprocessor #### **DISTINCTIVE CHARACTERISTICS** - Member of Am386 E CPU Series - Am386 CPU Core - Designed for embedded applications - Socket compatible with 386SX processor - Industry standard architecture allows use of existing peripheral support chips, development tools, and application software - Ideal for embedded applications - Low power consumption - 3-5 V operation (25 MHz) - Fully static operation - High performance - 25- and 33-MHz operating frequencies - 32-bit internal architecture - Four levels of hardware-enforced protection - Optimized for the cost-sensitive embedded marketplace - 16-bit data plan - Real and protected mode operation without paging - Full Segmentation Unit and Descriptor Table support - Supports world's largest software base for x86 architectures - Compatible with Microsoft at Work<sup>TM</sup> and Novell NEST embedded software - Coprocessor interface; supports 387SX-compatible math coprocessor - Advanced packaging options - 100-pin Plastic Quad Flat Pack - 100-pin Thin Quad Flat Pack - Extended temperature versions available - Based on AMD® advanced CMOS technology \*AMDISO45\* #### **BLOCK DIAGRAM** 18420A-001 #### LOGIC SYMBOL #### **FUNCTIONAL DESCRIPTION** #### **True Static Operation** The Am386SE microprocessor incorporates a true static design. Unlike dynamic circuit design, the Am386SE CPU 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 energy efficent embedded control devices. #### Standby Mode This true static design allows for a standby mode. At any operating speed (33 to 0 MHz), the Am386SE 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 20 $\mu$ A at DC. Not only does this feature improve battery life, but it also simplifies the design in the following ways: 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 I<sub>CC</sub> True static design also allows lower operating I<sub>CC</sub> when operating at any speed. #### Performance On Demand (Am386SE CPU) The Am386SE 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 DIAGRAMS** ## Top Side View—100-Lead Plastic Quad Flat Pack and Thin Quad Flat Pack #### Notes: Pin 1 is marked for orientation. NC = Not connected; connection of an NC pin may cause a malfunction or incompatibility with future versions of the Am386SE microprocessor. # CONNECTION DIAGRAMS (continued) Pin Side View—100-Lead Plastic Quad Flat Pack and Thin Quad Flat Pack #### Notes: Pin 1 is marked for orientation. NC = Not connected; connection of an NC pin may cause a malfunction or incompatibility with future versions of the Am386SE microprocessor. ## AMD AMD ## PIN DESIGNATION TABLES (sorted by Functional Grouping) | Add | ress_ | Da | ıta | Cor | ntrol | NC | ν <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>54<br>55<br>56<br>58<br>59<br>60<br>61<br>62<br>64<br>65<br>66<br>70<br>72<br>73<br>74<br>75<br>76<br>79<br>80 | D0 D1 D2 D3 D4 D5 D6 D7 D8 D9 D10 D11 D12 D13 D14 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 BHE BLE BUSY CLK2 D/C ERROR FLT HLDA HOLD INTR LOCK M/IO NA NMI PEREQ READY RESET 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 Number) | Pin No. | Pin Name | Pin No. | Pin Name | Pin No. | Pin Name | Pin No. | Pin Name | Pin No. | Pin Name | |---------|-----------------|---------|-----------------|---------|-----------------|---------|-----------------|---------|-----------------| | 1 | D0 | 21 | Vcc | 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 | Vcc | | 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 | Vcc | 28 | FLT | 48 | Vcc | 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 | Vcc | 30 | NC | 50 | V <sub>SS</sub> | 70 | A16 | 90 | D8 [ | | 11 | V <sub>SS</sub> | 31 | NC | 51 | A2 | 71 | Vcc | 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 | <b>A</b> 5 | 74 | A19 | 94 | D5 ] | | 15 | CLK2 | 35 | V <sub>SS</sub> | 55 | <b>A</b> 6 | 75 | A20 | 95 | D4 | | 16 | ADS | 36 | ERROR | 56 | A7 | 76 | A21 | 96 | D3 | | 17 | BLE | 37 | PEREQ | 57 | Vcc | 77 | V <sub>SS</sub> | 97 | v <sub>cc</sub> | | 18 | A1 | 38 | NMI | 58 | A8 | 78 | V <sub>SS</sub> | 98 | Vss | | 19 | BHE | 39 | Vcc | 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. | Valid Combinations | | | | | | |--------------------|--------------------------------------|--|--|--|--| | AM386SE | 25KC<br>25KI<br>25VC<br>25VI<br>33KC | | | | | #### 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/R, D/C, M/IO, BHE, BLE, and A23–A1) are being driven at the Am386SE 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. #### CLK<sub>2</sub> #### CLK2 (Input) Provides the fundamental timing for the Am386SE 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 bidirectional and output signals, including HLDA, to the three-state condition. #### **HLDA** #### Bus Hold Acknowledge (Active High; Output) Output indicates that the Am386SE 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 Am386SE 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/ið #### Memory/IO (Output) A bus cycle definition pin that distinguishes memory cycles from input/output cycles. #### ÑĀ #### **Next Address (Active Low; Input)** Used to request address pipeline. #### 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 Am386SE microprocessor. #### NM ## Non-Maskable Interrupt Request (Active High; Input) A non-maskable input that signals the Am386SE 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 Am386SE microprocessor. 11 #### READY #### **Bus Ready (Active Low; Input)** Terminates the bus cycle. #### RESET #### Reset (Active High; Input) Suspends any operation in progress and places the Am386SE microprocessor in a known reset state. #### $V_{CC}$ #### System Power (Input) Provides the 3.0-5 V nominal DC supply input. ### $v_{\text{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. #### **Am386SE ARCHITECTURE OVERVIEW** The Am386SE microprocessor is code compatible with the Am386DE, 286, and 8086 microprocessors. System manufacturers can provide Am386DE CPU-based embedded controllers optimized for performance and Am386SE CPU-based embedded controllers optimized for cost, both sharing the same operating systems and application software. Systems based on the Am386SE microprocessor can access the world's largest existing microcomputer software base. Instruction pipelining, high-bus bandwidth, and a very high-performance ALU ensure short average instruction execution times and high system throughput. The Am386SE CPU is capable of execution at sustained rates of 2.5–3.0 million instructions per second (MIPS). The Am386SE 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. #### **Base Architecture** The Am386SE 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 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 Am386SE microprocessor has two modes of operation: Real Address Mode (Real Mode) and Protected Address Mode (Protected Mode). In Real Mode the Am386SE 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. Finally, to facilitate high-performance system hardware designs, the Am386SE microprocessor bus interface offers address pipelining and direct Byte Enable signals for each byte of the data bus. #### Register Set The Am386SE microprocessor has 30 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 Am386SE 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 CR0 32-bit control register is used to control the global nature of the Am386SE microprocessor. The CR0 register contains bits that set the different processor modes (Protected, Real, and Coprocessor Emulation). Reserved for future use—do not use. 18420A-003 Figure 1. Am386SE Microprocessor Registers System Address Registers: These four special registers reference the tables or segments supported by the 80286/Am386SE/Am386DE 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. #### **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 Am386SE 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 Am386SE microprocessor has a control register of 32 bits, CR0, to hold the machine state of a global nature. This register is shown in Figure 1 and Figure 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 72 through 86). Figure 2. Status and Control Register Bit Functions ### PRELIMINARY ### Table 1. Flag Definitions | 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; 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 instruction executes. TF is cleared by the single-step interrupt. | | 9 | IF | Interrupt-Enable Flag—When set, maskable interrupts will cause the CPU to transfer control to an interrupt vector specified location. | | 10 | DF | Direction Flag—Causes string instructions to auto-increment (default) the 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 (high-order bit) of the result but did not result in a carry/borrow out of the high-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. | | 14 | NT | Nested Task—Indicates that the execution of the current task is nested within 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. | #### Table 2. CR0 Definitions | Bit Position | Name | Function | |--------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | PE | Protection Mode Enable—Places the Am386SE microprocessor into 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 loading CR0; it cannot be reset by the LMSW instruction. | | 1 | МР | 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 exception (number 7) on ESC instructions to allow emulating a processor extension. | | 3 | TS | Task Switched—Indicates the next instruction using a processor extension will cause Exception 7, allowing software to test whether the current processor extension context belongs to the current task. | All Am386SE 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 instruction generally is two bytes long. The average instruction is 3.2 bytes long. Since the Am386SE CPU has a 16-byte prefetch instruction queue, an average of five 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 Am386SE 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 Am386SE 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 Am386SE microprocessor supports a larger unit of memory in segments. Memory can be divided up into one or more variable length segments, which can be swapped to disk or shared between programs. The Am386SE CPU supports segmentation in order to provide maximum flexibility to the system designer. Segmentation is useful for organizing memory in logical modules, and, as such, is a tool for the application programmer. 18420A~005 П Figure 3. Address Translation #### **Address Spaces** The Am386SE microprocessor has two types of address spaces: logical 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. Each task on the Am386SE CPU has a maximum of 16K (2<sup>14</sup>–1) selectors. The segmentation unit translates the logical address space into a 32-bit physical address space. The 32-bit physical address is then truncated into a 24-bit physical address. The physical address is what appears on the address pins. The total address space of the Am386SE CPU is 16 Mbytes. The primary differences between Real Mode and Protected Mode are how the segmentation unit performs the translation of the logical address into the physical address and the size of the address space. In Real Mode, the segmentation unit shifts the selector left four bits and adds the result to the effective address to form the physical address. This physical address is limited to 1 Mbyte. In protected mode, 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 physical address. This address reflects physical memory and is truncated so that only the lower 24 bits of this address are used to address the 16-Mbyte memory address space. 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 Am386SE CPU, segments are variable sized blocks of physical 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 16 Mbytes. 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 16-Mbyte physical address space. This creates a system where the virtual address space is the same as the physical address space. Further details of segmentation are discussed in the section Protected Mode Architecture on page 24. #### **Addressing Modes** The Am386SE 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 physical 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. **Table 3. Segment Register Selection Rules** | 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, SS, ES, FS, GS | | [ESP] | SS | CS, SS, ES, FS, GS | Combinations of these three components make up the six additional addressing modes. - Direct Mode: The operand's offset is contained as part of the instruction as an 8-, 16-, or 32-bit displacement. - Register Indirect Mode: A Base register contains the address of the operand. - 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. - 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. 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 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. #### Differences Between 16- and 32-bit Addresses In order to provide software compatibility with the 8086 and the 80286, the Am386SE 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 Am386SE 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 Kbytes 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 Am386SE CPU addressing modes. When executing 32-bit code, the Am386SE 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. Figure 4. Addressing Mode Calculations 18420A-006 #### **Data Types** The Am386SE 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 Am386SE 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 to 4 Gbytes. **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 Am386SE 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 | BX, BP | Any 32-bit GP<br>Register | | Index Register | SI, DI | Any 32-bit GP<br>Register | | Scale Factor | None | 1, 2, 4, 8 | | Displacement | 0, 8, 16 bits | 0, 8, 32 bits | Figure 5 illustrates the data types supported by the Am386SE microprocessor and a 387SX compatible math coprocessor. #### I/O Space The Am386SE CPU has two distinct physical address spaces: physical memory and I/O. Generally, peripherals are placed in I/O space, although the Am386SE CPU also supports memory-mapped peripherals. The I/O space consists of 64 Kbytes 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 Kbytes. The 64-Kbyte I/O address space refers to physical addresses since I/O instructions do not go through the segmentation 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 Am386SE microprocessor and shows where the return address points. The Am386SE 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 Am386SE 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 Am386SE 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 moves). Figure 5. Am386SE Microprocessor Supported Data Types Table 5. Interrupt Vector Assignments | Function | Interrupt<br>Number | Instructions That<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 References | Yes | FAULT | | | Reserved for Future Use | 14 | <del> </del> | | | | | Coprocessor Error | 16 | ESC, WAIT | Yes | FAULT | | | Reserved for Future Use | 17-32 | | | <b> </b> | | | Two Byte Interrupt | 0-255 | INT n | No | TRAP | | Note: Some debug exceptions may report both traps on the previous instruction and faults on the next instruction. 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 Am386SE 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 Am386SE 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 the section Single-Step Trap on page 22. #### 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 Am386SE microprocessor invokes the NMI service routine first. If maskable interrupts are still enabled after the NMI service routine has been invoked, then the Am386SE CPU will invoke the appropriate interrupt service routine. #### **Exception Checking Sequence** As the Am386SE microprocessor executes instructions, it follows a consistent cycle in checking for exceptions. Consider the case of the Am386SE microprocessor having just completed an instruction. It then performs the following checks before reaching the point where the next instruction is completed. This cycle is repeated as each instruction is executed, and occurs in parallel with instruction decoding and execution. - 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. - Check for Exception 1 Faults in the next instruction (Instruction Execution Breakpoint set in the Debug Registers for the next instruction). - Check for Segmentation Faults that prevented fetching the entire next instruction (Exceptions 11 and 13). - Check for Faults decoding the next instruction (Exception 6 if illegal op-code; Exception 6 if in Real 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)). - If WAIT op-code, check if TS=1 and MP=1(Exception 7 if both are 1). - If ESCape op-code for math coprocessor, check if EM=1 or TS=1 (Exception 7 if either is 1). - If WAIT op-code or ESCape op-code for math coprocessor, check ERROR input signal (Exception 16 if ERROR input is asserted). - Check each memory reference required by the instruction for segmentation faults that prevent transferring the entire memory quantity (Exceptions 11, 12, and 13). #### Instruction Restart The Am386SE 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 the previous Exception Checking Sequence), the Am386SE microprocessor invokes the appropriate exception service routine. #### **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. #### Reset and Initialization When the processor is initialized or Reset, the registers have the values shown in Table 6. The Am386SE CPU will then start executing instructions near the top of physical memory, at location 0FFFFF0H. When the first intersegment Jump or Call is executed, address lines A23—A20 will drop Low for CS-relative memory cycles, and the Am386SE CPU will only execute instructions in the lower 1 Mbyte 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 Am386SE 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 Am386SE microprocessor will start executing instructions at the top of physical memory. #### Table 6. Register Values after Reset | Register | Reset Value | Notes | |---------------------------|---------------------------|-------| | Flag Word (EFLAGS) | uuuu0002H | 1 | | Machine Status Word (CR0) | นนนนน10H | | | Instruction Pointer (EIP) | 0000FFF0H | | | Code Segment (CS) | F000H | 2 | | Data Segment (DS) | 0000Н | 3 | | Stack Segment (SS) | 0000Н | | | Extra Segment (ES) | 0000Н | 3 | | Extra Segment (FS) | 0000Н | | | Extra Segment (GS) | 0000Н | | | EAX Register | 0000H | 4 | | EDX Register | Component and Stepping ID | 5 | | All Other Registers | Undefined | 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 Am386SE microprocessor, like the Am386DE microprocessor, offers testability features that include a self-test and direct access to the page translation cache. #### Self-Test The Am386SE 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 Am386SE CPU can be tested during self-test. Self-Test is initiated on the Am386SE 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. 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. #### **Debugging Support** The Am386SE 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 (OCCH). - The single-step capability provided by the TF bit in the flag register. - 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 OCCH, 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 autovectored to Exception 1. #### **Debug Registers** The Debug Registers are an advanced debugging feature of the Am386SE 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 Am386SE microprocessor contains six Debug Registers, consisting of four breakpoint address 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 6 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 Am386SE 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 Am386SE microprocessor in Real Mode is 64 Kbytes, 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** 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-Mbyte 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-Kbytes long, and may be read, written, or executed. The Am386SE 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 0FFFFFH are reserved for system initialization. #### Interrupts Many of the exceptions discussed in the Interrupts and Exceptions section on page 20, are not applicable to Real Mode operation; in particular, Exceptions 10 and 11 do not occur in Real Mode. Other exceptions have slightly different meanings in Real Mode; Table 7 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 Am386SE 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, shut-down 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. - 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. Table 7. 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 offset = 0FFFFH. An attempt to execute past the end of CS segment. | Before<br>Instruction | | SS Segment Overrun exception | 12 | Stack Reference beyond offset = 0FFFFH. | Before<br>Instruction | #### **LOCK Operation** The only instruction forms where the LOCK prefix is legal on the Am386SE microprocessor are shown in Table 8. The LOCK prefix is not supported during repeat string instructions. Table 8. Legal Instructions for the LOCK Prefix | Op-Code | Operands<br>(Dest. Source) | |--------------------------------------|----------------------------| | BIT Test and<br>SET/RESET/COMPLEMENT | Mem, Reg/Immed | | XCHG | Reg, Mem | | хсна | 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 Am386SE microprocessor. The LOCK prefix can be used at any privilege level, but only on the instruction forms listed in Table 8. #### PROTECTED MODE ARCHITECTURE The complete capabilities of the Am386SE microprocessor are unlocked when the processor operates in Protected Virtual Address Mode (Protected Mode). Protected Mode vastly increases the physical address space to 4 Gb (232 bytes). In addition, Protected Mode allows the Am386SE CPU to run all of the existing Am386DE CPU (using only 16 Mb of physical memory), 80286, and 8086 CPU's software, while providing a sophisticated memory management and a hardwareassisted protection mechanism. Protected Mode allows the use of additional instructions specially optimized for supporting multitasking operating systems. The base architecture of the Am386SE 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 physical address. The address is then used as 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 7). 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. #### Segmentation Segmentation is a method of memory management. It provides the basis for software protection and is 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 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 Am386SE 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 Kbytes. 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 physical base address and the 16-bit limit of each table. Figure 7. Protected Mode Addressing Figure 8. Descriptor Table Registers Each of the tables has a register associated with it: GDTR, LDTR, and IDTR (see Figure 8). 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 Am386SE 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 Am386SE 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 tuture 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. 18420A-010 #### **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 physical address space. These attributes include the 32-bit base physical 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 9 shows the general format of a descriptor. All segments on the Am386SE 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 Am386SE microprocessor has two main categories of segments: system segments and non-system 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 10 shows the general format of a code and data descriptor, and Table 9 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. #### System Descriptor Formats (S=0) System segments describe information about operating system tables, task, and gates. Figure 11 shows the general format of system segment descriptors, and the various types of system segments. Am386SE CPU system descriptors (which are the same as Am386DE CPU system descriptors) contain a 32-bit base physical 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 Am386SE Microprocessor and 80286 Descriptors In order to provide operating system compatibility with the 80286, the Am386SE 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 Am386SE 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 Am386SE CPU call gates. Table 9. 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.<br>Base and Limit are not used. | | | 6–5 | Descriptor Privilege Levels (DPL) | Segmer | nt 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. Expand down segment, offsets must be > limit. | If Data<br>Segment | | 1 | Writeable (W) | <b>W</b> = 0<br><b>W</b> = 1 | Data segment may not be written into. Data segment may be written into. | (S = 1,<br>E = 0) | | 3 | Executable (E) | E = 1 | Descriptor type is code segment. | | | 2 | Conforming (C) | C = 1 | Code segment may only be executed.<br>when CPL ≥ DPL and CPL remains unchanged. | If Data<br>Segment | | 1 | Readable (R) | R = 0<br>R = 1 | 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. Segment selector has been loaded into segment recorrused by selector test instructions. | gister | #### 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 12. 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. #### Seament 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. Figure 9. Segment Descriptors Figure 10. Code and Data Descriptors | 31 | | | | | | _ | | | _ | | | <u>o</u> | Byte Address | |----|-------------------|---|---|---|--------------------|----------------|---|----------|---|------|---------------|----------|--------------| | Г | Segment Base 15-0 | | | | Segment Limit 15–0 | | | | | 0 | | | | | | Base 31–24 | G | D | 0 | 0 | Limit<br>19–16 | Р | DPL<br>L | 0 | Туре | Base<br>23-16 | | +4 | #### Type Definition Type Definition Invalid Λ Invalid Available 80286 TSS Available TSS 1 2 LDT Undefined (Reserved) Busy 80286 TSS В **Busy TSS** С Am386SE CPU Call Gate 80286 Call Gate Task Gate (for 80286 or Am386SE CPU Task) D Undefined (Reserved) 80286 Interrupt Gate Am386SE CPU Interrupt Gate 80286 Trap Gate Am386SE CPU Trap Gate Figure 11. System Descriptors 18420A-013 #### Protection The Am386SE 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 four-level hierarchical privilege system is an extension of the user/supervisor privilege mode commonly used by minicomputers. The Privilege Levels (PL) are numbered 0 through 3. Level 0 is the most privileged level. #### **Rules of Privilege** The Am386SE 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 Am386SE 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 IRPL 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. 18420A-014 Figure 12. Example Descriptor Selection #### 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 Am386SE 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. 18420A-016 Figure 13. Sample I/O Permission Bit Map 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 10. 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 descriptor 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. Table 10. Descriptor Types Used for Control Transfer | 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 | TOT | | Intersegment to a lower privilege level (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** Interrupt Instruction, Exception, External Interrupt | Task Gate | IDT | #### Notes: <sup>\*</sup>NT (Nested Task bit of flag register) = 0 <sup>\*\*</sup>NT (Nested Task bit of flag register) = 1 #### **Task Switching** A very important attribute of any multitasking/multi-user operating system is its ability to rapidly switch between tasks or processes. The Am386SE 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 intersegment 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 14) containing the entire execution state. A task gate descriptor contains a TSS selector. The Am386SE microprocessor supports both 80286 and Am386SE CPU TSSs. The limit of an Am386SE CPU TSS must be greater than 64H (2BH for a 80286 TSS), and can be as large as 16 Mbytes. 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 Am386SE 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 Am386SE 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 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 Am386SE microprocessor switches tasks, it sets the TS bit. The Am386SE 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 Am386SE 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 Am386SE 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. Type = 8: Busy TSS 18420A-015 Figure 14. TSS and TSS Registers #### **FUNCTIONAL DATA** The Am386SE microprocessor features a straightforward functional interface to the external hardware (see Figure 15). The Am386SE CPU has separate parallel buses for data and address. The data bus is 16-bits in width, and bidirectional. The address bus outputs 24-bit address values using 23 address lines and two Byte Enable signals. The Am386SE 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 Am386SE microprocessor bus cycles perform data transfer in a minimum of only two clock periods. The maximum transfer bandwidth at 16 MHz is therefore 16 Mbyte/s. However, any bus cycle will be extended for more than two clock periods if external hardware withholds acknowledgment of the cycle. The Am386SE 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 Am386SE 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 Am386SE 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 Am386SE 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 16 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. Figure 15. Functional Signal Groups 18420A-017 18420A-018 Figure 16. CLK2 Signal and Internal Processor Clock #### Data Bus (D15-D0) These three-state, bidirectional signals provide the general purpose data path between the Am386SE 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 Am386SE microprocessor for coprocessor commands is 8000F8H, the I/O addresses driven by the Am386SE CPU for coprocessor data are 8000FCH or 8000FEH or cycles to a 387SX math coprocessor. The address bus is capable of addressing 16 Mbytes of physical memory space (000000H through FFFFFFH), and 64 Kbytes of I/O address space (000000H through 00FFFFH) for programmed I/O. The address bus is active High and will float during Bus Hold Acknowledge. The Byte Enable outputs, BHE and BLE, directly indicate which bytes of the 16-bit data bus are involved with the current transfer. BHE applies to D15–D8 and BLE applies to D7–D0. If both BHE and BLE are asserted, then 16 bits of data are being transferred. See Table 11 for a complete decoding of these signals. The Byte Enables are active Low and will float during Bus Hold Acknowledge. **Table 11. 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 of the data bus, D7-D0 | | 1 | 1 | Never occurs | #### Bus Cycle Definition Signals (W/R, D/C, M/IO, LOCK) These three-state outputs define the type of bus cycle being performed: W/R distinguishes between write and read cycles; D/C distinguishes between data and control cycles; M/IO distinguishes between memory and I/O cycles; and, 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/R, D/C, and M/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/R, D/C, and M/IO, are given in Table 12. 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 which is to be locked. The beginning of a bus cycle is determined when READY is returned in a previous bus cycle and another is pending (ADS is active), or the clock in which 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 Table 12. Bus Cycle Definition | M/iō | M/iō D/C | | 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: Shutdown: Address = 2 Address = 0 BHE = 1 BHE = 1 BLE = 0 BLE = 0 | No | | 1 | 1 | 0 | Memory Data Read | Some Cycles | | 1 | 1 | 1 | Memory Data Write | Some Cycles | locked longer than desired. The $\overline{\text{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 Am386SE 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 BHE and BLE are accepted or provided. When READY is sampled active during a read cycle or interrupt acknowledge cycle, the Am386SE microprocessor latches the input data and terminates the cycle. When 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 $\overline{\rm BHE},\ BLE,\ A23-A1,\ W/\overline{\rm R},\ D/\overline{\rm C},\ and\ M/\overline{\rm O}$ from the Am386SE CPU even if the end of the current cycle is not being acknowledged on $\overline{\rm 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. $\overline{\rm NA}$ is ignored in CLK cycles in which $\overline{\rm ADS}$ or $\overline{\rm READY}$ is activated. This signal is active Low and must satisfy setup and hold times (t15 and t16) for correct operation. See the sections Read and Write Cycles on page 43, and Pipelined Address on page 46 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 the section Entering and Exiting Hold Acknowledge on page 51 for additional information. #### Bus Hold Request (HOLD) This input indicates some device other than the Am386SE microprocessor requires bus master-ship. When control is granted, the Am386SE CPU floats A23–A1, BHE, BLE, D15–D0, $\overline{\text{LOCK}}$ , $M/\overline{\text{IO}}$ , D/ $\overline{\text{C}}$ , W/ $\overline{\text{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 Am386SE 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 Am386SE microprocessor floated outputs have internal pull-up resistors. See the section Resistor Recommendations, on page 59 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 Am386SE 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 Am386SE microprocessor. The other output or bidirectional signals (D15–D0, BHE, BLE, A23–A1, W/R, D/C, M/IO, LOCK, and 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 13). Pull-up resistors may be desired on several signals to avoid spurious activity when no bus master is driving them. See the section Resistor Recommendations on page 59 for additional information. When the HOLD signal is made inactive, the Am386SE 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 13. Output Pin State During HOLD | Pin Value | Pin Names | |-----------|--------------------------------------------------------| | 1 | HLDA | | Float | LOCK, M/IO, D/C, 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 Am386SE microprocessor will not honor a HOLD request until the current bus operation is complete. The Am386SE microprocessor breaks 32-bit data or I/O accesses into 2 internally locked 16-bit bus cycles; the LOCK signal is not asserted. The Am386SE 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 Am386SE micro-processor 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 ensure 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 Am386SE 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 Am386SE microprocessor. In response, the Am386SE microprocessor transfers information between the math coprocessor and memory. Because the Am386SE 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 Am386SE microprocessor 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<sub>CC</sub> 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 Am386SE microprocessor performs an internal self-test (see the section Bus Activity During and Following Reset on page 53). 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 Am386SE microprocessor when a coprocessor instruction is encountered, and if active, the Am386SE 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 Am386SE 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<sub>CC</sub> 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 Am386SE microprocessor Flag Register IF bit. When the Am386SE 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 Am386SE 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 Am386SE 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 Am386SE 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 reasserted 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: - 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 Am386SE microprocessor encounters the IRET instruction. - An interrupt request is recognized only on an instruction boundary of the Am386SE 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 Am386SE 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. - If interrupt service routine requires a task switch, time must be allowed for the task switch. - If the interrupt service routine saves registers that are not automatically saved by the Am386SE microprocessor. #### Reset This input signal suspends any operation in progress and places the Am386SE microprocessor in a known reset state. The Am386SE 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 14. If RESET and HOLD are both active at a point in time, RESET takes priority even if the Am386SE 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 Am386SE 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 Am386SE microprocessor address signals are designed to simplify external system hardware. Higher-order 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 BHE and BLE are asserted when their associated data bus bytes are involved with the present bus cycle, as listed in Table 15. 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 the section Bus Functional Description on page 39. Table 14. Pin State (Bus Idle) During Reset | Pin Name | Signal Level During Reset | |----------|---------------------------| | ĀDS | 1 | | D15-D0 | Float | | BHE, BLE | 0 | | A23-A1 | 1 | | W/R | 0 | | D/C | 1 | | M/IO | 0 | | LOCK | 1 | | HLDA | 0 | Table 15. Byte Enables and Associated Data and Operand Bytes | | Byte Enable<br>Signal | Associated Data Bus | |---|-----------------------|----------------------------------| | Γ | 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 17, 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 Am386SE microprocessor has separate, parallel buses for data and address. The data bus is 16-bits in width and is bidirectional. 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/O Low can be used to easily generate a coprocessor select signal. Figure 17. Physical Memory and I/O Spaces The definition of each bus cycle is given by three 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{BHE}$ and $\overline{BLE}$ , and the other address signals, A23–A1. A status signal, $\overline{ADS}$ , indicates when the Am386SE 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) - 7. Interrupt acknowledge (always locked) - 8. Indicate halt, or indicate shutdown Table 12 shows the encoding of the bus cycle definition signals for each bus cycle. See the Bus Cycle Definition Signals section, on page 35 for additional information. When the Am386SE 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 Am386SE 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 Am386SE microprocessor asserting its Hold Acknowledge (HLDA) output. ## **Bus Functional Description** The Am386SE microprocessor has separate, parallel buses for data and address. The data bus is 16-bits in width and is bidirectional. The address bus provides a 24-bit value using 23 signals for the 23 upper-order address bits and 2 Byte Enable signals to directly indicate the active bytes. These buses are interpreted and controlled by several definition signals. 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 Am386SE 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 18. 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. #### Note: Fastest non-pipelined cycles consist of T1 and T2. Figure 18. Fastest Read Cycles with Non-Pipelined Address Timing Every bus cycle continues until it is acknowledged by the external system hardware, using the Am386SE 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 (NA) input. When address pipelining is selected, the address (BHE, BLE, and A23–A1) and definition (W/R, D/C, M/IO, and LOCK) of the next cycle are available before the end of the current cycle. To signal their availability, the Am386SE microprocessor address status output (ADS) is asserted. Figure 19 illustrates the fastest read cycles with pipelined address timing. Note from Figure 19 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. Figure 19. Fastest Read Cycles with Pipelined Address Timing 18420A-021 I #### **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{\text{NA}}$ (Next Address) input may be asserted to select pipelined address timing for the next bus cycle. When pipelining is selected and the Am386SE 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{\text{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 20. If READY is negated, as in Figure 21, the Am386SE 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 Am386SE microprocessor terminates it. When a read cycle is acknowledged, the Am386SE CPU latches the information present at its data pins. When a write cycle is acknowledged, the Am386SE 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. Figure 20. Various Bus Cycles with Non-Pipelined Address (Zero Wait States) 18420A-022 #### 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. Figure 21. 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 20 shows a mixture of read and write cycles with non-pipelined address timing. Figure 20 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 (ADS) is simultaneously asserted. During read or write cycles the data bus behaves as follows. If the cycle is a read, the Am386SE microprocessor floats its data signal to allow driving by the external device being addressed. The Am386SE 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 Am386SE CPU beginning in phase two of T1 until phase one of the bus state following cycle acknowledgment. Figure 21 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 NA during each T2 state, except the last one, as shown in Figure 21, Cycles 2 and 3. If 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 22. 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. T1—First clock of a non-pipelined bus cycle (Am386SE CPU 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 (Am386SE CPU asserts HLDA). The fastest bus cycle consists of two states: T1 and T2. Four basic states describe bus operation when not using pipelined address. Figure 22. 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{\text{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 Am386SE microprocessor to enter three additional bus states not shown in Figure 22. Figure 26, 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 Am386SE 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 23, 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). 18420A-025 T Figure 23. Transitioning to Pipelined Address During Burst of Bus Cycles If $\overline{\text{NA}}$ is sampled active, the Am386SE microprocessor is free to drive the address and bus cycle definition of the next bus cycle, and assert $\overline{\text{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 Am386SE CPU has the following characteristics: The next address may appear as early as the bus state after NA was sampled active (see Figure 23 and Figure 24). 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 25, Cycle 3). Provided the current bus cycle is not yet acknowledged by READY asserted, T2P will be entered as soon as the Am386SE 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 Am386SE CPU cannot produce a new address more frequently than every two processor clock periods (see Figure 23, Figure 24, and Figure 25). - 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 25, Cycle 1). 18420A-026 #### Note: Following any idle bus state (Ti) the address is always non-pipelined and $\overline{\rm 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. Figure 24. Fastest Transition to Pipelined Address Following Idle Bus State 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. Figure 25. Details of Address Pipelining During Cycles with Wait States ## Initiating and Maintaining Pipelined Address Using the state diagram Figure 26, 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{\rm 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, Idle Non-Pipelined Pipelined States Cycle Cycle 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 Cycle The transition to pipelined address is shown functionally by Figure 24, 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{\text{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 24. Once NA is sampled active during the current cycle, the Am386SE microprocessor is free to drive a new address and bus cycle definition on the bus as early as the next bus state. In Figure 24, 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 24, Cycle 1 and Figure 23, Cycle 2. Figure 24 shows transition during the very first cycle after an idle bus state, which is the fastest possible transition into address pipelining. Figure 23, 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 (NA is asserted at that time), and T2P (provided the Am386SE 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 24, Cycle 1). Figure 24, 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 $\overline{\text{NA}}$ and detecting that the Am386SE 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 $\overline{\text{ADS}}$ . Figure 23 and Figure 24, however, each show pipelining ending after Cycle 4, because Cycle 4 ends in T2I. This indicates the Am386SE 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 $\overline{\text{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 $\overline{\text{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 Am386SE 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 (see Figure 27). 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 Am386SE 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 Am386SE 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. Figure 26. Complete Bus States (Including Pipelined Address) ### **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 in Figure 28, Bus Cycle Definition Signals, and an address of 2. The halt indication cycle must be acknowledged by READY asserted. A halted Am386SE CPU resumes execution when INTR (if interrupts are enabled), NMI, or RESET is asserted. ## **Shutdown Indication Cycle** The Am386SE 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 the Bus Cycle Definition Signals section and an address of 0. The shutdown indication cycle must be acknowledged by READY asserted. A shut-down Am386SE microprocessor resumes execution when NMI or RESET is asserted (see Figure 29). ### **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 Am386SE microprocessor floats all outputs or bidirectional signals, except for HLDA. HLDA is asserted as long as the Am386SE CPU remains in the Bus Hold Acknowledge state. In the Bus Hold Acknowledge state, all inputs except HOLD, FLT, and RESET are ignored. Figure 27. Interrupt Acknowledge Cycles 18420A-029 #### Note: 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 $\overline{\text{NA}}$ has no practical effect. Choose the approach which is simplest for your system hardware design. Th may be entered from a bus idle state, as in Figure 30, or after the acknowledgment of the current physical bus cycle, if the LOCK signal is not asserted, as in Figure 31 and Figure 32. 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 30. The following bus state will be T1 if a bus request is internally pending, as in Figure 31 and Figure 32. Th is exited in response to RESET being asserted. If a rising edge occurs on the edge-triggered NMI in-put while in Th, the event is remembered as a non-mask-able interrupt 2 and is serviced when Th is exited, unless the Am386SE 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 Am386SE microprocessor drives its pins to defined states during reset, as in Table 14 (Pin State During Reset on page 39), and performs internal reset activity as usual. If HOLD remains asserted when RESET is inactive, the Am386SE CPU enters the Hold Acknowledge state before performing its first bus cycle, provided HOLD is still asserted when the Am386SE microprocessor would otherwise perform its first bus cycle. #### **FLOAT** Activating the FLT input floats all Am386SE microprocessor bidirectional and output signals, including HLDA. Asserting FLT isolates the Am386SE microprocessor from the surrounding circuitry. As the Am386SE 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 Am386SE CPU to be electrically isolated from the surrounding circuitry. This allows connection of an emulator to the Am386SE microprocessor PQFP without removing it from the PCB. This method of emulation is referred to as ON-Circuit Emulation (ONCE). П Figure 28. Example Halt Indication Cycle from Non-Pipelined Cycle #### **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 Am386SE microprocessor (Figure 34). 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 Am386SE CPU will exit FLOAT in a valid state. Asserting the FLT input unconditionally aborts the current bus cycle and forces the Am386SE CPU into the FLOAT mode. Since activating FLT unconditionally forces the Am386SE CPU into FLOAT mode, the Am386SE microprocessor is not guaranteed to enter FLOAT in a valid state. After deactivating FLT, the Am386SE CPU is not guaranteed 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 Am386SE microprocessor must be reset to return it to a valid state. Reset should be asserted before FLT is deasserted. This will ensure that the Am386SE 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 Am386SE 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 29. 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 33 and Figure 40. A self-test may be requested at the time RESET goes inactive by having the BUSY input at a Low level, as shown in Figure 33. The self-test requires approximately (2<sup>20</sup> + 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 Am386SE microprocessor attempts to proceed with the reset sequence afterwards. After the RESET falling edge (and after the self-test if it was requested), the Am386SE 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 Am386SE 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 Am386SE microprocessor, after reset, holds a component identifier and revision identifier in its DX register. The Am386SE microprocessor, after RESET, holds a component identifier and revision identifier in its DX register. In the DH portion, the lower nibble 3H refers to the Am386 CPU architecture. The upper nibble 2H refers to the second version of the Am386 microprocessor family. In the lower DL portion, the upper nibble EH identifies the processor as a member of the Am386 E Series. The lower nibble holds the 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 Am386SE microprocessor revision identifier will track that of the Am386DE CPU where possible. 18420A-032 #### Note: For maximum design flexibility, the Am386SE CPU has no internal pull-up resistors on its outputs. The design may require an external pull-up on ADS and other outputs to keep them negated during float periods. Figure 30. Requesting Hold from Idle Bus 18420A-033 #### 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. Figure 31. Requesting Hold from Active Bus (NA Inactive) #### 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. Figure 32. Requesting Hold from Idle Bus (NA Active) #### Notes: \*Approximately - 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. 18420A-035 Figure 33. Bus Activity from Reset Until First Code Fetch 18420A--036 Figure 34. 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. ## Coprocessor Interfacing The Am386SE microprocessor provides an automatic interface for a 387SX math coprocessor. A 387SX math coprocessor uses an I/O mapped interface driven automatically by the Am386SE CPU and assisted by three dedicated signals: BUSY, ERROR, and PEREQ. As the Am386SE 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 opcode was required when the 8086 or 8088 was used with the 8087 math coprocessor). Custom coprocessors can be included in Am386SE microprocessor-based systems by 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 instructions for high-speed coprocessor communication. The BUSY and ERROR inputs of the Am386SE microprocessor may also be used for the custom coprocessor interface, if such hardware assist is desired. These signals can be tested by the WAIT opcode (9BH). The WAIT instruction will wait until the BUSY input is inactive (interruptible 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 coprocessor interface is memory-mapped, protection of the addresses used for the interface can be provided with the Am386SE CPU's on-chip segmentation mechanism. 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 16. Note that 387SX math coprocessor interface addresses are beyond the 0H–0FFFFH range for programmed I/O. When the Am386SE microprocessor supports the 387SX math coprocessor, the Am386SE CPU automatically generates bus cycles to the coprocessor interface addresses. Table 16. Math Coprocessor Port Address | Address in Am386SE<br>CPU I/O Space | 387SX-Compatible Math<br>Coprocessor Register | |-------------------------------------|-----------------------------------------------| | 8000F8H | Op-Code Register | | 8000CH/8000FEH* | Operand Register | Note: \*Generated as 2nd bus cycle during Dword transfer. Table 17. Connections for CMD0 and CMD1 inputs for a 387SX | _ | Connection | |------|---------------------------------------------| | CMD0 | Connected directly to Am386SE CPU A2 signal | | CMD1 | Connected to ground | To correctly map 387SX math coprocessor registers to the appropriate I/O addresses, connect the $\overline{\text{CMD0}}$ and $\overline{\text{CMD1}}$ lines of a 387SX math coprocessor, as listed in Table 17. ## 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 Am386SE CPU's CR0 register. ## PACKAGE THERMAL SPECIFICATIONS The Am386SE microprocessor is specified for operation at a case temperature. The case temperature may be measured in any environment to determine whether the Am386SE 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$ ia from the following equations: $$Tj = Tc + P \bullet \Theta jc$$ $Ta = Tj - P \bullet \Theta ja$ $Tc = Ta + P \bullet [\Theta ja - \Theta jc]$ #### **ELECTRICAL SPECIFICATIONS** The following sections describe recommended electrical connections for the Am386SE microprocessor, and its electrical specifications. ## **Power and Grounding** The Am386SE 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_{\rm CC}$ and 18 $V_{\rm SS}$ pins separately feed functional units of the Am386SE microprocessor. Power and ground connections must be made to all external $V_{CC}$ and $V_{SS}$ pins of the Am386SE microprocessor. On the circuit board, all $V_{CC}$ pins should be connected on a $V_{CC}$ plane, and $V_{SS}$ pins should be connected on a GND plane. #### **Power Decoupling Recommendations** Liberal decoupling capacitors should be placed near the Am386SE microprocessor. The Am386SE 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 Am386SE microprocessor and decoupling capacitors as much as possible. #### **Resistor Recommendations** The ERROR, FLT, and BUSY inputs have internal pull-up resistors of approximately 20 Kohms, and the PEREQ input has an internal pull-down resistor of approximately 20 Kohms, built into the Am386SE 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 18 are recommended. However, a particular design may have reason to adjust the resistor values recommended here, or after 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 Am386SE 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{\text{NA}}$ ) through a pull-up in the range of 20 Kohms to $V_{\text{CC}}$ . Table 18. Recommended Resistor Pull-Ups to Vcc | Pin | Signal | Pull-Up Value | Purpose | |-----|--------|------------------|--------------------------------------------------------------------------| | 16 | ĀDS | 20 Kohms<br>±10% | Lightly pull ADS inactive during Am386SE<br>CPU Hold Acknowledge states | | 26 | LOCK | 20 Kohms<br>±10% | Lightly pull LOCK inactive during Am386SE<br>CPU Hold Acknowledge states | #### 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 damage to the device. Functionality at or above these limits is not implied. 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.0 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 (25 MHz) $V_{CC} = 3.6 \text{ V} - 5.5 \text{ V}$ ; $T_{CASE} = 0^{\circ}\text{C}$ to +100°C (Extended Temperature $T_{CASE} = -40^{\circ}\text{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 <sub>IH</sub> | Input High Voltage | | 2.0 | V <sub>CC</sub> + 0.3 | ٧ | | V <sub>ILC</sub> | CLK2 Input Low Voltage | (Note 1) | -0.3 | +0.8 | ٧ | | ViHC | CLK2 Input High Voltage (25 MHz) | | 2.7 | V <sub>CC</sub> + 0.3 | ٧ | | V <sub>OL</sub> | Output Low Voltage I <sub>OL</sub> = 4 mA: A23-A1, D15-D0 I <sub>OL</sub> = 5 mA: BHE, BLE, W/R, D/C, M/IO LOCK, ADS, HLDA | (Note 6) | | 0.45<br>0.45 | <b>&gt;</b> | | V <sub>OH</sub> | Output High Voltage OH = 1.0 mA: A23-A1, D15-D0 OH = 0.2 mA: A23-A1, D15-D0 OH = 0.9 mA: BHE, BLE, WR, D/C, LOCK, ADS, M/IO, HLDA OH = 0.18 mA: BHE, BLE, W/R, D/C, LOCK, ADS, M/IO, HLDA OH = 0.18 mA: BHE, BLE, W/R, D/C, LOCK, ADS, M/IO, HLDA | (Note 6) | 2.4<br>V <sub>CC</sub> = 0.5<br>2.4<br>V <sub>CC</sub> = 0.5 | | ><br>><br>> | | lu | Input Leakage Current (All pins except PEREQ, BUSY, ERROR, FLT) | 0 V ≤ V <sub>IN</sub> ≤ V <sub>CC</sub> | | ±15 | μА | | l <sub>iH</sub> | Input Leakage Current (PEREQ pin) | V <sub>IH</sub> = 2.4 V (Note 2) | | 200 | μА | | I <sub>IL</sub> | Input Leakage Current<br>(BUSY, ERROR, FLT) | V <sub>IL</sub> = 0.45 V (Note 3) | | -400 | μА | | Iro | Output Leakage Current | 0.45 V ≤ V <sub>OUT</sub> ≤ V <sub>CC</sub> | | ±15 | μА | | Icc | Supply Current<br>CLK2 = 50 MHz: Oper. Freq. 25 MHz | V <sub>CC</sub> Typ = 5.0 V<br>I <sub>CC</sub> Typ = 160 | | V <sub>CC</sub> = 5.5<br>190 | V<br>mA | | I <sub>CCSB</sub> | Standby Current (Note 5) | I <sub>CCSB</sub> Typ = 20 μA | | 150 | μΑ | | 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 | | C <sub>CLK</sub> | CLK2 Capacitance | F <sub>C</sub> = 1 MHz (Note 4) | | 20 | pF | ### Notes: Tested at minimum operating frequency of the part. - 1. The Min value, -0.3, is not 100% tested. - 2. PEREQ input has an internal pull-down resistor. - 3. BUSY, ERROR, and FLT inputs each have an internal pull-up resistor. - 4. Not 100% tested. - 5. Measurement taken with inputs at rails; outputs unloaded; BUSY, FLT, and ERROR at VCC; and PEREQ at GND. - 6. Outputs are CMOS and will pull rail-to-rail if the load is not resistive. ## DC CHARACTERISTICS over COMMERCIAL operating ranges (25 MHz) $V_{CC} = 3.0 \text{ V} - 3.6 \text{ V}$ ; $T_{CASE} = 0^{\circ}\text{C}$ to +100°C (Extended Temperature $T_{CASE} = -40^{\circ}\text{C}$ to 100°C) | | | | Prelin | | | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------------------------------------------------|--------------------------------|--------------------------| | Symbol | Parameter Description | Notes | Min | Max | Unit | | V <sub>IL</sub> | Input Low Voltage | (Note 1) | - 0.3 | +0.8 | ٧ | | V <sub>tH</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 <sub>IHC</sub> | CLK2 Input High Voltage (25 MHz) | | 2.4 | V <sub>CC</sub> + 0.3 | V | | V <sub>OL</sub> | Output Low Voltage OL = 0.5 mA: A23-A1, D15-D0 OL = 0.5 mA: BHE, BLE, W/R, D/C, M/IO, LOCK, ADS, HLDA OL = 2 mA: A23-A1, D15-D0 OL = 2.5 mA: BHE, BLE, W/R, D/C, LOCK, ADS, M/IO, HLDA | (Note 5) | | 0.2<br>0.2<br>0.45<br>0.45 | V<br>V<br>V | | V <sub>OH</sub> | Output High Voltage I <sub>OH</sub> = 0.1 mA: A23-A1, D15-D0 I <sub>OH</sub> = 0.1 mA: BHE, BLE, W/R, D/C, LOCK, ADS, M/IO, HLDA I <sub>OH</sub> = 0.5 mA: A23-A1, D15-D0 I <sub>OH</sub> = 0.5 mA: BHE, BLE, W/R, D/C, LOCK, ADS, M/IO, HLDA | (Note 5)<br>(Note 6) | V <sub>CC</sub> - 0.2<br>V <sub>CC</sub> - 0.2<br>V <sub>CC</sub> - 0.45<br>V <sub>CC</sub> - 0.45 | | V<br>V<br>V | | l <sub>Li</sub> | Input Leakage Current (All pins except<br>PEREQ, BUSY, ERROR, FLT) | 0 V ≤ V <sub>IN</sub> ≤ V <sub>CC</sub> | | ±10 | μА | | I <sub>IH</sub> | Input Leakage Current<br>(PEREQ pin) | $V_{IH} = V_{CC} - 0.1 V$<br>$V_{IH} = 2.4 V \text{ (Note 2)}$ | | 300<br>200 | μ <b>Α</b><br>μ <b>Α</b> | | I <sub>IL</sub> | Input Leakage Current<br>(BUSY, ERROR, FLT) | V <sub>IL</sub> = 0.1 V<br>V <sub>IL</sub> = 0.45 V (Note 3) | | - 300<br>200 | μ <b>Α</b><br>μ <b>Α</b> | | I <sub>LO</sub> | Output Leakage Current | 0.1 V ≤ V <sub>OUT</sub> ≤ V <sub>CC</sub> | | ±15 | μΑ | | lcc | Supply Current (Note 6)<br>CLK2 = 50 MHz: Oper. Freq. 25 MHz | V <sub>CC</sub> = 3.3 V<br>I <sub>CC</sub> Typ = 95 | | V <sub>CC</sub> = 3.6 V<br>115 | mA | | Iccsb | Standby Current (Note 6) | I <sub>CCSB</sub> Typ = 10 μA | | 150 | μА | | 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 | | C <sub>CLK</sub> | CLK2 Capacitance | F <sub>C</sub> = 1 MHz (Note 4) | | 20 | pF | - 1. The Min value, -0.3, is not 100% tested. - PEREQ input has an internal pull-down resistor. BUSY, ERROR, and FLT inputs each have an internal pull-up resistor. - 4. Not 100% tested. - 5. Outputs are CMOS and will pull rail-to-rail if the load is not resistive. 6. Inputs at rails ( $V_{\rm CC}$ or $V_{\rm SS}$ ). ## DC CHARACTERISTICS over COMMERCIAL operating ranges (33 MHz) $V_{CC}$ = 4.5 V - 5.5 V; $T_{CASE}$ = 0°C to +100°C | | | | Prelin | | | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|--------------------------------------------------------------|--------------------------------|------------| | Symbol | Parameter Description | Notes | Min | Max | Unit | | V <sub>IL</sub> | Input Low Voltage | (Note 1) | -0.3 | +0.8 | ٧ | | V <sub>IH</sub> | Input High Voltage | | 2.0 | V <sub>CC</sub> + 0.3 | ٧ | | V <sub>ILC</sub> | CLK2 Input Low Voltage | (Note 1) | -0.3 | +0.8 | ٧ | | VIHC | CLK2 Input High Voltage | | 2.7 | V <sub>CC</sub> + 0.3 | <b>V</b> | | V <sub>OL</sub> | Output Low Voltage I <sub>OL</sub> = 4 mA: A23-A1, D15-D0 I <sub>OL</sub> = 5 mA: BHE, BLE, W/R, D/C M/IO, LOČK, ADS, HLDA | (Note 6) | | 0.45<br>0.45 | V | | V <sub>OH</sub> | Output High Voltage OH = 1 mA: A23-A1, D15-D0 OH = 0.9 mA: BHE, BLE, W/R, D/C, LOCK, ADS, M/IO, HLDA OH = 0.2 mA: A23-A1, D15-D0 OH = 0.18 mA: BHE, BLE, W/R, D/C, LOCK, ADS, M/IO, HLDA | (Note 6) | 2.4<br>2.4<br>V <sub>CC</sub> – 0.5<br>V <sub>CC</sub> – 0.5 | | >><br>>> | | ILI | Input Leakage Current (All pins except PEREQ, BUSY, ERROR, FLT) | 0 V ≤ V <sub>IN</sub> ≤ V <sub>CC</sub> | | ±15 | μА | | I <sub>IH</sub> | Input Leakage Current (PEREQ pin) | V <sub>IH</sub> = 2.4 V (Note 2) | | 200 | μ <b>A</b> | | ارر | Input Leakage Current (BUSY, ERROR, FLT) | V <sub>IL</sub> = 0.45 V (Note 3) | | -400 | μ <b>Α</b> | | I <sub>LO</sub> | Output Leakage Current | 0.45 V ≤ V <sub>OUT</sub> ≤ V <sub>CC</sub> | | ±15 | μА | | Icc | Supply Current<br>CLK2 = 66 MHz: Oper. Freq. 33 MHz | V <sub>CC</sub> = 5.0 V<br>I <sub>CC</sub> Typ = 210 | | V <sub>CC</sub> = 5.5 V<br>245 | mA | | IccsB | Standby Current (Note 5) | I <sub>CCSB</sub> Typ = 20 μA | 20 | 150 | μА | | C <sub>IN</sub> | Input Capacitance | F <sub>C</sub> = 1 MHz (Note 4) | | 10 | pF | | C <sub>OUT</sub> | Output or I/O 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 Tested at minimum operating frequency of the part. - 1. The Min value, -0.3, is not 100% tested. - 2. PEREQ input has an internal pull-down resistor. - 3. BUSY, ERROR, and FLT inputs each have an internal pull-up resistor. - 4. Not 100% tested. - 5. Measurement taken with inputs at rails; outputs unloaded; BUSY, FLT, and ERROR at VCC; and PEREQ at GND. - 6. 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 35. Inputs must be driven to the voltage levels indicated by Figure 35 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. Figure 35. Drive Levels and Measurement Points for Switching Characteristics ## SWITCHING CHARACTERISTICS over COMMERCIAL operating ranges (25 MHz) $V_{CC} = 3.0 - 5 \text{ V}$ ; $T_{CASE} = 0^{\circ}\text{C}$ to $100^{\circ}\text{C}$ (Extended Temperature Range; $T_{CASE} = -40^{\circ}\text{C}$ to $100^{\circ}\text{C}$ ) | Symbol | Parameter Description | Notes | | Ref.<br>Figure | Min. | Max. | Unit | |--------|---------------------------------------|------------------------------------|----------|----------------|------|------|------| | | Am386SE CPU | Half CLK2 freq. | | | 0 | 25 | MHz | | 1 | Am386SE CPU | | | 36 | 20 | | ns | | 2a | CLK2 High Time | at 2 V | | 36 | 7 | | ns | | 2b | CLK2 High Time | at (V <sub>CC</sub> - 0.8 V) | | 36 | 4 | | ns | | 3a | CLK2 Low Time | at 2 V | | 36 | 7 | | ns | | 3b | CLK2 Low Time | at 0.8 V | | 36 | 5 | | ns | | 4 | CLK2 Fall Time | (V <sub>CC</sub> – 0.8 V) to 0.8 V | (Note 3) | 36 | | 7 | ns | | 5 | CLK2 Rise Time | 0.8 V to (V <sub>CC</sub> - 0.8 V) | (Note 3) | 36 | | 7 | ns | | 6 | A23-A1 Valid Delay | C <sub>L</sub> = 50 pF | | 39 | 4 | 17 | ns | | 7 | A23-A1 Float Delay | | (Note 1) | 42 | 4 | 30 | ns | | 8 | BHE, BLE, LOCK Valid Delay | C <sub>L</sub> = 50 pF | | 39 | 4 | 17 | ns | | 9 | BHE, BLE, LOCK Float Delay | | (Note 1) | 42 | 4 | 30 | ns | | 10 | M/IO, D/C, W/FI, ADS Valid Delay | C <sub>L</sub> = 50 pF | | 39 | 4 | 17 | ns | | 11 | W/R, M/IO, D/C, ADS Float Delay | | (Note 1) | 42 | 4 | 30 | ns | | 12 | D15-D0 Write Data Valid Delay | C <sub>L</sub> = 50 pF | | 39,40 | 7 | 23 | ns | | 12a | D15-D0 Write Data Hold Time | C <sub>L</sub> = 50 pF | | 41 | 2 | | ns | | 13 | D15-D0 Write Data Float Delay | | (Note 1) | 42 | 4 | 22 | ns | | 14 | HLDA Valid Delay | C <sub>L</sub> = 50 pF | | 39 | 4 | 22 | ns | | 14f | HLDA Float Delay | | | 42 | 4 | 22 | ns | | 15 | NA Setup Time | | | 38 | 5 | | ns | | 16 | NA Hold Time | | | 38 | 3 | | ns | | 19 | READY Setup Time | | | 38 | 9 | | ns | | 20 | READY Hold Time | | | 38 | 4 | | ns | | 21 | D15-D0 Read Data Setup Time | | | 38 | 7 | | ns | | 22 | D15D0 Read Data Hold Time | | | 38 | 5 | | ns | | 23 | HOLD Setup Time | | | 38 | 9 | | ns | | 24 | HOLD Hold Time | | | 38 | 3 | | ns | | 25 | RESET Setup Time | | | 43 | 8 | | ns | | 26 | RESET Hold Time | | , | 43 | 3 | | ns | | 27 | NMI, INTR Setup Time | | (Note 2) | 38 | 6 | | ns | | 28 | NMI, INTR Hold Time | | (Note 2) | 38 | 6 | | ns | | 29 | PEREQ, ERROR, BUSY, FLT<br>Setup Time | | (Note 2) | 38 | 6 | | ns | | 30 | PEREQ, ERROR, BUSY, FLT<br>Hold Time | | (Note 2) | 38 | 5 | | ns | #### Notes <sup>1.</sup> Float condition occurs when maximum output current becomes less than ILO 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. <sup>3.</sup> These are not tested. They are guaranteed by design characterization. ## **SWITCHING CHARACTERISTICS over COMMERCIAL operating ranges (33 MHz)** $V_{CC}$ = 4.5 V - 5.5 V; $T_{CASE}$ = 0°C to 100°C | Symbol | Parameter Description | Notes | | Ref.<br>Figure | Min. | Max. | Unit | |--------|---------------------------------------|------------------------|----------|----------------|------|------|------| | | Am386SE CPU | Half CLK2 freq. | | | 0 | 33 | MHz | | 1 | Am386SE CPU | | | 36 | 15 | | ns | | 2a | CLK2 High Time | at 2 V | | 36 | 6.25 | | ns | | 2b | CLK2 High Time | at 3.7 V | - | 36 | 4 | | ns | | 3a | CLK2 Low Time | at 2 V | | 36 | 6.25 | | ns | | 3b | CLK2 Low Time | at 0.8 V | | 36 | 4.5 | | ns | | 4 | CLK2 Fall Time | 3.7 V to 0.8 V | (Note 3) | 36 | | 4 | ns | | 5 | CLK2 Rise Time | 0.8 V to 3.7 V | (Note 3) | 36 | | 4 | ns | | 6 | A23-A1 Valid Delay | C <sub>L</sub> = 50 pF | (Note 4) | 39 | 4 | 15 | ns | | 7 | A23-A1 Float Delay | | (Note 1) | 42 | 4 | 20 | ns | | 8 | BHE, BLE, LOCK Valid Delay | C <sub>L</sub> = 50 pF | | 39 | 4 | 15 | ns | | 9 | BHE, BLE, LOCK Float Delay | | (Note 1) | 42 | 4 | 20 | ns | | 10 | M/IO, D/C, W/R, ADS Valid Delay | C <sub>L</sub> = 50 pF | | 39 | 4 | 15 | ns | | 11 | W/R, M/IO, D/C, ADS Float Delay | | (Note 1) | 42 | 4 | 20 | ns | | 12 | D15-D0 Write Data Valid Delay | C <sub>L</sub> = 50 pF | (Note 4) | 39,40 | 7 | 23 | ns | | 12a | D15-D0 Write Data Hold Time | C <sub>L</sub> = 50 pF | | 41 | 2 | | ns | | 13 | D15-D0 Write Data Float Delay | | (Note 1) | 42 | 4 | 17 | ns | | 14 | HLDA Valid Delay | C <sub>L</sub> = 50 pF | | 39 | 4 | 20 | ns | | 14f | HLDA Float Delay | | (Note 1) | 42 | 4 | 20 | ns | | 15 | NA Setup Time | | | 38 | 5 | | ns | | 16 | NA Hold Time | | | 38 | 2 | | ns | | 19 | READY Setup Time | | | 38 | 7 | | ns | | 20 | READY Hold Time | | | 38 | 4 | | ns | | 21 | D15-D0 Read Data Setup Time | | | 38 | 5 | | ns | | 22 | D15-D0 Read Data Hold Time | | | 38 | 3 | | ns | | 23 | HOLD Setup Time | | | 38 | 9 | | ns | | 24 | HOLD Hold Time | | | 38 | 2 | | ns | | 25 | RESET Setup Time | | | 43 | 5 | | ns | | 26 | RESET Hold Time | | | 43 | 2 | | ns | | 27 | NMI, INTR Setup Time | | (Note 2) | 38 | 5 | | ns | | 28 | NMI, INTR Hold Time | | (Note 2) | 38 | 5 | | ns | | 29 | PEREQ, ERROR, BUSY, FLT<br>Setup Time | | (Note 2) | 38 | 5 | | ns | | 30 | PEREQ, ERROR, BUSY, FLT<br>Hold Time | | (Note 2) | 38 | 4 | | 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. - 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 distribution capacitive load. 18420A--038 Figure 36. CLK2 Timing (25, 33 MHz) Figure 37. AC Test Circuit ## **SWITCHING WAVEFORMS** Figure 38. Input Setup and Hold Timing Figure 39. Output Valid Delay Timing ## **SWITCHING WAVEFORMS (continued)** Figure 40. Write Data Valid Delay Timing (25 MHz) 18420A-042 Figure 41. Write Data Hold Timing Figure 42. Output Float Delay and HLDA Valid Delay Timing Figure 43. RESET Setup and Hold Timing and Internal Phase Figure 44. Typical Output Valid Delay Versus Load Capacitance at Maximum Operating Temperature (C<sub>L</sub>=120 pF) 18420A-047 Figure 45. Typical Output Valid Delay Versus Load Capacitance at Maximum Operating Temperature (C<sub>1</sub> =75 pF) Figure 46. Typical Output Valid Delay Versus Load Capacitance at Maximum Operating Temperature (C<sub>L</sub> =50 pF) 18420A-049 Figure 47. Typical Output Rise Time Versus Load Capacitance at Maximum Operating Temperature # DIFFERENCES BETWEEN THE Am386SE CPU AND THE Am386DE CPU The following are the major differences between the Am386SE CPU and the Am386DE CPU: - The Am386SE 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 Am386DE CPU uses four byte selects, - BE3-BE0, to distinguish between the different bytes on its 32-bit bus. - The Am386SE CPU has no bus sizing option. The Am386DE CPU can select between either a 32-bit bus or a 16-bit bus by use of the BS16 input. The Am386SE CPU has a 16-bit bus size. - The NA pin operation in the Am386SE CPU is identical to that of the NA pin on the Am386DE CPU with one exception: the Am386DE CPU NA pin cannot be - activated on 16-bit bus cycles (where BS16 is Low in the Am386DE CPU case), whereas NA can be activated on any Am386SE CPU bus cycle. - The contents of all Am386SE CPU registers at reset are identical to the contents of the Am386DE CPU registers at reset, except the DX register. The DX register contains a component-stepping identifier at reset, that is, in Am386DE CPU, after reset DH = 3 indicates Am386DE CPU in Am386SE CPU, after reset DH = 23H indicates Am386SE CPU - The Am386DE CPU uses A31 and M/IO as selects for the math coprocessor. The Am386SE CPU uses A23 and M/IO as selects. - 6. The Am386DE CPU prefetch unit fetches code in four-byte units. The Am386SE CPU prefetch unit reads two bytes as one unit (like the 80286). In BS16 mode, the Am386DE 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 Am386DE CPU will fetch all four bytes before addressing the new request. - 7. Both Am386DE CPU and Am386SE CPU have the same logical address space. The only difference is that the Am386DE CPU has a 32-bit physical address space and the Am386SE CPU has a 24-bit physical address space. The Am386SE CPU has a physical memory address space of up to 16 Mbytes instead of the 4 Gbytes available to the Am386DE CPU. Therefore, in Am386SE 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 Am386DE CPU system uses only the lower 16 Mbytes of physical address, then there will be no extra effort required to migrate Am386DE CPU software to the Am386SE CPU. In spite of this difference in physical address space, the Am386SE CPU and Am386DE CPU can run the same operating systems and applications within their respective physical memory constraints. - The Am386SE CPU has an input called FLT which three-states all bidirectional 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. ## Am386SE Microprocessor 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 the 25-MHz Am386SE CPU). The actual clock count of an Am386SE 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 - The instruction has been prefetched, decoded, and is ready for execution. - 2. Bus cycles do not require wait states. - There are no local bus HOLD requests delaying processor access to the bus. - 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 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 x clocks for read or write - 4 x clocks for read and write - -- If instructions access a 32-bit operand on odd address add: - 4 x clocks for read or write - 8 x clocks for read and write #### **Wait States** Wait states add 1 clock per wait state to instruction execution for each data access. ## Am386SE Microprocessor Instruction Set Clock Count Summary | | | Clock Count | | Notes | | |-------------------------------------------------|-----------------------------------------------|-------------------------|------------------------------|-------------------------|------------------------------| | Instruction | Format | Real<br>Address<br>Mode | Protected<br>Address<br>Mode | Real<br>Address<br>Mode | Protected<br>Address<br>Mode | | GENERAL DATA TRANSFER | | | | | | | MOV = Move | | | | | | | Register to Register/Memory | 1 0 0 0 1 0 0 w mod reg r/m | 2/2 | 2/2* | ь | h | | Register/Memory to Register | 1 0 0 0 1 0 1 w mod reg r/m | 2/4 | 2/4* | b | h | | 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 | | Immediate to Register (short form) | 1 0 1 1 w reg immediate data | 2 | 2 | | | | Memory to Accumulator (short form) | 1 0 1 0 0 0 0 w full displacement | 4* | 4* | b | h | | Accumulator to Memory (short 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 3 r/m | 2/5 | 22/23 | b | h, i, j | | Segment Register to Register/Memory | 1 0 0 0 1 1 0 0 mod sreg r/m | 2/2 | 2/2 | b | h | | MOVSX = Move with Sign Extension | | | | | | | Register from Register/Memory | 0 0 0 0 1 1 1 1 1 1 0 1 1 1 1 1 w mod reg r/m | 3/6* | 3/6* | b | 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 r/m | 3/6* | 3/6* | b | h | | PUSH = Push | | | | | | | Register/Memory | 1 1 1 1 1 1 1 1 mod 1 1 0 r/m | 5/7* | 7/9* | b | h | | Register (short form) | 0 1 0 1 0 reg | 2 | 4 | b | h | | Segment Register (ES,CS,SS, or DS) (short form) | 0 0 0 sreg 2 1 1 0 | 2 | 4 | 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 0 | 2 | 4 | b | h | | immediate | 0 1 1 0 1 0 s 0 immediate data | 2 | 4 | ь | h | | PUSHA = Push Ali | 01100000 | 18 | 34 | b | h | | POP = Pop | | | | | | | Register/Memory | 1 0 0 0 1 1 1 1 mod 0 0 0 r/m | 5/7 | 7/9 | b | h | | Register (short form) | 0 1 0 1 1 reg | 6 | 6 | b | h | | Segment Register (ES, CS, SS, or DS) | 000 sreg 2111 | 7 | 25 | b | h, i, j | | 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, i, j | | POPA = Pop Ail | 01100001 | 24 | 40 | b | h | | 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, h | | Register with Accumulator (short form) | 1 0 0 1 0 reg | 3 | 3 | | | | IN = Input From: | | | | | | | Fixed Port | 1 1 1 0 0 1 0 w port number | 12* | 6*/26* | | s/t, m | | Variable Port | 1110110w | 13* | 7*/27* | | s/t, m | | If CPI < IOPI ** If CPI > IOPI | <u></u> | | | | | <sup>\*</sup> If CPL≤IOPL \*\* If CPL>IOPL | | | Clock Count | | ock Count No | | |---------------------------------------|----------------------------------------------|--------------------------|------------------------------|--------------------------|------------------------------| | Instruction | Format | Fleat<br>Address<br>Mode | Protected<br>Address<br>Mode | Fleai<br>Address<br>Mode | Protected<br>Address<br>Mode | | OUT = Output To: | | | | | | | Fixed Port | 1 1 1 0 0 1 1 w port number | 10* | 4*/24* | | s/t, m | | Variable Port | 1110111w | 11* | 5*/25* | | s/t, m | | LEA = Load EA to Register | 1 0 0 0 1 1 0 1 mod reg r/m | 2 | 2 | | | | SEGMENT CONTROL | | | | | | | LDS = Load Pointer to DS | 1 1 0 0 0 1 0 1 mod reg r/m | 7* | 26*/28* | b | h, i, j | | LES ≈ Load Pointer to ES | 1 1 0 0 0 1 0 0 mod reg r/m | 7* | 26*/28* | b | h, i, j | | LFS ≠ Load Pointer to FS | 0 0 0 0 1 1 1 1 1 0 1 1 0 1 0 0 mod reg r/m | 7* | 26*/28* | b | h, i, j | | LGS = Load Pointer to GS | 0 0 0 0 1 1 1 1 1 0 1 1 0 1 0 1 mod reg r/m | 7* | 26*/28* | ь | h, i, j | | LSS ≈ Load Pointer to SS | 0 0 0 0 1 1 1 1 1 0 1 1 0 0 1 0 mod reg r/m | 7* | 26*/28* | ь | h, i, j | | FLAG CONTROL | | | | | | | CLC ≈ Clear Carry Flag | 11111000 | 2 | 2 | | | | CLD ≈ Clear Direction Flag | 1111100 | 2 | 2 | | : | | CLI = Clear Interrupt Enable Flag | 1 1 1 1 1 0 1 0 | 8 | 8 | | m | | CLTS = Clear Task Switched Flag | 00001111 00000110 | 5 | 5 | С | 1 | | CMC = Complement Carry Flag | 1 1 1 1 0 1 0 1 | 2 | 2 | | | | LAHF = Load AH into Flag | 1001111 | 2 | 2 | | | | POPF = Pop Flags | 10011101 | 5 | 5 | b | h, n | | PUSHF = Push Flags | 10011100 | 4 | 4 | b | h | | SAHF = Store AH into Flags | 10011110 | 3 | 3 | | | | STC = Set Carry Flag | 11111001 | 2 | 2 | | | | STD = Set Direction Flag | 1111101 | | | | | | STI = Set interrupt Enable Flag | 1111011 | 8 | 8 | | m | | ARITHMETIC | | | | | | | 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** | ь | h | | Memory to Register | 0 0 0 0 0 0 1 w mod reg r/m | 6* | 6* | b | h | | Immediate to Register/Memory | 1 0 0 0 0 0 s w mod 0 0 0 r/m immediate data | 2/7** | 2/7** | b | 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 | 0 0 0 1 0 0 d w mod reg r/m | 2 | 2 | | | | | <del></del> | | | | | <sup>\*</sup> If CPL>IOPL | | | Clock | Clock Count | | tes | |-----------------------------------------|----------------------------------------------|-------------------------|------------------------------|-------------------------|------------------------------| | instruction | Format | Real<br>Address<br>Mode | Protected<br>Address<br>Mode | Real<br>Address<br>Mode | Protected<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 | 1 0 0 0 0 0 s w mod 0 1 0 r/m immediate data | 2/7** | 2/7** | b | 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 w mod 0 0 0 r/m | 2/6** | 2/6** | ь | 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** | ь | h | | Memory from Register | 0 0 1 0 1 0 1 w mod reg r/m | 6. | 6* | b | h | | Immediate from Register/Memory | 1 0 0 0 0 0 s w mod 1 0 1 r/m immediate data | 2/7** | 2/7** | b | h | | Immediate from Accumulator (short form) | 0 0 1 0 1 1 0 w immediate data | 2 | 2 | | | | SBB = Subtract with Borrow | <del></del> | | Į. | | | | 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** | b | h | | Memory from Register | 0 0 0 1 1 0 1 w mod reg r/m | 6* | 6* | ь | h | | Immediate from Register/Memory | 1 0 0 0 0 0 s w mod 0 1 1 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 | <del></del> | | | | | | Register/Memory | 1 1 1 1 1 1 w reg 0 0 1 r/m | 2/6 | 2/6 | ь | 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* | ь | h | | Register with Memory | 0 0 1 1 1 0 1 w mod reg r/m | 6. | 6* | ь | h | | Immediate with Register/Memory | 1 0 0 0 0 0 s 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* | b | ħ | | AAA = ASCII Adjust for Add | 0 0 1 1 0 1 1 1 | 4 | 4 | | | <sup>\*</sup> If CPL≤ IOPL \*\* If CPL> IOPL | <del></del> | | Clock Count | | Notes | | | |--------------------------------------------|---------------------------------------------|----------------------------------------------|------------------------------|-------------------------|------------------------------|--| | Instruction | Format | Real<br>Address<br>Mode | Protected<br>Address<br>Mode | Real<br>Address<br>Mode | Protected<br>Address<br>Mode | | | AAS = ASCII Adjust for Subtract | 00111111 | 4 | 4 | | | | | DAA = Decimal Adjust for Add | 0 0 1 0 0 1 1 1 | 4 | 4 | | | | | DAS = Decimal Adjust for Subtract | 00101111 | 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 | 0 0 0 0 1 1 1 1 1 0 1 0 1 1 1 1 mod reg r/m | | | | | | | Multiplier –Byte<br>Word<br>Doubleword | | 12-17/15-20*<br>12-25/15-28*<br>12-41/17-46* | 225/1528* | b, đ<br>b, d<br>b, đ | d, h<br>d, h<br>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 | 13-26/14-27<br>13-42/16-45 | b, d<br>b, d | d, h<br>d, h | | | D(V = 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 | | • | | | | | DivisorByte<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 | 11010101 00001010 | 19 | 19 | | | | | AAM = ASCII Adjust for Multiply | 11010100 00001010 | 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 | L, and SHR) | | ł | <br> | | | | Register/Memory by 1 | 1 1 0 1 0 0 0 w mod TTT r/m | 3/7** | 3/7** | ь | h | | <sup>\*</sup> If CPLSIOPL \*\* If CPL>IOPL | • | | Clock Count Note | | | tes | |---------------------------------------------|-----------------------------------------------------------------------------|-------------------------|------------------------------|-------------------------|------------------------------| | Instruction | Format | Real<br>Address<br>Mode | Protected<br>Address<br>Mode | Real<br>Address<br>Mode | Protected<br>Address<br>Mode | | LOGIC (continued) | | | : | | | | Not Through Carry (ROL, ROR, SAL, SAR, S | HL, and SHR) -(continued) | | | | l | | 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 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 t/m | 3/7** | 3/7** | | | | SHRD = Shift Right Double | | | | | | | Register/Memory by Immediate | 0 0 0 0 1 1 1 1 1 0 1 0 1 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 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** | ь | ħ | | 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 | | | | | | <sup>\*</sup> If CPL≤IOPL \*\* If CPL>IOPL <sup>(1)</sup> Immediate 8-Bit Data | · · | | | _ | · | | |----------------------------------------------|----------------------------------------------|-------------------------|------------------------------|-------------------------|------------------------------| | 1 | | Clock | Count | No | tes | | Instruction | Format | Real<br>Address<br>Mode | Protected<br>Address<br>Mode | Real<br>Address<br>Mode | Protected<br>Address<br>Mode | | LOGIC (continued) | | | | | | | Immediate to Register/Memory | 1 0 0 0 0 0 0 w mod 0 0 1 r/m immediate data | 2/7** | 2/7** | b | h | | Immediate to Accumulator (short form) | 0 0 0 0 1 1 0 w immediate data | 2 | 2 | | | | XOR = Exclusive Or | | | | | | | Register to Register | 0 0 1 1 0 0 d w mod reg r/m | 2 | 2 | | | | Register to Memory | 0 0 1 1 0 0 0 w mod reg r/m | 7** | 7** | ь | h | | Memory to Register | 0 0 1 1 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 1 0 r/m immediate data | 2/7** | 2/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** | 2/6** | b | h | | STRING MANIPULATION | | | | | | | CMPS = Compare Byte/Word | 1010011w | 10* | 10* | b | h | | INS = Input Byte/Word from DX Port | 0 1 1 0 1 1 0 w | 15 | 9*/29** | b | s/t, h, m | | LODS = Load Byte/Word to AL/AX/EAX | 1010110w | 5 | 5* | ь | h | | MOVE = Move Byte/Word | 1 0 1 0 0 1 0 w | 7 | 7** | b | h | | OUTS = Output Byte/Word to DX Port | 0 1 1 0 1 1 1 w | 14 | 8*/28** | ь | s/t, h, m | | SCAS = Scan Byte/Word | 1010111w | 7* | 7* | b | h | | STOS = Store Byte/Word from AL/AX/EX | 1010101w | 4* | 4* | b | h | | XLAT = Translate String | 1 1 0 1 0 1 1 1 | 5* | 5* | | 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 1 0 0 1 1 w | 5+9n** | 5+9n** | b | h | | 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 INS = Input String | 1 1 1 1 0 0 1 0 0 1 1 0 1 1 0 w | 13+6n* | 7+6n*/<br>27+6n** | 6 | s/t, h, m | | REP LODS = Load String | 1 1 1 1 0 0 1 0 | 5+6n* | 5+6n* | b | h | | 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 | | REP OUTS = Output String | 1 1 1 1 0 0 1 0 0 1 1 0 1 1 1 w | 12+5n* | 6+5n*/<br>26+5n** | b | 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* | 5+8n* | b | h | | REPNE SCAS ≈ Scan String (Find AL/AX/EAX) | 11110010 1010111w | 5+8n* | 5+8n* | ь | h | | REP STOS = Store String | 11110010 1010101w | 5+5n* | 5+5n* | b | h | | | | | | | | | * H CPI <iodi **="" cpi="" h="">IODI</iodi> | | | | | | <sup>\*</sup> If CPL≤IOPL \*\* If CPL>IOPL | BSR = Scan Bit Reverse 0 0 0 0 1 1 1 1 | | | Clock | Count | No | les | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|-----------------------------------------------------|----------|----------|---------|------------| | ### ### ############################## | | | Address | Address | Address | Address | | BBF = Scan Bit Forward | | Format | MCGB | Mode | MODE | Mode | | BSR = Scan Bit Reverse 0 0 0 0 1 1 1 1 | BIT MANIPULATION | | | ] . | | | | ### Test Bit ### Register/Memory, Immediate ### Do 0 0 0 1 1 1 1 1 0 1 1 1 0 1 0 mod 100 | 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* | b | h | | Register/Memory, Immediate | 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* | b | h | | Register/Memory, Register | BT = Test Bit | | | | | | | ### BTC = Test Bit and Complement Register/Memory, Immediate | 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, Immediate | Register/Memory, Register | 0 0 0 0 1 1 1 1 1 1 0 1 0 0 0 1 1 mod reg r/m | 3/12* | 3/12* | ь | h | | Register/Memory, Register | BTC = Test Bit and Complement | | | | | | | ### ### ### ### ### ### ### ### ### ## | Register/Memory, Immediate | 0 0 0 0 1 1 1 1 1 1 0 1 1 1 0 1 0 mod 1 1 1 r/m (1) | 6/8* | 6/8* | b | h | | Register/Memory, Immediate | 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 | h | | Register/Memory, Register | BTR = Test Bit and Reset | | | | | | | ### BTS = Test Bit and Set ### Register/Memory, Immediate ### Register/Memory, Register ### CONTROL TRANSFER ### CALL = Call Direct Within Segment | 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, Immediate | 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 | h | | Register/Memory, Register | BTS = Test Bit and Set | | | | | | | 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 indirect Within Segment 1 1 1 1 1 1 1 1 1 1 mod 0 1 0 r/m 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) Via Call Gate to Same Privilege Level Via Call Gate to Different Privilege Level (No Parameters) Via Call Gate to Different Privilege Level (x Parameters) From 80286 Task to Am386SE CPU TSS From Mand Manda See CPU Task to 80286 TSS From Am386SE CPU Task to 80286 TSS From Mand Manda See CPU Task to Manda See CPU TSS Indirect Intersegment 1 1 1 1 1 1 1 1 1 mod 0 1 1 r/m Protected Mode Only (Indirect Intersegment) Via Call Gate to Different Privilege Level Na Call Gate to Different Privilege Level Na Call Gate to Different Privilege Level Na Call Gate to Different Privilege Level (X Parameters) Via Call Gate to Different Privilege Level (X Parameters) Via Call Gate to Different Privilege Level (X Parameters) Via Call Gate to Different Privilege Level (X Parameters) From 80286 Task to Am386SE CPU TSS 80286 TSS From 80286 Task to 80286 TSS From 80286 Task to 80286 TSS From 80286 Task to 80286 TSS From 80286 Task to 80286 TSS | Register/Memory, Immediate | 0 0 0 0 1 1 1 1 1 0 1 1 1 0 1 0 mod 1 0 1 r/m (1) | 6/8* | 6/B* | b | h | | Direct Within Segment | 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 | | T + m* 9 + m* b r | CONTROL TRANSFER | | | İ | | | | Register/Memory Indirect Within Segment | CALL = Call | | | | | | | Direct Intersegment | Direct Within Segment | 1 1 1 0 1 0 0 0 full displacement | 7 + m* | 9 + m* | b | r | | Direct Intersegment 1 0 0 1 1 0 1 0 1 unsigned full offset, selector 17 + m* 42 + m* b j, k, r Protected Mode Only (Direct Intersegment) Via Call Gate to Same Privilege Level Via Call Gate to Different Privilege Level (No Parameters) From 80286 Task to 80286 TSS From 80286 Task to 80286 TSS From Am386SE CPU TSS From Am386SE CPU Task to 80286 TSS From Am386SE CPU Task to Am386SE CPU TSS Indirect Intersegment Via Call Gate to Different Privilege Level Via Call Gate to Different Privilege Level Via Call Gate to Different Privilege Level Via Call Gate to Different Privilege Level Via Call Gate to Different Privilege Level Via Call Gate to Different Privilege Level (No Parameters) From 80286 Task to 80286 TSS From 80286 Task to 80286 TSS From 80286 Task to 80286 TSS From 80286 Task to 80286 TSS From 80286 Task to 80286 TSS From 80286 Task to Am386SE CPU TSS From 80286 Task to Am386SE CPU TSS From 80286 Task to Ma386SE CPU TSS From 80286 Task to Ma386SE CPU TSS From Am386SE CPU Task to 80286 TSS From 80286 Task to Ma386SE CPU TSS From Am386SE CPU Task to 80286 TSS From Am386SE CPU Task to 80286 TSS From Am386SE CPU Task to 80286 TSS From Am386SE CPU Task to 80286 TSS From Am386SE CPU Task to 80286 TSS Till + 8+m No in | Register/Memory Indirect Within Segment | 1 1 1 1 1 1 1 1 mod 0 1 0 r/m | | | ь | h, r | | Protected Mode Only (Direct Intersegment) Via Call Gate to Same Privilege Level Via Call Gate to Different Privilege Level (No Parameters) Via Call Gate to Different Privilege Level (No Parameters) Prom 80286 Task to 80286 TSS From 80286 Task to 80286 TSS From Am386SE CPU TSS From Am386SE CPU Task to 80286 TSS Indirect Intersegment 1 1 1 1 1 1 1 1 1 1 mod 0 1 1 r/m Protected Mode Only (Indirect Intersegment) Via Call Gate to Different Privilege Level Via Call Gate to Different Privilege Level Via Call Gate to Different Privilege Level Via Call Gate to Different Privilege Level (x Parameters) From 80286 Task to 80286 TSS From 80286 Task to 80286 TSS From 80286 Task to 80286 TSS From 80286 Task to 80286 TSS From 80286 Task to 80286 TSS From Am386SE CPU Task to 80286 TSS Thi, i, k, r | - | | | | ь | i. k. r | | Via Call Gate to Same Privilege Level 64 + m h, j, k, r Via Call Gate to Different Privilege Level (No Parameters) 98 + m h, j, k, r Via Call Gate to Different Privilege Level (x Parameters) 106+8x+m h, j, k, r From 80286 Task to 80286 TSS 285 h, j, k, r From Am386SE CPU TSS 310 h, j, k, r From Am386SE CPU Task to Am386SE CPU TSS 285 h, j, k, r Indirect Intersegment 30 + m 46 + m b h, j, k, r Protected Mode Only (Indirect Intersegment) 30 + m 46 + m b h, j, k, r Via Call Gate to Same Privilege Level 68 + m h, j, k, r Via Call Gate to Different Privilege Level (No Parameters) 102 + m h, j, k, r Via Call Gate to Different Privilege Level (x Parameters) 110+8x+m h, j, k, r From 80286 Task to 80286 TSS h, j, k, r h, j, k, r From 80286 Task to Am386SE CPU TSS h, j, k, r From Am386SE CPU Task to 80286 TSS h, j, k, r h, j, k, r From Am386SE CPU Task to 80286 TSS h, j, k, r h, j, k, r | • | draighed full order, defector | | | | | | Via Cali Gate to Different Privilege Level (No Parameters) 98 + m h, j, k, r Via Cali Gate to Different Privilege Level (x Parameters) 106-8x+m h, j, k, r From 80286 Task to 80286 TSS 285 h, j, k, r From Am386SE CPU Task to 80286 TSS 310 h, j, k, r From Am386SE CPU Task to 80286 TSS 285 h, j, k, r Indirect Intersegment 30 + m 46 + m b h, j, k, r Via Cali Gate to Same Privilege Level 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | 64 + m | | h, j, k, r | | From 80286 Task to 80286 TSS From 80286 Task to Am386SE CPU TSS From M386SE CPU Task to 80286 TSS From Am386SE CPU Task to 80286 TSS From Am386SE CPU Task to Am386SE CPU TSS Indirect Intersegment 1 | Via Call Gate to Different Privilege Level ( | | | 98 + m | | | | From 80286 Task to Am386SE CPU TSS From Am386SE CPU Task to 80286 TSS From Am386SE CPU Task to 80286 TSS Indirect Intersegment 1 1 1 1 1 1 1 1 1 mod 0 1 1 r/m Protected Mode Only (Indirect Intersegment) Via Call Gate to Same Privilege Level Via Call Gate to Different Privilege Level (No Parameters) From 80286 Task to 80286 TSS From 80286 Task to Am386SE CPU TSS From Am386SE CPU Task to 80286 TSS From Am386SE CPU Task to 80286 TSS From Am386SE CPU Task to 80286 TSS From Am386SE CPU Task to 80286 TSS From Am386SE CPU Task to 80286 TSS In j, k, r In j, k, r In j, k, r In j, k, r | | x Parameters) | | r | | | | From Am386SE CPU Task to 80286 TSS From Am386SE CPU Task to Am386SE CPU TSS Indirect Intersegment 1 | | | | 1 | | | | Trom Am386SE CPU Task to Am386SE CPU TSS 392 h, j, k, r | | | | | | | | Indirect Intersegment 1 | | | | | | | | 1 1 1 1 1 1 1 mod 0 1 1 r/m | From Am386SE CPU Task to Am386SE C | PUTSS | | 392 | | h, j, k, r | | Via Call Gate to Same Privilege Level 68 + m h, j, k, r Via Call Gate to Different Privilege Level (No Parameters) 102 + m h, j, k, r Via Call Gate to Different Privilege Level (x Parameters) 110+8x+m h, j, k, r From 80286 Task to 80286 TSS h, j, k, r h, j, k, r From B0286 Task to Am386SE CPU TSS n, j, k, r n, j, k, r From Am386SE CPU Task to 80286 TSS n, j, k, r n, 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 | | Via Call Gate to Different Privilege Level (No Parameters) 102 + m h, j, k, r Via Call Gate to Different Privilege Level (x Parameters) 110+8x+m h, j, k, r From 80286 Task to 80286 TSS h, j, k, r h, j, k, r From Am386SE CPU Task to 80286 TSS h, j, k, r h, j, k, r | Protected Mode Only (Indirect Intersegment) | <del></del> | | | | | | Via Call Gate to Different Privilege Level (x Parameters) 110+8x+m h, j, k, r From 80286 Task to 80286 TSS h, j, k, r From 80286 Task to Am386SE CPU TSS h, j, k, r From Am386SE CPU Task to 80286 TSS h, j, k, r | - | | | | 1 | | | From 80286 Task to 80286 TSS h, j, k, r From 80286 Task to Am386SE CPU TSS h, j, k, r From Am386SE CPU Task to 80286 TSS h, j, k, r | | | | | | | | From 80286 Task to Am386SE CPU TSS h, j, k, r From Am386SE CPU Task to 80286 TSS h, j, k, r | | ( Parameters) | | 110+8x+m | | | | From Am386SE CPU Task to 80286 TSS h, j, k, r | | | | | | | | | | | | | | | | From Amagese CPU lask to Amagese CPU 155 | | DIL TOO | | | | | | | From Am386SE CPU Task to Am386SE 0 | PU ISS | | 399 | | n, j, k, r | <sup>\*</sup> If CPL≤IOPL \*\* If CPL>IOPL <sup>(1)</sup> Immediate 8-Bit Data | Instruction Format CONTROL TRANSFER (continued) JMP = Unconditional Jump Short | 7 + m<br>7 + m<br>9 + m /<br>14 + m | Protected Address Mode 7 + m 7 + m 9 + m / 14 + m 31 + m | Real<br>Address<br>Mode | Protected<br>Address<br>Mode<br>r<br>r | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|--------------------------------------------------------------|-------------------------|----------------------------------------------------------------------------------| | CONTROL TRANSFER (continued) JMP = Unconditional Jump Short 1 1 1 0 1 0 1 1 8-bit displacement Direct within Segment 1 1 0 1 0 0 0 1 full displacement Register/Memory Indirect Within Segment 1 1 1 1 1 1 1 1 mod 1 0 0 r/m Direct Intersegment 1 1 1 0 1 0 1 0 1 0 1 0 unsigned full offset, selector Protected Mode Only (Direct Intersegment) Via Call Gate to Same Privilege Level From 80286 Task to 80286 TSS From 80286 Task to Am386SE CPU TSS From Am386SE CPU Task to 80286 TSS | 7+m<br>9+m/<br>14+m | 7+m<br>9+m/<br>14+m | b | r | | Short 1 1 1 0 1 0 1 1 8-bit displacement Direct within Segment 1 1 1 0 1 0 0 0 1 full displacement Register/Memory Indirect Within Segment Direct Intersegment 1 1 1 1 1 1 1 1 1 1 1 mod 1 0 0 r/m Direct Intersegment 1 1 1 0 1 0 1 0 1 0 unsigned full offset, selector Protected Mode Only (Direct Intersegment) Via Call Gate to Same Privilege Level From 80286 Task to 80286 TSS From 80286 Task to Am386SE CPU TSS From Am386SE CPU Task to 80286 TSS | 7+m<br>9+m/<br>14+m | 7+m<br>9+m/<br>14+m | b | r | | Short 1 1 1 0 1 0 1 1 8-bit displacement Direct within Segment 1 1 0 1 0 0 0 1 full displacement Register/Memory Indirect Within Segment 1 1 1 1 1 1 1 1 1 mod 1 0 0 r/m Direct Intersegment 1 1 1 0 1 0 1 0 1 0 0 unsigned full offset, selector Protected Mode Only (Direct Intersegment) Via Call Gate to Same Privilege Level From 80286 Task to 80286 TSS From 80286 Task to Am386SE CPU TSS From Am386SE CPU Task to 80286 TSS | 7+m<br>9+m/<br>14+m | 7+m<br>9+m/<br>14+m | b | r | | Direct within Segment Register/Memory Indirect Within Segment Direct Intersegment 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 7+m<br>9+m/<br>14+m | 7+m<br>9+m/<br>14+m | b | r | | Register/Memory Indirect Within Segment 1 1 1 1 1 1 1 1 1 mod 1 0 0 r/m Direct Intersegment 1 1 1 0 1 0 1 0 unsigned full offset, selector Protected Mode Only (Direct Intersegment) Via Call Gate to Same Privilege Level From 80286 Task to 80286 TSS From 80286 Task to 80286 TSS From Am386SE CPU Task to 80286 TSS | 9+m/<br>14+m | 9+m/<br>14+m | b | | | Direct Intersegment Direct Intersegment 1 1 1 0 1 0 1 0 unsigned full offset, selector Protected Mode Only (Direct Intersegment) Via Call Gate to Same Privilege Level From 80286 Task to 80286 TSS From 80286 Task to Am386SE CPU TSS From Am386SE CPU Task to 80286 TSS | 14 + m | 14 + m | b | h, r | | Protected Mode Only (Direct Intersegment) Via Call Gate to Same Privilege Level From 80286 Task to 80286 TSS From 80286 Task to Am386SE CPU TSS From Am386SE CPU Task to 80286 TSS | 16 + m | 31 + m | | 1 | | Via Call Gate to Same Privilege Level From 80286 Task to 80286 TSS From 80286 Task to Am386SE CPU TSS From Am386SE CPU Task to 80286 TSS | | | | j, k, r | | | | 53 + m | | 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 | 17 + m | 31 + m | b | h, j, k, r | | Protected Mode Only (Indirect Intersegment) Via Call Gate to Same Privilege Level From 80286 Task to 80286 TSS From 80286 Task to Am386SE CPU TSS From Am386SE CPU Task to 80286 TSS From Am386SE CPU Task to Am386SE CPU TSS RET = Return from Call | | 49 + m<br>328 | | h, j, k, r<br>h, j, k, r<br>h, j, k, r<br>h, j, k, r<br>h, j, k, r<br>h, j, k, r | | | | 12 + m | ь | g, h, r | | Within Segment | | | | | | Within Segment Adding Immediate to SP 1 1 0 0 0 0 1 0 16-bit displacement | | 12 + m | ь | g, h, r | | Intersegment | ŀ | 36 + m | ь | g, h, j, k, r | | Intersegment Adding Immediate to SP 1 1 0 0 1 0 1 0 16-bit displacement | | 36 + m | ь | g, h, j, k, r | | Protected Mode Only (RET): to Different Privilege Level Intersegment | | 72 | 1 | h, j, k, r | | Intersegment Adding Immediate to SP | | 72 | | h, j, k, r | | CONDITIONAL JUMPS (Note: Times are Jump "Taken or Not Taken") | | | | | | JO = Jump on Overflow | | | | | | 8-bit Displacement | 7 + m or 3 | 7 + m or 3 | | r | | Full Displacement | 7 + m or 3 | 7 + m or 3 | | r | | JNO = Jump on Not Overflow full displacement | | | | | | 8-bit Displacement | 7 + m or 3 | 7 + m or 3 | } | r | | Full Displacement 0 1 1 1 0 0 0 1 8-bit displacement 0 0 0 0 1 1 1 1 1 0 0 0 0 0 1 tuli displacement | 7 + m or 3 | 7 + m or 3 | | r | | Undergrade in the control of con | | | | | <sup>\*</sup> If CPLSIOPL \*\* If CPL>IOPL | | | Clock Count | | Notes | | |----------------------------------------|-----------------------------------------------------|-------------------------|------------------------------|-------------------------|-----------------------------| | Instruction | Format | Real<br>Address<br>Mode | Protected<br>Address<br>Mode | Real<br>Address<br>Mode | Protecte<br>Address<br>Mode | | CONDITIONAL JUMPS (continued) | | | | | | | JB/JNAE = Jump on Below/Not Above or | Equal | | | | | | 8-bit Displacement | 0 1 1 1 0 0 1 0 8-bit displacement | 7 + m or 3 | 7 + m or 3 | | ٦ | | 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/Above or | Equal | | | | ł | | 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 | | r | | JE/JZ = Jump on Equal/Zero | | | | | 1 | | 8-bit Displacement | 0 1 1 1 0 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 0 1 0 0 full displacement | 7 + m or 3 | 7 + m or 3 | | r | | JNE/JNZ = Jump on Not Equal/Not Zero | | | | | } | | 8-bit Displacement | 0 1 1 1 0 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 0 1 0 1 full displacement | 7 + m or 3 | 7 + m or 3 | | r | | JBE/JNA = Jump on Below or Equal/Not | Above | | | | | | 8-bit Displacement | 0 1 1 1 0 1 1 0 8-bit displacement | 7 + m or 3 | 7 + m or 3 | | ŗ | | 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 or Equal/ | Above | | | | | | 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 B-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 | | | | | 1 | | 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 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 Even | | | 1 | | | | 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/Parity Od | d | | | | | | 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 | | | | | | Clock | Count | Not | es<br>I | |----------------------------------------------|-----------------------------------------------------|-------------------------|------------------------------|-------------------------|------------------------------| | Instruction | Format | Real<br>Address<br>Mode | Protected<br>Address<br>Mode | Real<br>Address<br>Mode | Protected<br>Address<br>Mode | | CONDITIONAL JUMPS (continued) | | | | | | | JL/JNGE = Jump on Less/Not Greater or | Equal | | | | | | 8-bit Displacement | 0 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 | | , | | 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 | | , | | 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 | | | | | | 6-bit Displacement | 0 1 1 1 1 1 1 0 8-bit displacement | 7 + m or 3 | 7 + m or 3 | | , | | 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 | reater | | | | | | 8-bit Displacement | 0 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 Are | 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 | 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 | | SETN8 = Set Byte on Not Below/Above o | r Equal | | | | | | To Register/Memory | 0 0 0 0 1 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 1 0 0 1 0 1 0 1 0 1 mod 0 0 0 r/m | 4/5* | 4/5* | | h | | Address Size Prefix differentiates JCXZ from | 150//2 | | | L | | <sup>\*</sup> Address Size Prefix differentiates JCXZ from JECXZ | | | Clock Count | | Notes | | |------------------------------------------|--------------------------------------------------|-------------------------|------------------------------|-------------------------|------------------------------| | Instruction | Format | Resi<br>Address<br>Mode | Protected<br>Address<br>Mode | Real<br>Address<br>Mode | Protected<br>Address<br>Mode | | CONDITIONAL BYTE SET (continued) | | | | | | | SETBE/SETNA = Set Byte on Below or Eq | usl/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 o | r 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 | 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 Parity/Parity E | | } | | | | | To Register/Memory | 0 0 0 0 1 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/P | | | | | | | 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 Gr | | • | | | | | 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 | 4/5* | 4/5* | | h | | SETNL/SETGE = Set Byte on Not Less/Gn | | | | | | | 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 | 4/5* | 4/5* | | h | | SETLE/SETNG = Set Byte on Less or Equ | <del></del> | | | | | | 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 | <u> </u> | | | | | | 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 | | "" | 40 | | " | | L = 0 | 1 1 0 0 1 0 0 0 16-bit displacement, 8-bit level | 10 | 10 | b | h | | L=1<br>L>1 | | 14<br>17 + 8 (n - 1) | 14<br>17 + 8 (n -1) | b<br>b | h<br>h | | LEAVE = Leave Procedure | | 17 + 0 (11 – 1) | 17 + 4 (11 - 17 | | " | | INTERRUPT INSTRUCTIONS | 1 1 0 0 1 0 0 1 | 4 | 4 | b | h | | INT = Interrupt: | | | | | | | Type Specified | | | | | | | Type 3 | 1 1 0 0 1 1 0 1 type | 37 | | ь | 1 | | INTO = Interrupt 4 if Overflow Flag Set | 11001100 | 33 | | ь | 1 | | If OF = 1 | 11001110 | 25 | | | | | If OF = 0 | | 35<br>3 | 3 | b, ө | | | | | | | | I | <sup>&</sup>quot; If CPLSIOPL "" If CPLSIOPL | | | Clock | Count | Notes | | | |-----------------------------------------------------------------|--------------------------------------------|-------------------------|------------------------------|-------------------------|------------------------------|--| | Instruction | Format | Real<br>Address<br>Mode | Protected<br>Address<br>Mode | Real<br>Address<br>Mode | Protected<br>Address<br>Mode | | | INTERRUPT INSTRUCTIONS (contin | ued) | | | | | | | INT = Interrupt: | | | | | | | | Type Specified | | | | | | | | Туре 3 | | | | | | | | Bound = Interrupt 5 if Detected Valu | e Out of Range 0 1 1 0 0 0 1 0 mod reg r/m | | | | | | | If Out of Range | • | 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 | · · | | 71 | | | | | Via Interrupt or Trap Gate to Differe | <del>-</del> | | 111 | | g, j, k, r<br>g, j, k, r | | | From 80286 Task to 80286 TSS via | | | 438 | | g, j, k, r | | | From 80286 Task to Am386SE CPI<br>From Am386SE CPU Task to 8028 | | | 465 | | g, j, k, r | | | From Am386SE CPU Task to Am38 | | | 440 | | g, j, k, r | | | FIGHT ANDOOSE OF O TASK to ANISC | DOSE CFU 133 VIA TASK GALE | | 467 | | g, j, k, r | | | INT: Type 3 | | | | | | | | Via Interrupt or Trap Gate to Same | Privilege Level | | | | | | | Via Interrupt or Trap Gate to Differe | | | 71 | | g, j, k, r | | | From 80286 Task to 80286 TSS via | | | 111<br>382 | | g, j, k, r | | | From 80286 Task to Am386SE CPI | | | 409 | | g, j, k, r<br>g, j, k, r | | | From Am386SE CPU Task to 8028 | | | 384 | | g, j, k, r | | | From Am386SE CPU Task to Am36 | BESE CPU ISS VIA TASK GATE | | 411 | | g, j, k, r | | | INTO | | | | | | | | Via Interrupt or Trap Gate to Same | Privilege Level | | | | | | | Via Interrupt or Trap Gate to Differe | ant Privilege Level | | 71 | | g, j, k, r | | | From 80286 Task to 80286 TSS via | Task Gate | | 111 | | g, j, k, r | | | From 80286 Task to Am386SE CPI | | | 384 | | g, j, k, r | | | From Am386SE CPU Task to 8028 | | | 328 | | g, j, k, r | | | From Am386SE CPU Task to Am38 | B6SE CPU TSS via Task Gate | | Am386DE<br>413 | | g, j, k, r<br>g, j, k, r | | | BOUND | | | | | 9,,,,,,, | | | Via Interrupt or Trap Gate to Same | Privilege Level | | | | | | | Via interrupt or Trap Gate to Differe | | | 71 | | g, j, k, r | | | From 80286 Task to 80286 TSS via | Task Gate | | 111 | | g, j, k, r | | | From 80286 Task to Am386SE CPI | U TSS via Task Gate | | 358 | | g, j, k, r | | | | | | 388 | | g, j, k, r | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - 1 | | | | | | | | 1 | | | | | | | | - 1 | | | | | | | | - 1 | | | | | | | | 1 | | | | | | | | I | | | | | | | | | | 1 | 1 | | | | | Clock | Count | Not | es | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|--------------------------------------|--------------------------------------|-------------------------|--------------------------------------------------------------------------------| | Instruction | Format | Reel<br>Address<br>Mode | Protected<br>Address<br>Mode | Real<br>Address<br>Mode | Protected<br>Address<br>Mode | | INTERRUPT INSTRUCTIONS (continued) | | | | | | | BOUND (continued) From Am386SE CPU Task to 80286 TS: From Am386SE CPU Task to Am386SE | | | 368<br>398 | | 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,i | | Protected Mode Only (IRET) Via Interrupt or Trap Gate to Same Privi Via Interrupt or Trap Gate to Different Pr From 80286 Task to 80286 TSS From 80286 Task to Am386SE CPU TS From Am386SE CPU Task to 80286 TS From Am386SE CPU Task to Am386SE | rivilege Level (within Task)<br>S<br>S | | 42<br>86<br>285<br>318<br>328<br>377 | | g,h,j,k,r<br>g,h,j,k,r<br>h, j, k, r<br>h, j, k, r<br>h, j, k, r<br>h, j, k, r | | PROCESSOR CONTROL | | | | | | | HLT = Halt | 1 1 1 1 0 1 0 0 | 5 | 5 | | 1 | | 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 0 1 0 1 1 eee reg | 10/4/5 | 10/4/5 | | ' | | Register from CR3CR0 | 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 | | | | 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 | | ţ | | 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 | | NOP = No Operation | 10010000 | 3 | 3 | | 1 | | WAIT = Wait until BUSY pin is negated | | 6 | 6 | | 1 | | PROCESSOR EXTENSION INSTRUCTIO | | | | | | | Processor Extension Escape | 1 1 0 1 1 T T T mod L L L r/m TTT and LLL bits are op-code information for coprocessor. | See 387SX<br>Data sheet<br>for clock | 1 | | h | | PREFIX BYTES | | counts | | İ | | | Address Size Prefix | 0 1 1 0 0 1 1 1 | 0 | 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | • | | Clock | Count | No | tes | |--------------------------------------------|-----------------------------------------------|-------------------------|------------------------------|-------------------------|------------------------------| | Instruction | Format | Real<br>Address<br>Mode | Protected<br>Address<br>Mode | Real<br>Address<br>Mode | Protected<br>Address<br>Mode | | PREFIX BYTES (continued) | | | | | | | LOCK = Bus Lock Prefix | 11110000 | 0 | 0 | | m | | Operand Size Prefix | 01100110 | 0 | 0 | | | | Segment Override Prefix | | | | | | | cs | 0 0 1 0 1 1 1 0 | 0 | 0 | | | | DS | 0 0 1 1 1 1 1 0 | 0 | 0 | | | | ES | 0 0 1 0 0 1 1 0 | 0 | 0 | | | | FS | 0 1 1 0 0 1 0 0 | 0 | 0 | | | | GS | 0 1 1 0 0 1 0 1 | 0 | 0 | | | | SS | 0 0 1 1 0 1 1 0 | 0 | 0 | | | | PROTECTION CONTROL | | | | | | | ARPL = Adjust Requested Privilege Lev | rel | | | | | | From Register/Memory | 0 1 1 0 0 0 1 1 mod reg r/m | N/A | 20/21** | а | 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, i | | LIDT = Load Interrupt Descriptor | | | | ; | | | Table Register | 0 0 0 0 1 1 1 1 0 0 0 0 0 0 1 mod 0 1 1 r/m | 11* | 11* | b, c | h, l | | LLDT = Load Local Descriptor | | | | | | | Table Register 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* | 8 | 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, 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 | mocing initial | N/A | 20/21* | a | g, h, j, p | | LTR = Load Task Register | | N/A | 25/26* | а | g, h, j, p | | 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 | 3 3 3 3 1 1 1 1 3 3 3 3 3 3 3 1 mod 3 3 1 mm | | | | J | | 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 | 00001111 0000001 mod 000 mm | | | , | | | | | | | | _ | | 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 | | | | | | | | | * If CPL ≤ IOPL ** If CPL > IOPL | | | | | | | | <del></del> | Clock | Count | Not | es | |-----------------------------------------|-----------------------------------------------|-------------------------|------------------------------|-------------------------|------------------------------| | Instruction | Format | Real<br>Address<br>Mode | Protected<br>Address<br>Mode | Real<br>Address<br>Mode | Protected<br>Address<br>Mode | | PROTECTION CONTROL (continued) | | | | | | | SLDT = Store Local Descriptor Table Reg | ister | | | | | | 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 1 mod 1 0 0 r/m | 2/2* | 2/2* | b, c | h, I | | STR = Store Task Register | | | | | | | To 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 | 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 | 0 0 0 0 1 1 1 1 0 0 0 0 0 0 0 0 mod 1 0 1 t/m | N/A | 15/16* | a | g, h, j, p | | "If CPL ≤ OPL " If CPL > OPL | | | | | | ### **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 Address Mode: d. The Am386SE 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 | ml]$ , 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. - q. LOCK is asserted during descriptor table accesses. #### Notes h through r apply to Protected Address Mode only: - 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. - . 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 - 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 field of the flag register is 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 Am386SE Microprocessor Instruction Set Clock Count Summary Table (pages 72 thru 86). 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 48 illustrates several of the fields that can appear in an instruction, such as the mod field and the r/m field. but Figure 48 does not show all fields. Several smaller fields also appear in certain instructions, sometimes within the op-code bytes themselves. Table 19 is a complete list of all fields appearing in the Instruction Set. Further ahead, following Table 19, are detailed tables for each field. #### 32-Bit Extensions of the Instruction Set With the Am386SE 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, no code segment descriptors are used, but a D value of 0 is assumed internally by the Am386SE CPU when operating in this mode (for 16-bit default sizes compatible with the 8086/80186/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 **Table 19. Fields Within Instructions** | Field<br>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/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 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 | Note: Table 19 shows encoding of individual instructions. Figure 48. General Instruction Format 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 is16 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. 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 | CX | 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 reg Field<br>During 16-Bit Data Operations | | | | |------------------------------------------------------------------|---------------------------|----|--| | | Function of w Field | | | | reg | (when w = 0) (when w = 1) | | | | 000 | AL | AX | | | 001 | CL | cx | | | 010 | DL | DX | | | 011 | BL | вх | | | 100 | AH | SP | | | 101 | CH | 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) | | | | 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 Am386SE 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 48) 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. #### Encoding of 16-Bit Address Mode with mod r/m Byte | 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] | | 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:[Sl + 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 | RegisterSee Below | | 11 111 | Register—See Below | | | 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 | cx | | | | 11 010 | DL | DX | | | | 11 011 | BL | вх | | | | 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 | вн | EDI | # Encoding of 32-Bit Address Mode with mod r/m Byte (no s-i-b byte present) | 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] | | 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 During 32-Bit Data Operations | | | |----------------------------------------------------------------|--------------|--------------| | Function of w Field | | 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 | CH | EBP | | 11 110 | DH | ESI | | 11 111 | вн | EDI EDI | | Register Specified by reg or 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 | | ## Encoding of 32-Bit Address Mode (mod r/m byte and s-i-b byte present): | 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] | | | , | | ss | Scale Factor | |----|--------------| | 00 | x1 | | 01 | <b>x</b> 2 | | 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. ## Note: Mod field in mod r/m byte; ss, index, and 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 | |----------|----------------------------------------------------------------| | | Register/Memory ← Register | | 0 | reg Field indicates Source Operand; | | | mod r/m or mod ss index base indicates Destination<br>Operand. | | $\vdash$ | Register ← Register/Memory | | 1 | reg Field indicates Destination Operand: | | | 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. | 8 | Effect on<br>Immediate Data8 | Effect on<br>Immediate Data 16l32 | |---|----------------------------------------------------------|-----------------------------------| | 0 | None | None | | 1 | Sign-Extended Data8 to Fill 16-Bit or 32-Bit Destination | 140116 | ## Encoding of Conditional Test (tttn) Field For the conditional instructions (conditional jumps and set on condition), ttn 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 a | Do not use any other encoding | | | | ## When Interpreted as Test Register Field | eee Code | ee Code Reg Name | | | | |-------------------------------|------------------|--|--|--| | 110 | TR6 | | | | | 111 | TR7 | | | | | Do not use any other encoding | | | | | ## PHYSICAL DIMENSIONS For reference only. All dimensions measured in inches unless otherwise noted. BSC is an ANSI standard for Basic Space Centering. ## PQB 100—Plastic Quad Flat Pack; Trimmed and Formed 20010A CL85 08/04/93 MH #### Notes: - All measurements are in inches unless otherwise noted. - 2. Not to scale. For reference only. ## PQT 100-Metric Thin Quad Flat Pack-Plastic Package; Trimmed and Formed #### Notes: - 1. All measurements are in millimeters unless otherwise noted. - 2. Not to scale. For reference only. # PQT 100 (continued) #### Notes: 1. Not to scale. For reference only. AMD and Am386 are registered trademarks of Advanced Micro Devices, Inc. Microsoft at Work is a trademark of Microsoft Corp. Product names used in this publication are for identification purposes only and may be trademarks of their respective companies. | North American | | | International (Continued) | | | |-------------------------|-----------------------------------------|-------------------|----------------------------------------------------------------------------------------------------|----------------|------------------------------| | ALABAMA(205) 882-9122 | | LATIN AMERICA. | | | | | | | (602) 242-4400 | Ft. Lauderdale | | (305) 484-8600 | | CALIFORNIA, | | | | FAX | (305) 485-9736 | | | | (310) 645-1524 | SINGAPORE | | (65) 3481188 | | | | (714) 752-6262 | | FAX | (65) 348016 | | | | (916) 786-6700 | SWEDEN, | | | | San Diego | | | Stockholm area | TEL | (08) 98 61 80 | | San Jose(408) | | | (Bromma) | FAX | (08) 98 09 00 | | Woodland Hills(81 | | (818) 878-9988 | TAIWAN, Taipei | TEL | (886) 2-7153536 | | CANADA, Ontario, | | | | FAX | (886) 2-7122183 | | Kanata | | (613) 592-0060 | UNITED KINGDOM, | | | | Willowdale | | (416) 222-7800 | Manchester area | TEL | (0925) 830380 | | COLORADO(30 | | | | | 1 1 | | CONNECTICUT | | | London area | TEL | (0925) 83020<br>(0483) 74044 | | FLORIDA. | *************************************** | | (Woking) | FAX | (0483) 75619 | | | | (813) 530-9971 | ( | | , , , | | | | (407) 361-0050 | North American Representatives | | | | | | (407) 862-9292 | | ш.,ор.оо. | | | , , | * | | CANADA | | | | | | (404) 449-7920 | Burnaby, B.C DAVETEK MARKETING (604) 430-36 | | | | | | (208) 377-0393 | | | NICS (613) 592-006 | | ILLINOIS, | | | Mississauga, Onta | | | | | | (708) 773-4422 | VITEL ELECTRONICS(905) 564-9720 | | | | | | (708) 505-9517 | Lachine, Quebec – VI | TEL ELECTRON | ICS (514) 636-595 | | | | (301) 381-3790 | ILLINOIS | | | | | | (617) 273-3970 | Skokie – INDUSTR | | | | | | (612) 938-0001 | REPRESENTATIVE | ES, INC | (708) 967-843 | | NEW JERSEY, | | | IOWA | | | | | | (609) 662-2900 | LORENZ SALES | | (319) 377-4666 | | Parsippany | | (201) 299-0002 | KANSAS | | ` ' | | NEW YORK, | | | Merriam – LORENZ SALES(913) 469-131 | | | | | | (914) 279-8323 | | | (316) 721-0500 | | Rochester | ****** | (716) 425-8050 | MEXICO | . 071220 | | | NORTH CAROLINA | | , . | | IIKA ELECTRON | ICA (619) 498-834 | | | Charlotte(704) 875- 3091 | | Chula Vista - SONIKA ELECTRONICA (619) 498-8344<br>Guadalajara - SONIKA ELECTRONICA (523) 647-4256 | | | | Raleigh (919) 878- 8111 | | | Mexico City – SONIKA ELECTRONICA (523) 754-6480 | | | | OHIO. | | (0,12, 0.10 0.1.1 | | | | | | (ille) | (614) 891-6455 | | KA ELECTRUNIC | DA (523) 358-928 | | Columbus (Westerville) | | MICHIGAN | | | | | OREGON (503) | | | Holland - COM-TEK SALES, INC (616) 335-841 | | | | | | | | EK SALES, INC. | (313) 227-000 | | | | (215) 398-8006 | MINNESOTA | | | | TEXAS. | | (510) 046 7000 | Mel Foster Tech. S | Sales, Inc | (612) 941-979 | | Austin | | | MISSOURI | | | | | | | LORENZ SALES(314) 997-4558 | | | | Houston(713) 376-8084 | | NEBRASKA | | | | | International | | | LORENZ SALES | | (402) 475-466 | | | | | NEW MEXICO | | ` ' | | BELGIUM, Antwerpen TEL | | | | RT STATES | (505) 883-434 | | | | (03) 248 46 42 | NEW YORK | | | | FRANCE, Paris | | (1) 49-75-10-10 | | YCOM, INC | (315) 437-834 | | | FAX | (1) 49-75-10-13 | Hauppauge – CON | APONENT | | | GERMANY, | | | CONSULTANTS | NC. | (516) 273-505 | | Bad Homburg | | (06172)-24061 | OHIO | ., | | | | | (06172)-23195 | | ELISS DOOT . C | O (513) 433-677 | | München | | (089) 45053-0 | | | 0(216) 899-937 | | | | (089) 406490 | | JOS ROUT & CC | (210) 899-937 | | | | (852) 865-4525 | PENNSYLVANIA | N 00 IN0 | /410) 010 050 | | Wanchai | FAX | (852) 865-4335 | | K CO.,INC | (412) 242-950 | | ITALY, Milano | TEL | (02) 3390541 | PUERTO RICO | | | | | FAX | (02) 38103458 | | C, INC | (809) 746-655 | | JAPAN, | | • • | UTAH | | | | | TEL | (03) 3346-7550 | | ARKETING | (801) 288-250 | | • | FAX | (03) 3342-5196 | WASHINGTON | | | | Osaka | TEL | (06) 243-3250 | ELECTRA TECHN | ICAL SALES | (206) 821-744 | | | FAX | (06) 243-3253 | WISCONSIN | | . , | | KODEA Cooul | | (82) 2-784-0030 | Brookfield - INDUS | STRIAL | | | NOREA, Secul | | | | | (414) 574-939 | 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. One AMD Place, P.O. Box 3453, Sunnyvale, CA 9408B-3453, USA Tel: (408) 732-2400 • TWX: 910-339-9280 • TELEX: 34-6306 • TOLL FREE: (800) 538-8450 APPLICATIONS HOTLINE & LITERATURE ORDERING • TOLL FREE: (800) 222-9323 • (408) 749-5703 © 1994 Advanced Micro Devices, Inc. 18420B 4/7/94 Con-8M-6/94-0 Printed in USA