# intel®

### Pentium<sup>®</sup> II Processor Specification Update

Release Date: February 11, 1998

Order Number: 243337-011

The Pentium® II processor may contain design defects or errors known as errata which may cause the product to deviate from published specifications. Current characterized errata are documented in this Specification Update.

Information in this document is provided in connection with Intel products. No license, express or implied, by estoppel or otherwise, to any intellectual property rights is granted by this document. Except as provided in Intel's Terms and Conditions of Sale for such products, Intel assumes no liability whatsoever, and Intel disclaims any express or implied warranty, relating to sale and/or use of Intel products including liability or warranties relating to fitness for a particular purpose, merchantability, or infringement of any patent, copyright or other intellectual property right. Intel products are not intended for use in medical, life saving, or life sustaining applications.

Intel may make changes to specifications and product descriptions at any time, without notice.

Designers must not rely on the absence or characteristics of any features or instructions marked "reserved" or "undefined." Intel reserves these for future definition and shall have no responsibility whatsoever for conflicts or incompatibilities arising from future changes to them.

The Pentium® II processor may contain design defects or errors known as errata which may cause the product to deviate from published specifications. Current characterized errata are available on request.

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

Copies of documents which have an ordering number and are referenced in this document, or other Intel literature, may be obtained by calling 1-800-548-4725 or by visiting Intel's website at http://www.intel.com

Copyright © Intel Corporation 1996, 1997.

\* Third-party brands and names are the property of their respective owners.

#### CONTENTS

| REVISION HISTORY                                            | v  |
|-------------------------------------------------------------|----|
| PREFACE                                                     | vi |
| Specification Update for Pentium <sup>®</sup> II Processors |    |
| GENERAL INFORMATION                                         |    |
| ERRATA                                                      |    |
| DOCUMENTATION CHANGES                                       |    |
| SPECIFICATION CLARIFICATIONS                                |    |
| SPECIFICATION CHANGES                                       |    |
|                                                             |    |

### int<sub>el</sub>.

### **REVISION HISTORY**

| Date of Revision                      | Version | Description                                                                                                                                                                                           |
|---------------------------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| May 1997                              | -001    | This document is the first Specification Update for the Pentium <sup>®</sup> II processor.                                                                                                            |
| June 1997                             | -002    | Added Erratum 25. Update Erratum 13 status in the<br>Summary Table of Changes. Added Documentation<br>Change Table and Documentation Change 1. Added<br>300-MHz Pentium II processor information.     |
| July 1997                             | -003    | Added Erratum 26. Added Specification Change Table and Specification Changes 1 and 2.                                                                                                                 |
| August 1997                           | -004    | Added Erratum 27. Added Document Change 2 and Spec Changes 3, 4, 5, 6, and 7.                                                                                                                         |
| September 1997                        | -005    | Updated Erratum 27. Added Errata 28 and 29. Added<br>Document Change 3 and Spec Clarification 1. Added<br>C1 stepping information. Updated Spec Change 6.                                             |
| October 1997                          | -006    | Updated Errata 6 and 18, and S-spec table.                                                                                                                                                            |
| November 1997                         | -007    | Updated Erratum 22. Added Specification<br>Clarification 2, 3, and 4.                                                                                                                                 |
| December 1997                         | -008    | Updated and added notes to S-spec table. Updated package information table. Updated Erratum 24. Added Errata 30, 31, and 32.                                                                          |
| January 1998                          | -009    | Added notes to Pentium II processor markings.<br>Updated Erratum 28. Added Erratum 33. Added<br>Documentation Change 4 and 5. Added Specification<br>Change 5.                                        |
| January 26, 1998<br>(Special Edition) | -010    | Updated S-spec table. Added dA0 stepping information. Added Errata 34, 35, 36, 37, and 38.                                                                                                            |
| February 11, 1998                     | -011    | Added new processor markings. Corrected Errata 13<br>and 34 for steppings affected. Corrected typos in<br>summary table for Errata 34, 35, and 36. Added<br>Erratum 39. Added Documentation Change 6. |

### int<sub>el</sub>,

#### PREFACE

This document is an update to the specifications contained the *Pentium® II Processor Developer's Manual* (Order Number 243341), the *Pentium® II Processor* datasheet and the *Intel Architecture Software Developer's Manual, Volumes 1, 2 and 3* (Order Numbers 243190, 243191, and 243192, respectively). It is intended for hardware system manufacturers and software developers of applications, operating systems, or tools. It contains Specification Changes, S-Specs, Errata, Specification Clarifications, and Documentation Changes.

#### Nomenclature

**Specification Changes** are modifications to the current published specifications for the Pentium<sup>®</sup> II processor. These changes will be incorporated in the next release of the specifications.

**S-Specs** are exceptions to the published specifications, and apply only to the units assembled under that s-spec.

**Specification Clarifications** describe a specification in greater detail or further highlight a specification's impact to a complex design situation. These clarifications will be incorporated in the next release of the specifications.

**Documentation Changes** include typos, errors, or omissions from the current published specifications. These changes will be incorporated in the next release of the specifications. **Errata** are design defects or errors. Errata may cause the Pentium II processor's behavior to deviate from published specifications. Hardware and software designed to be used with any given processor stepping must assume that all errata documented for that processor stepping are present on all devices.

#### Identification Information

The Pentium II processor can be identified by the following values:

| <b>Family</b> <sup>1</sup> | 233-, 266-, 300-MHz Model 3 <sup>2</sup> | Model 5 <sup>2</sup> |
|----------------------------|------------------------------------------|----------------------|
| 0110                       | 0011                                     | 0101                 |

#### NOTES:

 The Family corresponds to bits [11:8] of the EDX register after RESET, bits [11:8] of the EAX register after the CPUID instruction is executed with a 1 in the EAX register, and the generation field of the Device ID register accessible through Boundary Scan.

2. The Model corresponds to bits [7:4] of the EDX register after RESET, bits [7:4] of the EAX register after the CPUID instruction is executed with a 1 in the EAX register, and the model field of the Device ID register accessible through Boundary Scan.

### The Pentium II processor's second level (L2) cache size can be determined by the following register contents:

| 512-Kbyte Unified L2 Cache <sup>1</sup> | 43h |
|-----------------------------------------|-----|
|-----------------------------------------|-----|

NOTE:

For the Pentium<sup>®</sup> II processor, the unified L2 cache size corresponds to the value in bits [3:0] of the EDX register after the CPUID
instruction is executed with a 2 in the EAX register. Other Intel microprocessor models or families may move this information to
other bit positions or otherwise reformat the result returned by this instruction; generic code should parse the resulting token stream
according to the definition of the CPUID instruction.

### Specification Update for Pentium<sup>®</sup> II Processors



#### **GENERAL INFORMATION**

#### Pentium<sup>®</sup> II Processor Markings

#### Dynamic Mark Area





NOTES:

- ZZZ = Speed (MHz).
- SYYYY = S-spec Number.
- LLL = Level 2 Cache Size (in Kilobytes).
- FFFFFFF = FPO # (Test Lot Traceability #).
- XXXX = Serialization Code.

| CPUID |        |       |               |                  |                     |                     |        |                     |                            |         |
|-------|--------|-------|---------------|------------------|---------------------|---------------------|--------|---------------------|----------------------------|---------|
| Туре  | Family | Model | Step-<br>ping | Core<br>Stepping | L1 Size<br>(Kbytes) | TagRAM/<br>Stepping | S-Spec | ECC/<br>Non-<br>ECC | Speed<br>(MHz)<br>Core/Bus | Notes   |
| 0     | 6      | 3     | 3             | C0               | 512                 | T6/B0               | SL264  | non-<br>ECC         | 233/66                     | 1, 2    |
| 0     | 6      | 3     | 3             | C0               | 512                 | T6/B0               | SL265  | non-<br>ECC         | 266/66                     | 1, 2    |
| 0     | 6      | 3     | 3             | C0               | 512                 | T6/B0               | SL268  | ECC                 | 233/66                     | 1, 2    |
| 0     | 6      | 3     | 3             | C0               | 512                 | T6/B0               | SL269  | ECC                 | 266/66                     | 1, 2    |
| 0     | 6      | 3     | 3             | C0               | 512                 | T6/B0               | SL28K  | non-<br>ECC         | 233/66                     | 1, 2, 3 |
| 0     | 6      | 3     | 3             | C0               | 512                 | T6/B0               | SL28L  | non-<br>ECC         | 266/66                     | 1, 2, 3 |
| 0     | 6      | 3     | 3             | C0               | 512                 | T6/B0               | SL28R  | ECC                 | 300/66                     | 1, 2    |
| 0     | 6      | 3     | 3             | C0               | 512                 | T6/B0               | SL2MZ  | ECC                 | 300/66                     | 1, 2, 3 |
| 0     | 6      | 3     | 3             | C0               | 512                 | T6/B0               | SL2PV  | ECC                 | 266/66                     | 1, 2, 3 |
| 0     | 6      | 3     | 4             | C1               | 512                 | T6/B0               | SL2HA  | ECC                 | 300/66                     | 1, 2    |
| 0     | 6      | 3     | 4             | C1               | 512                 | T6/B0               | SL2HC  | non-<br>ECC         | 266/66                     | 1, 2    |
| 0     | 6      | 3     | 4             | C1               | 512                 | T6/B0               | SL2HD  | non-<br>ECC         | 233/66                     | 1, 2    |
| 0     | 6      | 3     | 4             | C1               | 512                 | T6/B0               | SL2HE  | ECC                 | 266/66                     | 1, 2    |
| 0     | 6      | 3     | 4             | C1               | 512                 | T6/B0               | SL2HF  | ECC                 | 233/66                     | 1, 2    |
| 0     | 6      | 3     | 4             | C1               | 512                 | T6/B0               | SL2QA  | non-<br>ECC         | 233/66                     | 1, 2, 3 |
| 0     | 6      | 3     | 4             | C1               | 512                 | T6/B0               | SL2QB  | non-<br>ECC         | 266/66                     | 1, 2, 3 |
| 0     | 6      | 3     | 4             | C1               | 512                 | T6/B0               | SL2QC  | ECC                 | 300/66                     | 1, 2, 3 |
| 0     | 6      | 3     | 4             | C1               | 512                 | T6/B0               | SL2QD  | ECC                 | 266/66                     | 1, 2, 3 |
| 0     | 6      | 5     | 0             | dA0              | 512                 | T6P/A3              | SL2KA  | ECC                 | 333/66                     | 4, 5, 6 |

Basic Pentium<sup>®</sup> II Processor Identification Information

int<sub>el</sub>,

### int<sub>el</sub>.

#### PENTIUM® II PROCESSOR SPECIFICATION UPDATE

#### NOTES:

- 1. V<sub>CC CORE</sub> is specified for 2.8 V +100/-70 mV for all Pentium<sup>®</sup> II processors.
- T<sub>PLATE</sub> is specified for 5 °C 75 °C for all Pentium II processors with S.E.C. cartridge packages except for 300 MHz Pentium II processors (SL28R, SL2HA, SL2MZ, and SL2QC which have a Tplate specification for 5 °C 72 °C).
- 3. This is a boxed Pentium II processor with an attached fan heatsink.
- 4.  $V_{CCCORE}$  is specified for 2.0 V +100/-70 mV for these Pentium II processors.
- 5.  $T_{PLATE}$  is specified for 5 °C 65 °C for these Pentium II processors.
- The clock requirement for the product under these S-spec numbers differ from those in the current specification. These differences are as follows:

| T#                                                                                  | Parameter | Min | Nom | Max | Unit | Notes |  |
|-------------------------------------------------------------------------------------|-----------|-----|-----|-----|------|-------|--|
| V1':                                                                                | BCLK VIL  |     |     | 0.5 | v    |       |  |
| V2':                                                                                | BCLK VIH  | 2.0 |     |     | v    |       |  |
| Slot 1 Processor System Bus AC Specifications (Clock) at the Processor Edge Fingers |           |     |     |     |      |       |  |

#### **BCLK Signal Quality Guidelines for Edge Finger Measurement**

| T#   | Parameter      | Min  | Nom | Max  | Unit | Notes           |
|------|----------------|------|-----|------|------|-----------------|
| T3': | BCLK High Time | 3.99 |     |      | ns   | @>1.8 V a       |
| T4': | BCLK Low Time  | 4.39 |     |      | ns   | @<0.7 V a       |
| T5': | BCLK Rise Time | 1.02 |     | 2.68 | ns   | (0.7 V–1.8 V) a |
| T6': | BCLK Fall Time | 1.02 |     | 2.68 | ns   | (1.8 V–0.7 V) a |

NOTE:

a) This specification applies to Slot 1 processors when operating with a Slot 1 processor system bus frequency of 66 MHz.

|                  |          | Core       |                    |                                    |                       |  |  |  |  |
|------------------|----------|------------|--------------------|------------------------------------|-----------------------|--|--|--|--|
| S-Spec<br>Number | Stepping | Speed(MHz) | L2<br>Size(Kbytes) | Processor<br>Substrate<br>Revision | Cartridge<br>Revision |  |  |  |  |
| SL264            | C0       | 233        | 512                | D                                  | 3.00                  |  |  |  |  |
| SL265            | C0       | 266        | 512                | D                                  | 3.00                  |  |  |  |  |
| SL268            | C0       | 233        | 512                | D                                  | 3.00                  |  |  |  |  |
| SL269            | C0       | 266        | 512                | D                                  | 3.00                  |  |  |  |  |
| SL28K            | C0       | 233        | 512                | D                                  | 3.00                  |  |  |  |  |
| SL28L            | C0       | 266        | 512                | D                                  | 3.00                  |  |  |  |  |
| SL28R            | C0       | 300        | 512                | D                                  | 3.00                  |  |  |  |  |
| SL2MZ            | C0       | 300        | 512                | D                                  | 3.00                  |  |  |  |  |
| SL2PV            | C0       | 266        | 512                | D                                  | 3.00                  |  |  |  |  |
| SL2HA            | C1       | 300        | 512                | D                                  | 3.00                  |  |  |  |  |
| SL2HC            | C1       | 266        | 512                | D                                  | 3.00                  |  |  |  |  |
| SL2HD            | C1       | 233        | 512                | D                                  | 3.00                  |  |  |  |  |
| SL2HE            | C1       | 266        | 512                | D                                  | 3.00                  |  |  |  |  |
| SL2HF            | C1       | 233        | 512                | D                                  | 3.00                  |  |  |  |  |
| SL2QA            | C1       | 233        | 512                | D                                  | 3.00                  |  |  |  |  |
| SL2QB            | C1       | 266        | 512                | D                                  | 3.00                  |  |  |  |  |
| SL2QC            | C1       | 300        | 512                | D                                  | 3.00                  |  |  |  |  |
| SL2QD            | C1       | 266        | 512                | D                                  | 3.00                  |  |  |  |  |
| SL2KA            | dA0      | 333        | 512                | B1                                 | 3.00                  |  |  |  |  |

Pentium<sup>®</sup> II Processor Package Information

int<sub>el</sub>.



#### Summary Table of Changes

The following table indicates the Specification Changes, Errata, Specification Clarifications, or Documentation Changes which apply to the Pentium II processors. Intel intends to fix some of the errata in a future stepping of the component, and to account for the other outstanding issues through documentation or specification changes as noted. This table uses the following notations:

#### CODES USED IN SUMMARY TABLE

| X:                        | Specification Change, Erratum, Specification Clarification, or Documentation Change applies to the given processor stepping. |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------|
| Doc:                      | Intel intends to update the appropriate documentation in a future revision.                                                  |
| Fix:                      | This erratum is intended to be fixed in a future stepping of the component.                                                  |
| Fixed:                    | This erratum has been previously fixed.                                                                                      |
| NoFix:                    | There are no plans to fix this erratum.                                                                                      |
| (No mark) or (blank box): | This item is fixed in or does not apply to the given stepping.                                                               |
| AP:                       | APIC related erratum.                                                                                                        |
| SUB:                      | This column refers to errata on the Pentium <sup>®</sup> II processor substrate.                                             |
| Shaded:                   | This erratum is either new or modified from the previous version                                                             |

