• Aucun résultat trouvé

LITERATURE To order Intel literature or obtain literature pricing information

N/A
N/A
Protected

Academic year: 2022

Partager "LITERATURE To order Intel literature or obtain literature pricing information"

Copied!
922
0
0

Texte intégral

(1)
(2)

LITERATURE

To order Intel literature or obtain literature pricing information in the U.S. and Canada call or write Intel Literature Sales. In Europe and other international locations, please contact your local sales office or distributor.

INTEL LITERATURE SALES P.O. Box 7641

Mt. Prospect, IL 60056-7641

In the U.S. and Canada call toll free

(800) 548-4725

This 800 number is for external customers only.

CURRENT HANDBOOKS

Product line handbooks contain data sheets, application notes, article reprints and other design information. All handbooks can be ordered individually, and most are available in a pre-packaged set in the U.S. and Canada.

Title

SET OF FOURTEEN HANDBOOKS (Available in U.S. and Canada)

CONTENTS LISTED BELOW FOR INDIVIDUAL ORDERING:

CONNECTIVITY

EMBEDDED MICROCONTROLLERS EMBEDDED MICROPROCESSORS FLASH MEMORY (2 volume set) MICROPROCESSORS, VOL. 1:

InteI386'· 80286 & 8086 MICROPROCESSORS MICROPROCESSORS, VOL. 2:

InteI486'· MICROPROCESSORS MICROPROCESSORS, VOL. 3:

PENTIUM'· PROCESSORS

i750®, i860'·, i960® PROCESSORS AND RELATED PRODUCTS OEM BOARDS, SYSTEMS & SOFTWARE

PACKAGING

PERIPHERAL COMPONENTS PRODUCT OVERVIEW PROGRAMMABLE LOGIC NETWORKING

ADDITIONAL LITERATURE:

(Not included in handbook set) AUTOMOTIVE PRODUCTS

COMPONENTS QUALITY/RELIABILITY CUSTOMER LITERATURE GUIDE EMBEDDED APPLICATIONS (1993/94) INTERNATIONAL LITERATURE GUIDE (Available in Europe only)

MILITARY AND SPECIAL PRODUCTS (2 volume set) SYSTEMS QUALITY/RELIABILITY

Intel

Order Number ISBN

231003 N/A

231658 1-55512-202-7

270646 1-55512-203-5

272396 1-55512-204-3

210830 1-55512-214-0

230843 1-55512-196-9

241731 1-55512-197-7

241732 1-55512-198-5

272084 1-55512-217-5

280407 1-55512-201-9

240800 1-55512-208-6

296467 1-55512-207-8

210846 N/A

296083 1-55512-206-X

297360 1-55512-220-5

231792 1-55512-212-4

210997 1-55512-132-2

210620 N/A

270648 1-55512-179-9

EOO029 N/A

210461 1-55512-213-2

231762 1-55512-046-6

(3)

u.s. and CANADA LITERATURE ORDER FORM

NAME: ______________________________________________

~

COMPANY: _______________________________________ _ ADDRESS: ____________________________________________ _ CITY: _________________________ STATE: _ _ _ ZIP: ____ _ COUNTRY: _______________________________ __

PHONE NO.:

~

__

~

____________________________________ _

ORDER NO

Include postage:

Must add 15% of Subtotal to cover U.S.

and Canada postage. (20% all other.)

TITLE QTV. PRICE TOTAL

x

=

x

=

x

=

x

=

x

--- =

x

=

x

=

x

=

x

=

x

=

Subtotal.

Must Add Your Local Sales Tax

) Postage Total

Pay by check, money order, or include company purchase order with this form ($200 minimum). We also accept VISA,. MasterCard or American Express. Make payment to Intel Literature Sales. Allow 2-3 weeks for delivery.

D VISA D MasterCard D American Express Expiration Date _ _ _ _ _ _ _ _ _ _ _ _ _ Account No. _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ __

Signature _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ Mail To: Intel Literature Sales

P.O. Box 7641

Mt. Prospect, IL 60056-7641

International Customers outside the U.S. and Canada should use the International order form on the next page or contact their local Sales Office or Distributor.

For phone orders in the U.S. and Canada, call Toll Free: (800) 548-4725 or FAX to (708) 296-3699. Please print clearly in ink to expedite your order.

Prices good until 12/31/94.

Source HB

(4)

INTERNATIONAL LITERATURE ORDER FORM NAME:

COMPANY: ____________________________________________ _ ADDRESS:

~

__________________________________________ _ CITY: _________________________ STATE: _ _ _ ZIP:

COUNTRY: ____________________________________________ _ PHONE NO.:

~

__

~

____________________________________ __

ORDER NO TITLE QTY. PRICE TOTAL

x =

x =

x =

x =

x =

x =

x =

x =

x =

x =

Subtotal Must Add Your Local Sales Tax Total

PAYMENT

Cheques should be made payable to your local Intel Sales Office (see inside back cover).

Other forms of payment may be available in your country. Please contact the Literature Coordinator at your local Intel Sales Office for details.

The completed form should be marked to the attention of the LITERATURE COORDINATOR and returned to your local Intel Sales Office.

(5)

\NTEl. 1

-rCT/-- , /} /}

c;>

z

o

Founded in 1968 to pursue the integration of large numbers of transistors onto tiny silicon chips, Intel's history has been marked by a remarkable number of scientific breakthroughs and innovations. In 1971, Intel introduced the 4004, the first microprocessor. Containing 2300 transistors, this first commercially-available computer on a chip is considered primitive compared with today's million-plus transistor products.

Innovations such as the microprocessor, the erasable program- mable read-only memory (EPROM) and the dynamic random access memory (DRAM) revolutionized electronics by making integrated circuits the mainstay of both consumer and business computing products.

Over the last two and a half decades, Intel's business has evolved and today the company's focus is on delivering an extensive line of component, module and system-level building block products to the computer industry. The company's product line covers a broad spectrum, and includes microprocessors, flash memory, microcontrol- lers, a broad line of PC enhancement and local area network products, multimedia technology products, and massively parallel supercomputers. Intel's 32-bit X86 architecture, represented by the InteI386T>' and Intel486™ microprocessor families, are the de facto standard of modern business computing and installed in millions of PCs worldwide.

Intel has over 25,000 employees located in offices and manufac- turing facilities around the world. Today, Intel is the largest semicon- ductor company in the United States and the second largest in the world.

(6)

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

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

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

MDS is an ordering code only and is not used as a product name or trademark of Intel Corporation.

Intel Corporation and Intel's FASTPATH are not affiiiated with Kinetics, a division of Excelan, Inc. or its FASTPATH trademark or products.

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

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

Intel Corporation Literature Sales P.O. Box 7641

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

©INTEL CORPORATION. 1993

(7)

Intel486™ MICROPROCESSOR FAMILY PROGRAMMER'S REFERENCE MANUAL

1992

(8)
(9)

TABLE OF CONTENTS

CHAPTER 1

INTRODUCTION TO THE

Intel486™ MICROPROCESSOR FAMILY Page

1.1 ORGANIZATION OF THIS MANUAL ... 1-2 1.1.1 Part I-Application Programming ... ... ... 1-3 1.1.2 Part II-System Programming ... 1-3 1.1.3 Part 111-Numeric Processing ... 1-4 1.1.4 Part IV - Compatibility ... ... ... ... .... ... ... 1-5 1.1.5 Part V-Instruction Set ... ,... 1-6 1 .1.6 Appendices ... 1-6 1.2 RELATED LITERATURE ... 1-6 1.3 NOTATIONAL CONVENTIONS ... 1-7 1.3.1 Bit and Byte Order ... : ... 1-7 1.3.2 Undefined Bits and Software Compatibility ... ... ... ... 1-8 1.3.3 Instruction Operands ... ... ... ... ... ... ... 1-8 1.3.4 Hexadecimal Numbers ... 1-9 1.3.5 Segmented Addressing ... ... ... ... ... 1-9 1.3.6 Exceptions ... ... ... ... ... 1-9

