throbber
Programming the
`80386
`
`John H. Crawford
`Patrick P. Gelsinger
`
`~SYBEX®
`··
`~ San Francisco • Paris • Dusseldorf • London
`
`Oracle-1046 p.1
`Oracle v. Teleputers
`IPR2021-00078
`
`

`

`Cover design by Th omas In galls + Associates
`Cover photography by Casey Cartwright
`
`Ashton-Tate and dBASE are trademarks of Ashton-Tate.
`IBM, Personal Comp ut er AT, and PS/2 are trademarks of International Busin ess Mach ines
`Corporat ion .
`Intel is a trademar k ofi ntel Corporation.
`All mnemonics copyright Intel Corporation 1986, 1987.
`Lotus and 1-2-3 are tradema rks of Lotus Development Cor[Poration.
`MS-DOS is a tradema rk of Microso ft Corporation.
`Mu ltiMate is a trademark of Mult imat e Int ern ational, a sulbsidiar y of Ashton-Tate.
`UNIX is a trademark of AT&T Bell Laboratories.
`
`SYBEX is a registered trademar k of SYBEX, Inc .
`
`SYBEX is not affiliated with any manufacturer.
`
`Every effort has been made to suppl y complete and accurate informat ion. However, SYBEX
`assumes no responsibility for its use, nor for any infringements of patents or other rights of third
`parties which would result.
`
`Copyright © l 987 SYBEX Inc., 202 1 C hallenger Dri ve #100, Alam eda , CA 9450 1. World rights
`reserved. No part of this publication may be stored in a retrieval system, transmitted , or repro(cid:173)
`duced in any way, including but not limit ed to photo copy, photograph , magnetic or other record,
`without the prior agreement and written permission of the publisher .
`
`Library of Congress Card Number: 87-61199
`ISBN 0-89588-381-3
`Manufactured
`in the United States of America
`10 9 8 7 6 5 4
`
`Oracle-1046 p.2
`Oracle v. Teleputers
`IPR2021-00078
`
`

`

`34 Programming
`
`the 80386
`
`► Registers
`
`The register set available to the applications prog rammer consists of
`16 registers divided into three categories, as shown in Figure 2 .1. Additional
`registers are available to the systems programmer. Chapter 5 describes the
`registers
`that
`support memory management. Chapter
`8 describes
`the registers that support program debugging.
`
`GENERAL REGISTER SET
`
`STATUS/CONTROL REGISTERS
`
`SEGMENT REGISTERS
`
`31
`
`0
`
`31
`
`0
`
`15
`
`0
`
`IP
`
`EIP
`
`FLAGS
`
`EFLAGS
`
`16 15
`I
`I
`I
`
`i
`I
`I
`I
`I
`
`ES
`
`cs
`
`ss
`
`OS
`
`FS
`
`GS
`
`EAX
`
`ECX
`
`EDX
`
`EBX
`
`ESP
`
`EBP
`
`ESI
`
`EDI
`
`16 15 8 7
`I
`I
`
`AX
`
`I
`I
`I
`
`I AH I AL
`I
`I
`ex
`I
`I CH I CL
`DX
`I DH I DL
`
`I
`I
`BX
`I
`I BH I BL
`I
`I
`I
`I
`I
`I
`I
`I
`I
`I
`I
`I
`I
`I
`I
`I
`I
`
`SP
`
`BP
`
`SI
`
`DI
`
`► Figure 2 .1: 80386 registers
`
`Oracle-1046 p.3
`Oracle v. Teleputers
`IPR2021-00078
`
`

`

`Machine State and Memory Addressing 35
`
`The thr ee categories are as follows:
`
`1. Eight general-purpose 32-bit registers used for arithmetic and log(cid:173)
`ical operations, and for the base and index register components
`of memory addresses.
`2. Two 32-bit processor-control registers .
`3. Six 16-bit segment registers that address memory segments. Each
`regist er provides imm ediat e access to one segment of memory at
`a time. M emo ry segments will be explained later in this chapter
`and in detail in Chapter 5.
`
`Th e register set of the 80386 is a superset of the register set available on
`the previous processors in the 86 family. In cases where a 16-bit register was
`exten ded to provid e a 32-bit register on the 80386, the 386 register name
`is simply the old 16-bit register nam e prefixed with an E (for Extended).
`For example, the 16-bit AX register from the 8086 was extended to form
`the 32-bit EAX register on the 80386, the 16-bit IP (Instruction Pointer)
`register was extended
`to form the 32-bit EIP register on the 386, and
`so on.
`
`The General Registers
`Th e 80386 contains eight 32-bit general registers, used for arithmetic
`operations such as addition, subtraction, multiplication, and division , and
`also to form memory addresses, as described later in this chapter. These
`eight registers are nam ed EAX , ECX, EDX, EBX, ESP, EBP, ESI, and
`ED I, as shown in Figure 2 .1.
`The lower 16 bits of these registers can be accessed independently as
`16-bit registers, and are named AX, CX, DX, BX , SP, BP, SI, and DI.
`These are the eight 16-bit general-purpose
`registers from the previous 86
`family processors, and provide the compatible register set used for exe(cid:173)
`in Chapter 9. If one of these
`cuting 8086 and 286 code, as described
`16-bit registers is accessed, the upper 16 bits of the 32-bit general register
`are not disturbed.
`The high and low halves of the X registers-AX, BX, CX, and DX(cid:173)
`can be accessed independently as 8-bit registers. The suffix H or L is added
`to the first letter of the name of the 16-bit register to form the 8-bit register
`name for the high or low half of the register. For example, the AL register
`is the lowest 8 bits of the AX register, and also the lowest 8 bits of the
`EAX register. The AH register is the upper 8 bits of the AX register, and
`bits 8 through 15 of the EAX register. If one of these 8-bit registers is
`accessed, the remaining bits of the general register are not disturbed. You
`can see the overlap of the 8-bit, 16-bit, and 32-bit registers in Figure 2.1.
`
`Oracle-1046 p.4
`Oracle v. Teleputers
`IPR2021-00078
`
`

This document is available on Docket Alarm but you must sign up to view it.


Or .

Accessing this document will incur an additional charge of $.

After purchase, you can access this document again without charge.

Accept $ Charge
throbber

Still Working On It

This document is taking longer than usual to download. This can happen if we need to contact the court directly to obtain the document and their servers are running slowly.

Give it another minute or two to complete, and then try the refresh button.

throbber

A few More Minutes ... Still Working

It can take up to 5 minutes for us to download a document if the court servers are running slowly.

Thank you for your continued patience.

This document could not be displayed.

We could not find this document within its docket. Please go back to the docket page and check the link. If that does not work, go back to the docket and refresh it to pull the newest information.

Your account does not support viewing this document.

You need a Paid Account to view this document. Click here to change your account type.

Your account does not support viewing this document.

Set your membership status to view this document.

With a Docket Alarm membership, you'll get a whole lot more, including:

  • Up-to-date information for this case.
  • Email alerts whenever there is an update.
  • Full text search for other cases.
  • Get email alerts whenever a new case matches your search.

Become a Member

One Moment Please

The filing “” is large (MB) and is being downloaded.

Please refresh this page in a few minutes to see if the filing has been downloaded. The filing will also be emailed to you when the download completes.

Your document is on its way!

If you do not receive the document in five minutes, contact support at support@docketalarm.com.

Sealed Document

We are unable to display this document, it may be under a court ordered seal.

If you have proper credentials to access the file, you may proceed directly to the court's system using your government issued username and password.


Access Government Site

We are redirecting you
to a mobile optimized page.





Document Unreadable or Corrupt

Refresh this Document
Go to the Docket

We are unable to display this document.

Refresh this Document
Go to the Docket