of the document.

| NO. | C0 | <b>C1</b> | dA0 | SUB | Plans | ERRATA                                                                                                           |
|-----|----|-----------|-----|-----|-------|------------------------------------------------------------------------------------------------------------------|
| 1   | Х  | Х         | Х   |     | NoFix | FP Operand Pointer may be incorrectly calculated after<br>FP access which wraps 64-Kbyte boundary in 16-bit code |
| 2   | Х  | Х         | Х   |     | NoFix | Differences exist in debug exception reporting                                                                   |
| 3   | Х  | Х         | Х   |     | NoFix | FLUSH# servicing delayed while waiting for<br>STARTUP_IPI in 2-way MP systems                                    |
| 4   | Х  | Х         | Х   |     | NoFix | Code fetch matching disabled debug register may cause debug exception                                            |
| 5   | Х  | Х         | Х   |     | NoFix | Double ECC error on read may result in BINIT#                                                                    |
| 6   | Х  | Х         | Х   |     | NoFix | FP inexact-result exception flag may not be set                                                                  |
| 7   | Х  | Х         | Х   |     | NoFix | BTM for SMI will contain incorrect FROM EIP                                                                      |

| NO. | C0 | <b>C1</b> | dA0 | SUB | Plans | ERRATA                                                                                        |
|-----|----|-----------|-----|-----|-------|-----------------------------------------------------------------------------------------------|
| 8   | Х  | Х         | Х   |     | NoFix | I/O restart in SMM may fail after simultaneous MCE                                            |
| 9   | Х  | Х         | Х   |     | NoFix | Branch traps do not function if BTMs are also enabled                                         |
| 10  | Χ  | Х         | Х   |     | NoFix | Checker BIST failure in FRC mode not signaled                                                 |
| 11  | Χ  | Х         | Х   |     | NoFix | BINIT# assertion causes FRCERR assertion in FRC mode                                          |
| 12  | Х  | Х         | Х   |     | NoFix | Machine Check Exception handler may not always execute successfully                           |
| 13  | Х  | Х         | Х   |     | NoFix | MCE due to L2 parity error gives L1 MCACOD.LL                                                 |
| 14  | Χ  | Х         | Х   |     | NoFix | LBER may be corrupted after some events                                                       |
| 15  | Х  | Х         | Х   |     | NoFix | BTMs may be corrupted during simultaneous L1 cache line replacement                           |
| 16  | Х  |           |     |     | Fix   | System may hang due to internal protocol violation                                            |
| 17  | Х  |           |     |     | Fix   | Livelock condition may cause system hang                                                      |
| 18  | Х  | Х         |     |     | Fix   | Mispredicted branch may cause incorrect tag word on MMX <sup>TM</sup> technology instructions |
| 19  | Х  | Х         |     |     | Fix   | Thermal sensor/THERMTRIP# does not work                                                       |
| 20  | Х  | Х         |     |     | Fix   | Spurious machine check exception via IFU data parity error                                    |
| 21  | Х  | Х         |     |     | Fix   | Loss of inclusion in IFU can cause Machine Check<br>Exception                                 |
| 22  | X  | Х         |     |     | Fix   | Possible system hang when paging is disabled and re-<br>enabled from uncached memory          |
| 23  | Х  | Х         |     |     | Fix   | L2 performance counters miscount L2_RQSTS                                                     |
| 24  | Χ  | Х         |     |     | Fix   | Erroneous signaling of user mode protection violation                                         |
| 25  | Х  |           |     |     | Fix   | Invalid operation not signaled by the FIST instruction on some out of range operands          |
| 26  | Х  | Х         |     |     | Fix   | FLUSH# assertion disables L2 Machine Check Exception reporting                                |
| 27  | Х  | Х         |     |     | Fix   | EFLAGS may be incorrect after a multiprocessor TLB shootdown                                  |
| 28  | Х  | Х         | Х   |     | Fix   | Delayed line invalidation issue during 2-way MP data ownership transfer                       |

int<sub>el</sub>,

## int<sub>el</sub>,

### PENTIUM® II PROCESSOR SPECIFICATION UPDATE

| NO. | C0 | C1 | dA0 | SUB | Plans | ERRATA                                                                           |
|-----|----|----|-----|-----|-------|----------------------------------------------------------------------------------|
| 29  | Х  | Х  | Х   |     | Fix   | Potential early deassertion of LOCK# during split-lock cycles                    |
| 30  | Х  | Х  | Х   |     | NoFix | A20M# may be inverted after returning from SMM and Reset                         |
| 31  | Х  | Х  | Х   |     | Fix   | Reporting of floating-point exception may be delayed                             |
| 32  | Х  | Х  |     |     | NoFix | EFLAGS discrepancy on a page fault after a multiprocessor TLB shootdown          |
| 33  | Х  | Х  | Х   |     | NoFix | Near CALL to ESP creates unexpected EIP address                                  |
| 34  |    |    |     |     | Fixed | Deep Sleep exit transition may cause hang                                        |
| 35  |    |    | Х   |     | Fix   | Built-in self test always gives nonzero result                                   |
| 36  |    |    | Х   |     | Fix   | THERMTRIP# may not be asserted as specified                                      |
| 37  |    |    | Х   |     | Fix   | Cache state corruption in the presence of page A/D-bit setting and snoop traffic |
| 38  |    |    | Х   |     | Fix   | Snoop cycle generates spurious Machine Check<br>Exception                        |
| 39  | Х  | Х  | Х   |     | Fix   | MOVD/MOVQ instruction writes to memory prematurely                               |
| 1AP | Х  | Х  | Х   |     | NoFix | APIC access to cacheable memory causes SHUTDOWN                                  |
| 2AP | Х  | Х  | Х   |     | NoFix | 2-way MP systems may hang due to catastrophic errors<br>during BSP determination |
| 3AP | Х  | Х  | Х   |     | NoFix | Write to mask LVT (programmed as EXTINT) will not deassert outstanding interrupt |

| NO. | C0 | <b>C1</b> | dA0 | SUB | Plans DOCUMENTATION CHANGES                                                                        |                                     |  |
|-----|----|-----------|-----|-----|----------------------------------------------------------------------------------------------------|-------------------------------------|--|
| 1   | X  | Х         | Х   |     | Doc Note 4 of Table 13, note 6 of Table 16, Output Valid Delay specified to 2.5 V +5% in datasheet |                                     |  |
| 2   | Х  | Х         | Х   |     | Doc Invalid arithmetic operations and masked responses to them relative to FIST/FISTP instruction  |                                     |  |
| 3   | Х  | Х         | Х   |     | Doc                                                                                                | Doc FIDIV/FIDIVR m16int description |  |
| 4   | Х  | Х         | Х   |     | Doc                                                                                                | Doc PUSH does not pad with zeros    |  |
| 5   | Х  | Х         | Х   |     | Doc                                                                                                | Doc DR7, bit 10 is reserved         |  |
| 6   | X  | Х         | Х   |     | Doc Additional states that are not automatically saved and restored                                |                                     |  |

int<sub>el</sub>,

| NO. | C0 | <b>C1</b> | dA0 | SUB | Plans SPECIFICATION CLARIFICATIONS |                                                               |  |
|-----|----|-----------|-----|-----|------------------------------------|---------------------------------------------------------------|--|
| 1   | Х  | Х         | Х   |     | Doc Writes to WC memory            |                                                               |  |
| 2   | Х  | Х         | Х   |     | Doc                                | Multiple processors protocol and restrictions                 |  |
| 3   | Х  | Х         | Х   |     | Doc                                | Doc NMI handling while in SMM                                 |  |
| 4   | Х  | Х         | Х   |     | Doc                                | Doc Critical sequence of events during a page fault exception |  |
| 5   | Χ  | Х         | Х   |     | Doc                                | Doc Performance-Monitoring Counter issues                     |  |

| NO. | C0 | <b>C1</b> | dA0 | SUB | Plans SPECIFICATION CHANGES                                          |                                                                        |  |
|-----|----|-----------|-----|-----|----------------------------------------------------------------------|------------------------------------------------------------------------|--|
| 1   | Χ  | Х         | Х   |     | Doc BCLK period stability change from $\pm 250$ ps to $\pm 300$ ps   |                                                                        |  |
| 2   | Х  | Х         | Х   |     | Doc Vcc <sub>CORE</sub> transient tolerance change by 5 mV and 10 mV |                                                                        |  |
| 3   | X  | Х         | Х   |     | Doc Deep Sleep ICC CORE Specification change from 0.2 A to 0.35 A    |                                                                        |  |
| 4   | Х  | Х         | Х   |     | Doc                                                                  | Doc TRST# Pull-down Resistor                                           |  |
| 5   | Х  | Х         | Х   |     | Doc                                                                  | Doc 300 MHz Pentium® II Processor Maximum Temperature<br>Change        |  |
| 6   | Х  | Х         | Х   |     | Doc                                                                  | Doc S.E.C. Cartridge Mechanical Specifications                         |  |
| 7   | Х  | Х         | Х   |     | Doc                                                                  | Doc S.E.C. Cartridge Heatsink Attach Clearance Specification<br>Change |  |

### int<sub>el</sub>.

### ERRATA

#### 1. FP Operand Pointer May Be Incorrectly Calculated After FP Access Which Wraps 64-Kbyte Boundary in 16-Bit Code

**PROBLEM:** The FP Operand Pointer is the effective address of the operand associated with the last noncontrol floating-point instruction executed by the machine. If an 80-bit floating-point access (load or store) occurs in a 16-bit mode other than protected mode (in which case the access will produce a segment limit violation), the memory access wraps a 64-Kbyte boundary, and the floating-point environment is subsequently saved in 32-bit mode, the subtraction routine used to calculate the FP Operand Pointer will assume the floating-point access was in 32-bit mode, and the high word of the address will be FFFFh instead of 0000h. **IMPLICATION:** A 32-bit operating system running 16-bit floating-point code may encounter this erratum, under the following conditions:

- The operating system is using a segment greater than 64 Kbytes in size.
- An application is running in a 16-bit mode other than protected mode.
- An 80-bit floating-point load which wraps the 64-Kbyte boundary is executed.
- The operating system uses a 32-bit handler on an unmasked exception which occurs during the load.
- The exception handler uses the value contained in the FP Operand Pointer.

Wrapping an 80-bit floating-point load around a segment boundary in this way is not a normal programming practice. Intel has not currently identified any software which exhibits this behavior.

**WORKAROUND:** If the FP Operand Pointer is used in a 32-bit exception handler in an OS which may run 16-bit floating-point code, care must be taken to ensure that no 80-bit floating-point accesses are wrapped around a 64-Kbyte boundary.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 2. Differences Exist in Debug Exception Reporting

**PROBLEM:** There exist some differences in the reporting of code and data breakpoint matches between that specified by previous Intel processors' specifications and the behavior of the Pentium II processor, as described below:

#### CASE 1:

The first case is for a breakpoint set on a MOVSS or POPSS instruction, when the instruction following it causes a debug register protection fault (DR7.gd is already set, enabling the fault). The Pentium processor reports delayed data breakpoint matches from the MOVSS or POPSS

instructions by setting the matching DR6.bi bits, along with the debug register protection fault (DR6.bd). If additional breakpoint faults are matched during the call of the debug fault handler, the Pentium processor sets the breakpoint match bits (DR6.bi) to reflect the breakpoints matched by both the MOVSS or POPSS breakpoint and the debug fault handler call. The Pentium II processor only sets DR6.bd in either situation, and does not set any of the DR6.bi bits.

#### **CASE 2:**

In the second breakpoint reporting failure case, if a MOVSS or POPSS instruction with a data breakpoint is followed by a store to memory which crosses a 4-Kbyte page boundary, the breakpoint information for the MOVSS or POPSS will be lost. Previous processors retain this information across such a page split.

#### CASE 3:

If they occur after a MOVSS or POPSS instruction, the INT *n*, INTO, and INT3 instructions zero the DR6.Bi bits (bits B0 through B3), clearing pending breakpoint information, unlike previous processors.

#### CASE 4:

If a data breakpoint and an SMI (System Management Interrupt) occur simultaneously, the SMI will be serviced via a call to the SMM handler, and the pending breakpoint will be lost. IMPLICATION: When debugging or when developing debuggers for a Pentium II processor based system, this behavior should be noted. Normal usage of the MOVSS or POPSS instructions (i.e., following them with a MOV ESP) will not exhibit the behavior of cases 1-3. Debugging in conjunction with SMM will be limited by case 4 (no workaround has been identified for this case).

**WORKAROUND:** Following MOVSS and POPSS instructions with a MOV ESP instruction when using breakpoints will avoid the first three cases of this erratum.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

### 3. FLUSH# Servicing Delayed While Waiting for STARTUP\_IPI in 2-way MP Systems

**PROBLEM:** In a 2-way MP system, if an application processor is waiting for a startup interprocessor interrupt (STARTUP\_IPI), then it will not service a FLUSH# pin assertion until it has received the STARTUP\_IPI.