PART I-APPLICATION PROGRAMMING CHAPTER 2

BASIC PROGRAMMING MODEL

2.1 MEMORY ORGANIZATION ... 2-1 2.1.1 Unsegmented or "Flat" Model ... 2-3 2.1.2 Segmented Model... ... ... ... ... ... 2-3 2.2 DATA TYPES ... 2-3 2.3 REGISTERS ... :... 2-8 2.3.1 General Registers ... ... ... ... .... 2-8 2.3.2 Segment Registers ... 2-10 2.3.3 Stack Implementation .. ... ... ... 2-12 2.3.4 Flags Register ... ... ... 2-13 2.3.4.1 STATUS FLAGS ... 2-13 2.3.4.2 CONTROL FLAG .. ... ... ... ... 2-13 2 .. 3.4.3 INSTRUCTION POINTER ... 2-14 2.4 INSTRUCTION FORMAT ... '... 2-15 2.5 OPERAND SELECTION ... 2-17 2.5.1 Immediate Operands ... ;... 2-18 2.5.2 Register Operands ... ... 2-19 2.5.3 Memory Operands ... ... ... 2-19 2.5.3.1 SEGMENT SELECTION ... 2-20 2.5.3.2 EFFECTIVE-ADDRESS COMPUTATION ... 2-20 2.6 INTERRUPTS AND EXCEPTIONS ... 2-23 CHAPTER 3

APPLICATION PROGRAMMING

3.1 DATA MOVEMENT INSTRUCTIONS ... 3-1 3.1.1 General-Purpose Data Movement Instructions ... ... ... ... 3-1 3.1.2 Stack Manipulation Instructions . ... ... ... 3-2 3.1.3 Type Conversion Instructions ... 3-4

(10)

int:e L

TABLE OF CONTENTS

Page 3.2 BINARY ARITHMETIC INSTRUCTIONS ... ... 3-6 3.2.1 Addition and Subtraction Instructions ... 3-7 3.2.2 Comparison and Sign Change Instruction ... 3-8 3.2.3 Multiplication Instructions ... 3-8 3.2.4 Division Instructions ... ... 3-9 3.3 DECIMAL ARITHMETIC INSTRUCTIONS ... 3-10 3.3.1 Packed BCD Adjustment Instructions ... ... 3-10 3.3.2 Unpacked BCD Adjustment Instructions ... 3-10 3.4 LOGICAL INSTRUCTIONS ... :... 3-11 3.4.1 Boolean Operation Instructions ... 3-11 3.4.2 Bit Test and Modify Instructions ... 3-12 3.4.3 Bit Scan Instructions ... 3-12 3.4.4 Shift and Rotate Instructions ... ... 3-13 3.4.4.1 SHIFT INSTRUCTIONS ... 3-13 3.4.4.2 DOUBLE-SHIFT INSTRUCTIONS ... 3-14 3.4.4.3 ROTATE INSTRUCTIONS ... 3-16 3.4.4.4 FAST "bit bit" USING DOUBLE-SHIFT INSTRUCTIONS ... 3-19 3.4.4.5 FAST BIT STRING INSERT AND EXTRACT ... 3-20 3.4.5 Byte-Set-On-Condition Instructions ... ... ... ... ... 3-23 3.4.6 Test Instruction ... 3-23 3.5 CONTROL TRANSFER INSTRUCTIONS ... 3-23 3.5.1 Unconditional Transfer Instructions ... 3-23 3.5.1.1 JUMP INSTRUCTION ... 3-23 3.5.1.2 CALL INSTRUCTIONS .... ... ... ... ... ... 3-24 3.5.1.3 RETURN AND RETURN-FROM-INTERRUPT INSTRUCTIONS ... 3-24 3.5.2 Conditional Transfer Instructions ... 3-25 3.5.2.1 CONDITIONAL JUMP INSTRUCTIONS ... ,... 3-25 3.5.2.2 LOOP INSTRUCTIONS ... 3-26 3.5.2.3 EXECUTING A LOOP OR REPEAT ZERO TIMES ... ;... 3-26 3.5.3 Software Interrupts ... ... ... 3-27 3.6 STRING OPERATIONS ... ,... 3-27 3.6.1 Repeat Prefixes ... ... 3-28 3.6.2 Indexing and Direction Flag Control... 3-29 3.6.3 String Instructions ... ... 3-30 3.7 INSTRUCTIONS FOR BLOCK-STRUCTURED LANGUAGES ... 3-30 3.8 FLAG CONTROL INSTRUCTIONS ... ... 3-37 3.8.1 Carry and Direction Flag Control Instructions ... 3-37 3.8.2 Flag Transfer Instructions ... 3-37 3.9 NUMERIC INSTRUCTIONS .. ... ... 3-39 3.10 SEGMENT REGISTER INSTRUCTIONS ... 3-39 3.10.1 Segment-Register Transfer Instructions ... 3-40 3.10.2 Far Control Transfer Instructions ... 3-40 3.10.3 Data Pointer Instructions ... ;... 3-40 3.11 MISCELLANEOUS INSTRUCTIONS ... 3-41 3.11.1 CPUJD Detection Code ... ... 3-46 3.11.2 Address Calculation Instruction ... ... 3-46 3.11.3 No-Operation Instruction ... 3-46 3.11.4 Translate Instruction ... ... ... 3-46 3.11.5 Byte Swap Instruction ... ;... 3-46 3.11.6 Exchange-and-Add Instruction ... ;... 3-47 3.11.7 Compare-and-Exchange Instruction ... ,... ... 3-47

(11)

intel®

TABLE OF CONTENTS

PART II-SYSTEM PROGRAMMING CHAPTER 4

SYSTEM ARCHITECTURE Page

4.1 SYSTEM REGISTERS ... 4-1 4.1.1 System Flags ... ~... 4-2 4.1.2 Memory-Management Registers ... ... .... ... ... ... ... ... ... ... .... 4-4 4.1.3 Control Registers ... ... ... .... ... ... .... ... ... ... ... ... ... 4-5 4.1.4 Debug Registers ... ... ... ... ... .... ... ... ... ... ... ... ... ... 4-8 4.1.5 Test Registers ... 4"8 4.2 SYSTEM INSTRUCTIONS ... 4-9 CHAPTER 5

MEMORY MANAGEMENT

5.1 SELECTING A SEGMENTATION MODEL ... 5-3 5.1.1 Flat Model ... : ... ,... 5-3 5.1.2 Protected F=lat Model.. ... ... ... .... ... ... ... ... ... ... ... ... ... ... ... 5-4 5.1.3 Multi-Segment Model... ... ... ... ... ... ... ... .... ... .... .... ... .... 5-4 5.2 SEGMENT TRANSLATION ... :... 5-5 5.2.1 Segment Registers ... 5-7 5.2.2 Segment Selectors .. ... .... ... ... .... ... .... .... ... ... ... ... .... ... ... ... 5-8 5'.2.3 Segment Descriptors ... ; •... :... 5-10 5.2.4 Segment Descriptor Tables ... ... .... ... .... ... ... .... ... ... .... ... ... .... 5-15 5.2.5 Descriptor Table Base Registers ... : ... :. 5-16 5.3 Page Translation ... :... 5-17 5.3.1 PG Bit Enables Paging ... :... 5-18 5.3.2 Linear Address ... :... 5-18 5.3.3 Page Tables ... 5-19 5.3.4 Page-Table Entries ... 5-20 5.3.4.1 PAGE FRAME ADDRESS ... 5-20 5.3.4.2 PRESENT BIT ... 5-20 5.3.4.3 ACCESSED AND DIRTY BITS ... ;... 5-21 5.3.4.4 READ/WRITE AND USER/SUPERVISOR BITS ... 5-22 5.3.4.5 PAGE-LEVEL CACHE CONTROL BITS ... ;... 5-22 5.3.5 Translation Lookaside Buffer ... .... ... ... .... ... ... ... ... ... ... ... 5-22 5.4 COMBINING SEGMENT AND PAGE TRANSLATION ... 5-23 5.4.1 Flat Model ... ,... 5-23' 5.4.2 Segments Spanning Several Pages ... , ... ;... 5-24 5.4.3 Pages Spanning Several Segments ... ,... 5-24 5.4.4 Non-Aligned Page and Segment Boundaries .. ,... 5-24 5.4.5 Aligned Page and Segment Boundaries ... .... ... ... ... ... ... .... ... ... .... ... .... 5-24 5.4.6 Page-Table Per Segment ... 5-24 CHAPTER 6

