# VIA C3<sup>TM</sup> Ezra Processor **Datasheet** This is Version 1.05 of the VIA C3™ Ezra Processor Datasheet. # © 2001 VIA Technologies, Inc All Rights Reserved. VIA reserves the right to make changes in its products without notice in order to improve design or performance characteristics. This publication neither states nor implies any representations or warranties of any kind, including but not limited to any implied warranty of merchantability or fitness for a particular purpose. No license, express or implied, to any intellectual property rights is granted by this document. VIA makes no representations or warranties with respect to the accuracy or completeness of the contents of this publication or the information contained herein, and reserves the right to make changes at any time, without notice. VIA disclaims responsibility for any consequences resulting from the use of the information included herein. Cyrix and VIA C3 are trademarks of VIA Technologies, Inc. Centaur Hauls is a trademark of Centaur Technology Corporation. AMD, AMD K6, and Athlon are trademarks of Advanced Micro Devices, Inc. Microsoft and Windows are registered trademarks of Microsoft Corporation. Intel, Pentium, Celeron, and MMX are registered trademarks of Intel Corporation. Other product names used in this publication are for identification purposes only and may be trademarks of their respective companies. #### LIFE SUPPORT POLICY VIA processor products are not authorized for use as components in life support or other medical devices or systems (hereinafter life support devices) unless a specific written agreement pertaining to such intended use is executed between the manufacturer and an officer of VIA. - 1. Life support devices are devices which (a) are intended for surgical implant into the body or (b) support or sustain life and whose failure to perform, when properly used in accordance with instructions for use provided in the labeling, can be reasonably expected to result in a significant injury to the user. - 2. This policy covers any component of a life support device or system whose failure to perform can cause the failure of the life support device or system, or to affect its safety or effectiveness. # **Table of Contents** | 1 | INTRODU | JCTION | | |---|-----------|--------------------------------------|-----| | | 1.1 DATA | SHEET OUTLINE | 1-1 | | | 1.2 BASI | C FEATURES | 1-1 | | | 1.3 PRO0 | CESSOR VERSIONS | 1-2 | | | | PETITIVE COMPARISONS | | | | | PATIBILITY | | | 2 | ARCHITE | CTURE | | | | 2.1 INTRO | ODUCTION | 2-1 | | | | PONENT SUMMARY | | | | | AL ARCHITECTURE & FEATURES | | | | 2.2.2 | INSTRUCTION FETCH | | | | 2.2.3 | INSTRUCTION DECODE | 2-5 | | | 2.2.4 | BRANCH PREDICTION | 2-6 | | | 2.2.5 | INTEGER UNIT | | | | 2.2.6 | D-CACHE & DATAPATH | | | | 2.2.7 | L2 CACHE | | | | 2.2.8 | FP UNIT | | | | 2.2.9 | MMX UNIT | | | | 2.2.10 | 3DNOW! UNIT | | | | 2.2.11 | BUS UNIT | | | | 2.2.12 | POWER MANAGEMENT | 2-9 | | 3 | PROGRA | MMING INTERFACE | | | | 3.1 GENE | ERAL | 3-1 | | | | TIONAL FUNCTIONS | | | | 3.3 MACH | HINE-SPECIFIC FUNCTIONS | 3-2 | | | 3.3.1 | GENERAL | 3-2 | | | 3.3.2 | STANDARD CPUID INSTRUCTION FUNCTIONS | 3-2 | | | 3.3.3 | EXTENDED CPUID INSTRUCTION FUNCTIONS | 3-5 | | | 3.3.4 | PROCESSOR IDENTIFICATION | | | | 3.3.5 | EDX VALUE AFTER RESET | | | | 3.3.6 | CONTROL REGISTER 4 (CR4) | | | | 3.3.7 | MACHINE-SPECIFIC REGISTERS | 3-8 | | | 3 / OMIT | TED ELINICTIONS | 2.0 | | 4 | HARDWA | RE INTERFACE | | |----|---------------|----------------------------------|-----| | | 4.1 BUS I | NTERFACE | | | | 4.1.1 | | | | | | CLARIFICATIONS | | | | 4.1.3 | OMISSIONS | | | | | ESCRIPTION | | | | 4.3 POWI | ER MANAGEMENT | 4-6 | | | 4.4 TEST | & DEBUG | | | | 4.4.1 | | | | | 4.4.2 | JTAG | | | | 4.4.3 | DEBUG PORT | 4-7 | | 5 | ELECTRI | CAL SPECIFICATIONS | | | | 5.1 AC TI | MING TABLES | 5-1 | | | 5.2 DC SI | PECIFICATIONS | 5-2 | | | 5.2.1 | RECOMMENDED OPERATING CONDITIONS | 5-2 | | | 5.2.2 | MAXIMUM RATINGS | _ | | | 5.2.3 | DC CHARACTERISTICS | | | | 5.2.4 | POWER DISSIPATION | 5-3 | | 6 | <b>MECHAN</b> | ICAL SPECIFICATIONS | | | | 6.1 CPGA | A PACKAGE | 6-1 | | 7 | THERMA | L SPECIFICATIONS | | | | 7.1 INTR | ODUCTION | 7-1 | | | 7.2 TYPIC | CAL ENVIRONMENTS | 7-1 | | | 7.3 MEAS | SURING T <sub>C</sub> | 7-1 | | | | SURING TJ | | | | | MATING T <sub>C</sub> | | | Al | PPENDIX / | A MACHINE SPECIFIC REGISTERS | A-1 | | | A 1 GENE | FRAL | A-1 | | | | GORY 1 MSRS | | | | | CORV 2 MSRS | | **SECTION** 1 # INTRODUCTION The VIA C3™ Ezra processor is based on a unique internal architecture and is manufactured using an advanced 0.13µ CMOS technology. This architecture and process technology provides a highly compatible, high-performance, low-cost, and low-power solution for the desktop PC, notebook, and Internet Appliance markets. The VIA C3 Ezra processor is available in several MHz versions. When considered individually, the compatibility, function, performance, cost, and power dissipation of the VIA C3 Ezra processor family are all very competitive. When considered as a whole, the VIA C3 Ezra processor family offers a breakthrough level of *value*. # 1.1 DATASHEET OUTLINE The intent of this datasheet is to make it easy for a direct user—a board designer, a system designer, or a BIOS developer—to use the VIA C3 Ezra processor. Section 1 of the datasheet summarizes the key features of the VIA C3 Ezra processor. Section 2 provides a detailed description of the internal architecture of the VIA C3 Ezra processor. Section 3 specifies the primary programming interface. Section 4 does the same for the bus interface. Sections 5, 6, and 7 specify the classical datasheet topics of AC timings, pinouts, and mechanical specifications. Appendix A documents the VIA C3 Ezra processor machine specific registers (MSRs). # 1.2 BASIC FEATURES The VIA C3 Ezra processor family currently consists of one basic model with several different MHz versions. Due to its low power dissipation, the single model is ideally suited for both desktop and mobile applications. All versions share the following common features: Plug-compatible with Socket 370 processors in terms of bus protocol, electrical interface, and physical package - Software-compatible with thousands of x86 software applications available - MMX-compatible instructions - AMD-compatible 3DNow! instructions - Two large (64-KB each, 4-way) on-chip caches - 64-KB Level 2 victim cache - Two large TLBs (128 entries each, 8-way) with two page directory caches - Unique and sophisticated branch prediction mechanisms - Bus speeds up to 133 MHz - Extremely low power dissipation - Very small die (52 mm² in TSMC 0.13µ technology) # 1.3 PROCESSOR VERSIONS Typically, there are five specification parameters that characterize different versions of a processor family: package, voltage, maximum case temperature, external bus speed, and internal MHz. The VIA C3 Ezra processor family currently is offered in only one package (a Flex370-compatible ceramic PGA with heatslug), with nominal voltage (1.35V), and with only one maximum specified case temperature (70°C). The voltage is defined by the Flex370 VID pins. The internal MHz of a particular VIA C3 Ezra processor chip is defined by two parameters: the specified external bus speed and the internal bus-clock multiplier. VIA C3 Ezra processors come in two bus-speed versions: either 100MHz bus or 133 MHz bus. (Either version can also operate at 66MHz bus speeds.) Bus frequency select pins (BSEL 0 and BSEL 1) identify the appropriate bus speed (100 MHz or 133 MHz). The bus-clock multiplier is hardwired into each VIA C3 Ezra processor chip. That is, the ratio of the internal processor clock speed to the externally supplied bus clock is frozen for a particular chip<sup>1</sup>. Several different clock-multiplier versions are currently offered. . <sup>&</sup>lt;sup>1</sup> Actually, it is semi-frozen. A VIA-unique machine specific register allows programming to temporarily change the hard-wired multiplier. This capability, documented in Appendix A, is intended for special BIOS situations and test and debug usage. More information on these topics is included in Sections 4, 5, and 6 of this datasheet - The VIA C3 Ezra processor is initially available in a variety of speed grades: - 800 (6.0 x 133-MHz bus) - 800 (8.0 x 100-MHz bus) - 850 (8.5 x 100-MHz bus) - 866 (6.5 x 133-MHz bus) - Future versions of the VIA C3 Ezra processor may provide other speed grades and bus speed combinations. - Future versions of the VIA C3 Ezra processor may have different voltages # 1.4 COMPETITIVE COMPARISONS Section 2 of this datasheet contains considerable detail about the unique internal design of the VIA C3 Ezra processor. Such an internal architecture comparison, however, does not directly address the most important considerations of users: compatibility, availability, price, MHz, application performance, and power dissipation. For that reason, we do not provide a detailed architecture comparison with other processors in this datasheet. Instead, following is the high-level summary of an internal-architecture comparison: - The VIA C3 Ezra processor has better cache and TLB capabilities. These are critical to system performance for modern PC operating systems and applications. - The VIA C3 Ezra processor has a generally simpler internal architecture. However, the VIA C3 Ezra processor implements many advanced features critical to performance (such as sophisticated branch prediction) and is highly tuned for good application performance, especially on "integer" or office applications. - The VIA C3 Ezra processor has a much smaller die size (52 mm²). - The VIA C3 Ezra processor has lower power dissipation at the same MHz. # 1.5 COMPATIBILITY A VIA C3 Ezra processor can plug into existing Socket 370 motherboards and can operate without requiring changes to the system hardware (with one theoretical difference discussed in the next paragraph). No special jumpers or different board wiring is required. In most cases, however, a special BIOS is needed. Currently, BIOS support for the VIA C3 Ezra processor is available from Award, AMI, Phoenix, and Insyde. The VIA C3 Ezra processor requires external termination of bus signals. Physical and bus compatibility is covered in more detail in Section 4 of this datasheet. The VIA C3 Ezra processor supports 3DNow! instructions. The VIA C3 Ezra processor does NOT support multiple processors. These functions are defined as optional by, and are identified to software via, the CPUID instruction. The VIA C3 Ezra processor carefully follows the protocol for defining the availability of these optional features. Both the additional and omitted optional features are covered in more detail in Section 3 of this datasheet. To verify compatibility of the VIA C3 Ezra processor with real PC applications and hardware, VIA has performed extensive testing of hundreds of PC boards and peripherals, thousands of software applications, and all known operating systems. Indicative of this high compatibility, the VIA C3 Ezra will soon obtain Windows 98 and Windows NT certification. **SECTION** 2 # **ARCHITECTURE** # 2.1 INTRODUCTION The VIA C3 Ezra processor architecture is an extension of the VIA C3 Samuel (formerly known as VIA Cyrix III) processor architecture, which is different from any other x86 processor architecture. This unique processor architecture provides a significantly smaller die size using less power than any other x86 processor. The new VIA C3 Ezra processor improves performance (MHz and CPI) and further reduces die size and power over the base VIA C3 Samuel. (The major differences between the VIA C3 Samuel processor and the VIA C3 Ezra processor are highlighted in the descriptions below.) The VIA C3 Ezra processor architecture is based on, and directly exploits, some basic "facts" about the current x86 market, applications, and bus environment. While seemingly straightforward, these concepts are not exploited in other processor architectures. The major concepts that shape the VIA C3 Ezra processor architecture are: - A few instructions dominate x86 instruction execution time. Over 90% of instruction execution time is due to a few basic x86 instructions. Most x86 instructions have no significant impact on performance. - The VIA C3 Ezra processor design optimizes performance of the most important x86 instructions while minimizing the hardware provided for the little-used x86 functions (these are primarily implemented in microcode). The resulting instruction execution speed of highly used instructions is as good or better than comparable processors. For example, the VIA C3 Ezra processor executes x86 load-ALU-store instructions in only one clock as compared to several clocks on other processors. The execution time of little-used instructions is impacted to reduce die size, but this has no effect on real application performance. - Improving clock frequency has higher leverage than improving CPI. The result of advanced computer design approaches over the last few years has been that the improvements in cycles-perinstruction (CPI) often impact MHz improvements, and certainly impact die size. Our belief is that the best way to improve total performance and keep a small low-power die is to improve MHz. Thus, the VIA C3 Ezra processor family architecture provides improved performance by optimizing MHz via a 12-stage pipeline while maintaining a good CPI. Complex CPI-driven features such as out-of-order instruction execution are not implemented because they (1) impact MHz, (2) require a lot of die area and power, and (3) have little impact on real performance since... (the next point) - Memory performance is the limiting CPI performance factor. In modern PCs, the processor bus is slow compared to the internal clock frequency. Thus, off-chip memory-accesses dominate processor CPI as opposed to internal instruction execution performance. - The VIA C3 Ezra processor family addresses this phenomenon by providing many specific features designed to reduce bus activity: large primary caches, large TLBs, aggressive prefetching, an efficient level-2 cache (new to the VIA C3 Ezra processor), and so forth. - Different market segments have different workload characteristics. The hardware, operating systems, and applications used in our target market (low-end desktop and mobile PCs) have different technical characteristics than those in the high-end, workstation, or server market. - The VIA C3 Ezra processor family exploits these differences by implementing very specific design tradeoffs, providing high performance with low cost in the target environments. These optimizations are based on extensive analysis of actual behavior of target-market hardware and software. - Small is beautiful. VIA C3 Ezra processors are highly optimized for small die size. In addition to the obvious cost benefits, this small size reduces power consumption and improves reliability. # 2.2 COMPONENT SUMMARY ### 2.2.1 GENERAL ARCHITECTURE & FEATURES Figure 1 illustrates the basic 12-stage (integer) pipeline structure of the VIA C3 Ezra processor family. At a high level, there are four major functional groups: I-fetch, decode and translate, execution, and data cache. The *I-fetch* components deliver x86 instruction bytes from the large I-cache or the external bus. Large buffers allow fetching to proceed asynchronously to other operations. The *decode and translate* components convert x86 instruction bytes into internal execution forms. Branches are also identified, predicted, and the targets prefetched. Large buffers allow decoding and translating to proceed asynchronously to other operations. The *execution* components issue, execute, and retire internal instructions. The *data cache* components manage the efficient loading and storing of execution data to and from the caches, bus, and internal components. At one level the VIA C3 Ezra processor architecture seems simple; instructions are issued, executed, and retired in order, only one instruction can be issued per clock, and most data cache misses stall the pipeline. However, the design is actually highly optimized and highly tuned to achieve high performance in the targeted environment. Some of the significant features providing this performance are: ■ High internal clock frequency. The 12-stage pipeline facilitates high MHz - Large on-chip caches and TLBs. VIA C3 Ezra processors implement large caches and TLBs that significantly reduce stalls due to bus traffic. These primary caches and TLBs are larger than those on any other x86 processor: - Two 64-KB primary (L1) caches with 4-way associativity - A (new to the VIA C3 Ezra processor) 4-way 64-KB unified level-2 (L2) cache - Two 128-entry TLBs with 8-way associativity - Two 8-entry page directory caches that effectively eliminate loads of page directory entries upon TLB misses - A four-entry (8 bytes each) store queue that also forwards store data to subsequent loads - A four-entry write buffer that also performs write combining - Extensive features to further minimize bus stalls. These include: - Full memory type range registers (MTRRs) - A non-stalling write-allocate implementation - Implementation of the "cache lock" feature - Non-blocking out-of-order retirement of pipeline stores - Implementation of x86 prefetch instruction (3DNow!) - Implicit speculative *data* prefetch into D-cache - Aggressive implicit instruction prefetch into I-cache - Highly asynchronous execution with extensive queuing to allow fetching, decoding and translating, executing, and data movement to proceed in parallel - **High-performance bus implementation.** The VIA C3 Ezra processor (socket 370) compatible bus implementation includes the following performance enhancements: - No stalls on snoops - Up to 8 transactions can be initiated by the processor - Aggressive write pipelining - Smart bus allocation prioritization - 100MHz and 133MHz bus operation - Good performance for highly used instructions. Heavily used instructions—including complex functions such as protect-mode segment-register loads and string instructions—are executed fast. In particular, the pipeline is arranged to provide one-clock execution of the heavily used register—memory and memory-register forms of x86 instructions. Many instructions require fewer pipeline clocks than on comparable processors. Figure 1. The VIA C3 Ezra Processor Pipeline Structure #### 2.2.2 INSTRUCTION FETCH The first three pipeline stages (I, B, V) deliver aligned instruction data from the I-cache or external bus into the instruction decode buffers. These stages are fully pipelined such that on each clock cycle a new instruction fetch address is fetched from the I-cache and either 16 bytes (I-cache) or 8-bytes (bus) of instruction data is delivered for decode. The primary I-cache contains 64 KB organized as four-way set associative with 32-byte lines. The associated large I-TLB contains 128 entries organized as 8-way set associative. In addition, the I-TLB includes an eight-entry page directory cache that significantly reduces the TLB miss penalty. The cache, TLB, and page directory cache all use a pseudo-LRU replacement algorithm. As opposed to many other contemporary x86 processors, the data in the I-cache is exactly what came from the bus; that is, there are no "hidden" predecode bits. This allows a large cache capacity in a small physical size. The instruction data is predecoded as it comes out of the cache; this predecode is overlapped with other required operations and, thus, effectively takes no time. The fetched instruction data is placed sequentially into multiple buffers. Starting with a branch, the first branch-target byte is left adjusted into the instruction decode buffer (the XIB). As instructions are decoded, they are removed from the XIB. Each clock, new incoming fetch data is concatenated with the remaining data in the XIB. Once the XIB is filled, fetching continues to fill three 16-byte buffers that feed the XIB. If an I-cache miss occurs during the filling of the fetch buffers, up to four 32-byte lines are speculatively prefetched from the external bus into the cache. These prefetches are pipelined on the bus for optimal bus efficiency. This aggressive prefetch algorithm exploits the large size and four-way structure of the I-cache, as well as the high-bandwidth bus implementation. #### 2.2.3 INSTRUCTION DECODE Instruction bytes in the XIB are decoded and translated into the internal format by two pipeline stages (F, X). These units are fully pipelined such that, in general, an x86 instruction is decoded and translated every clock cycle. The F stage decodes and "formats" an x86 instruction (completely contained in the XIB) into an intermediate x86 format. This process requires only one clock cycle for every x86 instruction. However, instruction prefixes other than 0F require an additional cycle for each prefix. The internal-format instructions are placed into a five-deep FIFO queue: the FIQ. The FIQ facilitates the asynchronous fetch and "lookahead" capability of the formatter such that the extra cycles for prefixes rarely result in a bubble in the execution pipeline. The FIQ also allows for branch prediction to proceed even if the pipeline ahead of the branch is stalled. The X-stage "translates" an intermediate-form x86 instruction from the FIQ into the internal micro-instruction format. The output of the translator contains: (1) the internal micro-instruction stream to perform the x86 instruction function, (2) the immediate data fields from the x86 instruction, and (3) various x86 state information used to control execution (for example, operand size). The internal micro-instruction stream consists of micro-instructions directly generated by the translator plus, in some cases, an on-chip ROM address. The translator can generate up to three micro-instructions per clock plus a ROM address. Most x86 instructions except for repetitive string operations are translated in one clock. Executable micro-instructions can come from either the XIQ or the on-chip ROM. For performance-sensitive instructions, there is no delay due to access of micro-code from ROM. The microcode ROM capacity is larger than most x86 microcode ROMs to allow unimportant (relative to performance) func- tions to be performed in microcode (versus in hardware). The large size also allows the inclusion of extensive self-test microcode and extensive built-in debugging aids (for processor design debug). Instruction fetch, decode, and translation are made asynchronous from execution via a five-entry FIFO queue (the *XIQ*) between the translator and the execution unit. This queue allows the formatter and translator to "look-ahead" and continue translating x86 instructions even though the execution unit is stalled. # 2.2.4 BRANCH PREDICTION The VIA C3 Ezra processor implements a very unique and sophisticated, yet relatively small, branch prediction mechanism. Several different mechanisms predict all basic types of branches: jumps and calls using a displacement, returns, indirect jumps and calls, and "far" (inter-segment) branches (new to the VIA C3 Ezra processor). These types of jumps represent almost 25% of all instructions executed. The prediction starts when the branch is decoded in the F stage. If a branch is predicted taken, the target is fetched such that a four-clock "bubble" appears to occur. In practice however, this bubble averages less than two clocks due to the extensive instruction queuing below the F stage; the delay in fetching the predicted branch target is absorbed by execution of these queued instructions. There is also a special case: short forward branches that "hit" in the XIB require only one clock delay. For displacement-form branches, the target address is directly calculated. This direct calculation of the target address eliminates the need for a large branch-target buffer (a *BTB* or *BTAC*). The direct calculation always produces the correct address whereas a BTB often mispredicts the address, or fails to predict at all. Two different prediction algorithms are used to predict the direction of conditional branches. The underlying theory behind this approach is that, in practice, branches tend to fall into two categories. Most branches can be accurately predicted by a classic mechanism using a counter associated with the branch location. The associated VIA C3 Ezra processor mechanism is a simple array of predictors with 8K entries (versus 4K in the VIA C3 Samuel processor). However, about 20% of branches are hard to predict, because whether they branch or not depends on dynamic execution state. The VIA C3 Ezra processor mechanism for predicting these pattern-based branches uses a 13-bit global branch history XOR'd with the branch instruction address to index a branch history table with 8K entries (versus 4K in the VIA C3 Samuel processor). This branch-history mechanism is called *g-share* in the technical literature. A third 4K-entry table selects which predictor (simple or history-based) to use for a particular branch based on the previous behavior of the branch. All three predictor tables actually use a one-bit "agree/disagree" predictor rather than the conventional two-bit counter. This unique approach uses a static predictor that considers the type of conditional branch and what type of instruction previously set the condition flag being tested. Rather than indicate taken or not, the one-bit entry in the predictor tables predicts whether the conditional branch direction agrees with the static prediction. The static predictor is accurate about 70% of the time, and the dynamic predictor is accurate about 95% of the time. In addition, x86 return instructions are predicted by a 16-entry return-address stack. This prediction is about 90% accurate. Finally, indirect jump and call instructions are predicted using a conventional 128-entry (8-way) BTB (versus 64 and 4-way in the VIA C3 Samuel processor). This small array predicts about 75% of indirect branches correctly. The BTB is also used to predict inter-segment ("far") branches. # 2.2.5 INTEGER UNIT Internal micro-instructions are executed in a tightly coupled seven-stage (integer) pipeline that is similar in structure to a basic four-stage RISC pipeline with extra stages for memory loads and stores inserted. These extra stages allow instructions that perform a load and ALU operation, or a load, ALU, and store operation to execute in one clock. The micro-instructions and associated execution units are highly tuned for the x86 architecture. The micro-instructions closely resemble highly used x86 instructions. Examples of specialized hardware features supporting the x86 architecture are: hardware handling of the x86 condition codes, segment descriptor manipulation instructions, and hardware to automatically save the x86 floating-point environment. The integer execution stages are: - Decode stage (R): Micro-instructions are decoded, integer register files are accessed and resource dependencies are evaluated. - Addressing stage (A): Memory addresses are calculated and sent to the D-cache. The VIA C3 Ezra processor is capable of calculating most x86 instruction address forms in one clock; a few forms containing two registers or a shifted index register require two clocks. Addresses can be automatically incremented or decremented for implementing stack and string operations. - Some ALU operations are duplicated in this stage to reduce AGI (address generation interlock) stalls. For example, the sequence of adding to the stack pointer register followed by using it in a return does not cause an AGI. In general, register adds and moves are performed in the A-stage. - Cache Access stages (D, G): The D-cache and D-TLB are accessed and aligned load data returned at the end of the G-stage. The cache is fully pipelined such that a new load or store can be started and data returned each clock. - Execute stage (E): Integer ALU operations are performed. All basic ALU functions take one clock except multiply and divide. Load-ALU and Load-ALU-store instructions require only one clock (the data is loaded before the ALU stage). Results from the ALU can be forwarded to any instruction following the ALU instruction using a unique result-forwarding cache. - Branch instructions are evaluated in this stage and, if incorrectly predicted, the corrected branch address is sent to the I-cache during the next clock. No additional action is required for correctly predicted branches. - During this stage the floating-point, MMX, and 3DNow! execution units access their registers or consume the load data just delivered. These execution units "hang off" the end of the main execution unit so that load-ALU operations for these units can be pipelined in one clock. - Store stage (S): Integer store data is grabbed in this stage and placed in a store buffer. Positioning stores in this stage allows a one-clock load—ALU—store instruction. MMX and floating-point stores, however, are placed in the store buffer in a subsequent cycle due to their deep pipelines. - Write-back stage (W): The results of operations are committed to the register file. ### 2.2.6 D-CACHE & DATAPATH The D-cache contains 64 KB organized as four-way set associative with 32-byte lines. The associated large D-TLB contains 128 entries organized as 8-way set associative. In addition, the D-TLB includes an eight-entry page directory cache that significantly reduces the TLB miss penalty. The cache, TLB, and page directory cache all use a pseudo-LRU replacement algorithm. Associated with the D-cache are store and write buffers. All stores that pass the W-stage are placed in a four-entry store buffer (8 bytes each). Stores from the store buffer are drained to the D-cache or bus in actual program order, regardless of when the data appeared in the store buffers. Stores that miss the D-cache percolate to the write buffers where they wait for the bus. If the memory region is defined as write-combining, the stores can combine in the write buffers. # 2.2.7 L2 CACHE The VIA C3 Ezra processor contains an efficient level-2 cache. This L2 cache is *exclusive* (this approach is sometimes called a "victim" cache). This means that the contents of the L2 cache at any point in time are not contained in the two 64-KB L1 caches. As lines are displaced from the L1 caches (due to bringing in new lines from memory), the displaced lines are placed in the L2 cache. Thus, a future L1-cache miss on this displaced line can be satisfied by returning the line from the L2 cache instead of having to access the external memory. Thus, the total effective cache size on the VIA C3 Ezra processor is 192 KB (two 64-KB L1 caches and the 64-KB L2). Processors, such as the Intel Celeron processor, that have an *inclusive* L2 cache have a total effective cache size equal to the L2 size (128 KB in the case of the current Intel Celeron processor). This is because the contents of the L1 caches are duplicated within an inclusive L2 cache. The L2 cache is also "unified;" that is, it contains lines displaced from both the L1 I-cache and the l1 D-cache. Thus the L2 cache provides a significant assist for the cases where an I-fetch hits in the L1 data cache, or a data reference hits in the L1 I-cache. To provide correct execution semantics, these cases require the hit line to be ejected from the L1 cache. The VIA C3 Ezra processor L2 cache is 64 KB organized as four-way set associative with 32-byte lines and uses a pseudo-LRU replacement algorithm. # **2.2.8 FP UNIT** In addition to the integer execution unit, the VIA C3 Ezra processor has a separate 80-bit floating-point execution unit that can execute x86 floating-point instructions in parallel with integer instructions. The FP unit is clocked at ½ the processor clock speed; that is, in an 800-MHz VIA C3 Ezra processor, the FP-unit runs at 400 MHz. Floating-point instructions proceed through the integer R, A, D, and G stages. Thus, load-ALU x86 floating-point instructions do not require an extra clock for the load. Floating-point instructions are then passed from the integer pipeline to the FP-unit through an 8-instruction FIFO queue (new to the VIA C3 Ezra processor). This queue, which runs at the processor clock speed, decouples the slower running FP unit from the integer pipeline so that the integer pipeline can continue to process instructions overlapped with up to eight FP instructions. Basic arithmetic floating-point instructions (add, multiply, divide, square root, compare, etc.) are represented by a single internal floating-point instruction. Certain little-used and complex floating point instructions (sin, tan, etc.), however, are implemented in microcode and are represented by a long stream of instructions coming from the ROM. These instructions "tie up" the integer instruction pipeline such that integer execution cannot proceed until they complete. One floating-point instruction can issue form the FP queue to the FP unit every two clocks. The FP pipeline is six-stages deep following the E stage. It is partially pipelined: a non-dependent add or multiply can start every two clocks. # **2.2.9 MMX UNIT** The VIA C3 Ezra processor contains a separate execution unit for the MMX-compatible instructions. MMX instructions proceed through the integer R, A, D, and G stages. Thus, load-ALU x86 MMX instructions do not require an extra clock for the load. One MMX instruction can issue into the MMX unit every clock. The MMX multiplier is fully pipelined and can start one non-dependent MMX multiply[-add] instruction (which consists of up to four separate multiplies) every clock. Other MMX instructions execute in one clock. Multiplies followed by a dependent MMX instruction require two clocks. Architecturally, the MMX registers are the same as the floating-point registers. However, there are actually two different register files (one in the FP-unit and one in the MMX units) that are kept synchronized by hardware. # 2.2.10 3DNOW! UNIT The VIA C3 Ezra processor contains a separate execution unit for the 3DNow! instructions. These instructions are compatible with the AMD K6-II™ processor 3DNow! instructions and provide performance assists for graphics transformations via new SIMD single-precision floating-point capabilities. 3DNow! instructions proceed through the integer R, A, D, and G stages. Thus, load-ALU x86 3DNow! instructions do not require an extra clock for the load. One 3DNow! instruction can issue into the 3DNow! unit every clock The 3DNow! unit has two single-precision floating-point multipliers and two single-precision floating-point adders. Other functions such as conversions, reciprocal, and reciprocal square root are provided. The multiplier and adder are fully pipelined and can start any non-dependent 3DNow! instruction every clock. #### **2.2.11BUS UNIT** The VIA C3 Ezra processor bus unit provides an external bus interface, supporting bus speeds of 100 MHz and 133 MHz. The VIA C3 Ezra processor bus implementation has no stalls on snoops, up to eight transactions can be generated (versus four), and stores are more heavily pipelined on the bus. #### 2.2.12POWER MANAGEMENT Power management is not a component but rather a pervasive feature in all components. There are two major modes: powering down components based on bus signals such as stop clock and sleep, and dynamically powering off components during execution when they are not needed. The VIA C3 Ezra processor implements the bus-controlled power management modes including: auto-HALT power down state, stop grant state, sleep state, and deep sleep, or stop clock, state. While in normal running state, all major functional components are powered off when not in use. All caches, tags and TLBs are turned on and off on a clock-by-clock basis based on their usage. Other major components such as the MMX unit, the 3DNow! unit, the FP unit, and the ROM are turned on and off as used. In addition, even in blocks that are powered up, internal buses and latches hold their values when not needed to reduce dynamic power consumption. **SECTION** 3 # PROGRAMMING INTERFACE # 3.1 GENERAL The VIA C3 Ezra processor's functions include: - All basic x86 instructions, registers, and functions - All floating-point (numeric processor) instructions, registers and functions - All basic operating modes: real mode, protect mode, virtual-8086 mode - System Management Interrupt (SMI) and the associated System Management Mode (SMM) - All interrupt and exception functions - All debug functions (including the new I/O breakpoint function) - All input/output functions - All tasking functions (TSS, task switch, etc.) - Processor initialization behavior - Page Global Enable feature The VIA C3 Ezra processor, in addition to the MMX instructions, also includes instructions to boost the performance of 3D graphics compatible with the AMD 3DNow! Technology. However, there are some differences between the VIA C3 Ezra processor and the Celeron processor. These differences fall into three groups: ■ Implementation-specific differences. Examples are cache and TLB testing features, and performance monitoring features that expose the internal implementation features. These types of functions are incompatible among *all* different x86 implementations. - Omitted functions. Some Intel Celeron processor functions are not provided on the VIA C3 Ezra processor because they are not used or are not needed in the targeted PC systems. Examples are some specific bus functions such as functional redundancy checking and performance monitoring. Other examples are architectural extensions such as support for 4-MByte pages, Page Attribute Tables, etc. - These types of differences are similar to those among various versions of the processors. The CPUID instruction is used by system software to determine whether these features are supported. - Low-level behavioral differences. A few low-level VIA C3 Ezra processor functions are different from Intel Celeron because the results are (1) documented in the documentation as *undefined*, and (2) known to be different for different x86 implementations. That is, compatibility with the Intel Celeron processor for these functions is clearly not needed for software compatibility (or they would not be different across different implementations). This chapter summarizes the first three types of differences: additional functions, implementation-specific functions, and omitted functions. *Appendix A* contains more details on machine-specific functions. # 3.2 ADDITIONAL FUNCTIONS The VIA C3 Ezra processor includes AMD-compatible 3DNow! instructions to boost the performance of 3D applications. These instructions are not defined in this datasheet but are defined in the appropriate AMD documentation. # 3.3 MACHINE-SPECIFIC FUNCTIONS # 3.3.1 GENERAL All x86 processor implementations provide a variety of *machine-specific functions*. Examples are cache and TLB testing features and performance monitoring features that expose the internal implementation features. This section describes the VIA C3 Ezra processor machine-specific functions that are most likely used by software, and compares them to related processors where applicable. *Appendix A* describes the VIA C3 Ezra processor machine-specific registers (*MSRs*). This section covers those features of Intel Pentium-compatible processors that are used to commonly identify and control processor features. All Pentium-compatible processors have the same mechanisms, but the bit-specific data values often differ. ### 3.3.2 STANDARD CPUID INSTRUCTION FUNCTIONS The CPUID instruction is available on all contemporary x86 processors. The CPUID instruction has two standard functions requested via the EAX register. The first function returns a vendor identification string in registers EBX, ECX, and EDX. The second CPUID function returns an assortment of bits in EAX and EDX that identify the chip version and describe the specific features available. The EAX:EBX:ECX:EDX return values of the CPUID instruction executed with EAX == 0 are: Table 3-1. CPUID Return Values (EAX = 0) | REGISTER[BITS] –<br>MEANING | VIA C3 EZRA | |------------------------------------------------------------|--------------------| | EAX<br>(highest EAX input<br>value understood<br>by CPUID) | 1 | | EBX:EDX:ECX (vendor ID string) | "Centaur<br>Hauls" | The EAX return values of the CPUID instruction executed with EAX == 1 are: Table 3-2. CPUID EAX Return Values (EAX = 1) | EAX BITS - MEANING | VIA C3 EZRA | |--------------------|----------------------------------------------------------------------| | 3:0 - Stepping ID | | | 7:4 - Model ID | Same as the return<br>value in EDX after Reset<br>(see next section) | | 11:8 - Family ID | | | 13:12 – Type ID | | The EDX return values of the CPUID instruction with EAX == 1 are: Table 3-3 CPUID EDX Return Values (EAX = 1) | EDX BITS – MEANING | VIA C3 EZRA | NOTES | |------------------------------------------|-------------|-------| | 0 - FPU present | 1 | | | 1 - Virtual Mode Extension | 0 | | | 2 - Debugging Extensions | 1 | | | 3 - Page Size Extensions (4MB) | 0 | | | 4 - Time Stamp Counter (TSC) supported | 1 | | | 5 - Model Specific Registers present | 1 | | | 6 - Physical Address Extension | 0 | | | 7 - Machine Check Exception | 0 | | | 8 - CMPXCHG8B instruction | 0/1 | 1 | | 9 - APIC supported | 0 | 2 | | 10- Reserved | | | | 11- Fast System Call | 0 | | | 12- Memory Range Registers | 1 | | | 13 - PTE Global Bit supported | 1/0 | 3 | | 14- Machine Check Architecture supported | 0 | | | 15- Conditional Move supported | 0 | | | EDX BITS – MEANING | VIA C3 EZRA | NOTES | |----------------------------------------|-------------|-------| | 16- Page Attribute Table | 0 | | | 17- 36-bit Page Size Extension | 0 | | | 18- Processor serial number | 0 | | | 19:22 - Reserved | | | | 23- MMX supported | 1 | | | 24- FXSR | 0 | | | 25- Streaming SIMD Extension supported | 0 | | | 26:31 - Reserved | | | # Notes On CPUID Feature Flags: General: an "x/y" entry means that the default setting of this bit is x but the bit (and the underlying function) can be set to y using the FCR MSR. - 1. The CMPXCHG8B instruction is provided and always enabled, however, it appears disabled in the corresponding CPUID function bit 0 to avoid a bug in an early version of Windows NT. However, this default can be changed via a bit in the FCR MSR. - 2. SMP is not supported, it has no utility in the target system environment. - 3. The VIA C3 Ezra processor's support for Page Global Enable can be enabled or disabled by a bit in the FCR. The CPUID bit reports the current setting of this enable control. # 3.3.3 EXTENDED CPUID INSTRUCTION FUNCTIONS The VIA C3 Ezra processor supports extended CPUID functions. These functions provide additional information about the VIA C3 Ezra processor. Extended CPUID functions are requested by executing CPUID with EAX set to any value in the range 0x800000000 through 0x800000005. The following table summarizes the extended CPUID functions. **Table 3-4. Extended CPUID Functions** | EAX | TITLE | OUTPUT | |----------|------------------------------|----------------------------------------| | 80000000 | Largest Extended Function | EAX=80000006 | | | Input Value | EBX,ECX,EDX=Reserved | | 80000001 | Processor Signature and | EAX=Processor Signature | | | Feature Flags | EBX,ECX=Reserved | | | | EDX=Extended Feature Flags | | 80000002 | Processor Name String | EAX,EBX,ECX,EDX | | 80000003 | Processor Name String | EAX,EBX,ECX,EDX | | 80000004 | Processor Name String | EAX,EBX,ECX,EDX | | 80000005 | TLB and L1 Cache Information | EAX = Reserved | | | | EBX = TLB Information | | | | ECX = L1 Data Cache Information | | | | EDX = L1 Instruction Cache Information | | 80000006 | L2 Cache Information | EAX, EBX, EDX = Reserved | | | | ECX = L2 Cache Information | #### **Largest Extended Function Input Value (EAX==0x80000000)** Returns 0x80000006 in EAX, the largest extended function input value. # Processor Signature and Feature Flags (EAX==0x80000001) Returns processor version information in EAX, this value is identical to the value of EDX after RESET. Returns feature flags in EDX, this value is identical to the value in EDX after CPUID standard function 1, with the exception of bit 31: EDX[31]=0 3DNow! instructions not supported. EDX[31]=1 3DNow! instructions supported. Note that if FCR[20]=0 then 3DNow! instructions are not supported and EDX[31] will be 0. # Processor Name String (EAX==0x80000002-0x80000004) Returns the name of the processor, suitable for BIOS to display on the screen (ASCII). The string can be up to 48 characters in length. If the string is shorter, the rightmost characters are padded with zero. The leftmost characters go in EAX, then EBX, ECX, and EDX. The leftmost character goes in least significant byte (little endian). For example, the string "VIA Ezra" would be returned by extended function EAX=0x80000002 as follows: EAX = 0x20414956 EBX = 0x61727A45 ECX = 0x000000000 EDX = 0x000000000 Since the string is less than 17 bytes, the extended functions EAX=0x80000003 and EAX=0x80000004 return zero in EAX, EBX, ECX, and EDX. # L1 Cache Information (EAX == 0x80000005) Returns information about the implementation of the TLBs and caches: Table 3-5. L1 Cache & TLB Configuration Encoding | REGISTER | DESCRIPTION | VALUE | |------------|----------------------------------|-------| | EAX | Reserved | | | EBX | TLB Information | | | EBX[31:24] | D-TLB associativity | 8 | | EBX[23:16] | D-TLB # entries | 128 | | EBX[15: 8] | I-TLB associativity | 8 | | EBX[ 7: 0] | I-TLB # entries | 128 | | ECX | L1 Data Cache Information | | | ECX[31:24] | Size (Kbytes) | 64 | | ECX[23:16] | Associativity | 4 | | ECX[15: 8] | Lines per Tag | 1 | | ECX[ 7: 0] | Line Size (bytes) | 32 | | EDX | L1 Instruction Cache Information | | | EDX[31:24] | Size (Kbytes) | 64 | | EDX[23:16] | Associativity | 4 | | EDX[15: 8] | Lines per Tag | 1 | | EDX[ 7: 0] | Line Size (bytes) | 32 | # L2 Cache Information (EAX == 0x80000006) Returns information about the implementation of the L2 cache: Table 3-6. L2 Cache Configuration Encoding | REGISTER | DESCRIPTION | VALUE | |---------------|-------------|-------| | EAX, EBX, EDX | Reserved | | | ECX | L2 Data Cache Information | | |------------|---------------------------|----| | ECX[31:24] | Size (Kbytes) | 64 | | ECX[23:16] | Associativity | 4 | | ECX[15: 8] | Lines per Tag | 1 | | ECX[ 7: 0] | Line Size (bytes) | 32 | ### 3.3.4 PROCESSOR IDENTIFICATION The VIA C3 Ezra processor provides several machine-specific features. These features are identified by the standard CPUID function EAX=1. Other machine-specific features are controlled by VIA C3 Ezra MSRs. Some of these features are not backward-compatible with the predecessors in the IDT WinChip family. System software must not assume that all future processors in the VIA processor family will implement all of the same machine-specific features, or even that these features will be implemented in a backward-compatible manner. In order to determine if the processor supports particular machine-specific features, system software should follow the following procedure. Identify the processor as a member of the VIA processor family by checking for a Vendor Identification String of "CentaurHauls" using CPUID with EAX=0. Once this has been verified, system software must determine the processor version in order to properly configure the machine-specific registers. In general system software can determine the processor version by comparing the Family and Model Identification fields returned by the CPUID standard function EAX=1. If the processor version is not recognized then system software must not attempt to activate any machinespecific feature. # 3.3.5 EDX VALUE AFTER RESET. After reset the EDX register holds a component identification number as follows: | | 31:14 | 13:12 | 11:8 | 7:4 | 3:0 | |-----|----------|---------|-----------|----------|-------------| | EDX | Reserved | Type ID | Family ID | Model ID | Stepping ID | | | 18 | 2 | 4 | 4 | 4 | The specific values for the VIA C3 Ezra processor are: | PROCESSOR | TYPE ID | FAMILY ID | MODEL ID | STEPPING ID | |-------------|---------|-----------|----------|-------------| | VIA C3 Ezra | 0 | 6 | 7 | Begins at 8 | # 3.3.6 CONTROL REGISTER 4 (CR4) Control register 4 (CR4) controls some of the advanced features of the Celeron processor. The VIA C3 Ezra processor provides a CR4 with the following specifics: Table 3-7. CR4 Bits | CR4 BITS - MEANING | VIA C3 EZRA | CELERON<br>MODEL 6 | CELERON<br>MODEL 8 | NOTES | |------------------------------------------------|-------------|--------------------|--------------------|-------| | 0: VME: Enables VME feature | 0 | 0/1 | 0/1 | 1 | | 1: PVI: Enables PVI feature | 0 | 0/1 | 0/1 | 1 | | 2: TSD: Makes RDTSC inst privileged | 0/1 | 0/1 | 0/1 | | | 3: DE: Enables I/O breakpoints | 0/1 | 0/1 | 0/1 | | | 4: PSE: Enables 4-MB pages | 0 | 0/1 | 0/1 | 1 | | 5: PAE: Enables address extensions | r | r | r | | | 6: MCE: Enables machine check exception | 0/1 | 0/1 | 0/1 | 2 | | 7: PGE: Enables global page feature | 0/1 | 0/1 | 0/1 | | | 8: PCE: Enables RDPMC for all levels | 0/1 | 0/1 | 0/1 | | | 9: OSFXSR: Enables FXSAVE//FXRSTOR Support | r | r | 0/1 | | | 10: OSXMMEXCPT: O/S Unmasked Exception Support | r | r | 0/1 | | | 31:11 - reserved | r | r | r | | # **Notes On CR4** General: a "0/1" means that the default setting of this bit is 0 but the bit can be set to (1). A "0" means that the bit is always 0; it cannot be set. An "r" means that this bit is reserved. It appears as a 0 when read, and a GP exception is signaled if an attempt is made to write a 1 to this bit. - The VIA C3 Ezra processor does not provide this "Appendix H" function and this CR4 bit cannot be set. However, no GP exception occurs if an attempt is made to set this bit. The Cyrix 6x86MX processor also does not provide this function. - 2. The VIA C3 Ezra processor Machine Check has different specifics than the Machine Check function of compatible processors. # 3.3.7 MACHINE-SPECIFIC REGISTERS The VIA C3 Ezra processor implements the concept of Machine Specific Registers (MSRs). RDMSR and WRMSR instructions are provided and the CPUID instruction identifies that the VIA C3 Ezra processor supports MSRs. In general, the MSRs have no usefulness to application or operating system software and are not used. (This is to be expected since the MSRs are different on each processor.) *Appendix A* contains a detailed description of the VIA C3 Ezra processor's MSRs. # 3.4 OMITTED FUNCTIONS This section summarizes those functions that are not in the VIA C3 Ezra processor. #### Symmetric Multiprocessing Support: APIC This bus function is omitted since the target market for the VIA C3 Ezra processor is portables and typical desktop systems (which do not support APIC multiprocessing). A bit in the feature identification return from the CPUID instruction indicates whether this feature is present or not. This enhancement is not provided on the VIA C3 Ezra processor. #### **Other Functions** There are other functions that are not implemented in the VIA C3 Ezra processor. These are identified accordingly in the CPUID feature flags, Conditional Move instructions, Page Attribute Tables, 4-Mbyte pages, 36-bit Page Size Extension, and FXSAVE/FXRSTOR instructions. The VIA C3 Ezra processor does contain an L2 cache. Model specific registers pertaining to the L2 cache are detailed in Appendix A. Model specific registers pertaining to APIC, Machine Check, and Debug and Trace features are not supported. SECTION 4 # HARDWARE INTERFACE # 4.1 BUS INTERFACE The VIA C3 Ezra processor bus interface is commonly referred to as the Socket 370 interface. The majority of the pins within the bus interface are involved with the physical memory and I/O interface. The remaining pins are power and ground pins, test and debug support pins, and various ancillary control functions. The pins and associated functions are listed and described in this section. #### 4.1.1 DIFFERENCES The areas where the VIA C3 Ezra processor differs from compatible processors should not cause operational compatibility issues. These differences are: - Bus-to-core Ratio Control - Bus Frequency Control - Probe Mode / JTAG / TAP Port (see *Test and Debug Section*) #### **Bus-to-Core Frequency Ratio Control** The VIA C3 Ezra processor supports both fused and software control of the bus-to-core frequency ratio. At reset, the factory-set, fused ratio is used. This ratio can then be adjusted via software. This adjustment lasts until the next reset. Software can adjust the bus-to-core ratio using the VIA C3 Ezra processor's LongHaul extensions. These are documented separately in the VIA C3 LongHaul Specification. # **Bus Frequency Selection** The VIA C3 Ezra processor supports automated bus frequency selection through the BSEL pins. The BSEL pins are used as a mechanism whereby the processor and the system board can negotiate to support high frequency bus frequencies. The standard BSEL decoding is shown in Table 4-1. While the VIA C3 Ezra processor is designed to operate at bus frequencies of 66, 100, or 133 MHz, performance is improved by running at higher bus frequencies. Various speed bins preclude 133 MHz operation because the available bus-to-core ratios do not permit operation at the desired core MHz. Processors from these speed bins indicate this by shorting the BSEL[1] pin to ground internal to the package. For these processors the BSEL[0] pin is left floating. Processors from speed bins which permit 133 MHz bus operation indicate this by allowing both BSEL[1] and BSEL[0] to float. It is anticipated that motherboards will pull up both BSEL pins. The resulting BSEL-indicated bus frequency will then be either 100 MHz or 133 MHz according to speed bin. Bus operation at 66MHz is not desirable. **Table 4-1. BSEL Frequency Mapping** | BSEL[1] | BSEL[0] | BUS FREQUENCY | |---------|---------|---------------| | 0 | 0 | 66 MHz | | 0 | 1 | 100 MHz | | 1 | 0 | Reserved | | 1 | 1 | 133 MHz | # 4.1.2 CLARIFICATIONS #### **Power Supply Voltage** The VIA C3 Ezra processor automatically controls its core processor power supply voltage with the VID pins. The VID mapping for CPGA-packaged VIA C3 Ezra processors is in Table 4-2. This mapping corresponds to Intel's VRM8.4 specification. Note that the CPGA-packaged VIA C3 Ezra does not specify a VID4 pin. **Table 4-2. Core Voltage Settings** | VID3 | VID2 | VID1 | VID0 | VCORE | |------|------|------|------|-------| | 1 | 1 | 1 | 1 | 1.30V | | 1 | 1 | 1 | 0 | 1.35V | | 1 | 1 | 0 | 1 | 1.40V | | 1 | 1 | 0 | 0 | 1.45V | | 1 | 0 | 1 | 1 | 1.50V | | 1 | 0 | 1 | 0 | 1.55V | | 1 | 0 | 0 | 1 | 1.60V | | 1 | 0 | 0 | 0 | 1.65V | | 0 | 1 | 1 | 1 | 1.70V | | 0 | 1 | 1 | 0 | 1.75V | | 0 | 1 | 0 | 1 | 1.80V | | 0 | 1 | 0 | 0 | 1.85V | | 0 | 0 | 1 | 1 | 1.90V | | 0 | 0 | 1 | 0 | 1.95V | | 0 | 0 | 0 | 1 | 2.00V | | 0 | 0 | 0 | 0 | 2.05V | #### **VCC**cmos The VIA C3 Ezra processor routes the VCC1.5 pin to the VCCCMOS pin via the package. This signal is not used by the processor, but is intended to be used by the system as the power supply for CMOS level signals. VCCCMOS should not be expected to source more than 250mA. #### **RESET#** The VIA C3 Ezra processor is reset by the assertion of the RESET# pin. Current versions of the VIA C3 Ezra processor connect this pin to X-4 in the Socket370 pinout. Future versions of the VIA C3 Ezra processor may relocate RESET# to AH-4 in the Socket370 pinout. Board designers should always connect RESET# to both AH-4 and X-4 to ensure compatibility with all VIA processors. #### **Thermal Monitoring** The VIA C3 Ezra processor supports thermal monitoring via the THERMDN and THERMDP pins. However, it does not support the THERMTRIP# pin. The THERMTRIP# pin should be treated as reserved. #### 4.1.3 OMISSIONS # **Driver Termination** The VIA C3 Ezra processor requires external termination. System boards must terminate signals to ensure correct operation. # **Advanced Peripheral Interrupt Controller (APIC)** The APIC is not supported by the VIA C3 Ezra processor. The APIC pins (PICCLK, PICD0, and PICD1) are specified as reserved, but can be connected on the motherboard for compatibility with other processors. ### **Breakpoint and Performance Monitoring Signals** The VIA C3 Ezra processor internally supports instruction and data breakpoints. However, the VIA C3 Ezra processor does not support the external indication of breakpoint matches via the BP3-BP0 pins. Similarly, the VIA C3 Ezra processor contains performance monitoring hooks internally, but it does not support the indication of performance monitoring events on PM1-PM0. The associated pins are unconnected on the VIA C3 Ezra processor package. ### **Error Checking** The VIA C3 Ezra processor does not support error checking. The BERR#, BINIT#, AERR#, AP#[1:0], DEP#[7:0], IERR#, RP#, and RSP# pins do not exist and should be treated as reserved. #### **V**COREDET The VIA C3 Ezra processor does not connect to the VCOREDET pin. #### RTTCTRL The VIA C3 Ezra processor does not connect to the RTTCTRL pin. Future VIA processors will use the RTTCTRL pin to control integrated I/O pull-ups. #### **NCHCTRL** The VIA C3 Ezra processor does not connect to the NCHCTRL pin. Future VIA processors will use the NCHCTRL pin to control the output impedence of the GTL outputs. #### **SLEWCTRL** The VIA C3 Ezra processor does not connect to the SLEWCTRL pin. Future VIA processors may connect to the SLEWCTRL pin. # **EDGCTRL** The VIA C3 Ezra processor does not connect to the EDGECTRL pin. # 4.2 PIN DESCRIPTION **Table 4-3. Pin Descriptions** | Pin Name | Description | 1/0 | Clock | |----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------| | A[31:3]# | The address Bus provides addresses for physical memory and external I/O devices. During cache inquiry cycles, A31#-A3# are used as inputs to perform snoop cycles. | I/O | BCLK | | A20M# | A20 Mask causes the CPU to make (force to 0) the A20 address bit when driving the external address bus or performing an internal cache access. A20M# is provided to emulate the 1 MByte address wrap-around that occurs on the 8086. Snoop addressing is not affected. | I(1.5V) | ASYNC | | ADS# | Address Strobe begins a memory/I/O cycle and indicates the address bus (A31#-A3#) and transaction request signals (REQ#) are valid. | I/O | BCLK | | BCLK | Bus Clock provides the fundamental timing for the VIA C3 Ezra CPU. The frequency of the VIA C3 Ezra CPU input clock determines the operating frequency of the CPU's | I(2.5V) | | | Pin Name | Description | 1/0 | Clock | |-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------| | | bus. External timing is defined referenced to the rising edge of CLK. | | | | BNR# | Block Next Request signals a bus stall by a bus agent unable to accept new transactions. | I/O | BCLK | | BPRI# | Priority Agent Bus Request arbitrates for ownership of the system bus. | I | BCLK | | BSEL[1:0] | Bus Selection Bus provides system bus frequency data to the CPU. | 0 | BCLK | | BR0# | BR0# drives the BREQ[0]# signal in the system to request access to the system bus. | I/O | None | | CPUPRES# | CPU Present is grounded inside the processor to indicate to the system that a processor is present. | 0 | None | | D[63:0]# | Data Bus signals are bi-directional signals which provide the data path between the VIA C3 Ezra CPU and external memory and I/O devices. The data bus must assert DRDY# to indicate valid data transfer. | I/O | BCLK | | DBSY# | Data Bus Busy is asserted by the data bus driver to indicate data bus is in use. | I/O | BCLK | | DEFER# | Defer is asserted by target agent (e.g., north bridge) and indicates the transaction cannot be guaranteed as an in-order completion. | I | BCLK | | DRDY# | Data Ready is asserted by data driver to indicate that a valid signal is on the data bus. | I/O | BCLK | | FERR# | FPU Error Status indicates an unmasked floating-point error has occurred. FERR# is asserted during execution of the FPU instruction that caused the error. | O(1.5V) | ASYNC | | FLUSH# | Flush Internal Caches writing back all data in the modified state. | I(1.5V) | ASYNC | | HIT# | Snoop Hit indicates that the current cache inquiry address has been found in the cache (exclusive or shared states). | I/O | BCLK | | HITM# | Snoop Hit Modified indicates that the current cache inquiry address has been found in the cache and dirty data exists in the cache line (modified state). | I/O | BCLK | | IGNNE# | Ignore Numeric Error forces the VIA C3 Ezra CPU to ignore any pending unmasked FPU errors and allows continued execution of floating point instructions. | I(1.5V) | ASYNC | | INIT# | Initialization resets integer registers and does not affect internal cache or floating point registers. | I(1.5V) | ASYNC | | INTR | Maskable Interrupt | I(1.5V) | ASYNC | | NMI | Non-Maskable Interrupt | I(1.5V) | ASYNC | | LOCK# | Lock Status is used by the CPU to signal to the target that the operation is atomic. | I/O | BCLK | | PWRGD | Indicates that the processor's VCC is stable. | I | ASYNC | | REQ[4:0]# | Request Command is asserted by bus driver to define current transaction type. | I/O | BCLK | | RESET# | Resets the processor and invalidates internal cache without writing back. | I | BCLK | | RS[2:0]# | Response Status signals the completion status of the current transaction when the CPU is the response agent. | I | BCLK | | SLP# | Sleep, when asserted in the stop grant state, causes the CPU to enter the sleep state. | I(1.5V) | ASYNC | | SMI# | System Management (SMM) Interrupt forces the processor to save the CPU state to the top of SMM memory and to begin execution of the SMI services routine at the beginning of the defined SMM memory space. An SMI is a high-priority interrupt than NMI. | I(1.5V) | ASYNC | | STPCLK# | Stop Clock causes the CPU to enter the stop grant state. | I(1.5V) | ASYNC | | TRDY# | Target Ready indicates that the target is ready to receive a write or write-back transfer from the CPU. | I | BCLK | | VID[3:0] | Voltage Identification Bus informs the regulatory system on the motherboard of the CPU Core voltage requirements. | O(1.5V) | ASYNC | # 4.3 POWER MANAGEMENT The VIA C3 Ezra processor provides both static and dynamic power management. The VIA C3 Ezra processor supports five power management modes: NORMAL state, STOP GRANT state, AUTOHALT state, SLEEP state, and DEEPSLEEP state. The VIA C3 Ezra processor uses dynamic power management techniques to reduce power consumption in the NORMAL state. In NORMAL state, the on-chip arrays, selected datapaths, and the associated control logic are powered down when not in use. In addition, units which are in use attempt to minimize switching of inactive nodes. - NORMAL state is the normal operating state for the processor. - STOP GRANT state is the low power state where most of the processor clocks do not toggle. It is entered when the STPCLK# signal is asserted. Snoop cycles are supported in this state. - AUTO HALT state is the low power state where most of the processor clocks do not toggle. It is entered when the processor executes the HALT instruction. Snoop cycles are supported in this state. - SLEEP state is the very low power state where only the processor's PLL (phase lock loop) toggles. It is entered from STOP GRANT state when the processor samples the SLP# signal asserted. Snoop cycles that occur while in SLEEP state or during a transition into or out of SLEEP state will cause unpredictable behavior. - DEEP SLEEP state is the lowest power state. It is entered when the BCLK signal is stopped while the processor in is the SLEEP state. Snoop cycles will be completely ignored in this state. # 4.4 TEST & DEBUG # 4.4.1 BIST A Built-in Self-Test (BIST) can be requested as part of the VIA C3 Ezra processor reset sequence by holding INIT# asserted as RESET# is de-asserted. The VIA C3 Ezra processor BIST performs the following general functions: - A hardware-implemented exhaustive test of (1) all internal microcode ROM, and (2) the X86 instruction decode, instruction generation, and entry point generation logic. - An extensive microcode test of all internal registers and datapaths. - An extensive microcode test of data and instruction caches, their tags, and associated TLBs. BIST requires about four million internal clocks. #### **EAX Value After Reset** The result of a BIST is indicated by a code in EAX. Normally EAX is zero after reset. If a BIST is requested as part of the Reset sequence, EAX contains the BIST results. A 0 in EAX after BIST Reset means that no failures were detected. Any value other than zero indicates an error has occurred during BIST. # 4.4.2 JTAG The VIA C3 Ezra processor has a JTAG scan interface that is used for test functions and the proprietary Debug Port. However, the VIA C3 Ezra processor does not provide a fully compatible IEEE 1149.1 JTAG function. From a practical user viewpoint, JTAG does not exist and the associated pins (TCLK, and so forth) should not be used. # 4.4.3 DEBUG PORT Certain processors have a proprietary Debug Port which uses the JTAG scan mechanism to control internal debug features ("probe mode"). These interfaces are not documented and are available (if at all) only under a non-disclosure agreement. The VIA C3 Ezra processor does not have a debug interface. **SECTION** 5 # **ELECTRICAL SPECIFICATIONS** ## **5.1 AC TIMING TABLES** Table 5-1. Clock Switching Characteristics | and the first the first terms of | | | | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------|------|--------|---------|--| | PARAMETER | MIN | MAX | UNIT | FIGURE | NOTES | | | BCLK Frequency | 66 | 133 | MHz | | | | | BCLK Period | 7.5 | 15 | ns | | | | | BCLK High Time | 1.4 | | ns | | 2V | | | BCLK Low Time | 1.4 | | ns | | 0.8V | | | BCLK Fall Time | 0.4 | 1.6 | ns | | 2V-0.8V | | | BCLK Rise Time | 0.4 | 1.6 | ns | | 2V-0.8V | | | BCLK Period Stability | | ±250 | ps | | | | **Table 5-2. Output Delay Timings** | abie e zi e aipai zeiaj iiiii | . J - | | | | | |-------------------------------|-------|------|------|--------|-------| | PARAMETER | MIN | MAX | UNIT | FIGURE | NOTES | | Output Valid Delay H->L | 0.40 | 3.25 | ns | | (1) | | Output Valid Delay L->H | | 3.25 | ns | | (1) | | Input Setup Time | 0.95 | | ns | | (1) | | Input Hold Time | 1.0 | | ns | | (1) | | RESET# Pulse Width | 1.0 | | ms | | (1) | #### Notes: 1. Valid delay timings for these signals are specified into an idealized 50ohm resistor to 1.5V with VREF at 1.0V. Minimum values guaranteed by design. ### 5.2 DC SPECIFICATIONS #### 5.2.1 RECOMMENDED OPERATING CONDITIONS Functional operation of the VIA C3 Ezra processor is guaranteed if the conditions in Table 5-3 are met. Sustained operation outside of the recommended operating conditions may damage the device. **Table 5-3. Recommended Operating Conditions** | PARAMETER | MIN | NOM | MAX | UNITS | NOTES | |-----------------------------------------|--------|---------------------|-------|-------|-------| | Operating Case Temperature | 0 | | 70 | °C | | | V <sub>CORE</sub> Voltage | | 1.35 | | V | | | V <sub>CORE</sub> Static Tolerance | -0.080 | | 0.040 | V | (1) | | V <sub>CORE</sub> Dynamic Tolerance | -0.130 | | 0.080 | V | (2) | | V <sub>TT</sub> Voltage | 1.365 | | 1.635 | V | | | $V_{REF}$ | -2% | 2/3 V <sub>TT</sub> | +2% | V | | | V <sub>2.5</sub> – 2.5 V Supply Voltage | 2.375 | | 2.625 | V | | | V <sub>1.5</sub> – 1.5V Supply Voltage | 1.365 | | 1.635 | V | | #### Notes: - 1. DC measurement - 2. AC noise measured with bandwidth limited to 20MHz #### **5.2.2 MAXIMUM RATINGS** While functional operation is not guaranteed beyond the operating ranges listed in Table 5-4, the device may be subjected to the limits specified in Table 5-5 without causing long-term damage. These conditions must not be imposed on the device for a sustained period—any such sustained imposition may damage the device. Likewise exposure to conditions in excess of the maximum ratings may damage the device. **Table 5-4. Maximum Ratings** | PARAMETER | MIN | MAX | UNITS | NOTES | |-----------------------------------|------|------------------------|-------|-------| | Operating Case Temperature | -65 | 110 | °C | | | Storage Temperature | -65 | 150 | °C | | | Supply Voltage (V <sub>CC</sub> ) | -0.5 | 4.0 | V | | | CMOS I/O Voltage | -0.5 | V <sub>CMOS</sub> +0.5 | V | | | I/O Voltage | -0.5 | V <sub>TT</sub> +0.5 | V | | #### 5.2.3 DC CHARACTERISTICS Table 5-5. DC Characteristics | PARAMETER | MIN | MAX | UNITS | NOTES | |--------------------------------------------------------------------|------|----------|-------|--------------------------| | I <sub>OL</sub> – Low level output current | -9.0 | | mA | $@V = V_{OL(max)}$ | | V <sub>OH</sub> – High Level Output Voltage | | $V_{TT}$ | V | | | V <sub>OL</sub> – Low Level Output Voltage | 0 | 0.4 | V | @ I <sub>ol</sub> = -8mA | | I <sub>L</sub> – Input Leakage Current | | ± 15 | μΑ | | | I <sub>LU</sub> – Input Leakage Current for inputs with pull-ups | | 200 | μΑ | | | I <sub>LD</sub> – Input Leakage Current for inputs with pull-downs | | -400 | μΑ | | Table 5-6, CMOS DC Characteristics | PARAMETER | MIN | MAX | UNITS | NOTES | |---------------------------------------------|------------------------|-------------------|-------|-------------------| | V <sub>IL</sub> Input Low Voltage | -0.58 | 0.700 | V | | | V <sub>IH1.5</sub> – Input High Voltage | V <sub>REF</sub> + 0.2 | $V_{TT}$ | V | (2) | | V <sub>IH2.5</sub> – Input High Voltage | 2.0 | 3.18 | V | (3) | | V <sub>OL</sub> – Low Level Output Voltage | | 0.40 | V | @ I <sub>OL</sub> | | V <sub>OH</sub> – High Level Output Voltage | | V <sub>CMOS</sub> | V | (1) | | I <sub>OL</sub> – Low Level Output Current | 9 | | mA | @ V <sub>OL</sub> | | I <sub>LI</sub> – Input Leakage Current | | ±100 | μΑ | (4) | | I <sub>LO</sub> – Output Leakage Current | | ±100 | μΑ | (4) | #### Notes: - 1. All CMOS signals are open drain. - 2. Applies to all CMOS signals except BCLK. - 3. Applies only to BCLK. - 4. Leakage current is specified for the range between VSS and VCC. I/O's are diode clamped to the VCC and VSS rails. BCLK has three series diodes between the input and VCC and a single diode between the input and VSS. All other signals have a single diode between the signal and VCC and another single diode between the signal and VSS. #### **5.2.4 POWER DISSIPATION** Table 5-7 through Table 5-11 give the core power consumption for the VIA C3 Ezra processor at the various operating frequencies at 1.35 Volts. Note that this does not include the power consumed by the I/O pads. Table 5-8. Normal Mode V<sub>DD</sub> Power Consumption @ 1.35V | PARAMETER | TYPICAL <sup>3,4</sup> | MAX <sup>1,2</sup> | UNITS | NOTES | |-----------------------------------------------------------|------------------------|--------------------|-------|-------| | P <sub>DD</sub> - Normal Mode Operating Power Consumption | | | | | | VIA C3 Ezra 800 (6.0 X 133 MHz) | 5.0 | 8.5 | W | | | VIA C3 Ezra 800 (8.0 X 100 MHz) | 5.0 | 8.5 | W | | | VIA C3 Ezra 850 (8.5 X 100 MHz) | 5.5 | 9.3 | W | | | VIA C3 Ezra 866 (6.5 X 133 MHz) | 5.6 | 9.6 | W | | #### Notes: - 1. Not 100% tested or guaranteed. Consider these power numbers as an average of all parts and some deviation is expected. - 2. The above power consumption is preliminary and based on 70°C case and 1.35 Volts. - 3. Typical power is defined as the average power dissipated while running WinStone99 onWin98. Contact your VIA Sales Representative for further information. - 4. Thermal solutions must be designed to account for worst-case core and I/O power consumption. Table 5-9. StopGrant V<sub>DD</sub> Power Consumption @ 1.35V | PARAMETER | MAX <sup>1,2</sup> | UNITS | NOTES | |----------------------------------------------------------------------------|--------------------|-------|---------------------------| | P <sub>DD</sub> – StopGrant / AutoHalt Mode Operating<br>Power Consumption | | | No snooping activ-<br>ity | | VIA C3 Ezra 800 (6.0 X 133 MHz) | 1.6 | W | | | VIA C3 Ezra 800 (8.0 X 100 MHz) | 1.6 | W | | | VIA C3 Ezra 850 (8.5 X 100 MHz) | 2.3 | W | | | VIA C3 Ezra 866 (6.5 X 133 MHz) | 2.3 | W | | #### Notes: - 1. Not 100% tested or guaranteed. Consider these power numbers as an average of all parts and some deviation is expected. - 2. The above power consumption is preliminary and based on 70°C case and 1.35 Volts. Table 5-10. Sleep V<sub>DD</sub> Power Consumption @ 1.35V | PARAMETER | MAX <sup>1</sup> | UNITS | NOTES | |----------------------------------------------------------|------------------|-------|-------| | P <sub>DD</sub> – Sleep Mode Operating Power Consumption | | | | | VIA C3 Ezra 800 (6.0 X 133 MHz) | 1.6 | W | | | VIA C3 Ezra 800 (6.0 X 133 MHz) | 1.6 | W | | | VIA C3 Ezra 850 (8.0 X 100 MHz) | 2.3 | W | | | VIA C3 Ezra 866 (8.0 X 100 MHz) | 2.3 | W | | #### Notes: - 1. Not 100% tested or guaranteed. Consider these power numbers as an average of all parts and some deviation is expected. - 2. The above power consumption is preliminary and based on 70°C case and 1.35 Volts. Table 5-11. Deep Sleep VDD Power Consumption @ 1.35V | PARAMETER | MAX <sup>1</sup> | UNITS | NOTES | |------------------------------------------------------------------|------------------|-------|-------| | P <sub>DD</sub> – Deep Sleep Mode Operating Power<br>Consumption | | | | | VIA C3 Ezra 800 (8.0 X 100 MHz) | 1.1 | W | | | VIA C3 Ezra 800 (6.0 X 133 MHz) | 1.1 | W | | | VIA C3 Ezra 850 (8.0 X 100 MHz) | 1.8 | W | | | VIA C3 Ezra 866 (6.5 X 133 MHz) | 1.8 | W | | #### Notes: - 1. Not 100% tested or guaranteed. Consider these power numbers as an average of all parts and some deviation is expected. - 2. The above power consumption is preliminary and based on 70°C case and 1.35 Volts. Table 5-12. Vss-I/O Power Consumption | PARAMETER | TYPICAL | MAX | UNITS | NOTES | |----------------------------------------------|---------|-----|-------|-------| | Pss-I/O – I/O Operating<br>Power Consumption | 300 | 820 | mW | | **SECTION** 6 # **MECHANICAL SPECIFICATIONS** ## **6.1 CPGA PACKAGE** The VIA C3 Ezra processor is available in a Ceramic Pin Grid Array (CPGA) package. The VIA C3 Ezra processor's CPGA package is mechanically compatible with the ceramic and plastic staggered pin grid array (SPGA and PPGA) packages. Figure 6-1. CPGA Pinout (Pinside View) **Table 6-1. CPGA Pin Cross Reference** | Add | iress | Da | ata | Cont | rol | Power/0 | <u>Other</u> | Vcc | V <sub>TT</sub> | V <sub>ss</sub> | Reserved | |-------------|---------|-------------|---------|----------|---------|-------------------|--------------|-------|-----------------|-----------------|----------| | Pin<br>Name | Pin No. | Pin<br>Name | Pin No. | Pin Name | Pin No. | Pin Name | Pin No. | | Pin No. | | Pin No. | | A3# | AK-8 | D0# | W-1 | A20M# | AE-33 | CPUPRES# | C-37 | AA-5 | AH-20 | AM-22 | AK-24 | | A4# | AH-12 | D1# | T-4 | ADS# | AN-31 | PLL1 | W-33 | AB-2 | AK-16 | AM-26 | AL-11 | | A5# | AH-8 | D2# | N-1 | BCLK | W-37 | PLL2 | U-33 | AB-34 | AL-13 | AM-30 | AN-13 | | A6# | AN-9 | D3# | M-6 | BNR# | AH-14 | V <sub>1.5</sub> | AD-36 | AD-32 | AL-21 | AM-34 | V-4 | | A7# | AL-15 | D4# | U-1 | BPRI# | AN-17 | V <sub>2.5</sub> | Z-36 | AE-5 | AN-11 | AM-6 | B-36 | | A8# | AH-10 | D5# | S-3 | BR0# | AN-29 | V <sub>CMOS</sub> | AB-36 | E-5 | AN-15 | AN-3 | G-33 | | A9# | AL-9 | D6# | T-6 | BSEL0 | AJ-33 | VID0 | AL-35 | E-9 | G-35 | B-12 | E-37 | | A10# | AH-6 | D7# | J-1 | BSEL1 | AJ-31 | VID1 | AM-36 | F-14 | AA-33 | B-16 | C-35 | | A11# | AK-10 | D8# | S-1 | DBSY# | AL-27 | VID2 | AL-37 | F-2 | AA-35 | B-20 | E-35 | | A12# | AN-5 | D9# | P-6 | DEFER# | AN-19 | VID3 | AJ-37 | F-22 | AN-21 | B-24 | X-2 | | A13# | AL-7 | D10# | Q-3 | DRDY# | AN-27 | V <sub>REF0</sub> | E-33 | F-26 | E-23 | B-28 | C-33 | | A14# | AK-14 | D11# | M-4 | FERR# | AC-35 | V <sub>REF1</sub> | F-18 | F-30 | S-33 | B-32 | C-31 | | A15# | AL-5 | D12# | Q-1 | FLUSH# | AE-37 | V <sub>REF2</sub> | K-4 | F-34 | S-37 | B-4 | A-33 | | A16# | AN-7 | D13# | L-1 | HIT# | AL-25 | V <sub>REF3</sub> | R-6 | F-4 | U-35 | B-8 | A-31 | | A17# | AE-1 | D14# | N-3 | HITM# | AL-23 | V <sub>REF4</sub> | V-6 | H-32 | U-37 | D-18 | E-31 | | A18# | Z-6 | D15# | U-3 | IGNNE# | AG-37 | $V_{REF5}$ | AD-6 | H-36 | | D-2 | C-29 | | A19# | AG-3 | D16# | H-4 | INIT# | AG-33 | V <sub>REF6</sub> | AK-12 | J-5 | | D-22 | E-29 | | A20# | AC-3 | D17# | R-4 | INTR | M-36 | V <sub>REF7</sub> | AK-22 | K-2 | | D-26 | A-29 | | A21# | AJ-1 | D18# | P-4 | NMI | L-37 | THERMON | AL-29 | K-32 | | D-30 | J-33 | | A22# | AE-3 | D19# | H-6 | LOCK# | AK-20 | THERMDP | AL-31 | K-34 | | D-34 | J-35 | | A23# | AB-6 | D20# | L-3 | PWRGOOD | AK-26 | | | M-32 | | D-4 | L-35 | | A24# | AB-4 | D21# | G-1 | REQ0# | AK-18 | | | N-5 | | Z-34 | A-35 | | A25# | AF-6 | D22# | F-8 | REQ1# | AH-16 | | | P-2 | | E-11 | G-37 | | A26# | Y-3 | D23# | G-3 | REQ2# | AH-18 | | | P-34 | | E-15 | L-33 | | A27# | AA-1 | D24# | K-6 | REQ3# | AL-19 | | | R-32 | | E-19 | N-33 | | A28# | AK-6 | D25# | E-3 | REQ4# | AL-17 | | | R-36 | | E-7 | N-35 | | A29# | Z-4 | D26# | E-1 | RESET# | X-4 | | | S-5 | | F-20 | N-37 | | A30# | AA-3 | D27# | F-12 | RS0# | AH-26 | | | T-2 | | F-24 | Q-33 | | A31# | AD-4 | D28# | A-5 | RS1# | AH-22 | | | T-34 | | F-28 | Q-35 | | | | D29# | A-3 | RS2# | AK-28 | | | V-32 | | F-32 | Q-37 | | | | D30# | J-3 | SLP# | AH-30 | | | V-36 | | F-36 | R-2 | | | | D31# | C-5 | SMI# | AJ-35 | | | W-5 | | G-5 | W-35 | | | | D32# | F-6 | STPCLK# | AG-35 | | | Y-35 | | H-2 | Y-1 | | | | D33# | C-1 | TRDY# | AN-25 | | | Z-32 | | H-34 | AK-30 | | | | D34# | C-7 | | | | | AF-2 | | K-36 | AM-2 | | | | D35# | B-2 | | | | | AH-24 | | L-5 | F-10 | | | | D36# | C-9 | | | | | AH-32 | | M-2 | AN-23 | | | | D37# | A-9 | | | | | AH-36 | | M-34 | AC-37 | | Address | | Dá | ata | Cont | rol | Power/ | Other | Vcc | V <sub>TT</sub> | V <sub>ss</sub> | Reserved | |-------------|---------|-------------|---------|----------|---------|----------|---------|---------|-----------------|-----------------|----------| | Pin<br>Name | Pin No. | Pin<br>Name | Pin No. | Pin Name | Pin No. | Pin Name | Pin No. | Pin No. | | Pin No. | Pin No. | | | | D38# | D-8 | | | | | AJ-13 | | P-32 | AL-33 | | | | D39# | D-10 | | | | | AJ-17 | | P-36 | AN-35 | | | | D40# | C-15 | | | | | AJ-21 | | A-37 | AN-37 | | | | D41# | D-14 | | | | | AJ-25 | | AB-32 | AH-28 | | | | D42# | D-12 | | | | | AJ-29 | | AC-33 | AK-32 | | | | D43# | A-7 | | | | | AJ-5 | | AC-5 | AN-33 | | | | D44# | A-11 | | | | | AK-2 | | AD-2 | S-35 | | | | D45# | C-11 | | | | | AK-34 | | AD-34 | E-27 | | | | D46# | A-21 | | | | | AM-12 | | AF-32 | AG-1 | | | | D47# | A-15 | | | | | AM-16 | | AF-36 | AH-4 | | | | D48# | A-17 | | | | | AM-20 | | AG-5 | E-21 | | | | D49# | C-13 | | | | | AM-24 | | AH-2 | AC-1 | | | | D50# | C-25 | | | | | AM-28 | | AH-34 | W-3 | | | | D51# | A-13 | | | | | AM-32 | | AJ-11 | AF-4 | | | | D52# | D-16 | | | | | AM-4 | | AJ-15 | X-6 | | | | D53# | A-23 | | | | | AM-8 | | AJ-19 | Y-33 | | | | D54# | C-21 | | | | | B-10 | | AJ-23 | J-37 | | | | D55# | C-19 | | | | | B-14 | | AJ-27 | AE-35 | | | | D56# | C-27 | | | | | B-18 | | AJ-7 | AA-37 | | | | D57# | A-19 | | | | | B-22 | | AK-36 | AJ-3 | | | | D58# | C-23 | | | | | B-26 | | AL-3 | AK-4 | | | | D59# | C-17 | | | | | B-30 | | AM-10 | AL-1 | | | | D60# | A-25 | | | | | B-34 | | AM-14 | X-34 | | | | D61# | A-27 | | | | | B-6 | | AM-18 | | | | | D62# | E-25 | | | | | C-3 | | Q-5 | | | | | D63# | F-16 | | | | | D-20 | | R-34 | | | | | | | | | | | D-24 | | T-32 | | | | | | | | | | | D-32 | | T-36 | | | | | | | | | | | D-36 | | U-5 | | | | | | | | | | | D-6 | | V-2 | | | | | | | | | | | E-13 | | V-34 | | | | | | | | | | | E-17 | | X-32 | | | | | | | | | | | AJ-9 | | X-36 | | | | | | | | | | | D-28 | | Y-37 | | | | | | | | | | | AF-34 | | Y-5 | | | | | | | | | | | | | Z-2 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Table 6-2. CPGA with Heat Slug Dimensions **Table 6-3. CPGA Package Dimensions** | 6 1 1 | | Millin | neters | | Inches | | | | |--------|-----------------|--------|--------|---------------|---------|--------|-------|---------------| | Symbol | Typical | Min | Max | Notes | Typical | Min | Max | Notes | | A | 1.96 | 1.76 | 2.16 | | 0.077 | 0.069 | 0.085 | | | A1 | A1 1.00 typical | | | | 0.039 t | ypical | | | | A2 | 2.96 | 2.72 | 3.33 | | 0.116 | 0.107 | 0.131 | | | φВ | 0.046 | 0.41 | 0.51 | | 0.018 | 0.016 | 0.020 | | | D | 49.53 | 49.28 | 49.83 | | 1.950 | 1.940 | 1.962 | | | D1 | 45.72 | 45.47 | 45.97 | | 1.8 | 1.790 | 1.810 | | | D2 | 25.4 | 25.02 | 25.78 | | 1.00 | 0.985 | 1.015 | | | e1 | 2.54 | 2.41 | 2.67 | | 0.100 | 0.095 | 0.105 | | | L | 3.18 | 2.98 | 3.38 | | 0.125 | 0.117 | 0.133 | | | N | | | | Lead<br>count | | | | Lead<br>count | | S1 | 1.905 | 1.65 | 2.16 | count | 0.075 | 0.065 | 0.085 | count | **SECTION** # THERMAL SPECIFICATIONS ### 7.1 INTRODUCTION The VIA C3 Ezra is specified for operation with device case temperatures in the range of 0°C to 70°C. Operation outside of this range will result in functional failures and may potentially damage the device. Care must be taken to ensure that the case temperature remains within the specified range at all times during operation. An effective heat sink with adequate airflow is therefore a requirement during operation. #### 7.2 TYPICAL ENVIRONMENTS Typical thermal solutions involve three components: a heat sink, an interface material between the heat sink and the package, and a source of airflow. The best thermal solutions rely on the use of all three components. To the extent that any of these components are not used, the other components must be improved to compensate for such omission. In particular, the use of interface material such as thermal grease, silicone paste, or graphite paper can make a 40°C difference in the case temperature. Likewise, the imposition of airflow is realistically a requirement. # 7.3 MEASURING T<sub>C</sub> The case temperature ( $T_c$ ) should be measured by attaching a thermocouple to the center of the VIA C3 Ezra package. The heat produced by the processor is very localized so measuring the case temperature anywhere else will underestimate the case temperature. The presence of a thermocouple is inherently invasive; effort must be taken to minimize the effect of the measurement. The thermocouple should be attached to the processor through a small hole drilled in the heat sink. Thermal grease should be used to ensure that the thermocouple makes good contact with the package, but the thermocouple should not come in direct contact with the heat sink. #### **Physical Test Conditions** Case temperature measurements should be made in the worst case operating environments. Ideally, systems should be maximally configured, and tested at the worst-case ambient temperature. #### **Test Patterns** During normal operation the processor attempts to minimize power consumption. Consequently, normal power consumption is much lower than the maximum power consumption. Thermal testing should be done while running software which causes the processor to operate at its thermal limits. ## 7.4 MEASURING T<sub>J</sub> The junction temperature of the die can be measured by using the processor's on-chip diode. ## 7.5 ESTIMATING T<sub>C</sub> The VIA C3 Ezra processor's case temperature can be estimated based on the general characteristics of the thermal environment. This estimate is not intended as a replacement for actual measurement. Case temperature can be estimated from Table 7-1 below, where, $T_A \equiv Ambient Temperature$ $T_c \equiv Case Temperature$ $\theta_{CA} \equiv case-to-ambient thermal resistance$ $\theta_{IA} \equiv \text{junction-to-ambient thermal resistance}$ $\theta_{IC} \equiv junction-to-case thermal resistance$ $P \equiv power consumption (Watts)$ and, $$T_{J} = T_{C} + (P * \theta_{JC})$$ $$T_{A} = T_{I} - (P * \theta_{IA})$$ $$T_A = T_C - (P * \theta_{CA})$$ $$\theta_{_{\mathrm{CA}}}$$ = $\theta_{_{\mathrm{JA}}} - \theta_{_{\mathrm{JC}}}$ Table 7-1. CPGA $\theta_{JC}$ and $\theta_{JA}$ | | | θJA (°C/WATT) VS. LAMINAR AIRFLOW<br>(LINEAR FT/MIN) | | | | | OW . | |------------------------------|---------------------------|------------------------------------------------------|------|------|-----|-----|------| | Heat Sink in Inches (height) | θ <sub>JC</sub> (°C/Watt) | 0 | 100 | 200 | 400 | 600 | 800 | | 0.25 | 1.2 | 9.5 | 8.4 | 7.0 | 4.9 | 4.0 | 3.4 | | 0.35 | 1.2 | 9.2 | 7.9 | 6.4 | 4.4 | 3.7 | 3.2 | | 0.45 | 1.2 | 8.8 | 7.4 | 5.7 | 4.0 | 3.3 | 2.9 | | 0.55 | 1.2 | 8.5 | 6.9 | 5.1 | 3.6 | 3.0 | 2.7 | | 0.65 | 1.2 | 8.1 | 6.4 | 4.7 | 3.4 | 2.8 | 2.5 | | 0.80 | 1.2 | 7.4 | 5.7 | 4.3 | 3.2 | 2.6 | 2.4 | | 1.00 | 1.2 | 6.7 | 5.1 | 4.0 | 3.0 | 2.5 | 2.2 | | 1.20 | 1.2 | 6.3 | 4.7 | 3.7 | 2.8 | 2.4 | 2.2 | | 1.40 | 1.2 | 5.8 | 4.3 | 3.4 | 2.6 | 2.3 | 2.1 | | No Heat Sink | 1.6 | 14.7 | 13.4 | 12.0 | 9.1 | 7.7 | 6.8 | Environment: these estimates assume the use of thermal grease between the processor and the heat sink. Heat sinks are 1.95" square. **APPENDIX** # **MACHINE SPECIFIC REGISTERS** ### A.1 GENERAL Tables A-1 and A-2 summarize the VIA C3 Ezra processor machine-specific registers (MSRs). Further description of each MSR follows the table. MSRs are read using the RDMSR instruction and written using the WRMSR instruction. There are four basic groups of MSRs (not necessarily with contiguous addresses). Other than as defined below, a reference to an undefined MSR causes a General Protection exception. - 1. Generally these registers can have some utility to low-level programs (like BIOS). - Note that some of the MSRs (address 0 to 0x4FF) have no function in the VIA C3 Ezra processor. These MSRs do not cause a GP when used on the VIA C3 Ezra processor; instead, reads to these MSRs return zero, and writes are ignored. Some of these undocumented MSRs may have ill side effects when written to indiscriminately. Do not write to undocumented MSRs. - 2. There are some undocumented internal-use MSRs used for low-level hardware testing purposes. Attempts to read or write these undocumented MSRs cause unpredictable and disastrous results; so don't use MSRs that are not documented in this datasheet! - 3. MSRs used for cache and TLB testing. These use MSR addresses that are not used on compatible processor. These test functions are very low-level and complicated to use. They are not documented in this datasheet but the information will be provided to customers given an appropriate justification MSRs are not reinitialized by the bus INIT interrupt; the setting of MSRs is preserved across INIT. **Table A-1. Category 1 MSRs** | MSR | MSR NAME | ECX | EDX | EAX | TYPE | NOTES | |----------------|------------------------|------|--------------|--------------|------|-------| | TSC | Time Stamp Counter | 10h | TSC[63:32] | TSC[31:0] | RW | | | EBL_CR_POWERON | EBL_CR_POWERON | 2Ah | n/a | Control bits | RW | | | PERFCTR0 | Performance counter 0 | C1h | TSC[39:32] | TSC[31:0] | RW | 1 | | PERFCTR1 | Performance counter 1 | C2h | 0 | Count[31:0] | RW | | | BBL_CR_CTL3 | L2 Hardware Disabled | 11Eh | n/a | 00800000h | RO | | | EVNTSEL0 | Event counter 0 select | 186h | n/a | 00470079h | RO | 1 | | EVNTSEL1 | Event counter 1 select | 187h | n/a | Control bits | RW | | | MTRR | MTRRphysBase0 | 200h | Control bits | Control bits | RW | | | MTRR | MTRRphysMask0 | 201h | Control bits | Control bits | RW | | | MTRR | MTRRphysBase1 | 202h | Control bits | Control bits | RW | | | MTRR | MTRRphysMask1 | 203h | Control bits | Control bits | RW | | | MTRR | MTRRphysBase2 | 204h | Control bits | Control bits | RW | | | MTRR | MTRRphysMask2 | 205h | Control bits | Control bits | RW | | | MTRR | MTRRphysBase3 | 206h | Control bits | Control bits | RW | | | MTRR | MTRRphysMask3 | 207h | Control bits | Control bits | RW | | | MTRR | MTRRphysBase4 | 208h | Control bits | Control bits | RW | | | MTRR | MTRRphysMask4 | 209h | Control bits | Control bits | RW | | | MTRR | MTRRphysBase5 | 20Ah | Control bits | Control bits | RW | | | MTRR | MTRRphysMask5 | 20Bh | Control bits | Control bits | RW | | | MTRR | MTRRphysBase6 | 20Ch | Control bits | Control bits | RW | | | MTRR | MTRRphysMask6 | 20Dh | Control bits | Control bits | RW | | | MTRR | MTRRphysBase7 | 20Eh | Control bits | Control bits | RW | | | MTRR | MTRRphysMask7 | 20Fh | Control bits | Control bits | RW | | | MTRR | MTRRfix64K_00000 | 250h | Control bits | Control bits | RW | | | MTRR | MTRRfix16K_80000 | 258h | Control bits | Control bits | RW | | | MTRR | MTRRfix16K_A0000 | 259h | Control bits | Control bits | RW | | | MTRR | MTRRfix4K_C0000 | 268h | Control bits | Control bits | RW | | | MTRR | MTRRfix4K_C8000 | 269h | Control bits | Control bits | RW | | | MTRR | MTRRfix4K_D0000 | 26Ah | Control bits | Control bits | RW | | | MTRR | MTRRfix4K_D8000 | 26Bh | Control bits | Control bits | RW | | | MTRR | MTRRfix4K_E0000 | 26Ch | Control bits | Control bits | RW | | | MTRR | MTRRfix4K_E8000 | 26Dh | Control bits | Control bits | RW | | | MTRR | MTRRfix4K_F0000 | 26Eh | Control bits | Control bits | RW | | | MTRR | MTRRfix4K_F8000 | 26Fh | Control bits | Control bits | RW | | | MTRR | MTRRdefType | 2FFh | Control bits | Control bits | RW | | #### Notes: 1. PERFCTR0 is an alias for the lower 40 bits of the Time Stamp Counter. EVNTSEL0 is a read only MSR that reflects this limitation. Table A-2. Category 2 MSRs | MSR | MSR NAME | ECX | EDX | EAX | TYPE | NOTES | |------|-----------------------|-------|---------|------------|------|-------| | FCR | Feature Control Reg | 1107h | n/a | FCR value | RW | | | FCR2 | Feature Control Reg 2 | 1108h | FCR2_Hi | FCR2 value | RW | 1 | | FCR3 | Feature Control Reg 3 | 1109h | FCR3_Hi | FCR3 value | WO | 1 | #### Notes: 1. FCR2 and FCR3 provide system software with the ability to specify the Vendor ID string returned by the CPUID instruction. #### A.2 CATEGORY 1 MSRS # 10H: TSC (TIME STAMP COUNTER) VIA C3 Ezra processor has a 64-bit MSR that materializes the Time Stamp Counter (TSC). System increments the TSC once per processor clock. The TSC is incremented even during AutoHalt or StopClock. A WRMSR to the TSC will clear the upper 32 bits of the TSC. ### 2AH: EBL\_CR\_POWERON | 31:27 | 26 | 25:22 | 21:20 | 19:18 | 17:15 | 14 | 13 | 12:0 | |----------------|------------------------|-------|-------|-------|-------|-------|----------|------------------------------------------------------| | Res<br>'11000' | LowPow-<br>erEn<br>'1' | BF | Res | BSEL | Res | 1MPOV | IOQDepth | Reserved<br>(Ignored on write;<br>returns 0 on read) | | 5 | 1 | 4 | 2 | 2 | 3 | 1 | 1 | 13 | **IOQDepth:** 0 = In Order Queue Depth with up to 8 transactions 1 = 1 transaction **1MPOV:** 0 = Power on Reset Vector at 0xFFFFFFF0 (4Gbytes) 1 = Power on Reset Vector at 0x000FFFF0 (1 Mbyte) **BSEL:** 01 = 133 MHz Bus 10 = 100 MHz Bus BF: Bus Clock Frequency Ratio | 0000 | 5.0 | |---------------------------------------|------| | 0001 | 3.0 | | 0010 | 4.0 | | 0011 | 10.0 | | 0100 | 5.5 | | 0101 | 3.5 | | 0110 | 4.5 | | 0111 | 9.5 | | 1000 | 9.0 | | 1001 | 7.0 | | 1010 | 8.0 | | 1011 | 6.0 | | 1100 | 12.0 | | 1101 | 7.5 | | 1110 | 8.5 | | 1111 | 6.5 | | · · · · · · · · · · · · · · · · · · · | · | LowPowerEn: This bit always set to '1' ## C1H-C2H: PERFCTR0 & PERFCTR1 These are events counters 0 and 1. VIA C3 Ezra processor's PERFCTR0 is an alias for the lower 40 bits of the TSC. ## 11EH: BBL\_CR\_CTL3 | 31:24 | 23 | 22:0 | |----------|-----------------------|------------------------------------------------------| | Reserved | L2_Hdw_Disable<br>'1' | Reserved<br>(Ignored on write;<br>returns 0 on read) | | 8 | 1 | 23 | The VIA C3 Ezra processor does contain an L2 cache. For compatibility, this read-only MSR indicates to the BIOS or system software that the L2 is disabled even if the L2 is enabled. L2\_Hdw\_Disable: This bit always set to '1' ## 186H: EVNTSEL0 (EVENT COUNTER 0 SELECT) | 31:24 | 23:16 | 15:9 | 8:0 | |----------|----------|----------|----------------------------| | Reserved | Reserved | Reserved | CTR0 Event<br>Select = 79h | | <br>8 | 8 | 7 | 9 | PERFCTR0 is an alias for the lower 40 bits of the Time Stamp Counter. EVNTSEL0 is a read only MSR which reflects this limitation. The CTR0\_Event Select field always returns 0x0079, which corresponds to counting of processor clocks. # 187H: EVNTSEL1 (EVENT COUNTER 1 SELECT) | 31:24 | 23:16 | 15:9 | 8:0 | |----------|----------|----------|----------------------| | Reserved | Reserved | Reserved | CTR1 Event<br>Select | | 8 | 8 | 7 | 9 | VIA C3 Ezra processor have two MSRs that contain bits defining the behavior of the two hardware event counters: PERFCTR0 and PERFCTR1. The CTR1\_Event\_Select control field defines which of several possible events is counted. The possible Event Select values for PERFCTR1 are listed in the table below. Note that CTR1\_Event\_Select is a 9-bit field. The EVNTSEL1 register should be written before PERFCTR1 is written to initialize the counter. The counts are not necessarily perfectly exact; the counters are intended for use over a large number of events and may differ by one or two counts from what might be expected. Most counter events are internal implementation-dependent debug functions, having no meaning to software. The counters that can have end-user utility are: | EVENT | DESCRIPTION | |-------|---------------------------------------------| | C0h | Instructions executed | | 1C0h | Instructions executed and string iterations | | 79h | Internal clocks (default event for CTR0) | #### A.3 CATEGORY 2 MSRS ## 1107H: FCR (FEATURE CONTROL REGISTER) The FCR controls the major optional feature capabilities of the VIA C3 Ezra processor. Table A-3 contains the bit values for the FCR. The default settings shown for the FCR bits are not necessarily exact. The actual settings can be changed as part of the manufacturing process and thus a particular VIA C3 Ezra processor version can have slightly different default settings than shown here. All reserved bit values of the FCR must be preserved by using a read-modify-write sequence to update the FCR. Table A-3. FCR Bit Assignments | BIT | NAME | DESCRIPTION | DEFAULT | |-------|---------|----------------------------------------------------|---------| | 0 | | Reserved | 0 | | 1 | ECX8 | Enables CPUID reporting CX8 | 0 | | 2 | | Reserved | 0 | | 3 | | Reserved | 0 | | 4 | | Reserved | 0 | | 5 | DSTPCLK | Disables supporting STPCLK | 0 | | 6 | | Reserved | 0 | | 7 | EPGE | Enables CR4.PGE and CPUID.PGE (Page Global Enable) | 1 | | 8 | DL2 | Disables L2 Cache | 0 | | 9 | | Reserved | 1 | | 10 | | Reserved | 0 | | 11 | DPDC | Disables Page Directory cache | 0 | | 12 | EBRPRED | Enables Branch Prediction | 1 | | 13 | DIC | Disables I-Cache | 0 | | 14 | DDC | Disables D-Cache | 0 | | 15 | | Reserved | 1 | | 16 | | Reserved | 1 | | 17 | | Reserved | 1 | | 18 | | Reserved | 0 | | 19 | | Reserved | 1 | | 20 | | Reserved | 1 | | 21 | | Reserved | 1 | | 22:25 | SID | Stepping ID | 0 | | 26 | | Reserved | 0 | | 27 | | Reserved | 0 | | 28 | | Reserved | 1 | | 29 | | Reserved | 0 | | 30 | | Reserved | 0 | | 31 | | Reserved | 1 | ECX8: 0 = The CPUID instruction does not report the presence of the CMPXCHG8B instruc- tion (CX8 = 0). The instruction actually exists and operates correctly, however. 1 = The CPUID instruction reports that the CMPXCHG8B instruction is supported (CX8 = 1). **DSTPCLK:** 0 = STPCLK interrupt properly supported. 1 = Ignores SPCLK interrupt. EPGE: 0 = The processor does not support Page Global Enable and therefore CPUID Feature Flags reports EDX[13]=0; attempts to set CR4.PGE are ignored. 1 = The processor supports Page Global Enable and therefore CPUID Feature Flags re- ports EDX[13]=1; CR4.PGE can be set to 1. DL2: 0 = L2 Cache enabled. 1 = L2 Cache disabled. **DPDC:** 0 = Enables use of internal Page Directory Cache. 1 = Disables use of internal Page Directory Cache. **EBRPRED:** 0 = Disables branch prediction function. 1 = Enables branch prediction function. **DIC:** 0 = Enables use of I-Cache. 1 = Disables use of I-Cache: cache misses are performed as single transfer bus cycles, PCD is de-asserted. This overrides any setting of CR0.CD and CR0.NW. **DDC:** 0 = Enables use of D-Cache. 1 = Disables use of D-Cache: same semantics as for DIC except for D-Cache. # 1108H: FCR2 (FEATURE CONTROL REGISTER 2) This MSR contains more feature control bits — many of which are undefined. It is important that all reserved bits are preserved by using a read-modify-write sequence to update the MSR. 63:32 ## Last 4 characters of Alternate Vendor ID string AVS: 0 = The CPUID instruction vendor ID is "CentaurHauls" 1 = The CPUID instruction returns the alternate Vendor ID. The first 8 characters of the alternate Vendor ID are stored in FCR3 and the last 4 characters in FCR2[63:32]. These 12 characters are undefined after RESET and may be loaded by system software using WRMSR. Family ID: This field will be returned as the family ID field by subsequent uses of the CPUID in- struction Model ID: This field will be returned as the model ID field by subsequent uses of the CPUID in- struction ## 1109H: FCR (FEATURE CONTROL REGISTER 3) This MSR contains the first 8 characters of the alternate Vendor ID. The alternate Vendor ID is returned by the CPUID instruction when FCR2[AVS] is set to '1'. FCR3 is a write-only MSR. 63:32 First 4 characters of Alternate Vendor ID string 31:0 Middle 4 characters of Alternate Vendor ID string