**IMPLICATION:** After the 2-way MP initialization protocol, only one processor becomes the bootstrap processor (BSP). The other processor becomes a slave application processor (AP). After losing the BSP arbitration, the AP goes into a wait loop, waiting for a STARTUP\_IPI. The BSP can wake up the AP to perform some tasks with a STARTUP\_IPI, and then put it back to sleep with an initialization interprocessor interrupt (INIT\_IPI, which has the same

# int<sub>el</sub>,

affect as asserting INIT#), which returns it to a wait loop. The result is a possible loss of cache coherency if the offline processor is intended to service a FLUSH# assertion at this point. The FLUSH# will be serviced as soon as the processor is awakened by a STARTUP\_IPI, before any other instructions are executed. Intel has not encountered any operating systems that are affected by this erratum.

**WORKAROUND:** Operating system developers should take care to execute a WBINVD instruction before the AP is taken offline using an INIT\_IPI.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 4. Code Fetch Matching Disabled Debug Register May Cause Debug Exception

**PROBLEM:** The bits L0-3 and G0-3 enable breakpoints local to a task and global to all tasks, respectively. If one of these bits is set, a breakpoint is enabled, corresponding to the addresses in the debug registers DR0-DR3. If at least one of these breakpoints is enabled, any of these registers are **disabled** (i.e., Ln and Gn are 0), and RWn for the disabled register is 00 (indicating a breakpoint on instruction execution), normally an instruction fetch will not cause an instruction-breakpoint fault based on a match with the address in the disabled register (s). However, if the address in a disabled register matches the address of a code fetch which also results in a page fault, an instruction-breakpoint fault will occur.

**IMPLICATION:** While debugging software, extraneous instruction-breakpoint faults may be encountered if breakpoint registers are not cleared when they are disabled. Debug software which does not implement a code breakpoint handler will fail, if this occurs. If a handler is present, the fault will be serviced. Mixing data and code may exacerbate this problem by allowing disabled data breakpoint registers to break on an instruction fetch.

**WORKAROUND:** The debug handler should clear breakpoint registers before they become disabled.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 5. Double ECC Error on Read May Result in BINIT#

**PROBLEM:** For this erratum to occur, the following conditions must be met:

- Machine Check Exceptions (MCEs) must be enabled.
- A dataless transaction (such as a write invalidate) must be occurring simultaneously with a transaction which returns data (a normal read).
- The read data must contain a double-bit uncorrectable ECC error.

If these conditions are met, the Pentium II processor will not be able to determine which transaction was erroneous, and instead of generating an MCE, it will generate a BINIT#.

int<sub>e</sub>l.

**IMPLICATION:** The bus will be reinitialized in this case. However, since a double-bit uncorrectable ECC error occurred on the read, the MCE handler (which is normally reached on a double-bit uncorrectable ECC error for a read) would most likely cause the same BINIT# event.

**WORKAROUND:** Though the ability to drive BINIT# can be disabled in the Pentium II processor, which would prevent the effects of this erratum, overall system behavior would not improve, since the error which would normally cause a BINIT# would instead cause the machine to shut down. No other workaround has been identified.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 6. FP Inexact-Result Exception Flag May Not Be Set

**PROBLEM:** When the result of a floating-point operation is not exactly representable in the destination format (1/3 in binary form, for example), an inexact-result (precision) exception occurs. When this occurs, the PE bit (bit 5 of the FPU status word) is normally set by the processor. Under certain rare conditions, this bit may not be set when this rounding occurs. However, other actions taken by the processor (invoking the software exception handler if the exception is unmasked) are not affected. This erratum can only occur if the floating-point operation which causes the precision exception is immediately followed by one of the following instructions:

- FST m32real
- FST m64real
- FSTP m32real
- FSTP m64real
- FSTP m80real
- FIST m16int
- FIST m32int
- FISTP m16int
- FISTP m32int
- FISTP m64int

Note that even if this combination of instructions is encountered, there is also a dependency on the internal pipelining and execution state of both instructions in the processor. **IMPLICATION:** Inexact-result exceptions are commonly masked or ignored by applications, as it happens frequently, and produces a rounded result acceptable to most applications. The PE bit of the FPU status word may not always be set upon receiving an inexact-result exception. Thus, if these exceptions are unmasked, a floating-point error exception handler may not recognize that a precision exception occurred. Note that this is a "sticky" bit, i.e., once set by an inexact-result condition, it remains set until cleared by software. **WORKAROUND:** This condition can be avoided by inserting a NOP instruction between the two floating-point instructions.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 7. BTM for SMI Will Contain Incorrect FROM EIP

**PROBLEM:** A system management interrupt (SMI) will produce a Branch Trace Message (BTM), if BTMs are enabled. However, the FROM EIP field of the BTM (used to determine the address of the instruction which was being executed when the SMI was serviced) will not have been updated for the SMI, so the field will report the same FROM EIP as the previous BTM. **IMPLICATION:** A BTM which is issued for an SMI will not contain the correct FROM EIP, limiting the usefulness of BTMs for debugging software in conjunction with System Management Mode (SMM).

WORKAROUND: None identified at this time.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 8. I/O Restart in SMM May Fail After Simultaneous MCE

**PROBLEM:** If an I/O instruction (IN, INS, REP INS, OUT, OUTS, or REP OUTS) is being executed, and if the data for this instruction becomes corrupted, the Pentium II processor will signal a machine check exception (MCE). If the instruction is directed at a device which is powered down, the processor may also receive an assertion of SMI#. Since MCEs have higher priority, the processor will call the MCE handler, and the SMI# assertion will remain pending. However, upon attempting to execute the first instruction of the MCE handler, the SMI# will be recognized and the processor will attempt to execute the SMM handler. If the SMM handler is completed successfully, it will attempt to restart the I/O instruction, but will not have the correct machine state, due to the call to the MCE handler.

**IMPLICATION:** A simultaneous MCE and SMI# assertion may occur for one of the I/O instructions above. The SMM handler may attempt to restart such an I/O instruction, but will have corrupted state due to the MCE handler call, leading to failure of the restart and SHUTDOWN of the processor.

**WORKAROUND:** If a system implementation must support both SMM and MCEs, the first thing the SMM handler code (when an I/O restart is to be performed) should do is check for a pending MCE. If there is an MCE pending, the SMM handler should immediately exit via an RSM instruction and allow the MCE handler to execute and restart the I/O instruction. If there is not, the SMM handler may proceed with its normal operation.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 9. Branch Traps Do Not Function if BTMs Are Also Enabled

**PROBLEM:** If branch traps or branch trace messages (BTMs) are enabled alone, both function as expected. However, if both are enabled, only the BTMs will function, and the branch traps will be ignored.

**IMPLICATION:** The branch traps and branch trace message debugging features cannot be used together.

WORKAROUND: If branch trap functionality is desired, BTMs must be disabled.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 10. Checker BIST Failure in FRC Mode Not Signaled

**PROBLEM:** If a system is running in functional redundancy checking (FRC) mode, and the checker of the master-checker pair encounters a hard failure while running the built-in self test (BIST), the checker will tri-state all outputs without signaling an IERR#.

**IMPLICATION:** Assuming the master passes BIST successfully, it will continue execution unchecked, operating without functional redundancy. However, the necessary pull-up on the FRCERR pin will cause an FRCERR to be signaled. The operation of the master depends on the implementation of FRCERR.

**WORKAROUND:** For successful detection of BIST failure in the checker of an FRC pair, use the FRCERR signal, instead of IERR#.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 11. BINIT# Assertion Causes FRCERR Assertion in FRC Mode

**PROBLEM:** If a pair of Pentium II processors are running in functional redundancy checking (FRC) mode, and a catastrophic error condition causes BINIT# to be asserted, the checker in the master-checker pair will enter SHUTDOWN. The next bus transaction from the master will then result in the assertion of FRCERR.

**IMPLICATION:** Bus initialization via an assertion of BINIT# occurs as the result of a catastrophic error condition which precludes the continuing reliable execution of the system. Under normal circumstances, the master-checker pair would remain synchronized in the execution of the BINIT# handler. However, due to this erratum, an FRCERR will be signaled. System behavior then depends on the behavior of the system specific error recovery mechanisms. **WORKABOUND:** None identified at this time.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.



#### 12. Machine Check Exception Handler May Not Always Execute Successfully

**PROBLEM:** An asynchronous machine check exception (MCE), such as a BINIT# event, which occurs during an access that splits a 4-Kbyte page boundary may leave some internal registers in an indeterminate state. Thus, MCE handler code may not always run successfully if an asynchronous MCE has occurred previously.

**IMPLICATION:** An MCE may not always result in the successful execution of the MCE handler. However, asynchronous MCEs usually occur upon detection of a catastrophic system condition that would also hang the processor. Leaving MCEs disabled will result in the condition which caused the asynchronous MCE instead causing the processor to enter SHUTDOWN. Therefore, leaving MCEs disabled may not improve overall system behavior.

**WORKAROUND:** No workaround which would guarantee successful MCE handler execution under this condition has been identified.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 13. MCE Due to L2 Parity Error Gives L1 MCACOD.LL

**PROBLEM:** If a Cache Reply Parity (CRP) error, Cache Address Parity (CAP) error, or Cache Synchronous Error (CSER) occurs on an access to the Pentium II processor's L2 cache, the resulting Machine Check Architectural Error Code (MCACOD) will be logged with '01' in the LL field. This value indicates an L1 cache error; the value should be '10', indicating an L2 cache error. Note L2 ECC errors have the correct value of '10' logged.

**IMPLICATION:** An L2 cache access error, other than an ECC error, will be improperly logged as an L1 cache error in MCACOD.LL.

WORKAROUND: None identified at this time.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 14. LBER May Be Corrupted After Some Events

**PROBLEM:** The last branch record (LBR) and the last branch before exception record (LBER) can be used to determine the source and destination information for previous branches or exceptions. The LBR contains the source and destination addresses for the last branch or exception, and the LBER contains similar information for the last branch taken before the last exception. This information is typically used to determine the location of a branch which leads to execution of code which causes an exception. However, after a catastrophic bus condition which results in an assertion of BINIT# and the reinitialization of the buses, the value in the LBER may be corrupted. Also, after either a CALL which results in a fault or a software interrupt, the LBER and LBR will be updated to the same value, when the LBER should not have been updated.

**IMPLICATION:** The LBER and LBR registers are used only for debugging purposes. When this erratum occurs, the LBER will not contain reliable address information. The value of LBER should be used with caution when debugging branching code; if the values in the LBR and LBER are the same, then the LBER value is incorrect. Also, the value in the LBER should not be relied upon after a BINIT# event.

WORKAROUND: None identified at this time.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 15. BTMs May Be Corrupted During Simultaneous L1 Cache Line Replacement

**PROBLEM:** When Branch Trace Messages (BTMs) are enabled and such a message is generated, the BTM may be corrupted when issued to the bus by the L1 cache if a new line of data is brought into the L1 data cache simultaneously. Though the new line being stored in the L1 cache is stored correctly, and no corruption occurs in the data, the information in the BTM may be incorrect due to the internal collision of the data line and the BTM.

**IMPLICATION:** Although BTMs may not be entirely reliable due to this erratum, the conditions necessary for this boundary condition to occur have only been exhibited during focused simulation testing. Intel has currently not observed this erratum in a system level validation environment.

WORKAROUND: None identified at this time.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 16. System May Hang Due To Internal Protocol Violation

**PROBLEM:** Pentium II processor based systems may hang due to an internal protocol violation. When a snoopable transaction is issued on the bus and the cache line being accessed is in the modified state, the processor must deliver to the system bus an updated copy of the cache line. When the processor attempts to deliver the most up to date copy via an implicit writeback, the data transfer transaction fails and the DBSY# signal remains asserted until the next RESET#. This causes the system to hang indefinitely. In order to encounter this erratum, the following sequence of events must occur:

- 1. A snoopable transaction (transaction 1) is issued on the system bus. The processor contains in its L1 and/or L2 caches the data for this line in the modified state.
- 2. Another snoopable transaction (transaction 2) is issued and the processor contains this line only in its L2 cache in the modified state. Both of these transactions can be issued by either the chipset, by the processor (in which case they are of the self-snoop type), by another processor (2-way MP systems), or any combination thereof.
- 3. A nonsnoopable transaction is then issued (transaction 3) for which address bits A15-A5 are the same as those in transaction 2.
- 4. Transaction 3 is followed by a snoopable transaction (transaction 4).

## int<sub>el</sub>,

- 5. The completion of the data transfer phase of transaction 1 must line up with the snoop response phase of transaction 3. This data transfer phase of transaction 1 must occur after the ADS# of transaction 4 and line up with the completion of an internal cache transaction.
- 6. The internal cache transaction must miss the L2 targeting a line for eviction, but the internal cache transaction must be such that it has to be re-tried.

The result of this sequence of transactions causes the processor bus to lock up after delivering the data for transaction 1, but prior to delivering the data for transaction 2. Since this data is never delivered, DBSY# does not deassert and the system hangs.

**IMPLICATION:** The Pentium II processor may cause a system to hang if the above listed sequence of events occurs. This sequence is a necessary condition to hit the erratum, but multiple variations of this sequence which also cause this erratum are also possible. The probability of encountering this erratum increases with I/O queue depth greater than 4 and in 2-way MP systems.

WORKAROUND: None identified at this time.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 17. Livelock Condition May Cause System Hang

**PROBLEM:** A "livelock" situation could occur in 2-way MP Pentium II processor-based systems, when IOQ depth is set to 1, with a failure signature such that a processor arbitrates for the system bus but fails to drive out a transaction when it gains ownership of the bus. The processor then relinquishes bus ownership to another requester, but on re-arbitration performs the same repetitive actions. This course of action continues until RESET# is asserted. The failure signature in 2-way MP systems is such that both processors require execution of an explicit writeback cycle and both processors request the bus for this transaction. However, when the time comes to drive out the writeback transaction, the internal request has been suspended due to an internal blocking condition. After the internal blocking condition has gone away the original writeback request is re-asserted. However, by the time bus ownership has been re-gained, the blocking condition has recurred, thus suppressing the writeback request before the transaction can be driven out to the system bus.

The writeback which is waiting to go out on the system bus must be issued before the internal blocking condition can be removed. But the writeback can never be issued because of the recurring blocking condition. This causes an "infinite loop" situation to develop, and the processor essentially stops executing code.

**IMPLICATION:** This erratum was observed to occur when both processors are configured for IOQ depth = 1 in Intel commercial system testing.

WORKAROUND: None identified at this time.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

### int<sub>e</sub>l.

#### 18. Mispredicted Branch May Cause Incorrect Tag Word on MMX™ Technology Instructions

**PROBLEM:** After any MMX<sup>™</sup> technology instruction is executed, all of the FPU stack registers should be marked valid in the FPU tag word. If one or more of the first three instructions of a mispredicted branch are MMX technology instructions of the form "opcode reg, mem" not including MOVD and MOVQ, the FPU tag word is incorrectly modified. Some of the tag word bits may remain invalid. This tag word will remain incorrect until one of two events occur:

- 1. Any MMX<sup>TM</sup> technology instruction is executed four or more instructions after the branch target, or
- 2. An MMX technology instruction of the following type is executed:
  - Any MMX technology instruction of the form "opcode reg, reg"
  - MOVD
  - MOVQ
  - EMMS

The following are examples of code that will encounter this erratum.

#### Example 1:

| EMMS |  |
|------|--|
|      |  |

| ••• |        |                             |  |
|-----|--------|-----------------------------|--|
| Jcc | target | ; mispredicted as not taken |  |
| ••• |        |                             |  |

| PADDW  | mm0, [edi] | ; Is an "reg, mem" format instruction |
|--------|------------|---------------------------------------|
| FSTENV | env        |                                       |

In this example, the tag word stored in memory by FSTENV will be incorrect.

#### Example 2:

target:

target:

| EMM                                | S      |                                                                     |
|------------------------------------|--------|---------------------------------------------------------------------|
| <br>Jcc<br>                        | target | ; mispredicted as not taken                                         |
| PADDW<br>FUCOMPP<br>against mixing |        | mm0, [edi]<br>; depends on tag word, also violates coding guideline |
| FWAIT                              |        | ; floating-point and MMX <sup>™</sup> technology instructions       |

### int<sub>a</sub>,

In this example, the FUCOMPP instruction will cause a Numeric Invalid Operation Exception if the FPU stack fault exception is unmasked.

IMPLICATION: When writing code that mixes FP and MMX technology instructions where the target of a branch is an MMX technology instruction with a memory operand, the FPU tag word may be incorrect. Software that expects the FP stack register to be set to valid after an MMX technology instruction and utilizes this information may be affected.

If floating-point instructions are intermixed, the floating-point instructions may raise the floating-point stack exception. If this exception is unmasked, the application will receive an unexpected numeric exception. The result is application dependent. If the floating-point stack exception is masked, the floating-point instruction will compute with a indefinite operand instead of the register contents. In either case the result is application dependent. Applications that follow the Intel MMX Technology Coding Guidelines against intermixing floating-point and MMX technology code are not affected by this erratum.

If the floating-point tag word is saved immediately after an affected MMX technology instruction, an erroneous value will be stored. Program behavior is application dependent. This may also cause debuggers to temporarily display incorrect tag word contents.

WORKAROUND: All of the following must be applied to work around this erratum:

- Follow the Intel MMX<sup>™</sup> technology guidelines in the *Intel Architecture Developer's* Optimization Manual for writing MMX technology programs. Specifically, do not intermix MMX technology instructions and floating-point instructions on a per instruction basis.
- If it is possible that some of the tag word bits may be invalid prior to a branch, avoid using MMX technology instructions of the form "opcode reg, mem", except MOVD, MOVQ, within the first three instructions at the target of a branch.
- Use the FSAVE instruction to save all floating-point stack registers if at least one of the registers is valid during a context switch.
- Before a nonstandard transition from MMX technology code to floating-point code, execute a nonsusceptible MMX technology instruction such as MOVD eax, mm0.
- Floating point instructions should not depend on MMX technology instructions to set the ٠ tag word bits to valid.

STATUS: For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### Thermal Sensor/THERMTRIP# Does Not Work 19.

PROBLEM: THERMTRIP# is a feature of the Pentium II processor which asserts when the core reaches a certain temperature during operation as specified in the Pentium® II Processor datasheet. The Pentium II processor may assert THERMTRIP# at a temperature lower or higher than the specified trippoint of 135 °C for  $T_{JUNCTION}$ . When THERMTRIP# is asserted, the processor may shut down causing all execution to be halted.

**IMPLICATION:** When running the Pentium II processor, the Pentium II processor core may reach a temperature causing the processor to assert THERMTRIP# early. Once THERMTRIP# has been asserted, the processor may shut down due to this erratum. All execution after the SHUTDOWN will be halted. This erratum is only exhibited when  $T_{PLATE}$  is above the Maximum Specification of 75 °C (see the *Pentium® II Processor* datasheet, Order Number 243335, for details on specifications).

**WORKAROUND:** Avoid operation of the Pentium II processor outside of thermal specifications defined by the *Pentium® II Processor* datasheet. Do not monitor the THERMTRIP# pin (pin A15).

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 20. Spurious Machine Check Exception Via IFU Data Parity Error

**PROBLEM:** The Pentium II processor can signal an unrecoverable Machine Check Exception (MCE) in the event that the Instruction Fetch Unit (IFU) detects a mismatch when verifying instruction parity. The execution of code which modifies the current instruction sequence that may already be fetched into the processor can cause an instruction at a given address to appear differently depending on when it was fetched in time relative to its being modified. Thus, a speculatively prefetched instruction may have been modified such that it now differs from the copy of the same instruction resident in the instruction cache. This discrepancy (of one copy located in the speculative prefetch portion, and a different copy in the instruction cache) is sensed by the IFU. When the IFU detects that the instruction stream has been modified, it flushes the pipeline and attempts to restart the instruction stream. In the interim, the IFU recognizes the disparate instructions described above, and signals a data parity error. The data parity error is signaled as an MCE before the instruction stream has had a chance to restart. This MCE will cause an operating system that has enabled MCE to shut down. No incorrect code is executed by the processor in this situation (even if MCE is disabled). Note that this erratum occurs under a specific set of address dependencies and timing events.

**IMPLICATION:** Executing such a sequence by modifying code without proper synchronization may not always result in predictable program behavior. The processor's signaling of an MCE due to a data parity error in the IFU may then result in an unexpected system halt if the above conditions are met and MCEs are enabled.

**WORKAROUND:** It is possible for BIOS code to contain a workaround for this erratum. **STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 21. Loss of Inclusion In IFU Can Cause Machine Check Exception

**PROBLEM:** The Pentium II processor can signal an unrecoverable Machine Check Exception (MCE) as a consistency checking mechanism in the event that the Instruction Fetch Unit (IFU) detects differences in the consistency of code in instruction streaming buffers against code

# int<sub>el</sub>,

resident in the instruction cache, i.e., a loss of inclusion. When application code makes an operating system call, the processor transitions execution privilege levels. If the code for the OS call is not already resident in the level 1 cache, then the processor may prefetch code while identifying a cache line(s) for eventual eviction to make space for the new code. Upon return from the OS call, the processor continues execution of application code at the user level. The processor, due to deep speculation and branch prediction, may attempt to execute instructions from the previously prefetched kernel code starting by attempting to replace the victim line with kernel code in a buffer internal to the IFU. The IFU detects that the current application is insufficiently privileged to execute the kernel code and so, suppresses the eviction of the previously selected victim line. Despite having detected this condition, the IFU does replace this victim line with the kernel line. If the processor now attempts to restart execution of the current application code by refetching the original victim line it no longer finds it in the instruction cache. The IFU detects this loss of inclusion, and signals this by generating a MCE. If MCEs are enabled, this event can cause an operating system to shut down. Note that this erratum occurs under a specific set of address dependencies and timing events. IMPLICATION: The occurrence of all the conditions above can lead the IFU to signal a loss of inclusion by generating an MCE. If MCEs are enabled in the system, then the operating system may shut down upon noticing the MCE resulting in system failure. If MCEs are disabled, then unpredictable application behavior is theoretically possible, although current validation has shown execution to continue normally.

**WORKAROUND:** It is possible for BIOS code to contain a workaround for this erratum. **STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

### 22. Possible System Hang When Paging Is Disabled and Re-enabled from Uncached Memory

**PROBLEM:** If paging is disabled via the PG bit of CR0 and then later re-enabled while executing code from a page marked uncachable by its Page Table Entry (PCD=1) but located in memory mapped as Write Back or Write Through by the processor MTRRs, the processor could internally enter a state resulting in a system hang.

**IMPLICATION:** Operating systems that enable and disable paging with the above described memory configurations could hang. Intel has not observed this erratum to date in laboratory testing of commercially available operating systems and applications.

**WORKAROUND:** It is possible for BIOS code to contain a workaround for this erratum. **STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 23. L2 Performance Counters Miscount L2\_RQSTS

**PROBLEM:** L2\_RQSTS is a performance counter that counts the number of L2 cache access requests. This counter increments for each incoming L2 cache request. In some cases, an L2

int<sub>el</sub>,

request cannot be serviced by the L2 Cache. This request is then retried at a later time when the request can be serviced by the L2 cache. When this happens, the L2\_RQSTS counter counts the initial L2 cache request **and** the retried L2 cache request, thereby counting the same request twice.

**IMPLICATION:** The L2\_RQSTS counter may contain a larger erroneous number of L2 cache requests due to this erratum. This erratum does not affect functionality of the Pentium II processor. This erratum only affects the performance counter specified.

WORKAROUND: None identified at this time.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 24. Erroneous Signaling of User Mode Protection Violation

**PROBLEM:** If the Pentium II processor attempts to access a page in physical memory marked not present (Present bit clear), a page fault exception (#PF) is generated. Before proceeding, there is a narrow internal timing window where the processor verifies that no other higher priority fault conditions are present. During this time, it is possible for another agent to allocate a new page directory or page table entry (PDE/PTE) corresponding to the same linear address of the original access, writing new values into the PDE/PTE with the Access bit (A-bit) or the Dirty bit (D-bit) cleared. When the original processor completes its checking for other fault conditions, and re-examines the A/D bit of the recently modified PDE/PTE, it finds that it has been cleared. Internal hardware correctly signals this scenario as a condition to which the processor should respond by setting the A/D bit, but erroneously reports it as a generic paging protection violation. Instead of attempting to set the appropriate A/D bit, this event is reported as an Int14 with exception code 0x05, i.e., user mode protection violation.

**IMPLICATION:** The occurrence of this scenario will result in the erroneous signaling of a user mode protection violation instead of a page fault and may result in application termination depending on operating system behavior in response to a user mode protection violation. Intel has only observed this erratum to date in laboratory testing of multiprocessor systems. **WORKAROUND:** Operating systems which allocate new PTEs and PDEs should set the Access bit

(A-bit) and Dirty bit (D-bit) to work around this erratum. Alternately, an operating system's Int14 handler can determine if a protection violation condition truly exists, and if none is found, return without further action.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 25. Invalid Operation Not Signaled By The FIST Instruction on Some Out of Range Operands

**PROBLEM:** On certain, large, negative, floating-point operands, and only in three of the four possible processor rounding modes, the instructions FIST[P] m16int and FIST[P] m32int do not detect that the operand is so large that it will not fit into the target data size. As a consequence,

# int<sub>el</sub>,

the expected Invalid Operation exception response for this situation is not correctly provided, nor is the Invalid Operation flag set in the Floating Point status word as specified in the *Intel Architecture Programmers Reference Manual, Volume 2*. Under the failing conditions, noted below, the precision exception (#PE) will also be incorrectly set.

The erratum occurs only when all of the following conditions are met:

- 1. Operations are unaffected.
- 2. The FIST[P] instruction is either a 16- or 32-bit operation; 64-bit Either the 'to nearest', 'to zero' or 'up' rounding modes are being used. The round 'down' mode is unaffected by this erratum.
- 3. The sign bit of the floating-point operand is negative.
- 4. The floating-point operand being converted is significantly more negative than can be described by the integer size being targeted.

#### ACTUAL vs. EXPECTED RESPONSE

#### A. Actual Response:

When the required conditions are encountered, the processor provides the following response:

- Return the MAXNEG value (8000h for FIST16 & 80000000h for FIST32) to memory.
- The IE (Invalid Operation) bit in the Floating Point status word is *not set* to flag the use of an invalid operand.
- The PE (precision error) bit the Floating Point status word is set.
- No exception handler is invoked.
- In the case of a FISTP instruction the Operand will have been popped from the floating point stack

#### B. Expected Response

The expected processor response when the invalid operation exception is *masked* is:

- Return the MAXNEG value (8000h for FIST16 & 8000000h for FIST32) to memory.
- The IE (Invalid Operation) bit in the Floating Point status word is *set* to flag the overflow.
- The PE (precision error) bit the Floating Point status word is *not set*.

The expected processor response when the invalid operation exception is unmasked is:

- Do not return a result to memory. Keep the original operand intact on the stack.
- The IE (Invalid Operation) bit in the Floating Point status word is *set* to flag the overflow.
- The PE (precision error) bit the Floating Point status word is not set.
- Vector to the user numeric exception handler.

int\_\_\_\_

**IMPLICATION:** Erroneous operation results when the operand is so large that it will not fit into the target data size. The operands affected by this erratum are significantly outside (by a factor of 3X) the range that can be, correctly, converted to an integer value. The figure below and corresponding table identifies the normal range of integer numbers (between A and B) and the starting point of the operands affected by this erratum. Discrete failing operands will be present in the range between point C and the maximum negative number that can be represented by the processor ( $-2^{1023}$  in double precision format). Note 2 below gives a qualitative description of the nature of the discrete failing values. Software that does not rely on the Invalid Operation exception flag being set and signaled by either an exception OR by software polling is not impacted by this erratum.



| 16-bit Operation | А                | В                | С                  |
|------------------|------------------|------------------|--------------------|
|                  | -32,768.0        | +32,767.0        | < -98304.0         |
| 32-bit Operation | А                | В                | С                  |
|                  | -2,147,483,648.0 | +2,147,483,647.0 | < -6,442,450,944.0 |

WORKAROUND: Any of two software workarounds will avoid occurrence of this erratum:

- 1. Range checking performed prior to execution of the FIST[P] instruction will prevent the overflow condition from occurring, and may already be implemented as a standard coding style.
- 2. Software can use the presence of MAXNEG in the result integer to indicate that an out of range conversion may have occurred.

Note 1: A possible alternative is to use the FIST64 instruction to store the converted operand to memory and access the lower 16 or 32 bits as the required integer. Even though this mechanism will not signal an attempted out of range conversion with a 16 bit or 32 bit target, it is currently in use by many compilers today.

Note 2: The values affected by this erratum are those which contain an exponent value within the affected range, AND a specific bit pattern at a specific offset within the mantissa, AND at least one nonzero bit to the right of the above bit pattern. The offset within the mantissa is a function of the floating point exponent value. The specific bit pattern is 0x8000 for FIST16 and

### int<sub>el</sub>,

0x80000000 for FIST32. This means that for any given exponent within the range, one mantissa value in every 2<sup>16</sup> possible mantissa values exhibits the erratum for FIST16, and one mantissa value in every 2<sup>32</sup> possible mantissa values exhibits the erratum for FIST32.

Examples of affected values for FIST16, 80 bit binary notation (not an exhaustive list) (xx means any bit pattern, yy means any nonzero bit pattern)

| sign | exponent       | mantissa                                |
|------|----------------|-----------------------------------------|
| 1    | 10000000010100 | 1xxxxx10000000000000000yyyyyyyyyyyyyyyy |
| 1    | 10000000010101 | 1xxxxxx10000000000000000yyyyyyyyyyyyyyy |
| 1    | 10000000010110 | 1xxxxxx1000000000000000yyyyyyyyyyyyyyyy |

Examples of affected values for FIST32, 80 bit binary notation (not an exhaustive list) (xx means any bit pattern, yy means any nonzero bit pattern)

| sign | exponent       | mantissa                               |
|------|----------------|----------------------------------------|
| 1    | 10000000100011 | 1xxxx100000000000000000000000000000000 |
| 1    | 10000000100100 | 1xxxxx10000000000000000000000000000000 |
| 1    | 10000000100101 | 1xxxxxx1000000000000000000000000000000 |

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 26. FLUSH# Assertion Disables L2 Machine Check Exception Reporting

**PROBLEM:** Upon FLUSH# assertion, the L2 Machine Check Exception generation is disabled. Once the FLUSH# pin is asserted, the processor disables the L2 MCA, by clearing the associated MCi\_CTL control register to "0"s. This operation is invisible to the software being executed.

**IMPLICATION:** Errors that should be reported by the L2 MCA are not reported from the time that the FLUSH# signal is asserted until the time that the MCi\_CTL register is written back to all "1"s. All other errors will continue to be logged as normal.

**WORKAROUND:** Platform specific code (e.g., BIOS or system management software) has the potential for driving a device to assert the FLUSH# pin. If the platform specific code asserts the FLUSH# pin, this code should be enhanced to detect that MCA Exceptions are globally enabled (via register CR4.MCE). The code should then write "0"s to all of the MCi\_CTL registers to clear any spurious entries and then write "1"s to all of the MCi\_CTL registers in order to re-enable exception reporting. Hardware devices in systems that require L2 error reporting which could assert the FLUSH# pin should not assert FLUSH#.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 27. EFLAGS May Be Incorrect After A Multiprocessor TLB Shootdown

PROBLEM: When the Pentium II processor executes a read-modify-write arithmetic instruction with memory as the destination, it is possible for a page fault to occur during the execution of the store on the memory operand after the read operation has completed but before the write operation completes. In this case the EFLAGS value pushed onto the stack of the page fault handler may be reflective of the status of the EFLAGS register after the instruction would have completed execution rather than that before it has executed under a certain set of circumstances. This class of instruction will initially perform a load operation that has the side effect of ensuring that the final store portion of the instruction will successfully complete. The load ensures this by bringing the page table information of the page containing the data into the DTLB. This page entry could be evicted from the DTLB by speculative loads from other instructions that hit the same way of the DTLB, before the store is executed. DTLB eviction will require at least three load operations that have linear address bits 15:12 equal to each other and address bits 31:16 different from each other in close physical proximity to the arithmetic operation. If, in the very small window of time between the page eviction and the store execution, the page table entry has had its page permissions tightened (e.g., from Present to Not Present, or from Read/Write to Read Only, etc.) by the operating system in main memory by another processor (with no corresponding synchronization and subsequent TLB flush, the store will generate a DTLB miss and a call to the OS's page fault handler. The EFLAGS register may have already been updated by the arithmetic portion of the instruction before entry to the page fault handler. If under these circumstances the fault handler elects to restart the instruction the re-execution may generate an incorrect result. Instructions affected by this erratum are the memory destination forms of ADC, SBB, RCR & RCL (instructions that use a flag, carry, as input to the instruction). It should be noted that the locked version of these instructions is not impacted by this erratum.

**IMPLICATION:** This scenario can only occur in a multiprocessor system running under an operating system that implements a "lazy" TLB shootdown. Lazy TLB shootdown occurs when one processor makes changes to the page tables in memory, and then signals other processors to remove the page entry from their TLB without a multiprocessor synchronization being performed. To date, Intel has not observed this erratum in any laboratory testing of commercially available software applications.

In a multiprocessor system the arithmetic flags of the EFLAGS register and its memory stack image, may contain incorrect data if the read-modify-write arithmetic instruction encounters a page fault. Page Fault handler software that uses the resulting EFLAGS may see incorrect information. If the original instruction is restarted by the page fault handler, the instruction may produce incorrect results based on the prior modifications of the EFLAGS register. **WORKAROUND:** Software may use the locked form of the ADC, SBB, RCR & RCL instructions to avoid this erratum. Operating systems should ensure that no processor is currently accessing a page that is scheduled to have its page permissions tightened, e.g., moved from Present to Not Present or have a page fault handler that can handle any incorrect state. Intel is working

with Multiprocessor Operating System vendors to ensure that an OS level workaround is implemented as required.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 28. Delayed Line Invalidation Issue During 2-Way MP Data Ownership Transfer

**PROBLEM:** In 2-way MP systems, each processor may attempt to modify a different portion of the same cache line, referenced as line 'A' in the discussion below. When this erratum occurs (with the following example given for a 2-way MP system with processors noted as 'P0' and 'P1'), each processor contains a shared copy of line A in both their L1 and L2 caches. Each processor must issue an invalidation cycle before that processor can definitively source the results of its internal write to a portion of line A to the other processors.

There exists a narrow timing window when, if P0 wins the external bus invalidation race and gains ownership rights to line A due to the sequence of bus invalidation traffic, P1 may not have completed the pending invalidation of its own, currently valid and shared copy of line A. During this window, it is possible for a P1 internal opportunistic write to a portion of line A (while awaiting ownership rights) to occur with the original shared copy of line A still resident in P1's L2 cache. Such internal modification is permissible subject to delaying the broadcast of such changes until line ownership has actually been gained. However, the processor must ensure that any internal re-read by P1 of line A returns with data in the order actually written; in this case, this should be the data written by P0. In the case of this erratum, the internal re-read uses the data which was written by P1.

**IMPLICATION:** Multiprocessor or threaded application synchronization that is implemented via operating system-provided synchronization constructs are not affected by this erratum. Applications which rely upon the usage of locked semaphores rather than memory ordering are also unaffected. Uniprocessor systems are not affected by this erratum. Intel has not identified, to date, any commercially available application or operating system software which is affected by this erratum. If the erratum does occur, the delayed line invalidation that occurs naturally due to the fact that one processor will necessarily win the invalidation race allows a narrow timing window to exist where one processor may re-read a line that it just wrote internally, but return with the stale data that was present from the previous shared state rather than the data written more recently by another processor.

**WORKAROUND:** Deterministic barriers beyond which program variables will not be modified can be achieved via the usage of locked semaphore operations, and this scheme has been shown to effectively work around this erratum.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 29. Potential Early Deassertion of LOCK# During Split-Lock Cycles

**PROBLEM:** During a split-lock cycle there are four bus transactions; 1st ADS# (a partial read), 2nd ADS# (a partial read), 3rd ADS# (a partial write), and the 4th ADS# (a partial write). Due to this erratum, LOCK# may deassert one clock after the 4th ADS# of the split-lock cycle instead of after the RS# assertion corresponding to the 4th ADS# has been sampled. The following sequence of events are required for this erratum to occur:

- 1. A lock cycle occurs (split or nonsplit).
- 2. Five more bus transactions (assertion of ADS#) occur.
- 3. A split-lock cycle occurs and BNR# toggles after the 3rd ADS# (partial write) of the split-lock cycle. This in turn delays the assertion of the 4th ADS# of the split-lock cycle. BNR# toggling at this time could most likely happen when the bus is set for an IOQ depth of 2.

When all of these events occur, LOCK# will be deasserted in the next clock after the 4th ADS# of the split-lock cycle.

**IMPLICATION:** This may affect chipset logic which monitors the behavior of LOCK# deassertion. **WORKAROUND**: None identified.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 30. A20M# May Be Inverted After Returning From SMM and Reset

PROBLEM: This erratum is seen when software causes the following events to occur:

- 1. The assertion of A20M# in real address mode.
- 2. After entering the 1-Mbyte address wrap-around mode caused by the assertion of A20M#, there is an assertion of SMI# intended to cause a Reset or remove power to the processor. Once in the SMM handler, software saves the SMM state save map to an area of nonvolatile memory from which it can be restored at some point in the future. Then software asserts RESET# or removes power to the processor.
- 3. After exiting Reset or completion of power-on, software asserts SMI# again. Once in the SMM handler, it then retrieves the old SMM state save map which was saved in event 2 above and copies it into the current SMM state save map. Software then asserts A20M# and executes the RSM instruction. After exiting the SMM handler, the polarity of A20M# is inverted.

**IMPLICATION:** If this erratum occurs, A20M# will behave with a polarity opposite from what is expected (i.e., the 1-Mbyte address wrap-around mode is enabled when A20M# is deasserted, and does not occur when A20M# is asserted).

**WORKAROUND:** Software should save the A20M# signal state in nonvolatile memory before an assertion of RESET# or a power down condition. After coming out of Reset or at power on, SMI# should be asserted again. During the restoration of the old SMM state save map described in event 3 above, the entire map should be restored, except for bit 5 of the byte at

offset 7F18h. This bit should retain the value assigned to it when the SMM state save map was created in event 3. The SMM handler should then restore the original value of the A20M# signal.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

## 31. Reporting of Floating-Point Exception May be Delayed

**PROBLEM:** The Pentium II processor normally reports a floating-point exception for an instruction when the next floating-point or MMX technology instruction is executed. The assertion of FERR# and/or the INT 16 interrupt corresponding to the exception may be delayed until the floating-point or MMX technology instruction *after* the one which is expected to trigger the exception, if the following conditions are met:

- 1. A floating-point instruction causes an exception.
- 2. Before another floating-point or MMX<sup>TM</sup> technology instruction, any one of the following occurs:
  - a. A subsequent data access occurs to a page which has not been marked as accessed, or
  - b. Data is referenced which crosses a page boundary, or
  - c. A possible page-fault condition is detected which, when resolved, completes without faulting.

3. The instruction causing event 2 above is followed by a MOVQ or MOVD store instruction. **IMPLICATION:** This erratum only affects software which operates with floating-point exceptions unmasked. Software which requires floating-point exceptions to be visible on the next floating-point or MMX technology instruction, and which uses floating-point calculations on data which is then used for MMX technology instructions, may see a delay in the reporting of a floating-point instruction exception in some cases. Note that mixing floating-point and MMX technology instructions in this way is not recommended.

**WORKAROUND:** Inserting a WAIT or FWAIT instruction (or reading the floating-point status register) between the floating-point instruction and the MOVQ or MOVD instruction will give the expected results. This is already the recommended practice for software.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

## 32. EFLAGS Discrepancy On A Page Fault After A Multiprocessor TLB Shootdown

**PROBLEM:** This erratum may occur when the Pentium II processor executes one of the following read-modify-write arithmetic instructions and a page fault occurs during the store of the memory operand: ADD, AND, BTC, BTR, BTS, CMPXCHG, DEC, INC, NEG, NOT, OR, ROL/ROR, SAL/SAR/SHL/SHR, SHLD, SHRD, SUB, XOR, and XADD. In this case, the

EFLAGS value pushed onto the stack of the page fault handler may reflect the status of the register after the instruction would have completed execution rather than before it. The following conditions are required for the store to generate a page fault and call the operating system page fault handler:

- 1. The store address entry must be evicted from the DTLB by speculative loads from other instructions that hit the same way of the DTLB before the store has completed. DTLB eviction requires at least three load operations that have linear address bits 15:12 equal to each other and address bits 31:16 different from each other in close physical proximity to the arithmetic operation.
- 2. The page table entry for the store address must have its permissions tightened during the very small window of time between the DTLB eviction and execution of the store. Examples of page permission tightening include from Present to Not Present or from Read/Write to Read Only, etc.
- 3. Another processor, without corresponding synchronization and TLB flush, must cause the permission change.

**IMPLICATION:** This scenario may only occur on a multiprocessor platform running an operating system that performs "lazy" TLB shootdowns. The memory image of the EFLAGS register on the page fault handler's stack prematurely contains the final arithmetic flag values although the instruction has not yet completed. Intel has not identified any operating systems that inspect the arithmetic portion of the EFLAGS register during a page fault nor observed this erratum in laboratory testing of software applications.

**WORKAROUND:** No workaround is needed upon normal restart of the instruction, since this erratum is transparent to the faulting code and results in correct instruction behavior. Operating systems may ensure that no processor is currently accessing a page that is scheduled to have its page permissions tightened or have a page fault handler that ignores any incorrect state. **STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 33. Near CALL to ESP Creates Unexpected EIP Address

**PROBLEM:** As documented, the CALL instruction saves procedure linking information in the procedure stack and jumps to the called procedure specified with the destination (target) operand. The target operand specifies the address of the first instruction in the called procedure. This operand can be an immediate value, a general purpose register, or a memory location. When accessing an absolute address indirectly using the stack pointer (ESP) as a base register, the base value used is the value in the ESP register before the instruction executes. However, when accessing an absolute address directly using ESP as the base register, the base value of ESP **after** the return value is pushed on the stack, not the value in the ESP register **before** the instruction executed.

**IMPLICATION:** Due to this erratum, the processor may transfer control to an unintended address. Results are unpredictable, depending on the particular application, and can range from no effect to the unexpected termination of the application due to an exception. Intel has observed this erratum only in a focused testing environment. Intel has not observed any commercially available operating system, application, or compiler that makes use of or generates this instruction.

**WORKAROUND:** If the other seven general purpose registers are unavailable for use, and it is necessary to do a CALL via the ESP register, first push ESP onto the stack, then perform an **indirect** call using ESP (e.g., CALL [ESP]). The saved version of ESP should be popped off the stack after the call returns.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

## 34. Deep Sleep Exit Transition May Cause Hang

**PROBLEM:** Under normal operating conditions, when a system enters a power conservation mode, it enters System Management Mode (SMM), puts the processor in the Stop Grant State, followed by Sleep State and then may enter Deep Sleep State. Upon a resume event, the processor exits Deep Sleep but remains in SMM execution space until the SMI handler completes the system resume cycle.

If, prior to entering the Deep Sleep, the system was in SMM space, it is possible for the processor to exit Deep Sleep state and begin making accesses in the 'normal' memory space instead of staying in SMM space. The converse is also possible, i.e., if the processor is in 'normal' space prior to entering the Deep Sleep state, the processor may exit Deep Sleep and make accesses in SMM space instead.

**IMPLICATION:** Systems may execute incorrect code after exiting Deep Sleep, due to accesses to incorrect address space. This may produce unpredictable behavior, most likely hanging the system.

WORKAROUND: Avoid entering Deep Sleep. The table below offers the possible state transitions:

| # | System State             |                    | Process                                 | or State           | Possible Solutions                                                                                                                                                                    |                                                                                                                                                                                       |
|---|--------------------------|--------------------|-----------------------------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | Name                     | ACPI<br>Equivalent | Transition                              | ACPI<br>Equivalent | Description                                                                                                                                                                           | Suggested<br>Solution                                                                                                                                                                 |
| 1 | Active                   | S0                 | Normal to<br>Stop Grant                 | C0, C1             | N/A                                                                                                                                                                                   | None<br>necessary                                                                                                                                                                     |
| 2 | Active                   | S0                 | Stop Grant<br>to Sleep to<br>Deep Sleep | C1, C3             | Use Stop<br>Grant/Sleep<br>only; do not<br>use Deep<br>Sleep                                                                                                                          | BIOS can<br>specify the<br>C3 latency<br>time to be<br>>1000 $\mu$ s in<br>the ACPI<br>FACP table<br>(P_LVL3_LA<br>T, worst case<br>hardware<br>latency for<br>the C3 state).         |
| 3 | Powered<br>On<br>Suspend | \$1, \$2           | Stop Grant<br>to Deep<br>Sleep          | C1, C3             | Reset CPU<br>only and<br>flush the<br>cache<br>without<br>resetting<br>the PCI bus,<br>i.e., use<br>POS_CCL<br>state (POS<br>with CPU<br>Context<br>Lost)<br>instead of<br>POS state. | BIOS can<br>prevent the<br>OS from<br>entering the<br>S1 state by<br>NOT defining<br>the S1 object<br>in the ACPI<br>DSDT table.<br>Ensure that<br>the cache is<br>always<br>flushed. |

int<sub>el</sub>.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 35. Built-in Self Test Always Gives Nonzero Result

**PROBLEM:** The Built-in Self Test (BIST) of the Pentium II processor does not give a zero result to indicate a passing test. Regardless of pass or fail status, bit 6 of the BIST result in the EAX register after running BIST is set.

**IMPLICATION:** Software which relies on a zero result to indicate a passing BIST will indicate BIST failure.

WORKAROUND: Mask bit 6 of the BIST result register when analyzing BIST results.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

## 36. THERMTRIP# May Not be Asserted as Specified

**PROBLEM:** THERMTRIP# is a signal on the Pentium II processor which is asserted when the core reaches a critical temperature during operation as detailed in the processor specification. The Pentium II processor may not assert THERMTRIP# until a much higher temperature than the one specified is reached.

**IMPLICATION:** The THERMTRIP# feature is not functional on the Pentium II processor. Note that this erratum can only occur when the processor is running with a  $T_{PLATE}$  temperature over the maximum specification of 75 °C.

**WORKAROUND:** Avoid operation of the Pentium II processor outside of the thermal specifications defined by the processor specifications.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

### 37. Cache State Corruption in the Presence of Page A/D-bit Setting and Snoop Traffic

**PROBLEM:** If an operating system uses the Page Access and/or Dirty bit feature implemented in the Intel architecture and there is a significant amount of snoop traffic on the bus, while the processor is setting the Access and/or Dirty bit the processor may inappropriately change a single L1 cache line to the modified state.

**IMPLICATION:** The occurrence of this erratum may result in cache incoherency, which may cause parity errors, data corruption (with no parity error), unexpected application or operating system termination, or system hangs.

**WORKAROUND:** It is possible for BIOS code to contain a workaround for this erratum. **STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

## 38. Snoop Cycle Generates Spurious Machine Check Exception

**PROBLEM:** The processor may incorrectly generate a Machine Check Exception (MCE) when it processes a snoop access that does not hit the L1 data cache. Due to an internal logic error, this type of snoop cycle may still check data parity on undriven data lines. The processor generates a spurious machine check exception as a result of this unnecessary parity check.

**IMPLICATION:** A spurious machine check exception may result in an unexpected system halt if Machine Check Exception reporting is enabled in the operating system.

WORKAROUND: It is possible for BIOS code to contain a workaround for this erratum.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 39. MOVD/MOVQ Instruction Writes to Memory Prematurely

**PROBLEM:** When an instruction encounters a fault, the faulting instruction should not modify any CPU or system state. However, when the MMX technology store instructions MOVD and MOVQ encounter any of the following events, it is possible for the store to be committed to memory even though it should be canceled:

- 1. If CR0.EM = 1 (Emulation bit), then the store could happen prior to the triggered invalid opcode exception.
- 2. If the floating-point Top-of-Stack (FP TOS) is not zero, then the store could happen prior to executing the processor assist routine that sets the FP TOS to zero.
- 3. If there is an unmasked floating-point exception pending, then the store could happen prior to the triggered unmasked floating-point exception.
- 4. If CR0.TS = 1 (Task Switched bit), then the store could happen prior to the triggered Device Not Available (DNA) exception.

If the MOVD/MOVQ instruction is restarted after handling any of the above events, then the store will be performed again, overwriting with the expected data. The instruction will not be restarted after event 1. The instruction will definitely be restarted after events 2 and 4. The instruction may or may not be restarted after event 3, depending on the specific exception handler.

**IMPLICATION:** This erratum causes unpredictable behavior in an application if MOVD/MOVQ instructions are used to manipulate semaphores for multiprocessor synchronization, or if these MMX instructions are used to write to uncacheable memory or memory mapped I/O that has side effects, e.g., graphics devices. This erratum is completely transparent to all applications that do not have these characteristics. When each of the above conditions are analyzed:

- 1. Setting the CR0.EM bit forces all floating-point/MMX<sup>™</sup> instructions to be handled by software emulation. The MOVD/MOVQ instruction, which is an MMX instruction, would be considered an invalid instruction. Operating systems typically terminates the application after getting the expected invalid opcode fault.
- 2. The FP TOS not equal to 0 case only occurs when the MOVD/MOVQ store is the first MMX instruction in an MMX technology routine and the previous floating-point routine did not clean up the floating-point states properly when it exited. Floating-point routines commonly leave TOS to 0 prior to exiting. For a store to be executed as the first MMX instruction in an MMX technology routine following a floating-point routine, the software would be implementing instruction level intermixing of floating-point and MMX instructions. Intel does not recommend this practice.
- 3. The unmasked floating-point exception case only occurs if the store is the first MMX technology instruction in an MMX technology routine and the previous floating-point routine exited with an unmasked floating-point exception pending. Again, for a store to be executed as the first MMX instruction in an MMX technology routine following a floating-

point routine, the software would be implementing instruction level intermixing of floatingpoint and MMX instructions. Intel does not recommend this practice.

4. Device Not Available (DNA) exceptions occur naturally when a task switch is made between two tasks that use either floating-point instructions and/or MMX instructions. For this erratum, in the event of the DNA exception, data from the prior task may be temporarily stored to the present task's program state.

**WORKAROUND:** Do not use MMX instructions to manipulate semaphores for multiprocessor synchronization. Do not use MOVD/MOVQ instructions to write directly to I/O devices if doing so triggers user visible side effects. An OS can prevent old data from being stored to a new task's program state by cleansing the FPU explicitly after every task switch. Follow Intel's recommended programming paradigms in the *Intel Architecture Developer's Optimization Manual* for writing MMX technology programs. Specifically, do not mix floating-point and MMX instructions. When transitioning to new a MMX technology routine, begin with an instruction that does not depend on the prior state of either the MMX technology registers or the floating point registers, such as a load or PXOR mm0, mm0. Be sure that the FP TOS is clear before using MMX instructions.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

## 1AP. APIC Access to Cacheable Memory Causes SHUTDOWN

**PROBLEM:** APIC operations which access memory with any type other than uncacheable (UC) are illegal. If an APIC operation to a memory type other than UC occurs and Machine Check Exceptions (MCEs) are disabled, the processor will enter SHUTDOWN after such an access. If MCEs are enabled, an MCE will occur. However, in this circumstance, a second MCE will be signaled. The second MCE signal will cause the Pentium II processor to enter SHUTDOWN. **IMPLICATION:** Recovery from a PIC access to cacheable memory will not be successful. Software that accesses only UC type memory during APIC operations will not encounter this erratum.

**WORKAROUND:** Ensure that the memory space to which PIC accesses can be made is marked as type UC (uncacheable) in the memory type range registers (MTRRs) to avoid this erratum. **STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

## 2AP. 2-way MP Systems May Hang Due to Catastrophic Errors During BSP Determination

**PROBLEM:** In 2-way MP systems, a catastrophic error during the bootstrap processor (BSP) determination process should cause the assertion of IERR#. If the catastrophic error is due to the APIC data bus being stuck at electrical zero, then the system hangs without asserting IERR#.

int<sub>e</sub>l.

**IMPLICATION:** 2-way MP systems may hang during boot due to a catastrophic error. This erratum has not been observed to date in a typical commercial system, but was found during focused system testing using a grounded APIC data bus.

WORKAROUND: None identified at this time.

**STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

#### 3AP. Write to Mask LVT (Programmed as EXTINT) Will Not Deassert Outstanding Interrupt

**PROBLEM:** If the APIC subsystem is configured in Virtual Wire Mode implemented through the local APIC, (i.e., the 8259 INTR signal is connected to LINTO and LVT1's interrupt delivery mode field is programmed as EXTINT), a write to LVT1 intended to mask interrupts will not deassert the internal interrupt source if the external LINTO signal is already asserted. The interrupt will be erroneously posted to the Pentium II processor despite the attempt to mask it via the LVT.

**IMPLICATION:** Because of the masking attempt, interrupts may be generated when the system software expects no interrupts to be posted.

**WORKAROUND:** Software can issue a write to the 8259A interrupt mask register to deassert the LINTO interrupt level, followed by a read to the controller to ensure that the LINTO signal has been deasserted. Once this is ensured, software may then issue the write to mask LVT entry 1. **STATUS:** For the steppings affected see the Summary Table of Changes at the beginning of this section.

## **DOCUMENTATION CHANGES**

The Documentation Changes listed in this section apply to the *Pentium® II Processor* datasheet. All Documentation Changes will be incorporated into a future version of the appropriate Pentium II processor documentation.

## 1. Note 4 of Table 13 and Note 6 of Table 16, Output Valid Delay Specified to 2.5 V +5%

The following change is to Section 2.13., Table 13, *System Bus AC Specifications (CMOS Signal Group)* and Section 2.13., Table 16, *System Bus AC Specifications (TAP Connection)*. Note 4 of Table 13 and Note 6 of Table 16 in the *Pentium® II Processor* datasheet state that the 2.5 V Output Valid Delay is specified to  $V_{CCCORE}$ . This is incorrect. Each note should read "Valid delay timings for these signals are specified to 2.5 V +5%. See Table 3 for pull-up resistor values."

## 2. Invalid Arithmetic Operations and Masked Responses to Them Relative to FIST/FISTP Instruction

The Pentium<sup>®</sup> Pro Family Developer's Manual, Volume 2: Programmer's Reference Manual, Table 7-20 and the Intel Architecture Software Developer's Manual, Volume 1, Table 7-20 show "Invalid Arithmetic Operations and the Masked Responses to Them." The table entry corresponding to the FIST/FISTP condition is missing, and is shown below:

| Condition                                                                         | Masked Response                       |  |
|-----------------------------------------------------------------------------------|---------------------------------------|--|
| FIST/FISTP instruction when input operand <> MAXINT for destination operand size. | Return MAXNEG to destination operand. |  |

When FIST/FISTP instruction is executed with input operand <> and the destination operand size is MAXINT, the floating-point zero-divide exception will return MAXNEG to the destination operand as its masked response.

## 3. FIDIV/FIDIVR m16int Description

The Pentium<sup>®</sup> Pro Family Developer's Manual, Volume 2: Programmer's Reference Manual, pages 11-118 and 11-121, and the Intel Architecture Software Developer's Manual, Volume 1, pages 3-118 and 3-122, show in the Description column for the FIDIV *m16int* instruction as "Divide ST(0) by *m64int* by ST(0) and store the result in ST(0)" and FIDIVR *m16int* instruction as "Divide *m64int* by ST(0) and store the result in ST(0)" In both of these cases, *m64int* should be replaced with *m16int*.

#### 4. PUSH Does Not Pad With Zeros

The *Pentium® Pro Family Developer's Manual, Volume 2: Programmer's Reference Manual*, page 4-2, and the *Intel Architecture Software Developer's Manual, Volume 1*, page 4-3, contain a section regarding stack alignment. The last sentence in the first paragraph of this section, which reads "If a 16-bit value is pushed onto a 32-bit wide stack, the value is automatically padded with zeros out to 32-bits." should be removed. The PUSH instruction does not pad with zeros.

#### 5. DR7, Bit 10 is Reserved

The Pentium® Pro Family Developer's Manual, Volume 3: Operating Systems Writer's Manual, shows Figure 10-1., Debug Registers. Bit 10 of DR7 should be "Reserved" instead of "1".

#### 6. Additional States That Are Not Automatically Saved and Restored

In Section 9.4.1. of the *Pentium® Pro Family Developer's Manual, Volume 3: Operating Systems Writer's Manual,* and in Section 11.4.1. of the *Intel Architecture Software Developer's Manual, Volume 3: System Programming Guide,* the end of section lists the registers that are not automatically saved and restored following an SMI and the RSM instruction, respectively. The last two paragraphs should be as follows:

The following state is not automatically saved and restored following an SMI and the RSM instruction, respectively:

- Debug registers DR0 through DR3.
- The FPU registers.
- The MTRRs.
- Control register CR2.
- The model-specific registers (for the P6 family and Pentium® processors) or test registers TR3 through TR7 (for the Pentium and Intel486<sup>TM</sup> processors).
- The state of the trap controller.
- The machine-check architecture registers.
- The APIC internal interrupt state (ISR, IRR, etc.).
- The Microcode Update state.

If an SMI is used to power down the processor, a power-on reset will be required before returning to SMM, which will reset much of this state back to its default values. So an SMI handler that is going to trigger power down should first read these registers listed above directly, and save them (along with the rest of RAM) to nonvolatile storage. After the power-on reset, the continuation of the SMI handler should restore these values, along with the rest of the system's state. Anytime the SMI handler changes these registers in the processor it must also save and restore them.

#### NOTE

A small subset of the MSRs (such as the time-stamp counter and performance-monitoring counter) are not arbitrarily writeable and therefore cannot be saved and restored. SMM-based power-down and restoration should only be performed with operating systems that do not use or rely on the values of these registers. Operating system developers should be aware of this fact and ensure that their operating-system assisted power-down and restoration software is immune to unexpected changes in these register values.

# int<sub>e</sub>l,

## SPECIFICATION CLARIFICATIONS

The Specification Clarifications listed in this section apply to the *Pentium® II Processor at 233 MHz, 266 MHz and 300 MHz* datasheet. All Specification Clarifications will be incorporated into a future version of the appropriate Pentium II processor documentation.

#### 1. Writes to WC Memory

Section 11.3. of the *Pentium® Pro Family Developer's Manual, Volume 3: Operating System Writer's Guide,* identifies that "Writes" to a region of WC memory "may be delayed and combined in the write buffer to reduce memory accesses." This sentence should state that "Writes" to a region of WC memory "may be delayed and combined in the write buffer to reduce memory accesses. The writes may be delayed until the next occurrence of a buffer or processor serialization event, e.g., CPUID execution, a read or write to uncached memory, interrupt occurrence, LOCKed instruction execution, etc., if the WC buffer is partially filled."

#### 2. Multiple Processors Protocol and Restrictions

Section 7.5.2., "Protocol Requirements and Restrictions," in the *Pentium® Pro Family Developer's Manual, Volume 3: Operating System Writer's Guide*, contain inconsistencies which will be clarified as follows:

#### 7.5.2. Protocol Requirements and Restrictions

The MP protocol imposes the following requirements and restrictions on the system:

- An APIC clock (APICLK) must be provided on all systems based on the Pentium<sup>®</sup> Pro processor.
- All interrupt mechanisms must be disabled for the duration of the MP protocol algorithm including the window of time between the assertion of INIT# or receipt of an INIT IPI by the application processors and the receipt of a STARTUP IPI by the application processors. That is, requests generated by interrupting devices must not be seen by the local APIC unit (on board the processor) until the completion of the algorithm. Failure to disable the interrupt mechanisms may result in processor shutdown.
- The MP protocol should be initiated only after a hardware reset. After completion of the protocol algorithm, a flag is set in the APIC base MSR of the BSP (APIC\_BASE.BSP) to indicate that it is the BSP. This flag is cleared for all other processors. If a processor or the system is subject to an INIT sequence (either through the INIT# pin or an INIT IPI), then the MP protocol is not re-executed. Instead, each processor examines its BSP flag to determine whether the processor should boot or wait for a STARTUP IPI.

### 3. NMI Handling While in SMM

Section 9.7., "NMI Handling While in SMM," in the *Pentium® Pro Family Developer's Manual, Volume 3: Operating System Writer's Guide*, will be clarified as follows:

#### 9.7. NMI Handling while in SMM

NMI interrupts are blocked upon entry to the SMI handler. If an NMI request occurs during the SMI handler, it is latched and serviced after the processor exits SMM. Only one NMI request will be latched during the SMI handler. If an NMI request is pending when the processor executes the RSM instruction, the NMI is serviced before the next instruction of the interrupted code sequence.

Although the NMI requests are blocked when the CPU enters SMM, they may be enabled through software by executing an IRET/IRETD instruction. If the SMM handler requires the use of NMI interrupts, it should invoke a dummy interrupt service routine for the purpose of executing an IRET/IRETD instruction. Once an IRET/IRETD instruction is executed, NMI interrupt requests are serviced in the same "real mode" manner in which they are handled outside of SMM.

## 4. Critical Sequence of Events During a Page Fault Exception

Section 3.6.4., "Page-Directory and Page-Table Entries," in the *Pentium® Pro Family Developer's Manual, Volume 3: Operating System Writer's Guide*, will be clarified as follows:

If the processor generates a page-fault exception, the operating system must carry out the following operations in this order:

- 1. Copy the page from disk storage into physical memory if needed.
- 2. Load the page address into the page-table or page-directory entry and set its *present* flag. Other bits, such as the dirty and accessed bits, may also be set at this time.
- 3. Invalidate the current page table entry in the TLB (see Section 3.7., "Translation Lookaside Buffers (TLBs)" for a discussion of TLBs and how to invalidate them).
- 4. Return from the page fault handler to restart the interrupted program or task.

## 5. Performance-Monitoring Counter Issues

The following table documents the characterized differences between the behavior of the Pentium II processor's performance-monitoring counters and that documented in Appendix B, *Performance Monitoring Counters*, of the *Pentium® Pro Family Developer's Manual, Volume 3: Operating System Writer's Guide*.

The following table replaces Table B-1, Appendix B, *Pentium® Pro Family Developer's Manual, Volume 3*. The only change to this new table are enhanced descriptions of the events counted.

| Unit                           | Event<br>Number | Mnemon-<br>ic Event<br>Name | Unit<br>Mask | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Comments |
|--------------------------------|-----------------|-----------------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| Data<br>Cache<br>Unit<br>(DCU) | 43Н             | DATA_<br>MEM_<br>REFS       | 00Н          | All loads from any<br>memory type. All<br>stores to any memory<br>type. Each part of a<br>split is counted<br>separately. The internal<br>logic counts not only<br>external memory loads<br>and stores, but also<br>internal retries.<br>Note: 80 bit floating<br>point accesses are<br>double counted, since<br>they are decomposed<br>into a 16 bit exponent<br>load and a 64 bit<br>mantissa load.<br>Memory accesses are<br>only counted when they<br>are actually performed.<br>E.g., a load that gets<br>squashed because a<br>previous cache miss is<br>outstanding to the same<br>address, and which<br>finally gets performed,<br>is only counted once.<br>Does not include I/O<br>accesses, or other<br>nonmemory accesses. |          |
|                                | 45H             | DCU_LIN<br>ES_IN            | 00H          | Total lines allocated in the DCU.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          |
|                                | 46H             | DCU_M_<br>LINES_IN          | 00H          | Number of M state<br>lines allocated in the<br>DCU.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          |

| Unit                                       | Event<br>Number | Mnemon-<br>ic Event<br>Name            | Unit<br>Mask | Description                                                                                                                                                                                                                                                                                                                                         | Comments                                                                                                                                                                                                                                                                                         |
|--------------------------------------------|-----------------|----------------------------------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                            | 47H             | DCU_M_<br>LINES_<br>OUT                | 00H          | Number of M state<br>lines evicted from the<br>DCU. This includes<br>evictions via snoop<br>HITM, intervention or<br>replacement.                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                  |
|                                            | 48H             | DCU_<br>MISS_<br>OUT-<br>STAND-<br>ING | 00H          | Weighted number of<br>cycles while a DCU<br>miss is outstanding,<br>incremented by the<br>number of outstanding<br>cache misses at any<br>particular time.<br>Cacheable read<br>requests only are<br>considered.<br>Uncacheable requests<br>are excluded. Read-for-<br>ownerships are counted<br>as well as line fills,<br>invalidates, and stores. | An access that<br>also misses the<br>L2 is short-<br>changed by 2<br>cycles (i.e., if<br>count is N<br>cycles, should<br>be N+2 cycles).<br>Subsequent<br>loads to the<br>same cache line<br>will not result in<br>any additional<br>counts. Count<br>value not<br>precise, but still<br>useful. |
| Instr-<br>uction<br>Fetch<br>Unit<br>(IFU) | 80H             | IFU_<br>IFETCH                         | 00H          | Number of instruction<br>fetches, both cacheable<br>and noncacheable.<br>Including UC fetches.                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                  |
|                                            | 81H             | IFU_<br>IFETCH_<br>MISS                | 00H          | Number of instruction<br>fetch misses. All<br>instruction fetches that<br>do not hit the IFU, i.e.,<br>that produce memory<br>requests. Includes UC<br>accesses.                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                  |

| Unit                     | Event<br>Number | Mnemon-<br>ic Event<br>Name | Unit<br>Mask | Description                                                                                                                                                                                                                                                                                      | Comments |
|--------------------------|-----------------|-----------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
|                          | 85H             | ITLB_<br>MISS               | 00H          | Number of ITLB misses.                                                                                                                                                                                                                                                                           |          |
|                          | 86H             | IFU_<br>MEM_<br>STALL       | 00H          | Number of cycles<br>instruction fetch is<br>stalled, for any reason.<br>Includes IFU cache<br>misses, ITLB misses,<br>ITLB faults and other<br>minor stalls.                                                                                                                                     |          |
|                          | 87H             | ILD_<br>STALL               | 00H          | Number of cycles that<br>the instruction length<br>decoder is stalled.                                                                                                                                                                                                                           |          |
| L2<br>Cache <sup>1</sup> | 28H             | L2_<br>IFETCH               | MESI<br>OFH  | Number of L2<br>instruction fetches.<br>This event indicates<br>that a normal<br>instruction fetch was<br>received by the L2. The<br>count includes only L2<br>cacheable instruction<br>fetches; it does not<br>include UC instruction<br>fetches. It does not<br>include ITLB miss<br>accesses. |          |
|                          | 29Н             | L2_LD                       | MESI<br>OFH  | Number of L2 data<br>loads. This event<br>indicates that a normal,<br>unlocked, load memory<br>access was received by<br>the L2. It includes only<br>L2 cacheable memory<br>accesses; it does not<br>include I/O accesses,<br>other nonmemory<br>accesses, or memory                             |          |

## intപ്ര.

## PENTIUM® II PROCESSOR SPECIFICATION UPDATE

| Unit | Event<br>Number | Mnemon-<br>ic Event<br>Name | Unit<br>Mask | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Comments |
|------|-----------------|-----------------------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
|      |                 |                             |              | accesses such as<br>UC/WT memory<br>accesses. It does<br>include L2 cacheable<br>TLB miss memory<br>accesses.                                                                                                                                                                                                                                                                                                                                                                                                                 |          |
|      | 2AH             | L2_ST                       | MESI<br>OFH  | Number of L2 data<br>stores. This event<br>indicates that a normal,<br>unlocked, store<br>memory access was<br>received by the L2.<br>Specifically, it<br>indicates that the DCU<br>sent a read-for-<br>ownership request to<br>the L2. It also includes<br>Invalid to Modified<br>requests sent by the<br>DCU to the L2. It<br>includes only L2<br>cacheable store<br>memory accesses; it<br>does not include I/O<br>accesses, other<br>nonmemory accesses<br>like UC/WT stores. It<br>includes TLB miss<br>memory accesses. |          |
|      | 24H             | L2_LINES<br>_IN             | 00H          | Number of lines<br>allocated in the L2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |          |
|      | 26H             | L2_LINES<br>_OUT            | 00H          | Number of lines<br>removed from the L2<br>for any reason.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          |

## PENTIUM<sup>®</sup> II PROCESSOR SPECIFICATION UPDATE

| Unit                                        | Event<br>Number | Mnemon-<br>ic Event<br>Name | Unit<br>Mask                  | Description                                                                                                               | Comments                                                                                                                                                                         |
|---------------------------------------------|-----------------|-----------------------------|-------------------------------|---------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                             | 25H             | L2_M_<br>LINES_<br>INM      | 00H                           | Number of modified<br>lines allocated in the<br>L2.                                                                       |                                                                                                                                                                                  |
|                                             | 27H             | L2_M_<br>LINES_<br>OUTM     | 00H                           | Number of modified<br>lines removed from the<br>L2 for any reason.                                                        |                                                                                                                                                                                  |
|                                             | 2EH             | L2_<br>RQSTS                | MESI<br>0FH                   | Total number of L2 requests.                                                                                              |                                                                                                                                                                                  |
|                                             | 21H             | L2_ADS                      | 00H                           | Number of L2 address strobes.                                                                                             |                                                                                                                                                                                  |
|                                             | 22H             | L2_DBUS<br>_BUSY            | 00H                           | Number of cycles<br>during which the L2<br>cache data bus was<br>busy.                                                    |                                                                                                                                                                                  |
|                                             | 23H             | L2_DBUS<br>_BUSY_<br>RD     | 00H                           | Number of cycles<br>during which the data<br>bus was busy<br>transferring read data<br>from L2 to the<br>processor.       |                                                                                                                                                                                  |
| Exter-<br>nal<br>Bus<br>Logic<br>(EBL)<br>2 | 62H             | BUS_<br>DRDY_<br>CLOCKS     | 00H<br>(Self)<br>20H<br>(Any) | Number of clocks<br>during which DRDY#<br>is asserted. Essentially,<br>utilization of the<br>external system data<br>bus. | Unit Mask =<br>00H counts bus<br>clocks when the<br>processor is<br>driving DRDY#.<br>Unit Mask =<br>20H counts in<br>processor clocks<br>when any agent<br>is driving<br>DRDY#. |
|                                             | 63H             | BUS_<br>LOCK_<br>CLOCKS     | 00H<br>(Self)<br>20H<br>(Any) | Number of clocks<br>during which LOCK#<br>is asserted on the<br>external system bus.                                      | Always counts<br>in processor<br>clocks.                                                                                                                                         |

## PENTIUM® II PROCESSOR SPECIFICATION UPDATE

| Unit | Event<br>Number | Mnemon-<br>ic Event<br>Name       | Unit<br>Mask                  | Description                                                                                                                                                    | Comments                                                                                                                                                                                                 |
|------|-----------------|-----------------------------------|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 60H             | BUS_REQ<br>_OUT-<br>STAND-<br>ING | 00H<br>(Self)                 | Number of bus requests<br>outstanding. This<br>counter is incremented<br>by the number of<br>cacheable read bus<br>requests outstanding in<br>any given cycle. | Counts only<br>DCU full-line<br>cacheable reads,<br>not RFOs,<br>writes,<br>instruction<br>fetches, or<br>anything else.<br>Counts "waiting<br>for bus to<br>complete" (last<br>data chunk<br>received). |
|      | 65H             | BUS_<br>TRAN_<br>BRD              | 00H<br>(Self)<br>20H<br>(Any) | Number of burst read transactions.                                                                                                                             |                                                                                                                                                                                                          |
|      | 66H             | BUS_<br>TRAN_<br>RFO              | 00H<br>(Self)<br>20H<br>(Any) | Number of completed<br>read for ownership<br>transactions.                                                                                                     |                                                                                                                                                                                                          |
|      | 67H             | BUS_<br>TRANS_<br>WB              | 00H<br>(Self)<br>20H<br>(Any) | Number of completed write back transactions.                                                                                                                   |                                                                                                                                                                                                          |
|      | 68H             | BUS_<br>TRAN_<br>IFETCH           | 00H<br>(Self)<br>20H<br>(Any) | Number of completed<br>instruction fetch<br>transactions.                                                                                                      |                                                                                                                                                                                                          |
|      | 69H             | BUS_<br>TRAN_<br>INVAL            | 00H<br>(Self)<br>20H<br>(Any) | Number of completed invalidate transactions.                                                                                                                   |                                                                                                                                                                                                          |

| Unit | Event<br>Number | Mnemon-<br>ic Event<br>Name | Unit<br>Mask                  | Description                                                                                                                                                                       | Comments |
|------|-----------------|-----------------------------|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
|      | 6AH             | BUS_<br>TRAN_<br>PWR        | 00H<br>(Self)<br>20H<br>(Any) | Number of completed<br>partial write<br>transactions.                                                                                                                             |          |
|      | 6BH             | BUS_<br>TRANS_P             | 00H<br>(Self)<br>20H<br>(Any) | Number of completed partial transactions.                                                                                                                                         |          |
|      | 6CH             | BUS_<br>TRANS_<br>IO        | 00H<br>(Self)<br>20H<br>(Any) | Number of completed I/O transactions.                                                                                                                                             |          |
|      | 6DH             | BUS_<br>TRAN_<br>DEF        | 00H<br>(Self)<br>20H<br>(Any) | Number of completed deferred transactions.                                                                                                                                        |          |
|      | 6EH             | BUS_<br>TRAN_<br>BURST      | 00H<br>(Self)<br>20H<br>(Any) | Number of completed burst transactions.                                                                                                                                           |          |
|      | 70H             | BUS_<br>TRAN_<br>ANY        | 00H<br>(Self)<br>20H<br>(Any) | Number of all<br>completed bus<br>transactions. Address<br>bus utilization can be<br>calculated knowing the<br>minimum address bus<br>occupancy. Includes<br>special cycles, etc. |          |
|      | 6FH             | BUS_<br>TRAN_<br>MEM        | 00H<br>(Self)<br>20H<br>(Any) | Number of completed memory transactions.                                                                                                                                          |          |

## PENTIUM® II PROCESSOR SPECIFICATION UPDATE

| Unit | Event<br>Number | Mnemon-<br>ic Event<br>Name | Unit<br>Mask  | Description                                                                              | Comments                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|-----------------|-----------------------------|---------------|------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 64H             | BUS_<br>DATA_<br>RCV        | 00H<br>(Self) | Number of bus clock<br>cycles during which<br>this processor is<br>receiving data.       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|      | 61H             | BUS_BNR<br>_DRV             | 00H<br>(Self) | Number of bus clock<br>cycles during which<br>this processor is driving<br>the BNR# pin. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|      | 7AH             | BUS_HIT<br>-<br>DRV         | 00H<br>(Self) | Number of bus clock<br>cycles during which<br>this processor is driving<br>the HIT# pin. | Includes cycles<br>due to snoop<br>stalls.<br>The event<br>counts correctly,<br>but the BPM <i>i</i><br>pins function as<br>follows based on<br>the setting of the<br>PC bits (bit 19<br>in the<br>PerfEvtSel0 and<br>PerfEvtSel1<br>registers). If the<br>core clock to<br>bus clock ratio<br>is 2:1 or 3:1,<br>and a PC bit is<br>set, the BPM <i>i</i><br>pins will be<br>asserted for a<br>single clock<br>when the<br>counters<br>overflow. If the<br>PC bit is clear,<br>the processor<br>toggles the<br>BPM <i>i</i> pins when |

| Unit | Event<br>Number | Mnemon-<br>ic Event<br>Name | Unit<br>Mask  | Description                                                                               | Comments                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|-----------------|-----------------------------|---------------|-------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                 |                             |               |                                                                                           | the counter<br>overflows. If the<br>clock ratio is not<br>2:1 or 3:1, the<br>BPM <i>i</i> pins will<br>not function for<br>these<br>performance-<br>monitoring<br>counter events.                                                                                                                                                                                                                                                                                                            |
|      | 7BH             | BUS_<br>HITM_<br>DRV        | 00H<br>(Self) | Number of bus clock<br>cycles during which<br>this processor is driving<br>the HITM# pin. | Includes cycles<br>due to snoop<br>stalls.<br>The event<br>counts correctly,<br>but the BPM <i>i</i><br>pins function as<br>follows based on<br>the setting of the<br>PC bits (bit 19<br>in the<br>PerfEvtSel0 and<br>PerfEvtSel1<br>registers). If the<br>core clock to<br>bus clock ratio<br>is 2:1 or 3:1,<br>and a PC bit is<br>set, the BPM <i>i</i><br>pins will be<br>asserted for a<br>single clock<br>when the<br>counters<br>overflow. If the<br>PC bit is clear,<br>the processor |

## PENTIUM® II PROCESSOR SPECIFICATION UPDATE

| Unit                           | Event<br>Number | Mnemon-<br>ic Event<br>Name | Unit<br>Mask  | Description                                                                                                                                                                                                                                                                                                                                                                                                               | Comments                                                                                                                                                                                                                   |
|--------------------------------|-----------------|-----------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                |                 |                             |               |                                                                                                                                                                                                                                                                                                                                                                                                                           | toggles the<br>BPM <i>i</i> pins when<br>the counter<br>overflows. If the<br>clock ratio is not<br>2:1 or 3:1, the<br>BPM <i>i</i> pins will<br>not function for<br>these<br>performance-<br>monitoring<br>counter events. |
|                                | 7EH             | BUS_<br>SNOOP_<br>STALL     | 00H<br>(Self) | Number of clock cycles<br>during which the bus is<br>snoop stalled.                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                            |
| Float-<br>ing<br>Point<br>Unit | С1Н             | FLOPS                       | 00H           | Number of<br>computational floating-<br>point operations<br>retired. Excludes<br>floating point<br>computational<br>operations that cause<br>traps or assists.<br>Includes floating point<br>computational<br>operations executed by<br>the assist handler.<br>Includes internal sub-<br>operations of complex<br>floating point<br>instructions like<br>transcendentals.<br>Excludes floating point<br>loads and stores. | Counter 0 only                                                                                                                                                                                                             |

| Unit | Event<br>Number | Mnemon-<br>ic Event<br>Name | Unit<br>Mask | Description                                                                                                                                                                                                                                                                                                                                                                                                            | Comments                                                                                |
|------|-----------------|-----------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
|      | 10H             | FP_COMP<br>_OPS_<br>EXE     | 00Н          | Number of<br>computational floating-<br>point operations<br>executed. The number<br>of FADD, FSUB,<br>FCOM, FMULs,<br>integer MULs and<br>IMULs, FDIVs,<br>FPREMs, FSQRTS,<br>integer DIVs and<br>IDIVs. Note not the<br>number of cycles but,<br>the number of<br>operations. This event<br>does not distinguish an<br>FADD used in the<br>middle of a<br>transcendental flow<br>from a separate FADD<br>instruction. | Counter 0 only                                                                          |
|      | 11H             | FP_<br>ASSIST               | 00H          | Number of floating-<br>point exception cases<br>handled by microcode.                                                                                                                                                                                                                                                                                                                                                  | Counter 1 only.<br>This event<br>includes counts<br>due to<br>speculative<br>execution. |
|      | 12H             | MUL                         | 00H          | Number of multiplies.<br>Note: includes integer<br>and well FP multiplies<br>and is speculative.                                                                                                                                                                                                                                                                                                                       | Counter 1 only                                                                          |
|      | 13H             | DIV                         | 00H          | Number of divides.<br>Note: includes integer<br>and FP multiplies and<br>is speculative.                                                                                                                                                                                                                                                                                                                               | Counter 1 only                                                                          |

## PENTIUM® II PROCESSOR SPECIFICATION UPDATE

| Unit                         | Event<br>Number | Mnemon-<br>ic Event<br>Name | Unit<br>Mask | Description                                                                                                                                                                                                                                                                                                              | Comments       |
|------------------------------|-----------------|-----------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
|                              | 14H             | CYCLES_<br>DIV_<br>BUSY     | 00H          | Number of cycles that<br>the divider is busy, and<br>cannot accept new<br>divides. Note: includes<br>integer and FP divides,<br>FPREM, FPSQRT, etc.,<br>and is speculative.                                                                                                                                              | Counter 0 only |
| Mem-<br>ory<br>Order-<br>ing | 03H             | LD_<br>BLOCKS               | 00H          | Number of store buffer<br>blocks. Includes counts<br>caused by preceding<br>stores whose addresses<br>are unknown,<br>preceding stores whose<br>addresses are known to<br>conflict, but whose data<br>is unknown and<br>preceding stores that<br>conflicts with the load,<br>but which incompletely<br>overlap the load. |                |
|                              | 04H             | SB_DRAI<br>NS               | 00H          | Number of store buffer<br>drain cycles.<br>Incremented during<br>every cycle the store<br>buffer is draining.<br>Draining is caused by<br>serializing operations<br>like CPUID,<br>synchronizing<br>operations like XCHG,<br>Interrupt<br>acknowledgment as<br>well as other conditions<br>such as cache flushing.       |                |

| Unit                                                       | Event<br>Number | Mnemon-<br>ic Event<br>Name   | Unit<br>Mask | Description                                                                                                                                                                                                                                                                                                                                                                              | Comments                                                                                                                                                                                                                                                                                                |
|------------------------------------------------------------|-----------------|-------------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                            | 05H             | MIS-<br>ALIGN_<br>MEM_<br>REF | 00H          | Number of misaligned<br>data memory<br>references.<br>Incremented by 1 every<br>cycle during which<br>either the Pentium® II<br>load or store pipeline<br>dispatches a misaligned<br>uop. Counting is<br>performed if its the first<br>half or second half, or<br>if it is blocked,<br>squashed or misses.<br>Note in this context<br>misaligned means<br>crossing a 64 bit<br>boundary. | It should be<br>noted that<br>MISALIGN_M<br>EM_REF is only<br>an<br>approximation,<br>to the true<br>number of<br>misaligned<br>memory<br>references. The<br>value returned is<br>roughly<br>proportional to<br>the number of<br>misaligned<br>memory<br>accesses, i.e.,<br>the size of the<br>problem. |
| Instr-<br>uction<br>Decod<br>-ing<br>and<br>Retire<br>ment | СОН             | INST_<br>RETIRED              | ООН          | Number of instructions retired.                                                                                                                                                                                                                                                                                                                                                          | A hardware<br>interrupt received<br>during/after the<br>last iteration of<br>the REP STOS<br>flow causes the<br>counter to<br>undercount by 1<br>instruction.                                                                                                                                           |
|                                                            | С2Н             | UOPS_<br>RETIRED              | 00H          | Number of UOPs retired.                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                         |
|                                                            | D0H             | INST_<br>DECOD-<br>ER         | 00H          | Number of instructions decoded.                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                         |

## PENTIUM® II PROCESSOR SPECIFICATION UPDATE

| Unit            | Event<br>Number | Mnemon-<br>ic Event<br>Name                   | Unit<br>Mask | Description                                                                                          | Comments |
|-----------------|-----------------|-----------------------------------------------|--------------|------------------------------------------------------------------------------------------------------|----------|
| Inter-<br>rupts | C8H             | HW_INT_<br>RX                                 | 00H          | Number of hardware interrupts received.                                                              |          |
|                 | С6Н             | CYCLES_<br>INT_<br>MASKED                     | 00H          | Number of processor<br>cycles for which<br>interrupts are disabled.                                  |          |
|                 | С7Н             | CYCLES_<br>INT_<br>PENDING<br>_AND_<br>MASKED | 00H          | Number of processor<br>cycles for which<br>interrupts are disabled<br>and interrupts are<br>pending. |          |
| Bran-<br>ches   | С4Н             | BR_INST<br>_RETIRE<br>D                       | 00H          | Number of branch instructions retired.                                                               |          |
|                 | С5Н             | BR_MISS<br>_PRED_<br>RETIRED                  | 00H          | Number of<br>mispredicted branches<br>retired.                                                       |          |
|                 | С9Н             | BR_<br>TAKEN_<br>RETIRED                      | 00H          | Number of taken<br>branches retired.                                                                 |          |
|                 | САН             | BR_MISS<br>_PRED_<br>TAKEN_<br>RET            | 00H          | Number of taken<br>mispredictions<br>branches retired.                                               |          |
|                 | E0H             | BR_INST<br>-<br>DECOD-<br>ED                  | 00H          | Number of branch instructions decoded.                                                               |          |
|                 | E2H             | BTB_<br>MISSES                                | 00H          | Number of branches<br>that for which the BTB<br>did not produce a<br>prediction                      |          |
|                 | E4H             | BR_<br>BOGUS                                  | 00H          | Number of bogus branches.                                                                            |          |

| Unit   | Event<br>Number | Mnemon-<br>ic Event<br>Name | Unit<br>Mask | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Comments |
|--------|-----------------|-----------------------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
|        | E6H             | BA-<br>CLEARS               | 00H          | Number of time<br>BACLEAR is asserted.<br>This is the number of<br>times that a static<br>branch prediction was<br>made, where the branch<br>decoder decided to<br>make a branch<br>prediction because the<br>BTB did not.                                                                                                                                                                                                                                                                                                                                                             |          |
| Stalls | A2H             | RE-<br>SOURCE_<br>STALLS    | 00H          | Incremented by one<br>during every cycle that<br>there is a resource<br>related stall. Includes<br>register renaming<br>buffer entries, memory<br>buffer entries. Does not<br>include stalls due to<br>bus queue full, too<br>many cache misses,<br>etc., In addition to<br>resource related stalls,<br>this event counts some<br>other events.<br>Includes stalls arising<br>during branch<br>misprediction recovery,<br>e.g., if retirement of the<br>mispredicted branch is<br>delayed and stalls<br>arising while store<br>buffer is draining from<br>synchronizing<br>operations. |          |

| int <sub>el</sub> . |
|---------------------|
|---------------------|

| Unit                                   | Event<br>Number | Mnemon-<br>ic Event<br>Name    | Unit<br>Mask | Description                                                                                | Comments |
|----------------------------------------|-----------------|--------------------------------|--------------|--------------------------------------------------------------------------------------------|----------|
|                                        | D2H             | PARTIAL<br>_RAT_<br>STALLS     | 00H          | Number of cycles or<br>events for partial stalls.<br>Note Includes flag<br>partial stalls. |          |
| Seg-<br>ment<br>Reg-<br>ister<br>Loads | 06H             | SEG-<br>MENT_<br>REG_<br>LOADS | 00H          | Number of segment<br>register loads                                                        |          |
| Clocks                                 | 79H             | CPU_CLK<br>_UN-<br>HALTED      | 00H          | Number of cycles<br>during which the<br>processor is not halted.                           |          |

NOTES:

- Several L2 cache events, where noted, can be further qualified using the Unit Mask (UMSK) field in the PerfEvtSel0 and PerfEvtSel1 registers. The lower 4 bits of the Unit Mask field are used in conjunction with L2 events to indicate the cache state or cache states involved. The Pentium<sup>®</sup> II processor identifies cache states using the "MESI" protocol and consequently each bit in the Unit Mask field represents one of the four states: UMSK[3] = M (8H) state, UMSK[2] = E (4H) state, UMSK[1] = S (2H) state, and UMSK[0] = I (1H) state. UMSK[3:0] = MESI (FH) should be used to collect data for all states; UMSK = 0H, for the applicable events, will result in nothing being counted.
- All of the external bus logic (EBL) events, except where noted, can be further qualified using the Unit Mask (UMSK) field in the PerfEvtSel0 and PerfEvtSel1 registers. Bit 5 of the UMSK field is used in conjunction with the EBL events to indicate whether the processor should count transactions that are self generated (UMSK[5] = 0) or transactions that result from any processor on the bus (UMSK[5] = 1).

## SPECIFICATION CHANGES

The Specification Changes listed in this section apply to the *Pentium® II Processor* datasheet. All Specification Changes will be incorporated into a future version of the appropriate Pentium II processor documentation.

### 1. BCLK Period Stability Change from $\pm 250$ ps to $\pm 300$ ps

The following change is to Section 2.13., Table 10, *System Bus AC Specifications (Clock)*. The BCLK Period Stability for the Pentium II processor is changed from  $\pm 250$  picoseconds (ps) to  $\pm 300$  ps. This will be incorporated into the next revision of the *Pentium® II Processor* datasheet, Table 10, Section 2.13. The following reflects the exact changes to the table:

| T# Parameter                 | Min | Nom | Max  | Unit | Figure | Notes |
|------------------------------|-----|-----|------|------|--------|-------|
| T2: BCLK Period<br>Stability |     |     | ±300 | ps   |        | 7, 8  |

#### Table 10. System Bus AC Specifications (Clock)

NOTES:

7. Due to the difficulty of accurately measuring processor clock jitter in a system, it is recommended that a clock driver be used that is designed to meet the period stability specification into a test load of 10 to 20 pF. This should be measured on the rising edges of adjacent BCLKs crossing 1.25 V. The jitter present must be accounted for as a component of BCLK timing skew between devices.

8. The clock driver's closed loop jitter bandwidth must be set low to allow any PLL-based device to track the jitter created by the clock driver. The -20 dB attenuation point of the clock driver, as measured into a 10 to 20 pF load, should be less than 500 kHz. This specification may be ensured by design characterization and/or measured with a spectrum analyzer.

## 2. 300 MHz Pentium<sup>®</sup> II Processor Vcc<sub>CORE</sub> Transient Tolerance Change by 5 mV and 10 mV

The following changes are to Section 2.13., Table 6, *Pentium® II Processor Voltage and Current Specifications*.

The Baseboard Transient Tolerance in Table 6 is changed from minimum of -0.150 V and maximum of 0.150 V to a minimum of -0.145 V and a maximum of 0.145 V.

The Vcc<sub>CORE</sub> Transient Tolerance is also changed from a minimum of -0.195 V and a maximum of 0.195 V to a minimum of -0.185 V and a maximum of 0.185 V. The following reflects the exact changes to the table:

This is a 300 MHz Pentium II processor only change.

|                                      |                                                 |           | 0      |     | -     |      |       |
|--------------------------------------|-------------------------------------------------|-----------|--------|-----|-------|------|-------|
| Symbol                               | Parameter                                       | Core Freq | Min    | Тур | Max   | Unit | Notes |
| Baseboard<br>Tolerance,<br>Transient | Baseboard voltage,<br>transient tolerance level | 300 MHz   | -0.145 |     | 0.145 | V    | 5     |
| VccCORE<br>Tolerance,<br>Transient   | VccCORE voltage,<br>transient tolerance level   | 300 MHz   | -0.185 |     | 0.185 | V    | 6     |

#### Table 6. Pentium® II Processor Voltage and Current Specifications

NOTES:

5. These are the tolerance requirements, across a 20 MHz bandwidth, at the Slot 1 connector pins on the bottom side of the baseboard. The requirements at the Slot 1 connector pins account for voltage drops (and impedance discontinuities) across the connector, substrate edge fingers and to the processor core. The Slot 1 connector has the following requirements: Pin Self Inductance: 10.5 nH(max); Pin to Pin Capacitance: 2 pF(max, at 1 MHz); Contact Resistance: 12 mΩ (max averaged over power/ground contacts). Contact Intel for testing conditions of these requirements.

6. These are the tolerance requirements, across a 20 MHz bandwidth, **at the processor substrate edge fingers**. The requirements at the processor substrate edge fingers account for voltage drops (and impedance discontinuities) at the substrate edge fingers and to the processor core.

### 3. Deep Sleep ICC CORE Specification

In the *Pentium® II Processor at 233 MHz, 266 MHz and 300 MHz* datasheet, the ICC<sub>DSLP</sub> CORE MAX parameter, Table 6 on page 19 has been changed. Specifically, ICC<sub>DSLP</sub> CORE MAX has been changed from 0.2 A to 0.35 A.

#### 4. TRST# Pull-down Resistor

The Pentium II processor has a circuit to automatically reset the TAP port during a power on cycle. This circuit may not properly function during certain Vcc<sub>CORE</sub> supply ramp up and ramp down conditions if a pull-up resistor is used on TRST#. If the TAP port is not properly reset the processor may enter a test mode and fail to issue an instruction fetch. In the *Pentium® II Processor at 233 MHz, 266 MHz and 300 MHz* datasheet, Table 3, page 15, Note 3, a 470 ohm pull-down resistor is recommended on TRST#. This has been changed to read "The TRST# signal must be driven low at power on reset. This can be accomplished with a 680 ohm pull-down resistor". This value has been changed to reflect the reduced current drive capability of the ITP565. Also, Appendix Section A.1.52. currently reads "Pentium II processors self-reset during power on; therefore, it is not necessary to drive this signal during power on reset". This has been changed to read "TRST# must be driven low during power on reset. This can be accomplished with a 680 ohm pull-down resistor".

### 5. 300 MHz Pentium<sup>®</sup> II Processor Maximum Temperature Change

The following change is to Section 4.1., Table 20, page 38 of the *Pentium® II Processor at 233 MHz, 266 MHz, and 300 MHz* datasheet. The Max Tplate and Max Tcover specifications for the 300 MHz Pentium II processor have been increased from 70°C to 72°C.

| Processor<br>Core<br>Frequency<br>(MHz) | L2 Cache<br>Size (kB) | Max<br>Processor<br>Power <sup>2</sup> (W) | Max<br>Thermal<br>Plate<br>Power <sup>3</sup><br>(W) | Min<br>T <sub>PLATE</sub><br>(°C) | Max<br>T <sub>PLATE</sub><br>(°C) | Min T <sub>COVER</sub><br>(°C) | Max T <sub>COVER</sub><br>(°C) |
|-----------------------------------------|-----------------------|--------------------------------------------|------------------------------------------------------|-----------------------------------|-----------------------------------|--------------------------------|--------------------------------|
| 300                                     | 512                   | 43.0                                       | 41.4                                                 | 5                                 | 72                                | 5                              | 72                             |

Table 20. Pentium® II Processor Thermal Design Specification<sup>1</sup>

### 6. S.E.C. Cartridge Mechanical Specifications

The S.E.C. cartridge mechanical specifications provided in the *Pentium*® *II Processor at 233 MHz, 266 MHz and 300 MHz* datasheet contained incorrect tolerance information for some dimensions. Also, some of the information provided in the figures was duplicitous and not required to accurately use and design for the S.E.C. cartridge package. The revised figures provided in this section are meant to replace Figures 29 through 42, Table 23 and the accompanying notes found on page 44.

#### NOTES FOR FIGURE 1 THROUGH FIGURE 11

Unless otherwise specified, the following drawings are dimensioned in inches. All dimensions provided with tolerances are guaranteed to be met for all normal production product.

Figures and drawings labeled as "Reference Dimensions" are provided for informational purposes only. Reference Dimensions are extracted from the mechanical design database and are nominal dimensions with no tolerance information applied. Reference Dimensions are NOT checked as part of the processor manufacturing.

#### Drawings are not to scale.



Figure 1. S.E.C. Cartridge Top and Side Views



Figure 2. S.E.C. Cartridge Thermal Plate Side Dimensions

## PENTIUM® II PROCESSOR SPECIFICATION UPDATE



Figure 3. S.E.C. Cartridge Thermal Plate Side Dimensions



Figure 4. S.E.C. Cartridge Thermal Plate Flatness Dimensions



Figure 5. S.E.C. Cartridge Latch Arm, Thermal Plate Lug and Cover Lug Dimensions



intel

Figure 6. S.E.C. Cartridge Latch Arm, Cover and Thermal Plate Detail Dimensions







Figure 8. S.E.C. Cartridge Substrate Dimensions (Skirt not shown for clarity)



Figure 9. S.E.C. Cartridge Substrate Dimensions, Cover Side View

## intel



Figure 10. S.E.C. Cartridge Substrate Detail A



Figure 11. S.E.C. Cartridge Mark Locations (See Table 1 For Processor Markings)

| Table 1     | Table 1. Description Table for Processor Markings |  |  |  |  |
|-------------|---------------------------------------------------|--|--|--|--|
| Code Letter | Description                                       |  |  |  |  |
| А           | Logo                                              |  |  |  |  |
| В           | Product Name                                      |  |  |  |  |
| С           | Trademark                                         |  |  |  |  |
| D           | Logo                                              |  |  |  |  |
| Е           | Product Name                                      |  |  |  |  |
| F           | Dynamic Mark Area – with 2-D matrix               |  |  |  |  |

#### Table 1. Description Table for Processor Markings

## 7. S.E.C. Cartridge Heatsink Attach Clearance Specification Change

A change to the attach mechanism specification is provided below. The original specification for clearance of heatsink attach solutions is provided in Section 4.3. (and Figure 23 and Figure 24) in the *Pentium® II Processor at 233 MHz, 266 MHz and 300 MHz* datasheet. Figure 11 shows the revised maximum specifications for heatsink clip and Rivscrew\* attach mechanism designs. All heatsink clip and Rivscrew attachment solutions must remain within the respective maximum "permissable" zone as detailed in Figure 11.

The thermal plate shown in Figure 11 is used to portray the heatsink attach mechanism design space for the future Slot 1 processors. However, the maximum "permissable" design space is also valid for both the current Pentium II and future Slot 1 processors.

Please review the proposed specifications to guarantee compatibility with existing Pentium II and future Slot 1 processor heatsink attachment solutions. Note that the required heatsink attachment solution space should not exceed the maximum proposed design space while installed or during the installation and removal procedure.



Figure 12. Heatsink Attachment Mechanism Design Space