PROTECTION

6.1 SEGMENT-LEVEL PROTECTION ... 6-1 6.2 SEGMENT DESCRIPTORS AND PROTECTION ... 6-2 6.2.1 Type Checking ... ;.... 6-3 6.2.2 Limit Checking ... 6-4 6.2.3 Privilege Levels .. ... ... ... ... ... ... ... ... ... ... ... ... .... ... 6-5 6.3 RESTRICTING ACCESS TO DATA ... 6-7 6.3.1 Accessing Data in Code Segments .. ... .... ... ... ... ... ... ... .... 6-8 6.4 RESTRICTING CONTROL TRANSFERS ... 6-9 6.5 GATE DESCRiPTORS· ... 6-11

(12)

TABLE OF CONTENTS

Page 6.5.1 Stack Switching ... ... ... ... ... ... ... ... ... ... 6-13 6.5.2 Returning from a Procedure .... ... ... ... ... ... 6~ 17 6.6 INSTRUCTIONS RESERVED FOR THE OPERATING SYSTEM ... ;... 6-19 6.6.1 Privileged Instructions ... ,... 6-19 6.6.2 Sensitive Instructions ... 6-19 6.7 INSTRUCTIONS FOR POINTER VALIDATION ... 6-20 6.7.1 Descriptor Validation ... 6-21 6.7.2 Pointer Integrity and RPL ... : ... ,... 6-22 6.8 PAGE-LEVEL PROTECTION ... 6-22 6.8.1 Page-Table Entries Hold Protection Parameters ... 6-23 6.8.1.1 RESTRICTING ADDRESSABLE DOMAIN ... 6-23 6.8.1.2 TYPE CHECKING ... 6-24 6.8.2 Combining Protection of Both Levels of Page Tables ... ... ... ... ... . 6-24 6.8.3 Overrides to Page Protection ... ;... 6-24 6.9 COMBINING PAGE AND SEGMENT PROTECTION ... 6-25 CHAPTER 7

MULTITASKING .

7.1 TASK STATE SEGMENT ... :... 7-2 7.2 TSS DESCRIPTOR ... :... 7-4 7.3 TASK REGISTER ... 7-5 7.4 TASK GATE DESCRIPTOR ... 7-5 7.5 TASK SWITCHING ... ,... 7-8 7.6 TASK LINKING ... ' 7-10 7.6.1 Busy Bit Prevents Loops ... , ... ;... 7-10 7.6.2 Modifying Task Linkages ... , 7-13 7.7 TASK ADDRESS SPACE ... ,... 7-13 7.7.1 Task Linear-to-Physical Space Mapping ... ~... 7-14 7.7.2 Task Logical Address Space ... : ... ,... 7-14 CHAPTER 8

INPUT/OUTPUT

8.1 I/O ADDRESSING ... , ... ,... 8-1 8.1.1 I/O Address Space ... , ... ... ... 8-2 8.1.2 Memory-Mapped I/O ... , ... , ... ,... 8-3 8.2 I/O INSTRUCTIONS ... ,... 8-4 8.2.1 Register I/O .Instructions ... 8-4 8.2.2 Block I/O Instructions ... 8-5 8.3 PROTECTION AND I/O ... ;... 8-6 8.3.1 1/0·Privilege Level ... ,... 8-6 8.3.2 I/O Permission Bit Map ... , ... , ... ,... 8-7 CHAPTER 9

EXCEPTIONS AND INTERRUPTS

9.1 EXCEPTION AND INTERRUPT VECTORS ... ;... 9-1 9.2 INSTRUCTION RESTART ... 9-2 9.3 ENABLING AND DISABLING INTERRUPTS ... 9-3 9.3.1 NMI Masks Further NMls ... ,.... 9-3 9.3.2 IF Masks INTR ... 9-3 9.3.3 !;IF Masks Debug Faults ... :... 9-4 9.3.4 MOV or POP to SS Masks Some Exceptions and Interrupts ... ;... 9-4 9.4 PRIORITY AMONG SIMULTANEOUS EXCEPTIONS AND INTERRUPTS ... 9-5 9.5 INTERRUPT DESCRIPTOR TABLE ... ,... 9-5

(13)

intel®

TABLE OF CONTENTS

Page 9.6 IDT DESCRIPTORS ... 9-7 9.7 INTERRUPT TASKS AND INTERRUPT PROCEDURES ... 9-7 9.7.1 Interrupt Procedures ... 9-7 9.7.1.1 STACK OF INTERRUPT PROCEDURE ... '... 9-10 9.7.1.2 RETURNING FROM AN INTERRUPT PROCEDURE ... 9-11 9.7.1.3 FLAG USAGE BY INTERRUPT PROCEDURE ... ~ ... 9-11 9.7.1.4 PROTECTION IN INTERRUPT PROCEDURES ... 9-11 9.7.2 Interrupt Tasks ... 9-12 9.8 ERROR CODE ... 9-13 9.9 EXCEPTION CONDITIONS ... 9-14 9.9.1 Interrupt O-Divide Error ... ,... 9-14 9.9.2 Interrupt 1 - Debug Exceptions ... ... ... 9-14 9.9.3 Interrupt3-Breakpoint ... , ... ;.... 9-15 9.9.4 Interrupt 4-0verflow ... 9-15 9.9.5 Interrupt 5 - Bounds Check .... ... ... ... ... ... ... 9-15 9.9.6 Interrupt 6-lnvalid Opcode ... ,... 9-15 9.9.7 Interrupt 7 - Device Not Available ... ... 9-16 9.9.8 Interrupt 8-Double Fault ... 9-17 9.9.9 Interrupt 9-(lntel reserved. Do not use.) ... 9-18 9.9.10 Interrupt 10-lnvalid TSS ... 9-18 9.9.11 Interrupt 11 - Segment Not Present ... ... 9-19 9.9.12 Interrupt 12-Stack Exception .... , ... , ... , ... ,... 9-20 9.9.13 Interrupt 13 - General Protection ... ... 9-20 9.9.14 Interrupt 14- Page Fault ... 9-21 9.9.14.1 PAGE FAULT DURING TASK SWITCH ... 9-23 9.9.14.2 PAGE FAULT WITH INCONSISTENT STACK POINTER ... ,... 9-23 9.9.15 Interrupt 16 - Floating-Point Error ... ... 9-24 9.9.16 Interrupt 17 -Alignment Check ... ,... 9-24 9.10 EXCEPTION SUMMARY ... 9-25 9.11 ERROR CODE SUMMARY ... 9-25 CHAPTER 10

INITIALIZATION

10.1 PROCESSOR STATE AFTER RESET ... 10-1 10.2 Intel486 SX MICROPROCESSOR/lnteI487 SX MATH COPROCESSOR

INITIALIZATION ... 10-3 10.3 SOFTWARE INITIALIZATION IN REAL-ADDRESS MODE ... 10-5 10.3.1 System Tables ... , ... , ... 10-5 10.3.2 NMI Interrupt ... : ... 10-5 10.3.3 First Instruction ... ... ... ... ... ... ... 10-5 10.3.4 Enabling Caching ... , ... , ... 10-5 10.4 SWITCHING TO PROTECTED MODE ... ... 10-6 10.4.1 System Tables ... ... ... 10-6 10.4.2 NMI Interrupt ... 10-6 10.4.3 PE Bit ... ... ... 10-6 10.5 SOFTWARE INITIALIZATION IN PROTECTED MODE ... 10-6 10.5.1 Segmentation ... , ... , ... 10-7 10.5.2 Paging ... ;.; ... ; ... 10-7 10:5.3 Tasks. ... ... ... ... 10-7 10.6 TLB TESTING... ... 10-8 10.6.1 Structure of the TLB .. ... ... 10-8 10.6.2 Test Registers ... 10-9 10.6.3 Test Operations ... : ... 10-11

(14)

TABLE OF CONTENTS

Page 10.7 CACHE TESTING ... , ... 10-12 10.7.1 Structure of the Cache ... ; ... 10-12 10.7.2 Test Registers ... 10-13 10.7.3 Test Operations ... 10-15 10.8 INITIALIZATION EXAMPLE ... ; ... 10-16 CHAPTER 11

DEBUGGING

11.1 DEBUGGING SUPPORT ... 11-1 11.2 DEBUG REGISTERS ...•...•... .... 11-2 11.2.1 Debug Address Registers (DRO-DR3) ...•... 11-2 11.2.2 Debug Control Register (DR7) .... ... ... ... ... ... ... ... 11-2 11.2.3 Debug Status Register (DR6) ...•...•... 11-4 11.2.4 Breakpoint Field Recognition ... 11-5 11.3 DEBUG EXCEPTIONS ... 11-6 11.3.1 Interrupt 1 - Debug Exceptions ... 11-6 11.3.1.1 INSTRUCTION-BREAKPOINT FAULT ... 11-6 11 .3.1.2 DATA-BREAKPOI NT TRAP ... ... .... ... .... ... .... .... ... ... 11-7 11.3.1.3 GENERAL-DETECT FAULT ... 11-7 11.3.1.4 SINGLE-STEP TRAP ... : ...•... ; ... 11-8 11.3.1.5 TASK-SWITCH TRAP ... , ... 11-8 11.3.2 Interrupt 3 - Breakpoint Instruction ... ;... 11-8 CHAPTER 12

CACHING

12.1 INTRODUCTION TO CACHING ... 12-1 12.2 OPERATION OF THE INTERNAL CACHE ... 12-2 12.2.1 Cache Disabling Bits .. ... ... 12-2 12.2.2 Cache·Management Instructions ... 12-3 12.2.3 Self-Modifying Code ... 12-3 12.3 PAGE-LEVEL CACHE MANAGEMENT ... 12-3 12.3.1 Cache Management Bits ... ... 12-4 12.3.1.1 PCD BIT ... ·12-4 12.3.1.2 PWT BIT ... ... ... ... ... 12-4 CHAPTER 13

MULTIPROCESSING

13.1 LOCKED AND PSEUDO-LOCKED BUS CYCLES ... ; ... 13-1 13.1.1 LOCK Prefix and the LOCK# Signal ... ;; ... 13-2 13.1.2 Automatic Locking ... 13-3 13.1.3 Pseudo-Locking ... ; ... : ... 13-3

PART 111-NUMERIC PROCESSING

CHAPTER 14

INTRODUCTION TO NUMERIC APPLICATIONS

14.1 HISTORY ... 14-1 14.2 PERFORMANCE ... ... ... 14-2 14.3 EASE OF USE ... 14-3 14.4 APPLICATIONS ... : ... 14-4 14.5 PROGRAMMING INTERFACE ... ... 14-5

(15)

infel®

TABLE OF CONTENTS CHAPTER 15

ARCHITECTURE OF THE FLOATING-POINT UNIT Page

15.1 NUMERICAL REGISTERS ... 15-1 15.1.1 The FPU Register Stack ... ... ... 15-1 15.1.2 The FPU Status Word ... ... ... ... 15-2 15. '1.3 Control Word ... ... ... ... ... 15-5 15.1.4 The FPU Tag Word ... .' ... 15-6 15.1.5 Opcode Field of Last Instruction ... 15-7 15.1.6 The Numeric Instruction and Data Pointers ... 15-8 15.2 COMPUTATION FUNDAMENTALS ... 15-9 15.2.1 Number System ... 15-10 15.2.2 Data Types and Formats ... 15-12 15.2.2.1 BINARY INTEGERS ... 15-13 15.2.2:2 DECIMAL INTEGERS ... 15-13 15.2.2.3 REAL NUMBERS ... 15-13 15.2.3 Rounding Control... ... ... ... 15-16 15.2.4 Precision Control... ... ... ... ... ... ... 15-17 CHAPTER 16

SPECIAL COMPUTATIONAL SITUATIONS

16.1 SPECIAL NUMERIC VALUES ... 16-1 16.1.1 Denormal Real Numbers ... 16-1 16.1.1.1 DENORMALS AND GRADUAL UNDERFLOW... ... 16-4 16.1.2 Zeros ... ... 16-6 16.1.3 Infinity... ... ... ... 16-8 16.1.4 NaN (Not-a-Number) ... : ... 16-8 16.1.4.1 SIGNALING NaNs ... 16-10 16.1.4.2 QUIET NaNs ... 16-11 16.1.5 Indefinite ... 16-12 16.1.6 Encoding of Data Types .... ... 16-13 16.1.7 Unsupported Formats ... 16-13 16.2 NUMERIC EXCEPTIONS ... 16-18 16.2.1 Handling Numeric Exceptions.. ... ... ... ... 16-19 16.2.1.1 AUTOMATIC EXCEPTION HANDLING ... 16-19 16.2.1.2 SOFTWARE EXCEPTION HANDLING ... 16-20 16.2.2 Invalid Operation ... ... ... ... ... 16-21 16.2.2.1 STACK EXCEPTION ... ... ... ... ... 16-21 16.2.2.2 INVALID ARITHMETIC OPERATION ... 16-22 16.2.3 Division by Zero ... ... ... ... ... ... 16-22 16.2.4 Denormal Operand ... ... 16-23 16.2.5 Numeric Overflow and Underflow .. ... ... ... 16-24 16.2.5.1 OVERFLOW... ... ... ... ... 16-24 16.2.5.2 UNDERFLOW ... 16-26 16.2.6 Inexact (Precision) ... ; ... 16-27 16.2.7 Exception Priority... ... ... ... ... 16-27 16.2.8 Standard Underflow/Overflow Exception Handler ... 16-28 CHAPTER 17

FLOATING-POINT INSTRUCTION SET

17.1 SOURCE AND DESTINATION OPERANDS ... 17-1 17.2 DATA TRANSFER INSTRUCTIONS ... 17-2 17.3 NONTRANSCENDENTAL INSTRUCTIONS ... 17-2 17.4 COMPARISON INSTRUCTIONS ... 17-4

(16)

infel®

TABLE OF CONTENTS

Page 17.S TRANSCENDENTAL INSTRUCTIONS ... 17-S 17.6 CONSTANT INSTRUCTIONS ... 17-6 17.7 CONTROL INSTRUCTIONS ... 17-7 CHAPTER 18

NUMERIC APPLICATIONS

18.1 PROGRAMMING FACILITIES ... 18-1 18.1.1 High-Level Languages ... ... ... ... ... 18-1 18.1.2 C Programs c ... 18-1 18.1.3 PL/M-386/486 ... ... ... ... 18-2 18.1.4 ASM386/486 ... ... ... ... 18-4 18.1.4.1 DEFINING DATA ... 18-4 18.1.4.2 RECORDS AND STRUCTURES ... 18-S 18.1.4.3 Addressing Methods ... : ... 18-6 18.1.S Comparative Programming Example ... 18-7 18.2 CONCURRENT PROCESSING ... 18-12 18.2.1 Managing Concurrency '" ... 18-12 18.2.1.1 INCORRECT EXCEPTION SYNCHRONIZATION ... 18-13 18.2.1.2 PROPER EXCEPTION SYNCHRONIZATION ... 18-14 CHAPTER 19

SYSTEM-LEVEL CONSIDERATIONS

19.1 ARCHITECTURE ... ... 19-1 19.1.1 Independent of Addressing Mode ... ... ... 19-1 19.2 PROCESSOR INITIALIZATION AND CONTROL ... 19"1 19.2.1 System Initialization ... 19-2 19.2.2 Configuring the Numerics Environment ... 19-2 19.2.3 Initializing the .FPU ... 19-2 19.2.3.1 Intel486 DX CPU SOFTWARE EMULATION ... 19-3 19.2.3.2 Intel486 SX CPU SOFTWARE EMULATION PROCEDURE ... 19-3 19.2.4 Handling Numerics Exceptions ... ... 19-4 19.2.S Simultaneous Exception Response ... 19-5 19.2.6 Exception Recovery Examples ... ... 19-5 CHAPTER 20

NUMERIC PROGRAMMING EXAMPLES

20.1 CONDITIONAL BRANCHING EXAMPLE ... ; ... 20-1 20.2 EXCEPTION HANDLING EXAMPLES ... 20-2 20.3 FLOATING-POINT TO ASCII CONVERSION EXAMPLES ... 20-7 20.3.1 Function Partitioning ... 20-7 20.3.2 Exception Considerations ... 20-7 20.3.3 Special Instructions ... 20-21 20.3.4 Description of Operation ... 20-21 20.3.S Scaling the Value ... 20-22 20.3.S.1 INACCURACY IN SCALING ... ; ... 20-22 20.3.S.2 AVOIDING UNDERFLOW AND OVERFLOW ... 20-23 20.3.S.3 FINAL ADJUSTMENTS ... 20-23 20.3'.6 Output Format ... 20-23 20.4 TRIGONOMETRIC CALCULATION EXAMPLES ... : .... 20-23

(17)

intel®

TABLE OF CONTENTS

PART IV-COMPATIBILITY CHAPTER 21

EXECUTING 286 AND Intel386 DX OR SX CPU PROGRAMS Page

21.1 TWO WAYS TO RUN 2S6 CPU TASKS ... 21-2 21.2 DIFFERENCES FROM 2S6 CPU ... 21-2 21.2.1 Wraparound of 2S6 Processor 24-Bit Physical Address Space ... 21-2 21.2.2 Reserved Word of Segment Descriptor ... 21-2 21.2.3 New Segment Descriptor Type Codes ... : ... 21-3 21.2.4 Restricted Semantics of LOCK Prefix ... 21-3 21.2.S Additional Exceptions ... ... ... 21-3 21.3 DIFFERENCES FROM Intel3S6 CPU ... 21-4 21.3.1 New Flag ... ... ... ... ... 21-4 21.3.2 New Exception ... 21-4 21.3.3 New Instructions ... ... ... ... ... 21-4 21.3.4 New Control Register Bits ... ; ... 21-S 21.3.S New Page-Table Entry Bits ... 21-S 21.3.6 Changes in Segment Descriptor Loads ... 21-S CHAPTER 22

REAL-ADDRESS MOPE

22.1 ADDRESS TRANSLATION ... 22-1 22.2 REGISTERS AND INSTRUCTIONS ... 22-2 22.3 INTERRUPT AND EXCEPTION HANDLING ... : ... 22-3 22.4 ENTERING AND LEAVING REAL-ADDRESS MODE ... 22-4 22.4.1 Switching to Protected Mode ... ... 22-4 22.S SWITCHING BACK TO REAL-ADDRESS MODE ... ; ... 22-4 22.6 REAL-ADDRESS MODE EXCEPTIONS ... : ... 22-S 22.7 DIFFERENCES FROM SOS6 CPU ... 22-S 22.S DIFFERENCES FROM 2S6 CPU IN REAL-ADDRESS MODE ... 22-9 22.S.1 Bus Lock ... ... 22-10 22.S.2 Location of First Instruction ... 22-10 22.S.3 Initial Values of General Registers ... 22-10 22.S.4 Bus Hold ... 22-11 22.S.S Math Coprocessor Differences ... 22-11 22.9 DIFFERENCES FROM Intel3S6 DX CPU IN REAL-ADDRESS MODE ... 22-11 22.10 PROCESSOR DETECTION CODE ... 22-11 CHAPTER 23

VIRTUAL-8086 MODE

23.1 EXECUTING SOS6 CPU CODE ... 23-1 23.1.1 Registers and Instructions ... ... ... ... 23-1 23.1.2 Address Translation ... 23-2 23.2 STRUCTURE OF A VIRTUAL-SOS6 TASK ... 23-3 23.2.1 Paging for Virtual-SOS6 Tasks ... ... 23-4 23.2.2 Protection within a Virtual-SOS6 Task ... 23-S 23.3 ENTERING AND LEAVINGVIRTUAL-SOS6 Mode ... 23-S 23.3.1 Transitions Through Task Switches ... ... 23-6 23.3.2 Transitions Through Trap Gates and Interrupt Gates ... 23-7 23.4 ADDITIONAL SENSITIVE INSTRUCTIONS ... 23-S 23.4.1 Emulating SOS6 Operating System Calls ... 23-9 23.4.2 Emulating the Interrupt-Enable Flag ... 23-9 23.S VIRTUAL I/O ... 23-9 23.S.1 I/O-Mapped I/O ... ... ... ... ... ... 23-10

(18)

inteL

TABLE OF CONTENTS

Page 23.5.2 Memory-Mapped I/O ... ... ... ... ... 23-10 23.5.3 Special I/O Buffers ... ... ... ... ... ... .... 23-10 23.6 DIFFERENCES FROM 8086 CPU ... 23-11 23.7 DIFFERENCES FROM 286 CPU IN REAL-ADDRESS MODE ... 23-14 23.7.1 Privilege Level ... ; ... " 23-14 23.7.2 Bus Lock ... 23-14 23.8 DIFFERENCES FROM Intel386 DX AND SX CPUs ... 23-15 CHAPTER 24

MIXING 16-BIT AND 32-BIT CODE

24.1 USING 16-BIT AND 32-BIT ENVIRONMENTS ... , ... ; ... 24-2 24.2 MIXING 16-BIT AND 32-BIT OPERATIONS ... 24-2 24.3 SHARING DATA AMONG MIXED-SIZE CODE SEGMENTS ... 24-3 24.4 TRANSFERRING CONTROL AMONG MIXED-SIZE CODE SEGMENTS ... 24-4 24.4.1 Size of Code-Segment Pointer ... ; ... 24-4 24.4.2 Stack ManagemenUor Control Transfers ... 24-5 24.4.2.1 CONTROLLING THEOPERAND SIZE FOR A CALL ... 24-6 24.4.2.2 CHANGING SIZE OF A CALL ... 24-6 24.4.3 Interrupt Control Transfers ... 24-7 24.4.4 Parameter Translation ... ... 24-7 24.4.5 The Interface Procedure ... : ... 24-7 CHAPTER 25

COMPATIBILITY WITH THE 8087, Intel287 AND Intel387 MATH COPROCESSORS 25.1 DIFFERENCES FROM Intel386 CPU/lntel387 NPX SYSTEMS ... 25-1 25.2 DIFFERENCES FROM 286/lnte1287 SYSTEMS ... 25-2 25.2.1 Data Types and Exception Handling ... 25-3 25.2.2 Tag, Status, and Control Words ... ; ... 25-6 25.2.3 Instruction Set ... 25-8 25.3 DIFFERENCES FROM 8086/8087 SYSTEMS ... 25-11

CHAPTER 26 INSTRUCTION SET

PART V -INSTRUCTION SET

26.1 OPERAND-SIZE AND ADDRESS-SIZE ATTRIBUTES ... 26-1 26.1.1 Default Segment Attribute ... ... ... ... 26~ 1 26.1.2 Operand-Size and Address-Size Instruction Prefixes ... 26-1 26.1.3 Address-Size Attribute for Stack ... 26-2 26.2 INSTRUCTION FORMAT ... " 26-2 26.2.1 ModR/M and SIB Bytes ... 26-3 26.2.2 How to Read the Instruction Set Pages ... 26-8 26.2.2.1 OPCODE COLUMN ... 26-8 26.2.2.2 INSTRUCTION COLUMN ... 26-9 26.2.2.3 CLOCKS COLUMN ... : .... " ... 26-11 26.2.2.4 DESCRIPTION COLUMN ... " ... 26-12 26.2.2.5 OPERATION ... 26-12 26.2.2.6 DESCRIPTION ... : ... 26-16 26.2.2.7 FLAGS AFFECTED ... ... ... 26-16 26.2.2.8 PROTECTED MODE EXCEPTIONS ... ... ... 26-17 26.2.2.9 REAL ADDRESS MODE EXCEPTIONS ... ~ 26-17

(19)

intel®

TABLE OF CONTENTS

Page 26.2.2.10 VIRTUAL-8086 MODE EXCEPTIONS ... 26-17 AAA ... 26-18 AAD ... 26-19 AAM ... 26-20 AAS ... 26-21 ADC ... 26-22 ADD ... 26-24 AND ... 26-26 ARPL ... 26-27 BOUND ... 26-29 BSF ... 26-31 BSR ... 26-33 BSWAP ... 26-35 BT ... 26-36 BTC ... 26-38 BTR ... 26-40 BTS ... 26-42 CALL ... 26-44 CBW/CWDE ... 26-51 CLC ... : ... 26-52 CLD ... 26-53 CLI ... 26-54 CLTS ... 26-55 CMC ... 26-56 CMP ... 26-57 CMPS/CMPSB/CMPSW/CMPSD ... 26-59 CMPXCHG ... ... 26-62 CWD/CDQ ... ... 26-64 DAA ... 26-65 DAS ... 26-66 DEC ... 26-67 DIV ... 26-68 ENTER ... 26-70 F2XM1 ... 26-72 FABS ... 26-74 FADD/FADDP/FIADD ... 26-75 FBLD ... 26-77 FBSTP ... 26-79 FCHS ... 26-80 FCLEX/FNCLEX ... ... ... ... ... 26-81 FCOM/FCOMP/FCOMPP ... 26-82 FCOS ... 26-84 FDECSTP ... ~ ... 26-86 FDIV/FDIVP/FIDIV ... 26-87 FDIVR/FDIVPR/FIDIVR ... ... ... ... ... ... 26-89 FFREE ... 26-91 FICOM/FICOMP ... 26-92 FILD ... 26-94 FINCSTP ... ... ... 26-96 FINIT/FNINIT ... 26-97 FIST/FISTP ... 26-99 FLD ... 26-101

(20)

intel®

TABLE OF CONTENTS FLD1/FLDL2T/FLDL2E/

Page FLDPI/FLDLG2/FLDLN2/FLDZ ... , ... 26-103 FLDCW ... : ... 26-105 FLDENV ... 26-107 FMUL/FMULP/FIMUL ... 26-109 FNOP ... 26-111 FPATAN ... : ... 26~112

FPREM ... 26-113 FPREM1 ... 26-115 FPTAN ... 26-117 FRNDINT ... 26-119 FRSTOR ... 26-120 FSAVE/FNSAVE ... 26-122 FSCALE ... , 26-124 FSIN ... 26-125 FSINCOS ... 26-127 FSQRT ... ; ... 26-l29 FST/FSTP ... 26"130 FSTCW/FNSTCW ... 26-132 FSTENV/FNSTENV ... : ... 26-133 FSTSW/FNSTSW ... 26-135 FSUB/FSUBP/FISUB ... , ... ; ... 26-137 FSUBR/FSUBPR/FISUBR ... , ... 26-1.39 FTST ... 26-141 FUCOM/FUCOMP/FUCOMPP ... 26-143 FWAIT ... 26-145 FXAM ... ... ... ... ... ... ... ... ... ... ... ... ... 26-146 FXCH ... 26-148 FXTRACT ... : ... : ... 26-150 FYL2X ... ... 26-152 FYL2XP1 ... ... ... ... ... ... ... 26-154 HLT ... 26-156 IDIV ... 26~157 IMUL ... 26-159 IN ... : ... ; ... 26-161 INC ... 26-163 INS/INSB/INSW/INSD ... ~ ... : 26-164 INT/INTO ... 26-166 INVD ... 26-171 INVLPG ... 26-172 IRET/IRETD ... ' 26-173 Jcc ... 26-178 JMP ... : ... 26-182 LAHF ... 26-187 LAR ... : ... : ... 26-188 LEA ... 26-190 LEAVE ... ' ... ·26-192 LGDT/LIDT ... : ... 26-193 LGS/LSS/LDS/LES/LFS ... 26-195 LLDT ... ,26-198 LMSW ... ;. 26~200 LOCK ... ; ... 26-201 LODS/LODSB/LODSW/LODSD ... 26-203

(21)

infel®

TABLE OF CONTENTS

Page LOOP/LOOPeond ... 26-205 LSL ... 26-207 LTR ... 26-209 MOV ... 26-210 MOV ... ; ... 26-212 MOVS/MOVSB/MOVSW/MOVSD ... 26-214 MOVSX ... ... ... ... ... ... ... ... 26-216 MOVZX ... ... ... ... ... ... ... 26-217 MUL ... 26-218 NEG ... 26-220 NOP ... 26-221 NOT ... 26-222 OR ... 26-223 OUT ... 26-225 OUTS/OUTSB/OUTSW/OUTSD ... 26-227 POP ... 26-230 POPNPOPAD ... 26-233 POPF/POPFD ... 26-235 PUSH . ... .... ... ... ... ... ... ... ... ... ... ... ... ... ... ... .... ... .... 26-236 PUSHNPUSHAD ... ... ... ... ... ... ... ... ... .... ... ... ... ... ... ... 26-238 PUSHF/PUSHFD ... 26-240 RCL/RCR/ROL/ROR ... 26-241 REP/REPE/REPZ/REPNE/REPNZ ... ; ... 26-244 RET ... 26-247 SAHF ... : ... 26-251 SAL/SAR/SHL/SHR ...•... 26-252 SBB ... 26-255 SCAS/SCASB/SCASW/SCASD ... 26-257 SETee ... 26-259 SGDT/SIDT ... 26-261 SHLD .. ... .... ... .... ... ... ... ... ... .... ... ... ... ... ... ... 26-263 SHRD . ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... 26-265 SLDT .... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... 26-267 SMSW .. ... ... ... ... ... ... ... ... ... ... ... ... ... .... ... ... 26-268 STC ... 26-269 STD ... 26-270 STI ... 26-271 STOS/STOSB/STOSW/STOSD ... 26-272 STR ... 26-274 SUB ... 26-275 TEST ... : ... 26-277 VERR, VERW .... ... ... ... ... ... ... ... 26"278 WAIT ... : ... 26-280 WBINVD ... 26-281 XADD ... , ... 26-282 XCHG ...•... : ... 26-284 XLAT/XLATB ... 26-285 XOR ... 26-287

(22)

TABLE OF CONTENTS

APPENDIX A OPCODE MAP APPENDIX B

FLAG CROSS-REFERENCE APPENDIX C

STATUS FLAG SUMMARY APPENDIX D

CONDITION CODES APPENDIX E

INSTRUCTION FORMAT AND TIMING APPENDIX F

NUMERIC EXCEPTION SUMMARY APPENDIX G

CODE OPTIMIZATION APPENDIX H

REVISION HISTORY GLOSSARY

INDEX

APPENDICES

Figures

Figure Title Page

1-1 Bit and Byte Order ... ; .. ; .... ;... 1-7 2-1 Segmented Addressing .: ... :... 2-4 2-2 Fundamental Data Types ... ; ... :... 2-5 2-3 Bytes, Words, and Doublewords in Memory ... ;... 2-5 2-4 Data Types ... 2~7 2-5 Application Register Set ... :... 2-9 2-6 An Unsegmented Memory ... ... ... ... ... ... ... ... ... 2-10 2-7 A Segmented Memory ... : ... : ... : ... :... 2-11 2-8 Stacks ... ; ... : ... :...2-l3 2-9 EFLAGS Register ... :... 2~14 2-10 Effective Address Computation ... :... 2-21 3-1 PUSH Instruction ... ; ... : ... ;... 3-2 3-2 PUSHA Instruction ... , ... : ... : ... :... 3-3 3-3 POP Instruction ... ... ... ... ... ... ... ... 3-4 3-4 POPA Instruction ... 3-5 3-5 Sign Extension .... ... ... ... ... ... ... ... ... ... ... 3-5 3-6 SHLJSAL Instruction ... 3-14 3-7 SHR Instruction ... 3-15

(23)

int:et

TABLE OF CONTENTS

Figure 3-8 3-9 3-10 3-11 3-12 3-13 3-14 3-15 3-16 3-17 3-18 3-19 3-20 3-21 3-22 3-23 3-24 4-1 4-2 4-3 4-4 4-5 5-1 5-2 5-3 5-4 5-5 5-6 5-7 5-8

5~9

5-10 5-11 5-12 5-13 5-14 5-15 5-16 5-17 6-1 6-2 ' 6-3 6-4 6-5 6-6 6c7 6-8 6-9 6-10 7-1

Figures

Title

SAR Instruction ... . SHLD Instruction ... . SHRD Instruction ... . ROL Instruction ... . ROR Instruction ... . RCL Instruction ... . RCR Instruction ... . Formal Definition of the ENTER Instruction ... . Nested Procedures ... . Stack Frame After Entering MAIN ... . Stack Frame After Entering PROCEDURE A ... . Stack Frame After Entering PROCEDURE B ... . Stack Frame After Entering PROCEDURE C ... . Low Byte of EFLAGS Register ... . Flags Used with PUSHF and POPF ... . CPUJD, MCPJD Detection Code ... . ASCII Arithmetic Using BSWAP ... ; ... . System Flags ... . Memory Management Registers ... . Control Registers ... . Debug Registers ... . Test Registers ... . Flat Model ... : ... . Protected Flat Model ... . Multi-Segment Model ... . TI Bit Selects Descriptor Table ... ..

Segment Translation ... . Segment Registers ... . Segment Selector ... . Segment Descriptors ... . Segment Descriptor (Segment Not Present) ... . Descriptor Tables ... , ... . Pseudo-Descriptor Format ... . Format of a Linear Address ... ..

Page Translation ... : ... . Format of a Page Table Entry ... , .... . Format of a Page Table Entry for a Not-Present Page ... ..

Combined Segment and Page Address Translation ... . Each Segment Can Have Its Own Page Table ... ..

Descriptor Fields Used for Protection ... ..

Protection Rings ... . Privilege Check for Data Access ... ..

Privilege Check for Control Transfer Without Gate ... ..

Call Gate ... . Call Gate Mechanism ... . Privilege Check for Control Transfer with Call Gate ... . Initial Stack Pointers in a TSS ... ..

Stack Frame During Interlevel Call ... . Protection Fields of a Page Table Entry ... ..

Task State Segment ... ..

Page 3-15 3-16 3-17 3-18 3-18 3-18 3-19 3-32 3-33 3-34 3-35 3-35 3-36 3-38 3-38 3-42 3-48 4-2 4-4 4-5 4-8 4-9 5-3 5-5 5-6 5-8 5-9 5-9 5-10 5-11 5-14 5-15 5-16 5-19 5-19 5-20 5-21 5-23 5-25 .6-2 6-7 6-8 6-10 6-11 6-12 6-14 6-15 6-17 6-23 7-3

(24)

int:e L

TABLE OF CONTENTS

Figure 7-2 7-3 7-4 7-5 7c6 7-7 8-1 8"2.

9-1 9-2 9'3 9'4 9-.5 9-6 9-7 10-1 10-2 10-3 10-4 10-5 10-6 11-1

14~1

15-1 15-2 15-3 15-4 15-5 15-6 15-7 15-8 15-9 15-10 15-11 16-1 16-2 16-3 16-4 18-1 18-2 18-3 18-4 18"5 18-6 18-7

Figures

Title

TSS Descriptor ... : ... . TR Register ... : ... : ... : ... . Task Gate Descriptor ... : ... . Task. Gates Reference Tasks ... , ... ; ... . Nested Tasks ... . Overlapping Linear-to-Physical Mappings ... . Memory-Mapped I/O ...•...•...

I/O Permission Bit Map ... : ... . IDTR Register Locates IDT in Memory ... . . IDT Gate Descriptors ... . ,.Interrupt Procedure Call ... ; ... ; ... : ... . Stack Frame After Exception or Interrupt ... : ... ~ ... . Interrupt Task.Switch ... ; ... ; ... : ... . Error Code ... : ... ~ ... . Page Fault Error Code ... : ... ;; ... : ... . Contents of the EDX Register After Reset ... . Contents of theCRO Register After Reset ... : ... ; ... . TLB Structure ... . TLB Test Registers ... : ... . . Cache Structure ... i •••••••••••

Cache Test.Registers ... : ... . Debug Registers ... . Evolution and Performance of Numeric Processors ... : ... . Intel486™ FPU Register Set ... , ... . InteI486™ .. FPU Status Word ... . InteI486~~ FPU Control Word.Format ... . Tag Word Format ... , ... : ... ; ..

Opcode Field ... . Protected Mode Numeric Instruction .and Data Pointer Image in

Memory, 32-Bit Format ... : ... . Real Mode Numeric Instruction and Data Pointer Image in Memory;

32-Bit Format ...•.. : ... : ..

Protected Mode Numeric Instruction and Data Pointer Image in Memory, i6-Bit Format ... . Real Mode Numeric Instruction and Data Pointer Image in Memory,

.16-Bit Format ... : ... : .. . Double-Precisio(l Number System" ... ..

Numerical Data Formats ... : ... ; ... ; ... .

Floating~Point System with Denormals ... ..

Floating-Point System without Denormals ... ..

Arithmetic Example Using Infinity ... ..

Coprocessor Detection Code ... j ... ; ••••

Sample C-386/486 Program ... : ... : ... : ..

Sample Numeric Constants ... ;;.: ... ..

.Status. Word Record Definition ... , ... , ... . Str.ucture Definition ... ~ .. : ... ..

Sample PLlM-386/486 Program ... , ... ; ... ..

Sample ASM386/486 Program ... , .. . .Instructions and Register Stack ... .

Page 7-4 7-6 7-7 7-8 7-12 7"15 8-3 8-7 9-6 9-8 9-9 9-10 9-12 9-13 9-22 10-2 . 10-2 10-9 10-10 10-13 10-14 11-3 14-2 15-2 15-3 15-6 15-7 15-7 15-8 15-9 15-9 15-10 15-11 15-12

16-5 16-5 16-20 16-24 18-2 18-5 18-6 18-6.

18-8 18-9 18-11

(25)

infel®

TABLE OF CONTENTS

Figure 18-8 20-1 20-2 20-3 20-4 20-5 20-6 20-7 20-8 22-1 22-2 23-1 23-2 23-3 24-1 26-1 26-2 26-3 26-4

Figures

Title

Exception Synchronization Examples ... . Conditional Branching for Compares ... . Conditional Branching for FXAM ... . Full-State Exception Handler ... ; ... . Reduced-Latency Exception Handler ... . Reentrant Exception Handler ... . Floating-Point to ASCII Conversion Routine ... . Relationships Between Adjacent Joints ... ~ ..

Robot Arm Kinematics Example ... . 8086 Address Translation ... . Real-Address Detection Code ... . 8086 Address Translation ... . Entering and Leaving Virtual-B086 Mode ... ..

Privilege Level 0 Stack After Interrupt in Virtual-8086 Mode ... . Stack After Far 16- and 32-Bit Calls ... . Intel486™ Processor Instruction Format ... . ModR/M and SIB Byte Formats ... . Bit Offset for BIT[EAX, 21] ... . Memory Bit Indexing ... ..

Tables

Page 18-14 20-2 20-3 20-4 20-5 20-6 20-8 20-24 20-26 22-2 22-12 23-3 23-5 23-7 24-5 26-2 26-4 26-15 26-16

Table Title Page

2-1 Register Names .. ... ... ... ... 2-8 2-2 Status Flags ... ... ... ... ... 2-14 2-3 Default Segment Selection Rules ... ... ... ... ... 2-20 2-4 Exceptions and Interrupts ... :... 2-24 3-1 Operands for Division ... 3-9 3-2 Bit Test and Modify Instructions ... 3-12 3-3 Conditional Jump Instructions... 3-25 3-4 Repeat Instructions ... 3-29 3-5 Flag Control Instructions ... 3-37 5-1 Application Segment Types ... ... ... ... ... ... 5-12 6-1 System Segment and Gate Types ... ... ... ... ... 6-4 6-2 I nterlevel Return Checks ... ... ... ... ... ... 6-18 6-3 Valid Descriptor Types for LSL Instruction ... ... ... ... 6-21 6-4 Combined Page Directory and Page Table Protection ... 6-25 7-1 Checks Made during a Task Switch ... 7-11 7-2 Effect of a Task Switch on Busy, NT, and Link Fields ... 7-12 9-1 Exception and Interrupt Vectors ... 9-2 9-2 Priority Among Simultaneous Exceptions and Interrupts ... 9-5 9-3 I ntel Reserved Opcodes ... : ... ;... 9-16 9-4 Interrupt and Exceptions Classes ... 9-17 9-5 Invalid TSS Conditions ... 9-18 9-6 Alignment Requirements by DataType ... 9-24 9-7 Exception Summary ... 9-26 9-8 Error Code Summary .. ... ... ... ... ... ... ... 9-27

(26)

Table 10-1 10-2 10-3 10-4 10-5 11-1 11-2 12-1 14~1 14-2 14-3 15-1 15-2 15-3 15-4 15-5 16-1 16-2 16-3 16-4 16-5 16-6 16-7 16-8 16-9 16-10 16-11 16-12 17-1 17-2 17-3 17-4 17-5 17-6 17-7 17-8 18-.1 18~2 18-3 19-1 22-1 22-2 26-1 . 26-2·

26-3 26-4 26-5 26-6

TABLE OF CONTENTS

Tables

Title

Processor State Following Power-Up ... ; ... . Recommended Values of the FP Related Bits fm lI'teI486'· SX

Microprocessor/lntel487'M SX Math CoProcessor System ... ~ ... ~ ... . EM and MP Bits Interpretations ... ; .. ; ... . Meaning of Bit Pairs in the TR6 Register ... ;; ... ; ... . Encoding of Cache Test Control Bits ...•...

Breakpointing Examples ... ; .. : ... ; ... ~ ... . Debug Exception Conditions ... ; ... . Cache Operating Modes ... : ...•...

Numeric Processing Speed Comparisons ... . Numeric. Data Types ... ; ... ; .. . Principal Numeric Instructions· ... : ... . Condition Code Interpretation ... : ... . Correspondence Between FPU and IU Flag Bits ... ; ...•...

Summary of Format Parameters ... ; ... ; ... ; ... . Real Number Notation ... : ... : ... . Rounding Modes ... ; ... . Arithmetic and Nonarithmetic Instructions ... . Denormalized Values ... ; ... . Zero Operands and Results ... . Infinity Operands and Results ... . Rules for Generating QNaNs ... . Binary Integer Encodings ... . Packed Decimal Encodings ... . Single and Double Real Encodings ... . Extended Real Encodings ... . Unsupported Formats ... . Masked Response to Invalid Operations ... . Masked Overflow Results ... : ...•... , ... . Data Transfer Instructions ... . Nontranscendental Instructions (Besides Basic Arithmetic) ... . Basic Arithmetic Instructions and Operands ...•... : ... . Comparison Instructions ... . TEST Constants for Conditional Branching ... ; ... . Transcendental ·Instructions ...•...

Constant Instructions ... : ... . Control Instructions ... : ... : ... . PL/M-386/486 Built-In Procedures· ... : .. . ASM386/486 Storage Allocation Directives ... : ... ..

Addressing Method Examples ... : ... : ... : ... . . FPU State Following Initialization ... , ... ..

Exceptions and Interrupts ... . New Intel486'M CPU Exceptions ... , ... . Effective Size Attributes ... ; .... . 16-Bit Addressing Forms with the ModR/M. Byte ... . . 32-Bit Addressing Forms with the ModR/M Byte ... ..

32-Bit Addressing Forms with the SIB Byte ... . Task Switch Times for Exceptions ... ..

Exceptions' .:: ... : ... : ... ~ ... .

Page 10-3 10-4 10-4 10-10 10-15 11-5 11-6 12-3 14-2 14-6 14-7 15-4 15-5 15-14 15-14 15-16 16c2 16-3 16-6 16-9 16-12 16-14 16-15 16-16 16-17 16-18 16-22 16-25 17-2 17-3 17-3 17-4 17-5 17-6 17-7

17-7

18-3 18-4 18-7 19-3 22-6 22-9 26-2 26-5 29-6 26-7 26-12 26-17

(27)

Introduction to the Intel486 1

Microprocessor Family

(28)

Références

Documents relatifs

De ese modo, la última parte del volumen («The geographical dimensión») es especialmente interesante, mostrando –entre otros casos– cómo la vishwa sahitya en India no puede

Eah aliment is made of these three kinds of nutrients, with dierent perentages..

INT I Interrupt Request: The CPU recognizes an interrupt request on this line at the end of the current Instruction or while halted If the CPU IS In the HOLD

As some of these dressings can be quite expen- sive, researchers from the United Kingdom decided to review the evidence for the effectiveness of these

All data were thematically aggregated and meta-synthesized, revealing seven practice elements (a safe place, focusing on strengths and protective factors, developing

While doing so, I hope to point out areas for future research while also summarising what we do know (and what we do not know) about the impact of ICT on economic growth. Given

At the physical level, solutions are numerous and can be close to solutions in terrestrial networks such as cloud-RAN [9] by separating the RF and the baseband to

The difference in scores between the experimental and control group was greater for the multiple choice test than for the oral interview, suggesting that the cooperative