R
Intel 815 Chipset Family: 82815 Graphics and Memory Controller Hub (GMCH)
Datasheet
June 2000
Document Reference Number: 290688-001
82815 GMCH
R
Information in this document is provided in connection with Intel products. No license, express or implied, by estoppel or otherwise, to any intellectual property rights is granted by this document. Except as provided in Intel’s Terms and Conditions of Sale for such products, Intel assumes no liability whatsoever, and Intel disclaims any express or implied warranty, relating to sale and/or use of Intel products including liability or warranties relating to fitness for a particular purpose, merchantability, or infringement of any patent, copyright or other intellectual property right. Intel products are not intended for use in medical, life saving, or life sustaining applications. Intel may make changes to specifications and product descriptions at any time, without notice. Designers must not rely on the absence or characteristics of any features or instructions marked "reserved" or "undefined." Intel reserves these for future definition and shall have no responsibility whatsoever for conflicts or incompatibilities arising from future changes to them. The Intel 815 chipset GMCH may contain design defects or errors known as errata which may cause the product to deviate from published specifications. Current characterized errata are available on request. Contact your local Intel sales office or your distributor to obtain the latest specifications and before placing your product order.
2 2 I C is a 2-wire communications bus/protocol developed by Philips. SMBus is a subset of the I C bus/protocol and was developed by Intel. Implementations of the I2C bus/protocol may require licenses from various entities, including Philips Electronics N.V. and North American Philips Corporation.
Alert on LAN is a result of the Intel-IBM Advanced Manageability Alliance and a trademark of IBM Copies of documents which have an ordering number and are referenced in this document, or other Intel literature, may be obtained from: Intel Corporation www.intel.com or call 1-800-548-4725 *Third-party brands and names are the property of their respective owners. Copyright © Intel Corporation 2000
2
Datasheet
82815 GMCH
R
Contents
1. Overview.....................................................................................................................................13 1.1. 1.2. 1.3. 1.4. 1.5. 1.6. Related Documents .......................................................................................................13 The Intel 815 Chipset Family........................................................................................14 82815 GMCH Overview .................................................................................................16 Host Interface.................................................................................................................17 System Memory Interface ..............................................................................................17 Multiplexed AGP and Display Cache Interface ..............................................................18 1.6.1. AGP Interface ..............................................................................................18 1.6.2. Display Cache Interface...............................................................................18 Hub Interface..................................................................................................................18 82815 GMCH Integrated Graphics Support...................................................................19 1.8.1. Display, Digital Video Out, and LCD/Flat Panel/Digital CRT........................19 System Clocking ............................................................................................................20 GMCH Power Delivery ...................................................................................................20
1.7. 1.8. 1.9. 1.10. 2.
Signal Description.......................................................................................................................21 2.1. 2.2. 2.3. Host Interface Signals ....................................................................................................22 System Memory Interface Signals .................................................................................23 AGP Interface Signals....................................................................................................24 2.3.1. AGP Addressing Signals..............................................................................24 2.3.2. AGP Flow Control Signals............................................................................25 2.3.3. AGP Status Signals .....................................................................................25 2.3.4. AGP Clocking Signals (Strobes) ..................................................................26 2.3.5. AGP FRAME# Signals .................................................................................27 Display Cache Interface Signals ....................................................................................29 Hub Interface Signals.....................................................................................................30 Display Interface Signals................................................................................................30 Digital Video Output Signals/TV-Out Pins......................................................................31 Power Signals ................................................................................................................32 Clock Signals .................................................................................................................32 GMCH Power-Up/Reset Strap Options..........................................................................33 Multiplexed Display Cache and AGP Signal Mapping....................................................34 2.11.1. Display Cache Mapping at the AGP Connector ...........................................35 Register Nomenclature and Access Attributes ..............................................................37 PCI Configuration Space Access ...................................................................................38 3.2.1. PCI Bus Configuration Mechanism ..............................................................38 3.2.2. Logical PCI Bus #0 Configuration Mechanism.............................................39 3.2.3. Primary PCI (PCI0) and Downstream Configuration Mechanism ................39 3.2.4. Internal Graphics Device Configuration Mechanism....................................39 3.2.5. GMCH Register Introduction........................................................................39 I/O Mapped Registers ....................................................................................................40 3.3.1. CONF_ADDRConfiguration Address Register .........................................40 3.3.2. CONF_DATAConfiguration Data Register ...............................................41
2.4. 2.5. 2.6. 2.7. 2.8. 2.9. 2.10. 2.11. 3.
Configuration Registers ..............................................................................................................37 3.1. 3.2.
3.3.
Datasheet
3
82815 GMCH
R
3.4.
3.5.
Host-Hub Interface Bridge/DRAM Controller Device Registers (Device 0) ................... 42 3.4.1. VID—Vendor Identification Register (Device 0) .......................................... 44 3.4.2. DID—Device Identification Register (Device 0)........................................... 44 3.4.3. PCICMD—PCI Command Register (Device 0) ........................................... 45 3.4.4. PCISTS—PCI Status Register (Device 0) ................................................... 46 3.4.5. RID—Revision Identification Register (Device 0) ........................................ 47 3.4.6. SUBC—Sub-Class Code Register (Device 0) ............................................. 47 3.4.7. BCC—Base Class Code Register (Device 0).............................................. 47 3.4.8. MLT—Master Latency Timer Register (Device 0) ....................................... 48 3.4.9. HDR—Header Type Register (Device 0)..................................................... 48 3.4.10. APBASE—Aperture Base Configuration Register (Device 0: AGP Mode Only) .................................................................................................. 48 3.4.11. SVID—Subsystem Vendor Identification Register (Device 0) ..................... 50 3.4.12. SID—Subsystem Identification Register (Device 0) .................................... 50 3.4.13. CAPPTR—Capabilities Pointer (Device 0) .................................................. 50 3.4.14. GMCHCFG—GMCH Configuration Register (Device 0) ............................. 51 3.4.15. APCONT—Aperture Control (Device 0) ...................................................... 53 3.4.16. DRP—DRAM Row Population Register (Device 0)..................................... 54 3.4.17. DRAMT—DRAM Timing Register (Device 0).............................................. 55 3.4.18. DRP2—DRAM Row Population Register 2 (Device 0)................................ 56 3.4.19. FDHC—Fixed DRAM Hole Control Register (Device 0).............................. 57 3.4.20. PAM—Programmable Attributes Map Registers (Device 0)........................ 57 3.4.21. SMRAM—System Management RAM Control Register (Device 0) ........... 62 3.4.22. MISCC—Miscellaneous Control Register (Device 0) .................................. 64 3.4.23. CAPID—Capability Identification (Device 0: AGP Mode Only).................... 66 3.4.24. BUFF_SC—System Memory Buffer Strength Control Register (Device 0) .................................................................................................... 67 3.4.25. BUFF_SC2—System Memory Buffer Strength Control Register 2 (Device 0) .................................................................................................... 70 3.4.26. SM_RCOMP—System Memory R Compensation Control Register (Device 0) .................................................................................................... 71 3.4.27. SM—System Memory Control Register....................................................... 72 3.4.28. ACAPID—AGP Capability Identifier Register (Device 0: AGP Mode Only) .................................................................................................. 73 3.4.29. AGPSTAT—AGP Status Register (Device 0: AGP Mode Only) ................. 74 3.4.30. AGPCMD—AGP Command Register (Device 0: AGP Mode Only) ............ 75 3.4.31. AGPCTRL—AGP Control Register (Device 0: AGP Mode Only) ................ 76 3.4.32. APSIZE—Aperture Size (Device 0: AGP Mode Only) ................................. 77 3.4.33. ATTBASE—Aperture Translation Table Base Register (Device 0: AGP Mode Only) .................................................................................................................... 78 3.4.34. AMTT—AGP Multi-Transaction Timer (Device 0: AGP Mode Only) .......... 79 3.4.35. LPTT—AGP Low Priority Transaction Timer Register (Device 0: AGP Mode Only) .................................................................................................. 80 3.4.36. GMCHCFG—GMCH Configuration Register (Device 0: AGP Mode Only) .................................................................................................. 81 3.4.37. ERRCMD—Error Command Register (Device 0: AGP Mode Only)........... 82 AGP/PCI Bridge Registers (Device 1: Visible in AGP Mode Only)............................... 84 3.5.1. VID1—Vendor Identification Register (Device 1) ........................................ 85 3.5.2. DID1—Device Identification Register (Device 1)......................................... 85 3.5.3. PCICMD1—PCI-PCI Command Register (Device 1) .................................. 85 3.5.4. PCISTS1—PCI-PCI Status Register (Device 1).......................................... 87 3.5.5. RID1—Revision Identification Register (Device 1) ...................................... 88 3.5.6. SUBC1—Sub-Class Code Register (Device 1) ........................................... 88 3.5.7. BCC1—Base Class Code Register (Device 1)............................................ 88
4
Datasheet
82815 GMCH
R
3.6.
3.7.
3.8.
3.5.8. MLT1—Master Latency Timer Register (Device 1) .....................................89 3.5.9. HDR1—Header Type Register (Device 1) ...................................................89 3.5.10. PBUSN—Primary Bus Number Register (Device 1)....................................89 3.5.11. SBUSN—Secondary Bus Number Register (Device 1) ...............................90 3.5.12. SUBUSN—Subordinate Bus Number Register (Device 1) ..........................90 3.5.13. SMLT—Secondary Master Latency Timer Register (Device 1) ...................91 3.5.14. IOBASE—I/O Base Address Register (Device 1) ........................................92 3.5.15. IOLIMIT—I/O Limit Address Register (Device 1).........................................93 3.5.16. SSTS—Secondary PCI-PCI Status Register (Device 1)..............................94 3.5.17. MBASE—Memory Base Address Register (Device 1).................................95 3.5.18. MLIMIT—Memory Limit Address Register (Device 1) .................................96 3.5.19. PMBASE—Prefetchable Memory Base Address Register (Device 1) .........97 3.5.20. PMLIMIT—Prefetchable Memory Limit Address Register (Device 1)..........98 3.5.21. BCTRL—PCI-PCI Bridge Control Register (Device 1).................................99 3.5.22. ERRCMD1—Error Command Register (Device 1) ....................................101 Graphics Device Registers (Device 2: VISIBLE IN GFX Mode Only) .........................102 3.6.1. VID2—Vendor Identification Register (Device 2).......................................103 3.6.2. DID2—Device Identification Register (Device 2) .......................................103 3.6.3. PCICMD2—PCI Command Register (Device 2)........................................104 3.6.4. PCISTS2—PCI Status Register (Device 2) ...............................................105 3.6.5. RID2—Revision Identification Register (Device 2) ....................................106 3.6.6. PI—Programming Interface Register (Device 2) .......................................106 3.6.7. SUBC2—Sub-Class Code Register (Device 2) .........................................106 3.6.8. BCC2—Base Class Code Register (Device 2) ..........................................107 3.6.9. CLS—Cache Line Size Register (Device 2) ..............................................107 3.6.10. MLT2—Master Latency Timer Register (Device 2) ...................................107 3.6.11. HDR2—Header Type Register (Device 2) .................................................108 3.6.12. BIST—BIST Register (Device 2)................................................................108 3.6.13. GMADR—Graphics Memory Range Address Register (Device 2)...........109 3.6.14. MMADR—Memory Mapped Range Address Register (Device 2) .............110 3.6.15. SVID—Subsystem Vendor Identification Register (Device 2)....................110 3.6.16. SID—Subsystem Identification Register (Device 2)...................................111 3.6.17. ROMADR—Video BIOS ROM Base Address Register (Device 2) ............111 3.6.18. CAPPOINT—Capabilities Pointer Register (Device 2) ..............................111 3.6.19. INTRLINE—Interrupt Line Register (Device 2) ..........................................112 3.6.20. INTRPIN—Interrupt Pin Register (Device 2)..............................................112 3.6.21. MINGNT—Minimum Grant Register (Device 2).........................................112 3.6.22. MAXLAT—Maximum Latency Register (Device 2)....................................112 3.6.23. PM_CAPID—Power Management Capabilities ID Register (Device 2).....113 3.6.24. PM_CAP—Power Management Capabilities Register (Device 2) .............113 3.6.25. PM_CS—Power Management Control/Status Register (Device 2) ..........114 Display Cache Interface ...............................................................................................115 3.7.1. DRT—DRAM Row Type ............................................................................115 3.7.2. DRAMCL—DRAM Control Low .................................................................116 3.7.3. DRAMCH—DRAM Control High ................................................................117 Display Cache Detect and Diagnostic Registers..........................................................118 3.8.1. GRX—GRX Graphics Controller Index Register .......................................118 3.8.2. MSRMiscellaneous Output.....................................................................119 3.8.3. GR06Miscellaneous Register.................................................................119 3.8.4. GR10Address Mapping ..........................................................................120 3.8.5. GR11Page Selector ...............................................................................120
Datasheet
5
82815 GMCH
R
4.
Functional Description.............................................................................................................. 121 4.1. System Address Map .................................................................................................. 121 4.1.1. Memory Address Ranges .......................................................................... 122 4.1.2. Compatibility Area ..................................................................................... 123 4.1.3. Extended Memory Area............................................................................. 125 4.1.3.1. System Management Mode (SMM) Memory Range .................... 128 Memory Shadowing ..................................................................................................... 129 I/O Address Space ...................................................................................................... 129 4.3.1. GMCH Decode Rules and Cross-Bridge Address Mapping...................... 129 4.3.2. Address Decode Rules.............................................................................. 130 4.3.2.1. AGP Interface Decode Rules........................................................ 131 4.3.2.2. Legacy VGA Ranges .................................................................... 132 Host Interface .............................................................................................................. 133 4.4.1. Host Bus Device Support .......................................................................... 133 4.4.2. Special Cycles ........................................................................................... 135 System Memory DRAM Interface ................................................................................ 136 4.5.1. DRAM Organization and Configuration ..................................................... 136 4.5.1.1. Configuration Mechanism For DIMMs .......................................... 137 4.5.1.2. DRAM Register Programming ...................................................... 138 4.5.2. DRAM Address Translation and Decoding................................................ 138 4.5.3. DRAM Array Connectivity .......................................................................... 139 4.5.4. SDRAMT Register Programming .............................................................. 140 4.5.5. SDRAM Paging Policy............................................................................... 140 Intel Dynamic Video Memory Technology (D.V.M.T.)................................................ 140 Display Cache Interface............................................................................................... 141 4.7.1. Supported DRAM Types for Display Cache Memory ................................ 141 4.7.2. Memory Configurations ............................................................................. 142 4.7.3. Address Translation .................................................................................. 143 4.7.4. Display Cache Interface Timing ................................................................ 143 Internal Graphics Device ............................................................................................. 144 4.8.1. 3D/2D Instruction Processing.................................................................... 144 4.8.2. 3D Engine.................................................................................................. 145 4.8.3. Buffers ....................................................................................................... 145 4.8.4. Setup ......................................................................................................... 146 4.8.5. Texturing.................................................................................................... 146 4.8.6. 2D Operation ............................................................................................. 148 4.8.7. Fixed Blitter (BLT) and Stretch Blitter (STRBLT) Engines......................... 148 4.8.7.1. Fixed BLT Engine ......................................................................... 149 4.8.7.2. Arithmetic Stretch BLT Engine...................................................... 149 4.8.8. Hardware Motion Compensation ............................................................... 149 4.8.9. Hardware Cursor ....................................................................................... 150 4.8.10. Overlay Engine .......................................................................................... 150 4.8.11. Display....................................................................................................... 151 4.8.12. Flat Panel/Digital CRT Interface / 1.8V TV-Out Interface.......................... 152 4.8.13. DDC (Display Data Channel)..................................................................... 153 System Reset for the GMCH ....................................................................................... 154 System Clock Description............................................................................................ 154 Power Management .................................................................................................... 154 4.11.1. Specifications Supported........................................................................... 154
4.2. 4.3.
4.4.
4.5.
4.6. 4.7.
4.8.
4.9. 4.10. 4.11.
6
Datasheet
82815 GMCH
R
5.
Pinout and Package Information ..............................................................................................155 5.1. 5.2. 82815 GMCH Pinout ....................................................................................................155 Package Information ....................................................................................................162
6.
Testability..................................................................................................................................165 6.1. XOR TREE Testability Algorithm Example ..................................................................166 6.1.1. Test Pattern Consideration for XOR Chains 3 and 4, and 7 and 8............166 6.2. XOR Tree Initialization .................................................................................................167 6.2.1. Chain [1:6] Initialization ..............................................................................167 6.2.2. Chain [7:8] Initialization ..............................................................................167 6.3. XOR Chain ...................................................................................................................168 6.4. All Z ..............................................................................................................................172
Datasheet
7
82815 GMCH
R
Figures
Figure 1. Intel 815 Chipset Family System Block Diagram .................................................... 15 Figure 2. 82815 GMCH Block Diagram.................................................................................... 16 Figure 3. PAM Registers .......................................................................................................... 59 Figure 4. System Memory Address Map ................................................................................ 122 Figure 5. Detailed Memory System Address Map.................................................................. 122 Figure 6. DRAM Array Sockets .............................................................................................. 139 Figure 7. GMCH Display Cache Interface to 4 MB................................................................. 142 Figure 8. 3D/2D Pipeline Preprocessor.................................................................................. 144 Figure 9. Data Flow for the 3D Pipeline ................................................................................. 145 Figure 10. GMCH Pinout (Top View-Left Side) ...................................................................... 156 Figure 11. GMCH Pinout (Top View-Right Side).................................................................... 157 Figure 12. GMCH BGA Package Dimensions (Top and Side Views) .................................... 162 Figure 13. GMCH BGA Package Dimensions (Bottom View) ................................................ 163 Figure 14. XOR Tree Implementation .................................................................................... 165
Tables
Table 1. Supported System Bus and System Memory Bus Frequencies ................................ 20 Table 2. GMCH PCI Configuration Space (Device 0) .............................................................. 42 Table 3. Supported System Memory DIMM Configurations ..................................................... 54 Table 4. Attribute Bit Assignments ........................................................................................... 58 Table 5. PAM Registers and Associated Memory Segments .................................................. 59 Table 6. Summary of GMCH Error Sources, Enables and Status Flags ................................. 83 Table 7. GMCH Configuration Space (Device 1) ..................................................................... 84 Table 8. Device 2 Configuration Space Address Map (Internal Graphics)............................. 102 Table 9. Memory Segments and Their Attributes................................................................... 123 Table 10. Summay of Transactions Supported By GMCH..................................................... 133 Table 11. Host Responses Supported by the GMCH ............................................................ 134 Table 12. Special Cycles........................................................................................................ 135 Table 13. Sample Of Possible Mix And Match Options For 4 Row/2 DIMM Configurations ........................................................................................................ 137 Table 14. Data Bytes on DIMM Used for Programming DRAM Registers ............................. 138 Table 15. GMCH DRAM Address Mux Function.................................................................... 139 Table 16. Programmable SDRAM Timing Parameters .......................................................... 140 Table 17. Memory Size for each configuration :..................................................................... 142 Table 18. GMCH Local Memory Address Mapping................................................................ 143 Table 19. Partial List of Display Modes Supported ................................................................ 151 Table 20. Partial List of Flat Panel Modes Supported ............................................................ 152 Table 21. Partial List of TV-Out Modes Supported ................................................................ 153 Table 22. Alphabetical Pin Assignment.................................................................................. 158 Table 23. Package Dimensions ............................................................................................. 163 Table 24. XOR Test Pattern Example.................................................................................... 166 Table 25 XOR Chain 1 35 Inputs Output: SMAA5 (A12) ...................................................... 168 Table 26 XOR Chain 2 33 Inputs Output: SMAA2 (F12) ...................................................... 168 Table 27 XOR Chain 3 38 Inputs Output: SMAA0 (D13) ...................................................... 169 Table 28 XOR Chain 4 36 Inputs Output: SMAA9 (D13) ...................................................... 169 Table 29 XOR Chain 5 56 Inputs Output: SMD31 (K5) ........................................................ 170 Table 30 XOR Chain 6 60 Inputs Output: SMAA11 (A13) .................................................... 171 Table 31 XOR Chain 7 33 Inputs Output: SMAA8 (D12) ...................................................... 171 Table 32 XOR Chain 8 31 Inputs Output: SMAA4 (B12) ...................................................... 172
8
Datasheet
82815 GMCH
R
Revision History
Rev. -001 Initial Release Description Date June 2000
Datasheet
9
82815 GMCH
R
This page is intentionally left blank.
10
Datasheet
82815 GMCH
R
82815 GMCH Features
! Processor/Host BusSupport
Intel Pentium III processor and Intel® Celeron™ Processor in FC-PGA package Supports processor 370-Pin Socket Supports 32-Bit System Bus Addressing 4 deep in-order queue; 4 or 1 deep request queue Supports Uni-processor systems only In-order and Dynamic Deferred Transaction Support 66/100/133MHz System Bus Frequency GTL+ I/O Buffer 32 MB to 512 MB using 16Mb/64Mb/128Mb/256Mb technology Supports up to 3 double sided DIMMs at 100 MHz system memory bus Supports up to 2 double sided or 3 single sided DIMMs at 133 MHz system memory bus. 64-bit data interface 100/133 MHz system memory bus frequency Support for Asymmetrical SDRAM addressing only Support for x8 and x16 SDRAM device width Unbuffered, Non-ECC SDRAM only supported Refresh Mechanism: CBR ONLY supported Enhanced Open page arbitration SDRAM paging scheme Suspend to RAM support
! Integrated Graphics Controller Multiplexed with AGP
Controller 3D Hyper Pipelined Architecture -Parallel Data Processing (PDP) -Precise Pixel Interpolation (PPI) Full 2D H/W Acceleration Motion Video Acceleration Supports 133 MHz System Memory while running in non-CPC mode
! Integrated SDRAM Controller
! 3D Graphics Visual Enhancements
Flat & Gouraud Shading Mip Maps with Trilinear and Anisotropic Filtering Full Color Specular Fogging Atmospheric Effects Z Buffering 3D Pipe 2D Clipping Backface Culling
! 3D Graphics Texturing Enhancements ! Digital Video Output ! Display
Per Pixel Perspective Correction Texture Mapping Texture Compositing Texture Color Keying/Chroma Keying 85 MHz Flat Panel Monitor/Digital CRT Interface Or Digital Video Output for use with a external TV encoder Integrated 24-bit 230 MHz RAMDAC Gamma Corrected Video DDC2B Compliant Up to 1600x1200 in 8-bit Color at 85 Hz Refresh Hardware Accelerated Functions 3 Operand Raster BitBLTs 64x64x3 Color Transparent Cursor H/W Motion Compensation Assistance for S/W MPEG2 Decode Software DVD at 30 fps Digital Video Out Port NTSC and PAL TV Out Support H/W Overlay Engine with Bilinear Filtering Independent gamma correction, saturation, brightness & contrast for overlay Intel D.V.M. Technology
! Accelerated Graphics Port (AGP) Interface Multiplexed with
Internal Graphics Supports a single AGP device via a connector Supports AGP 2.0 including 4x AGP data transfers AGP Universal Connector support via dual mode buffers to allow AGP 2.0 3.3V or 1.5V signaling AGP PIPE# or SBA initiated accesses to SDRAM not snooped AGP FRAME# initiated accesses to SDRAM are snooped High priority access support Hierarchical PCI configuration mechanism Delayed transaction support for AGP-to-SDRAM reads that can not be serviced immediately
! 2D Graphics
! Arithmetic Stretch Blitter Video
! Arbitration Scheme and Concurrency
Intelligent Centralized Arbitration Model for Optimum Concurrency Support Concurrent operations of processor and System busses supported via dedicated arbitration and data buffering Distributed Data Buffering Model for optimum concurrency SDRAM Write Buffer with read-around-write capability Dedicated processor –SDRAM, hub interface-SDRAM and Graphics-SDRAM Read Buffers SMRAM space remapping to A0000h (128 KB) Optional Extended SMRAM space above 256 MB, additional 512 KB / 1MB TSEG from Top of Memory, cacheable Stop Clock Grant and Halt special cycle translation from the host to the hub interface ACPI Compliant power management APIC Buffer Management SMI, SCI, and SERR error indication
! Data Buffering
! Integrated Graphics Memory Controller ! Display Cache Interface multiplexed on the AGP interface
32-bit data interface 133 MHz SDRAM interface only. Flexible AGP In-Line Memory Module (AIMM) Implementation Support for 2 1Mx16, or 1 2Mx32 on AIMM card 4 MB maximum addressable 82801AA I/O Controller Hub (ICH) 82801BA I/O Controller Hub (ICH2) 544 BGA 1.85V core with 3.3V CMOS I/O
! Power Management Functions
! Supporting I/O Bridge ! Packaging/Power
Datasheet
11
82815 GMCH
R
82815 GMCH Simplified Block Diagram
HA[31:3]# HD[63:0]# ADS# BNR# BPRI# DBSY# DEFER# DRDY# HIT# HITM# HLOCK# HREQ[4:0]# HTRDY# RS[2:0]# CPURST# GTLREF[1:0] SMAA[12:0] SMAB[7:4]# SMAC[7:4]# SBS[1:0] SMD[63:0] SDQM[7:0] SCSA[5:0]# SCSB[5:0]# SRAS# SCAS# SWE# SCKE[5:0] SRCOMP HCLK SCLK LTCLK[1:0] LOCLK LRCLK DCLKREF HLCLK RESET# HLREF HL[10:0] HLSTRB HLSTRB# HLZCOMP VSYNC HSYNC IREF RED GREEN BLUE DDCK DDDA
Display Interface Host Bus Interface
Digital Video Out
LTVCL LTVDA TVCLKIN/INT# LTVCLKOUT[1:0] LTVBLANK# LTVDATA[11:0] LTVSYNC LTVHSYNC LCS# LDQM[3:0] LSRAS# LSCAS# LMA[11:0] LWE# LMD[31:0] PIPE# SBA[7:0] RBF# WBF# ST[2:0] AD_STB[1:0] AD_STB[1:0]# SB_STB SB_STB# G_FRAME# G_IRDY# G_TRDY# G_STOP# G_DEVSEL# G_REQ# G_GNT# G_AD[31:0]# G_C/BE[3:0]# G_PAR GRCOMP AGPREF
System Memory Interface
Display Cache Interface
Clock And Reset Signals
AGP Interface
Hub Interface
12
Datasheet
82815 GMCH
R
1.
Overview
The Intel 815 chipset family is a high-flexibility chipset designed to extend from the basic graphics/multimedia PC platform up to the mainstream performance desktop platform. The chipset consists of a 82815 Graphics and Memory Controller Hub (GMCH) and an I/O Controller Hub for the I/O subsystem. The GMCH integrates a system memory SDRAM controller that supports a 64-bit 100/133 MHz SDRAM array. The 82815 GMCH integrates a Display Cache SDRAM controller that supports a 32-bit 133 MHz SDRAM array for enhanced integrated 2D and 3D graphics performance. Multiplexed with the display cache interface is an AGP controller interface to enable graphics configuration and upgrade flexibility with the Intel 815 chipset family. The AGP interface and the internal graphics device are mutually exclusive. When the AGP port is populated with an AGP graphics card, the integrated graphics is disabled; thus, the display cache interface is not needed. There are two chipsets in the Intel® 815 chipset family: • Intel® 815 chipset: This chipset contains the 82815 GMCH and 82801AA ICH. • Intel® 815E chipset. This chipset contains the 82815 GMCH and 82801BA ICH2. Note: The only component difference between the Intel® 815 chipset and the Intel® 815E chipset is the I/O Controller Hub. This datasheet provides an overview of the 815 chipset family (see Section 1.2). The remainder of the document describes the Intel 82815 Graphics Memory Controller Hub (GMCH).
The Intel 815 chipset family may contain design defects or errors known as errata which may cause the product to deviate from published specifications. Current characterized errata are available on request.
1.1.
Related Documents
• AGTL+ I/O Specification: Contained in the Intel Pentium II Processor Databook • PCI Local bus Specification 2.2: Contact www.pcisig.com • Intel® 82801AA (ICH) and Intel® 82801AB (ICH0) I/O Controller Hub Datasheet (Document Number 290655) • Intel® 82801BA I/O Controller Hub (ICH2) Datasheet (Document Number 290687) • Intel® 82802 Firmware Hub (FWH) Datasheet (Document Number 290658) • Intel® 815 Chipset Design Guide (Document Number 298233) • Intel® 815E Chipset Design Guide (Document Number 298234)
Datasheet
13
82815 GMCH
R
1.2.
The Intel 815 Chipset Family
Figure 1 shows a typical system block diagram based on the Intel® 815 chipset family. The chipset uses a hub architecture with the GMCH as the host bridge hub and the I/O Controller Hub as the I/O hub. The GMCH supports processor bus frequencies of 66/100/133 MHz. The I/O Controller Hub is highly integrated providing many of the functions needed in today’s PC platforms; it also provides the interface to the PCI Bus. The GMCH and I/O Controller Hub communicate over a dedicated hub interface. 82801AA ICH and 82801BA ICH2 functions include: • PCI Rev 2.2 compliant with support for 33 MHz PCI operations • Supports up to 6 Req/Gnt pairs (PCI Slots) • Power management logic support • Enhanced DMA controller, interrupt controller, and timer functions • Integrated IDE controller Ultra ATA/66/33 (ICH) Ultra ATA/100/66/33 (ICH2) • USB host interface 1 host controller and supports 2 USB ports (ICH) 2 host controllers and supports 4 USB ports (ICH2) • Integrated LAN controller (ICH2 only) • System Management Bus (SMBus) compatible with most I2C devices ICH has bus master capability ICH2 has both bus master and slave capability • AC’97 2.1 compliant link for audio and telephony codecs 2 channels (ICH) Up to 6 channels (ICH2) • Low Pin Count (LPC) interface • Firmware Hub (FWH) interface support Intel’s FWH component is the 82802: It contains a Random Number Generator (RNG), five General Purpose Inputs (GPIs), register-based block locking, hardware-based locking, and Flash memory for platform code/data nonvolatile storage FWH component is also available from other suppliers • Alert on LAN* AOL (ICH and ICH2) AOL2 (ICH2 only)
14
Datasheet
82815 GMCH
R
Figure 1. Intel 815 Chipset Family System Block Diagram
® ® Intel PentiumIII Processor or ® Intel Celeron™ Processor
System Bus (66/100/133 MHz) Digital Video Out Encoder
® Intel 815 Chipset family
Digital Video Out 64 Bit / 82815 GMCH 100/133 MHz Only System (Graphics and Memory Memory Controller Hub) - Memory Controller - AGP Contoller - Graphcs Controller - 3D Engine - 2D Engine - Video Engine
TV
AGP Connector AGP Graphics Or AGP 2.0 Display Cache (4 MB SDRAM, 133 MHz Only)
Analog Display
Hub Interface
4 IDE Drives UltraATA/66/33 (ICH) UltraATA/100/66/33 (ICH2) 2 USB Ports; 1 HC (ICH) 4 USB Ports; 2 HC (ICH2) AC'97 Codec(s) AC'97 2.1 (optional) (ICH and ICH2) I/O Controller Hub (82801AA ICH and 82801BA ICH2) (ICH and ICH2)
PCI Slots PCI Bus
ISA Bridge (optional)
ISA Slots
Keyboard, Mouse, FD, PP, SP, IR
LPC I/F Super I/O (ICH and ICH2) PCI Agent
LAN Connect (ICH2 only) FWH (ICH and ICH2)
GPIO
815_SysBlk
Datasheet
15
82815 GMCH
R
1.3.
82815 GMCH Overview
Figure 2 is a block diagram of the GMCH illustrating the various interfaces and integrated functions. The functions and capabilities include: • Support for a single processor configuration • 64-bit AGTL+ based System Bus Interface at 66/100/133 MHz • 32-bit Host Address Support • 64-bit System Memory Interface with optimized support for SDRAM at 100/133 MHz • Integrated 2D & 3D Graphics Engines • Integrated H/W Motion Compensation Engine • Integrated 230 MHz DAC
• Integrated Digital Video Out Port
• 133 MHz Display Cache • AGP 1X/2X/4X Controller Figure 2. 82815 GMCH Block Diagram
System Bus Interface
Display Engine
HW Motion Comp
3D Engine 3D Engine 2D Engine
Buffer
Analog Display Out
DAC
Overlay
HW Cursor
Digital Video Out DDC/ I2C
Stretch BLT Eng BLT Eng
Memory Interface
System Memory
Digital Video Out Port
AGP Interface
AGP/ Display Cache Pins
Buffer
Local Memory Interface
Hub Interface
gmch_blk2.vsd
16
Datasheet
82815 GMCH
R
1.4.
Host Interface
The host interface of the GMCH is optimized to support the Intel Pentium® III processor and Intel CeleronTM processor in the FC-PGA package. The GMCH implements the host address, control, and data bus interfaces within a single device. The GMCH supports a 4-deep in-order queue (i.e., supports pipelining of up to 4 outstanding transaction requests on the host bus) . Host bus addresses are decoded by the GMCH for accesses to system memory, PCI memory and PCI I/O (via hub interface), PCI configuration space and Graphics memory. The GMCH takes advantage of the pipelined addressing capability of the processor to improve the overall system performance. The 82815 GMCH supports the 370-pin socket processor. • 370-pin socket (PGA370). The PGA370 is a zero insertion force (ZIF) socket that a processor in the FC-PGA package will use to interface with a system board.
1.5.
System Memory Interface
The GMCH integrates a system memory controller that supports a 64-bit 100/133 MHz SDRAM array. The only DRAM type supported is industry standard Synchronous DRAM (SDRAM). The SDRAM controller interface is fully configurable through a set of control registers. The GMCH supports industry standard 64-bit wide DIMMs with SDRAM devices. The thirteen multiplexed address lines (SMAA[12:0]) along with the two bank select lines (SBS[1:0]) allow the GMCH to support 2M, 4M, 8M, 16M, and 32M x64 DIMMs. Only asymmetric addressing is supported. The GMCH has 6 SCS# lines (2 copies of each for electrical loading), enabling the support of up to six 64-bit rows of SDRAM. The GMCH targets SDRAM with CL2 and CL3, and supports both single and double-sided DIMMs. Additionally, the GMCH also provides a 1024 deep refresh queue. The GMCH can be configured to keep up to 4 pages open within the memory array. Pages can be kept open in any one bank of memory. The Intel 815 chipset family supports up to 3 DIMM connectors in a system. A maximum of 2 doublesided or 3 single-sided DIMMs may be populated when the SDRAM interface is operating at 133 MHz. Upon detection that additional rows are populated beyond these configurations, the BIOS must downshift the SDRAM clocks to 100 MHz through a two-wire interface of the system clock generator. SCKE[5:0] is used in configurations requiring powerdown mode for the SDRAM.
Datasheet
17
82815 GMCH
R
1.6.
Multiplexed AGP and Display Cache Interface
The 82815 GMCH multiplexes an AGP interface with a display cache interface for internal 3D graphics performance improvement. The display cache is used only in the internal graphics. When an AGP card is installed in the system, the GMCH internal graphics will be disabled and the AGP controller will be enabled.
1.6.1.
AGP Interface
A single AGP connector is supported by the GMCH AGP interface. The AGP buffers operate in one of two selectable modes in order to support the AGP Universal Connector: • 3.3V drive, not 5 volt safe: This mode is compliant to the AGP 1.0 and 2.0 specifications. • 1.5V drive, not 3.3 volt safe: This mode is compliant with the AGP 2.0 specification. The following table shows the AGP Data Rate and the Signaling Levels supported by the GMCH.
Data Rate Signaling Level 1.5V 1x AGP 2x AGP 4x AGP Yes Yes Yes 3.3V Yes Yes No
The AGP interface supports 4x AGP signaling. AGP semantic (PIPE# or SBA[7:0]) cycles to SDRAM are not snooped on the host bus. AGP FRAME# cycles to SDRAM are snooped on the host bus. The GMCH supports PIPE# or SBA[7:0] AGP address mechanisms, but not both simultaneously. Either the PIPE# or the SBA[7:0] mechanism must be selected during system initialization. High priority accesses are supported. Only memory writes from the hub interface to AGP are allowed. No transactions from AGP to the hub interface are allowed.
1.6.2.
Display Cache Interface
The GMCH supports a Display Cache SDRAM controller with a 32-bit 133 MHz SDRAM array. The DRAM type supported is industry standard Synchronous DRAM (SDRAM) like that of the system memory. The local memory SDRAM controller interface is fully configurable through a set of control registers.
1.7.
Hub Interface
The hub interface is a private interconnect between the GMCH and the I/O Controller Hub.
18
Datasheet
82815 GMCH
R
1.8.
82815 GMCH Integrated Graphics Support
The GMCH includes a highly integrated graphics accelerator. Its architecture consists of dedicated multimedia engines executing in parallel to deliver high performance 3D, 2D, and motion compensation video capabilities. The 3D and 2D engines are managed by a 3D/2D pipeline preprocessor allowing a sustained flow of graphics data to be rendered and displayed. The deeply pipelined 3D accelerator engine provides 3D graphics quality and performance via per-pixel 3D rendering and parallel data paths which allow each pipeline stage to simultaneously operate on different primitives or portions of the same primitive. The GMCH graphics accelerator engine supports perspective-correct texture mapping, trilinear and anisotropic Mip-Map filtering, Gouraud shading, alpha-blending, fogging and Z-buffering. A rich set of 3D instructions permit these features to be independently enabled or disabled. For the GMCH, a Display Cache (DC) can be used for the Z-buffer (textures and display buffer(s) are located only in system memory). If the display cache is not used, the Z-buffer is located in system memory. The GMCH integrated graphics accelerator’s 2D capabilities include BLT and arithmetic STRBLT engines, a hardware cursor and an extensive set of 2D registers and instructions. The high performance 64-bit BitBLT engine provides hardware acceleration for many common Windows operations. In addition to its 2D/3D capabilities, the GMCH integrated graphics accelerator also supports full MPEG-2 motion compensation for software-assisted DVD video playback, a VESA DDC2B compliant display interface and a digital video out port which may support (via an external video encoder) NTSC and PAL broadcast standards and (via an external TMDS transmitter) digital Flat Panel or Digital CRT displays.
1.8.1.
Display, Digital Video Out, and LCD/Flat Panel/Digital CRT
The GMCH provides interfaces to a standard progressive scan monitor, TV-Out device, and TMDS transmitter. These interfaces are only active when running in internal graphics mode. • The GMCH directly drives a standard progressive scan monitor up to a resolution of 1600x1200 pixels. • The GMCH provides a Digital Video Out interface to connect an external device to drive a 1280x1024 resolution non-scalar DDP digital Flat Panel with appropriate EDID 1.2 data or digital CRTs. The interface has 1.8V signaling to allow it to operate at higher frequencies. This interface can also connect to a 1.8V TV-Out encoder.
Datasheet
19
82815 GMCH
R
1.9.
System Clocking
The 82815 GMCH has a new type of clocking architecture. It has integrated SDRAM buffers that run at either 100 or 133 MHz, independent of the system bus frequency. See table below for supported system bus and system memory bus frequencies. The system bus frequency is selectable between 66 MHz, 100 MHz, or 133 MHz. The GMCH uses a copy of the USB clock as the DOT Clock input for the graphics pixel clock PLL.
Table 1. Supported System Bus and System Memory Bus Frequencies
Front Side Bus Frequency 66 MHz 100 MHz 133 MHz 133 MHz System Memory Bus Frequency 100 MHz 100 MHz 100 MHz 133 MHz Display Cache Interface Frequency 133 MHz or DVMT 133 MHz or DVMT 133 MHz or DVMT 133 MHz or DVMT
1.10.
GMCH Power Delivery
The 82815 GMCH core voltage is 1.85V. System memory operates from a 3.3V supply. Display cache memory operates from the AGP 3.3V supply. AGP 1X/2X I/O can operate from either a 3.3V or a 1.5V supply. AGP 4X I/O requires a 1.5V supply. The AGP interface voltage is determined by the VDDQ generation on the motherboard.
20
Datasheet
82815 GMCH
R
2.
Signal Description
This section provides a detailed description of the GMCH signals. The signals are arranged in functional groups according to their associated interface. The states of all of the signals during reset are provided in the System Reset section. The “#” symbol at the end of a signal name indicates that the active, or asserted state occurs when the signal is at a low voltage level. When “#” is not present after the signal name the signal is asserted when at the high voltage level. The following notations are used to describe the signal type: I O I/OD I/O s/t/s As/t/s Input pin Output pin Input / Open Drain Output pin. This pin requires a pullup Bi-directional Input/Output pin Sustained Tristate. This pin is driven to its inactive state prior to tri-stating. Active Sustained Tristate. This applies to some of the hub interface signals. This pin is weakly driven to its last driven value.
The signal description also includes the type of buffer used for the particular signal: AGTL+ AGP Open Drain AGTL+ interface signal. Refer to the AGTL+ I/O Specification for complete details AGP interface signals. These signals can be programmed to be compatible with AGP 2.0 3.3V or 1.5V Signaling Environment DC and AC Specifications. In 3.3V mode the buffers are not 5V tolerant. In 1.5V mode the buffers are not 3.3V tolerant. The CMOS buffers are low voltage TTL compatible signals. These are 3.3V only. Low Voltage TTL compatible signals. There are 3.3V only. 1.8V signals for the digital video interface Analog CRT Signals
CMOS LVTTL 1.8V Analog
Note that the processor address and data bus signals (Host Interface) are logically inverted signals (i.e., the actual values are inverted of what appears on the processor bus). This must be taken into account and the addresses and data bus signals must be inverted inside the GMCH. All processor control signals follow normal convention. A 0 indicates an active level (low voltage) if the signal is followed by a # symbol and a 1 indicates an active level (high voltage) if the signal has no # suffix.
Datasheet
21
82815 GMCH
R
2.1.
Host Interface Signals
Signal Name CPURST# Type O AGTL+ Description CPU Reset. The GMCH asserts CPURST# while RESET# (PCIRST# from the I/O Controller Hub) is asserted and for approximately 1 ms after RESET# is deasserted. The GMCH also pulses CPURST# for approximately 1 ms when requested via a hub interface special cycle. The CPURST# allows the processor to begin execution in a known state. Host Address Bus. HA[31:3]# connect to the processor address bus. During processor cycles, HA[31:3]# are inputs. The GMCH drives HA[31:3]# during snoop cycles on behalf of Primary PCI. Note that the address bus is inverted on the processor bus. Host Data. These signals are connected to the processor data bus. Note that the data signals are inverted on the processor bus. Address Strobe. The processor bus owner asserts ADS# to indicate the first of two cycles of a request phase. Block Next Request. Used to block the current request bus owner from issuing a new request. This signal is used to dynamically control the processor bus pipeline depth. Priority Agent Bus Request. The GMCH is the only priority agent on the processor bus. It asserts this signal to obtain the ownership of the address bus. This signal has priority over symmetric bus requests and will cause the current symmetric owner to stop issuing new transactions unless the HLOCK# signal was asserted. Data Bus Busy. Used by the data bus owner to hold the data bus for transfers requiring more than one cycle. Defer. The GMCH will generate a deferred response as defined by the rules of the GMCH dynamic defer policy. The GMCH will also use the DEFER# signal to indicate a processor retry response. Data Ready. Asserted for each cycle that data is transferred. Hit. Indicates that a caching agent holds an unmodified version of the requested line. Also driven in conjunction with HITM# by the target to extend the snoop window. Hit Modified. Indicates that a caching agent holds a modified version of the requested line and that this agent assumes responsibility for providing the line. HITM# is also driven in conjunction with HIT# to extend the snoop window. Host Lock. All processor bus cycles sampled with the assertion of HLOCK# and ADS#, until the negation of HLOCK# must be atomic (i.e., no hub interface or GMCH graphics snoopable access to SDRAM is allowed when HLOCK# is asserted by the processor). Host Request Command. Asserted during both clocks of request phase. In the first clock, the signals define the transaction type to a level of detail that is sufficient to begin a snoop request. In the second clock, the signals carry additional information to define the complete transaction type. The transactions supported by the GMCH are defined in the Host Interface section of this document. HTRDY# I/O AGTL+ Host Target Ready. Indicates that the target of the processor transaction is able to enter the data transfer phase.
HA[31:3]#
I/O AGTL+
HD[63:0]# ADS# BNR#
I/O AGTL+ I/O AGTL+ I/O AGTL+ O AGTL+
BPRI#
DBSY# DEFER#
I/O AGTL+ O AGTL+ I/O AGTL+ I/O AGTL+ I/O AGTL+ I AGTL+
DRDY# HIT#
HITM#
HLOCK#
HREQ[4:0]#
I/O AGTL+
22
Datasheet
82815 GMCH
R
Signal Name RS[2:0]#
Type I/O AGTL+
Description Response Signals. Indicates type of response as shown below: 000 = Idle state 001 = Retry response 010 = Deferred response 011 = Reserved (not driven by the GMCH) 100 = Hard Failure (not driven by the GMCH) 101 = No data response 110 = Implicit Writeback 111 = Normal data response
GTLREF[1:0]
I
GTL Reference. Reference voltage input for the Host GTL interface. GTLREF is 2/3 * VTT. VTT is nominally 1.5V.
2.2.
System Memory Interface Signals
Signal Name SMAA[12:0] SMAB[7:4]# SMAC[7:4]# SBS[1:0] SBS[1:0] Type O CMOS Description Memory Address. SMAA[12:0], SMAB[7:4]#, and SMAC[7:4]# are used to provide the multiplexed row and column address to SDRAM. SBS[1:0] provide the Bank Select. Memory Bank Select. These signals define the banks that are selected within each DRAM row. The SMAx and SBS signals combine to address every possible location within a DRAM device. SBS[1:0] may be heavily loaded and require 2 SDRAM clock cycles for setup time to the SDRAMs. For this reason, all chip select signals (SCSA[5:0]# and SCSB[5:0]#) must be deasserted on any SDRAM clock cycle that one of these signals change. SMD[63:0] SDQM[7:0] SCSA[5:0]# SCSB[5:0]# SRAS# SCAS# SWE# SCKE[5:0] I/O CMOS O CMOS O CMOS O CMOS O CMOS O CMOS O CMOS O Memory Data. These signals are used to interface to the SDRAM data bus. Input/Output Data Mask. These pins act as synchronized output enables during read cycles and as a byte enables during write cycles. Chip Select. For the memory row configured with SDRAM, these pins perform the function of selecting the particular SDRAM components during the active state. SDRAM Row Address Strobe. These signals drive the SDRAM array directly without any external buffers. SDRAM Column Address Strobe. These signals drive the SDRAM array directly without any external buffers. Write Enable Signal. SWE# is asserted during writes to SDRAM. System Memory Clock Enable. SCKE SDRAM Clock Enable is used to signal a self-refresh or power-down command to an SDRAM array when entering system suspend. System Memory RCOMP. Used to calibrate the System memory I/O buffers. This pin should be connected to a 40 ohm resistor tied to 3.3V VCC (VSUS3.3).
O CMOS
SRCOMP
Datasheet
23
82815 GMCH
R
2.3.
AGP Interface Signals
For more details on the operation of these signals, refer to the AGP Interface Specification Revision 2.0. Some of the AGP interface signals are multiplexed with Display Cache interface signals. AGP inteface signals only function as documented in this section when the GMCH AGP interface is enabled (GMCH integrated graphics disabled). Refer to Section 2.11 for multiplexing map of AGP to Display Cache interface signals.
2.3.1.
AGP Addressing Signals
There are two mechanisms that the AGP master can enqueue AGP requests: PIPE# and SBA (side-band addressing). Upon initialization, one of the methods is chosen. The master may not switch methods without a full reset of the system. When PIPE# is used to enqueue addresses, the master is not allowed to queue addresses using the SBA bus. For example, during configuration time, if the master indicates that it can use either mechanism, the configuration software will indicate which mechanism the master will use. Once this choice has been made, the master will continue to use the mechanism selected until the system is reset (and reprogrammed) to use the other mode. This change of modes is not a dynamic mechanism but rather a static decision when the device is first being configured after reset.
Signal Name PIPE#
Type I AGP Pipeline.
Description
During PIPE# Operation. This signal is asserted by the AGP master to indicate a full-width address is to be enqueued on by the target using the AD bus. One address is placed in the AGP request queue on each rising clock edge while PIPE# is asserted. During SBA Operation. This signal is not used if SBA (Side Band Addressing) is selected. During FRAME# Operation. This signal is not used during AGP FRAME# operation.
SBA[7:0]
I AGP
Side-band Addressing. During PIPE# Operation. These signals are not used during PIPE# operation. During SBA Operation. These signals (the SBA, or side-band addressing, bus) are used by the AGP master (graphics component) to place addresses into the AGP request queue. The SBA bus and AD bus operate independently. That is, transactions can proceed on the SBA bus and the AD bus simultaneously. During FRAME# Operation. These signals are not used during AGP FRAME# operation.
24
Datasheet
82815 GMCH
R
2.3.2.
AGP Flow Control Signals
Signal Name RBF# Type I AGP Read Buffer Full. During PIPE# and SBA Operation. Read buffer full indicates if the master is ready to accept previously requested low priority read data. When RBF# is asserted the GMCH is not allowed to initiate the return low priority read data. That is, the GMCH can finish returning the data for the request currently being serviced, however it can not begin returning data for the next request. RBF# is only sampled at the beginning of a cycle. If the AGP master is always ready to accept return read data, then it is not required to implement this signal. During FRAME# Operation. This signal is not used during AGP FRAME# operation. W BF# I AGP Write-Buffer Full. During PIPE# and SBA Operation. W rite bufffer full indicates if the master is ready to accept Fast Write data from the GMCH. When WBF# is asserted the GMCH is not allowed to drive Fast Write data to the AGP master. WBF# is only sampled at the beginning of a cycle. If the AGP master is always ready to accept fast write data, then it is not required to implement this signal. During FRAME# Operation: This signal is not used during AGP FRAME# operation. Description
2.3.3.
AGP Status Signals
Signal Name ST[2:0] Type O AGP Status Bus. During PIPE# and SBA Operation. Provides information from the arbiter to a AGP Master on what it may do. ST[2:0] only have meaning to the master when its GNT# is asserted. When GNT# is deasserted, these signals have no meaning and must be ignored. Refer to the AGP Interface Specificaiton revision 2.0 for further explanation of the ST[2:0] values and their meanings. During FRAME# Operation. These signals are not used during FRAME# based operation; except that a ‘111’ indicates that the master may begin a FRAME# transaction. Description
Datasheet
25
82815 GMCH
R
2.3.4.
AGP Clocking Signals (Strobes)
Signal Name AD_STB0 Type I/O s/t/s AGP AD Bus Strobe-0. During 2X Operation. During 2X operation, this signal provides timing for the G_AD[15:0] and G_C/BE[1:0]# signals. The agent that is providing the data will drive this signal. During 4X Operation. During 4X operation, this is one-half of a differential strobe pair that provides timing information for the G_AD[15:0] and G_C/BE[1:0]# signals. AD_STB0# I/O s/t/s AGP AD Bus Strobe-0 Compliment. During 2X Operation. During 2X operation, this signal is not used. During 4X Operation. During 4X operation, this is one-half of a differential strobe pair that provides timing information for the G_AD[15:0] and G_C/BE[1:0]# signals. The agent that is providing the data will drive this signal. AD_STB1 I/O s/t/s AGP AD Bus Strobe-1. During 2X Operation. During 2X operation, this signal provides timing for the G_AD[16:31] and G_C/BE[2:3]# signals. The agent that is providing the data drives this signal. During 4X Operation. During 4X operation, this is one-half of a differential strobe pair that provides timing information for the G_AD[16:31] and G_C/BE[2:3]# signals. The agent that is providing the data drives this signal. AD_STB1# I/O s/t/s AGP AD Bus Strobe-1 Compliment. During 2X Operation. During 2X operation, this signal is not used During 4X Operation. During 4X operation, this is one-half of a differential strobe pair that provides timing information for the G_AD[16:31] and G_C/BE[2:3]# signals. The agent that is providing the data drives this signal. SB_STB I AGP SBA Bus Strobe. During 2X Operation. During 2X operation, this signal provides timing for the SBA bus signals. The agent that is driving the SBA bus drives this signal. During 4X Operation. During 4X operation, this is one-half of a differential strobe pair that provides timing information for the SBA bus signals. The agent that is driving the SBA bus drives this signal. SB_STB# I AGP SBA Bus Strobe Compliment. During 2X Operation. During 2X operation, this signal is not used. During 4X Operation. During 4X operation, this is one-half of a differential strobe pair that provides timing information for the SBA bus signals. The agent that is driving the SBA bus drives this signal. GRCOMP AGPREF O I AGP RCOMP. Used to calibrate AGP I/O buffers. This pin should be connected to a 40 ohm pull down resistor tied to VSS. AGP Reference. Reference voltage input for the AGP interface. AGPREF should be 0.4*VDDAGP when VDD is 3.3V, or 0.5* VDDAGP when VDD is 1.5V. Description
26
Datasheet
82815 GMCH
R
2.3.5.
AGP FRAME# Signals
Signal Name G_FRAME# Type I/O s/t/s AGP FRAME. During PIPE# and SBA Operation. Not used by AGP SBA and PIPE#, but used during AGP FRAME# . During Fast Write Operation. G_FRAME# is used to frame transactions as an output from the GMCH during Fast Writes. During FRAME# Operation. G_FRAME# is an output when the GMCH acts as an initiator on the AGP Interface. G_FRAME# is asserted by the GMCH to indicate the beginning and duration of an access. G_FRAME# is an input when the GMCH acts as a FRAME# based AGP target. As a FRAME# based AGP target, the GMCH latches the G-C/BE[3:0]# and the G_AD[31:0] signals on the first clock edge on which it samples G_FRAME# active. G_IRDY# I/O s/t/s AGP Initiator Ready. During PIPE# and SBA Operation. Not used while enqueueing requests via AGP SBA and PIPE#, but used during the data phase of PIPE# and SBA transactions. During FRAME# Operation. G_IRDY# is an output when GMCH acts as a FRAME# based AGP initiator and an input when the GMCH acts as a FRAME# based AGP target. The assertion of G_IRDY# indicates the current FRAME# based AGP bus initiator’s ability to complete the current data phase of the transaction. During Fast Write Operation. G_IRDY# indicates the AGP compliant master is ready to provide all write data for the current transaction. Once G_IRDY# is asserted for a write operation, the master is not allowed to insert wait states. The master is never allowed to insert a wait state during the initial data transfer (32 bytes) of a write transaction. However, it may insert wait states after each 32 byte block is transferred. G_TRDY# I/O s/t/s AGP Target Ready. During PIPE# and SBA Operation. Not used while enqueueing requests via AGP SBA and PIPE#, but used during the data phase of PIPE# and SBA transactions. During FRAME# Operation. G_TRDY# is an input when the GMCH acts as an AGP initiator and an output when the GMCH acts as a FRAME# based AGP target. The assertion of G_TRDY# indicates the target’s ability to complete the current data phase of the transaction. During Fast Write Operation. G_TRDY# indicates the AGP compliant target is ready to receive write data for the entire transaction (when the transfer size is less than or equal to 32 bytes) or is ready to transfer the initial or subsequent block (32 bytes) of data when the transfer size is greater than 32 bytes. The target is allowed to insert wait states after each block (32 bytes) is transferred on write transactions. G_STOP# I/O s/t/s AGP Stop. During PIPE# and SBA Operation. This signal is not used during PIPE# or SBA operation. During FRAME# Operation. STOP# is an input when the GMCH acts as a FRAME# based AGP initiator and an output when the GMCH acts as a FRAME# based AGP target. STOP# is used for disconnect, retry, and abort sequences on the AGP interface. Description
Datasheet
27
82815 GMCH
R
Signal Name G_DEVSEL#
Type I/O s/t/s AGP Device Select.
Description
During PIPE# and SBA Operation. This signal is not used during PIPE# or SBA operation. During FRAME# Operation. G_DEVSEL#, when asserted, indicates that a FRAME# based AGP target device has decoded its address as the target of the current access. The GMCH asserts G_DEVSEL# based on the SDRAM address range being accessed by a PCI initiator. As an input it indicates whether any device on the bus has been selected.
G_REQ#
I AGP
Request. During SBA Operation. This signal is not used during SBA operation. During PIPE# and FRAME# Operation. G_REQ#, when asserted, indicates that a FRAME# or PIPE# based AGP master is requesting use of the AGP interface. This signal is an input into the GMCH.
G_GNT#
O AGP
Grant. During SBA, PIPE# and FRAME# Operation. G_GNT# along with the information on the ST[2:0] signals (status bus) indicates how the AGP interface will be used next. Refer to the AGP Interface Specificaiton revision 2.0 for further explanation of the ST[2:0] values and their meanings. Address/Data Bus. During PIPE# and FRAME# Operation. G_AD[31:0] are used to transfer both address and data information on the AGP inteface. During SBA Operation. G_AD[31:0] are used to transfer data on the AGP interface.
G_AD[31:0]
I/O AGP
G_C/BE[3:0]#
I/O AGP
Command/Byte Enable. During FRAME# Operation. During the address phase of a transaction, G_C/BE[3:0]# define the bus command. During the data phase G_C/BE[3:0]# are used as byte enables. The byte enables determine which byte lanes carry meaningful data. The commands issued on the G_C/BE# signals during FRAME# based AGP are the same G_C/BE# command described in the PCI 2.1 and 2.2 specifications. During PIPE# Operation. W hen an address is enqueued using PIPE#, the C/BE# signals carry command information. Refer to the AGP 2.0 Interface Specification Revision 2.0 for the definition of these commands. The command encoding used during PIPE# based AGP is Different than the command encoding used during FRAME# based AGP cycles (or standard PCI cycles on a PCI bus). During SBA Operation. These signals are not used during SBA operation.
G_PAR
I/O AGP
Parity. During FRAME# Operation. G_PAR is driven by the GMCH when it acts as a FRAME# based AGP initiator during address and data phases for a write cycle, and during the address phase for a read cycle. G_PAR is driven by the GMCH when it acts as a FRAME# based AGP target during each data phase of a FRAME# based AGP memory read cycle. Even parity is generated across G_AD[31:0] and G_C/BE[3:0]#. During SBA and PIPE# Operation. This signal is not used during SBA and PIPE# operation.
NOTES: 1. LOCK#, SERR#, and PERR# signals are not supported on the AGP Interface (even for PCI operations). 2. PCI signals described in this table behave according to PCI 2.1 specifications when used to perform PCI transactions on the AGP interface.
28
Datasheet
82815 GMCH
R
2.4.
Display Cache Interface Signals
Some of the Display Cache interface signals are multiplexed with AGP interface signals. Display Cache interface signals only function as documented in this section when the GMCH integrated graphics is enabled (GMCH AGP interface disabled). Refer to Section 2.11 for multiplexing map of AGP to Display Cache interface signals.
Signal Name LCS# LDQM[3:0] Type O CMOS O AGP O CMOS Description Chip Select. For the memory row configured with SDRAM, this pin performs the function of selecting the particular SDRAM components during the active state. Input/Output Data Mask. These pins control the memory array and act as synchronized output enables during read cycles and as a byte enables during write cycles. SDRAM Row Address Strobe. The LRAS# signal is used to generate SDRAM Command encoded on LRAS#/LCAS#/LWE# signals. When LRAS# is sampled active at the rising edge of the SDRAM clock, the row address is latched into the SDRAMs. SDRAM Column Address Strobe. The LSCAS# signal is used to generate SDRAM Command encoded on LSRAS#/LSCAS#/LWE# signals. When LSCAS# is sampled active at the rising edge of the SDRAM clock, the column address is latched into the SDRAMs. Memory Address. LMA[11:0] are used to provide the multiplexed row and column address to SDRAM. Write Enable Signal. LWE# is asserted during writes to SDRAM. Memory Data. These signals are used to interface to the SDRAM data bus of SDRAM array. Display Cache Frequency Select. This signal indicates whether the display cache operates at 100 MHz or 133 MHz. The value of this pin is sampled at deassertion of CPURST# to determine display cache frequency. HIGH = 133 MHz (Default) LOW = 100 MHz Note: L_FSEL has a weak internal pull-up enabled during reset. Note: 100 MHz display cache is a non-validated feature and should be implemented only if OEM performs validation specifically on this feature.
LRAS#
LCAS#
O CMOS
LMA[11:0] LWE# LMD[31:0] L_FSEL
O AGP O CMOS I/O AGP I CMOS
Datasheet
29
82815 GMCH
R
2.5.
Hub Interface Signals
Signal Name HL[10:0] HLSTRB HLSTRB# HCOMP HLREF Type I/O I/O I/O I/O I Ref Description Hub Interface Signals. Signals used for the hub interface. Packet Strobe. One of two differential strobe signals used to transmit or receive packet data. Packet Strobe Compliment. One of two differential strobe signals used to transmit or receive packet data. Hub Compensation Pad. Used to calibrate the hub interface buffers. This pin should be connected to a 40 ohm resistor tied to 1.8V VCC (VSUS_1.8) HUB Reference. Sets the differential voltage reference for the hub interface.
2.6.
Display Interface Signals
Signal Name VSYNC HSYNC IWASTE IREF RED Type O 3.3V O 3.3V I Ref I Ref O Analog O Analog O Analog I/O CMOS Description CRT Vertical Synchronization. This signal is used as the vertical sync (polarity is programmable) or “ Vsync Interval”. CRT Horizontal Synchronization. This signal is used as the horizontal sync (polarity is programmable) or “ Hsync Interval”. Waste Reference. This signal must be tied to ground. I Reference. Set pointer resistor for the internal color palette DAC. CRT Analog Video Output from the internal color palette DAC. The DAC is designed for a 37.5 ohm equivalent load on each pin (e.g., 75 ohm resistor on the board, in parallel with the 75 ohm CRT load) CRT Analog video output from the internal color palette DAC. The DAC is designed for a 37.5 ohm equivalent load on each pin (e.g., 75 ohm resistor on the board, in parallel with the 75 ohm CRT load) CRT Analog video output from the internal color palette DAC. The DAC is designed for a 37.5 ohm equivalent load on each pin (e.g., 75 ohm resistor on the board, in parallel with the 75 ohm CRT load) CRT Monitor DDC Interface Clock. (Also referred to as VESATM “Display Data Channel”, also referred to as the “Monitor Plug-n-Play” interface.) For DDC1, DDCK and DDDA provide a unidirectional channel for Extended Display ID. For DDC2, DDCK and DDDA can be used to establish a bi-directional channel based on I2C protocol. The host can request Extended Display ID or Video Display Interface information over the DDC2 channel. CRT Monitor DDC Interface Data. See DDCK Description
GREEN
BLUE
DDCK
DDDA
I/O CMOS
30
Datasheet
82815 GMCH
R
2.7.
Digital Video Output Signals/TV-Out Pins
Signal Name TVCLKIN/INT# Type I 1.8V Description Low Voltage TV Clock In (TV-Out Mode). In 1.8V TV-Out usage, the TVCLKIN pin functions as a pixel clock input to the GMCH from the TV encoder. The TVCLKIN frequency ranges from 20 MHz to 40 MHz depending on the mode (e.g., NTSC or PAL) and the overscan compensation values in the TV Encoder. CLKIN has a worse case duty cycle of 60%/40% coming in to the GMCH. Flat Panel Interrupt (LCD Mode). In Flat Panel usage, the INT# pin is asserted to cause an interrupt (typically, to indicate a hot plug or unplug of a flat panel). In Flat Panel usage, this pin is connected internally to a pull-up resistor. LTVCLKOUT[1:0] O 1.8V LCD/TV Port Clock Out: These pins provide a differential pair reference clock that can run up to 85 MHz. Note: It is always recommended that these pins be used as a differential pair. Devices running at frequencies less than 65 MHz can operate in single-ended clock mode and use LTVCLKOUT[0] as the clock. When operating in singleended clock mode, LTVCLKOUT[1] is not used. LTVBLANK# O 1.8V Flicker Blank or Border Period Indication. BLANK# is a programmable output pin driven by the graphics control. When programmed as a blank period indication, this pin indicates active pixels excluding the border. When programmed as a border period indication, this pin indicates active pixel including the border pixels. LCD/TV Data. These signals are used to interface to the LCD/TV-Out data bus. Vertical Sync. VSYNC signal for the LTV interface. The active polarity of the signal is programmable. Horizontal Sync. HSYNC signal for the LTV interface. The active polarity of the signal is programmable. LCD/TV Clock. Clock pin for 2-wire interface. LCD/TV Data. Data pin for 2-wire interface.
LTVDATA[11:0] LTVVSYNC LTVHSYNC LTVCK LTVDA
O 1.8V O 1.8V O 1.8V I/OD CMOS I/OD CMOS
Datasheet
31
82815 GMCH
R
2.8.
Power Signals
Signal Name V1.8 VDDQ VSUS3.3 VCCDA VCCDACA1 VCCBA VCCDACA2 VCCDPLL VSSDA VSSDACA VSS VSSDPLL VSSBA Type Power Power Power Power Power Power Power Power Power Power Power Power Power Core Power (1.85V) AGP I/O and Display Cache Buffer Supply Power System Memory Buffer Power (Separate 3.3V power plane for power down modes) Display Power Signal (Connect to an isolated 1.85V plane with VCCDACA1 and VCCDACA2) Display Power Signal AGP/Hub I/F Power (1.85V) Display Power Signal System Memory PLL Power (1.85V) Display Ground Signal Display Ground Signal Core Ground System Memory PLL Ground AGP/Hub I/F Ground Description
2.9.
Clock Signals
Signal Name HCLK SCLK LTCLK[1:0] LOCLK LRCLK DCLKREF HLCLK RESET# Type I CMOS I CMOS O CMOS O CMOS I CMOS I CMOS I CMOS I Description Host Clock Input. Clock used on the host interface. Externally generated 66/100/133 MHz clock. System Memory Clock. Clock used on the output buffers of system memory. Externally generated 100/133 MHz clock. Display Cache Transmit Clocks. LTCLK[1:0] are internally generated display cache clocks used to clock the input buffers of the SDRAM devices. Output Clock. LOCLK is an internally generated clock used to drive LRCLK. Receive Clock. LRCLK is a display cache clock used to clock the input buffers of the GMCH. Display Interface Clock. DCLKREF is a 48 MHz clock generated by an external clock synthesizer to the GMCH. Hub Interface Clock. 66 MHz hub interface clock generated by an external clock synthesizer. Global Reset. Driven by the I/O Controller Hub when PCIRST# is active.
32
Datasheet
82815 GMCH
R
2.10.
GMCH Power-Up/Reset Strap Options
Pin Name SBA[7] SCAS# SWE# SMAA[11] SMAA[10] Strap Description Local Memory Frequency Select Host Frequency Host Frequency IOQ Depth ALL Z Configuration High = 133 MHz (default) Low = 100MHz High = 133 MHz (default) Low = 100 or 66 MHz High = 100 MHz (default) Low = 66 MHz High = 4 (default) Low = 1 High = Normal (default) Low = All Z SRAS# XOR Test mode High = Normal (default) Low = XOR test mode SMAA[9] FSB P-MOS Kicker Enable High = enabled (non-CuMine) (default) Low = disabled (CuMine) NOTES: 1. For normal operation, all strap pins must be set high “1” (except IOQ Depth and Host Frequency straps which should be set appropriately). 2. External reset signal used to sample the straps is RESET#. 3. All system memory reset straps have internal 50K ohm pull-ups during reset. Interface Type AGP/LM System Memory System Memory System Memory System Memory System Memory System Memory Buffer Type Input Bi-directional Bi-directional Bi-directional Bi-directional
Bi-directional
Bi-directional
Datasheet
33
82815 GMCH
R
2.11.
Multiplexed Display Cache and AGP Signal Mapping
Local Memory Signal Name LCAS# LCS# LDQM0 LDQM1 LDQM2 LDQM3 L_FSEL LMA0 LMA1 LMA10 LMA11/LBA LMA2 LMA3 LMA4 LMA5 LMA6 LMA7 LMA8 LMA9 LMD0 LMD1 LMD10 LMD11 LMD12 LMD13 LMD14 LMD15 LMD16 LMD17 LMD18 LMD19 LMD2 LMD20 AGP Signal Name G_AD26 G_STOP# G_AD0 G_AD10 SBA2 ST1 SBA7 G_AD22 G_AD15 G_FRAME# G_AD18 G_AD11 G_BE0# G_AD9 G_AD13 G_PAR G_TRDY# G_AD16 G_AD20 G_AD8 G_AD7 G_C/BE1# G_DEVSEL# G_IRDY# G_C/BE2# G_AD17 G_AD19 G_AD21 G_AD23 G_AD25 G_AD27 G_AD5 G_AD29 Local Memory Signal Name LMD21 LMD22 LMD23 LMD24 LMD25 LMD26 LMD27 LMD28 LMD29 LMD3 LMD30 LMD31 LMD4 LMD5 LMD6 LMD7 LMD8 LMD9 LRAS# LTCLK0 LTCLK1 LWE# AGP Signal Name G_AD31 SBA6 SBA4 PIPE# SBA1 SBA3 G_REQ# ST0 ST2 G_AD3 RBF# SBA0 G_AD1 G_AD6 G_AD4 G_AD2 G_AD12 G_AD14 G_C/BE3# G_AD30 G_AD28 SBA5
34
Datasheet
82815 GMCH
R
2.11.1.
Display Cache Mapping at the AGP Connector
The pin mapping assignments were made with the primary goal of optimizing the layout of the AIMM card (Display Cache add-in card that fits in the AGP connector). This was done based on the AGP signals as they exist on the standard AGP connector. Care was taken to avoid special types of AGP signals such as the strobes and any open-drain signals. Some signals that exist on the AGP connector that do not exist on the GMCH’s AGP interface could not be used for Display Cache signals.
Pin # 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 B OVRCNT# 5.0V 5.0V USB+ GND INTB# CLK REQ# LGM_OK VCC3.3 ST0 LGM_OK ST2 LGM_OK RBF# LGM_OK GND Reserved SBA0 LGM_OK VCC3.3 SBA2 LGM_OK SB_STB GND SBA4 LGM_OK SBA6 LGM_OK Reserved GND 3.3Vaux VCC3.3 AD31 LGM_OK AD29 LGM_OK VCC3.3 AD27 LGM_OK AD25 LGM_OK GND LMD19 LMD18 LMD21 LMD20 LMD23 LMD22 LDQM2 LMD31 LMD28 LMD29 LMD30 LMD27 Display Cache Signal A 12V TYPEDET# Reserved USBGND INTA# RST# GNT# VCC3.3 ST1 LGM_OK Reserved PIPE# LGM_OK GND WBF# SBA1 LGM_OK VCC3.3 SBA3 LGM_OK SB_STB# GND SBA5 LGM_OK SBA7 LGM_OK Reserved GND Reserved VCC3.3 AD30 LGM_OK AD28 LGM_OK VCC3.3 AD26 LGM_OK AD24 LGM_OK GND LCAS# LCKE LTCLK0 LTCLK1 LWE# L_FSEL LMD26 LMD25 LMD24 LDQM3 Display Cache Signal
Datasheet
35
82815 GMCH
R
Pin # 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
B AD_STB1 AD23 LGM_OK Vddq AD21 LGM_OK AD19 LGM_OK GND AD17 LGM_OK C/BE2# LGM_OK Vddq IRDY# LGM_OK 3.3Vaux GND Reserved VCC3.3 DEVSEL# LGM_OK Vddq PERR# GND SERR# C/BE1# LGM_OK Vddq AD14 LGM_OK AD12 LGM_OK GND AD10 LGM_OK AD8 LGM_OK Vddq AD_STB0 AD7 LGM_OK GND AD5 LGM_OK AD3 LGM_OK Vddq AD1 LGM_OK Vrefcg
Display Cache Signal — LMD17 — LMD16 LMD15 — LMD14 LMD13 — LMD12 — — — — LMD11 — — — — LMD10 — LMD9 LMD8 — LDQM1 LMD0 — — LMD1 — LMD2 LMD3 — LMD4 —
A AD_STB1# C/BE3# LGM_OK Vddq AD22 LGM_OK AD20 LGM_OK GND AD18 LGM_OK AD16 LGM_OK Vddq FRAME# LGM_OK Reserved GND Reserved VCC3.3 TRDY# LGM_OK STOP# LGM_OK PME# GND PAR LGM_OK AD15 LGM_OK Vddq AD13 LGM_OK AD11 LGM_OK GND AD9 LGM_OK C/BE0# LGM_OK Vddq AD_STB0# AD6 LGM_OK GND AD4 LGM_OK AD2 LGM_OK Vddq AD0 LGM_OK Vrefgc
Display Cache Signal — LRAS# — LMA0 LMA9 — LMA11 LMA8 — LMA10 — — — — LMA7 LCS# — — LMA6 LMA1 — LMA5 LMA2 — LMA4 LMA3 — — LMD5 — LMD6 LMD7 — LDQM0 —
36
Datasheet
82815 GMCH
R
3.
Configuration Registers
This chapter describes the following register sets: • PCI Configuration Registers. The GMCH contains PCI configuration registers for Device 0 (Host-hub interface Bridge/DRAM Controller), Device 1 (AGP Bridge), and Device 2 (GMCH internal graphics device). • Display Cache Interface Registers. This register set is used for configuration of the Display Cache (DC) interface. The registers are located in memory space. The memory space addresses listed are offsets from the base memory address programmed into the MMADR register (Device 2, PCI configuration offset 14h). • Display Cache Detect and Diagnostic Registers. This register set can be used for DC memory detection and testing. These registers are accessed via either I/O space or memory space. The memory space addresses listed are offsets from the base memory address programmed into the MMADR register (Device 1, PCI configuration offset 14h). Note that the GMCH also contains an extensive set of registers and instructions for controlling its graphics operations. Intel graphics drivers provide the software interface at this architectural level. The register/instruction interface is transparent at the Application Programmers Interface (API) level and thus, beyond the scope of this document.
3.1.
Register Nomenclature and Access Attributes
Mnemonic RO R/W R/WC R/WO Reserved Bits Description Read-Only. If a register is read-only, writes to this register have no effect. Read/Write. A register with this attribute can be read and written Read/Write Clear. A register bit with this attribute can be read and written. However, a write of a 1 clears (sets to 0) the corresponding bit and a write of a 0 has no effect. Read/Write-Once. A register bit with this attribute can be written to only once after power up. After the first write, the bit becomes read-only. Some of the GMCH registers described in this section contain reserved bits. These bits are labeled “Reserved” or “Intel Reserved”. Software must deal correctly with fields that are reserved. On reads, software must use appropriate masks to extract the defined bits and not rely on reserved bits being any particular value. On writes, software must ensure that the values of reserved bit positions are preserved. That is, the values of reserved bit positions must first be read, merged with the new values for other bit positions and then written back. Note that software does not need to perform read, merge, write operation for the configuration address register. In addition to reserved bits within a register, the GMCH contains address locations in the configuration space of the Host-hub interface Bridge/DRAM Controller and the internal graphics device entities that are marked either “Reserved” or Intel Reserved”. When a “Reserved” register location is read, a random value can be returned. (“Reserved” registers can be 8-, 16-, or 32-bit in size). Registers that are marked as “Reserved” must not be modified by system software. Writes to “Reserved” registers may cause system failure. Upon a Full Reset, the GMCH sets all of its internal configuration registers to predetermined default states. Some register values at reset are determined by external strapping options. The default state represents the minimum functionality feature set required to successfully bring up the system. Hence, it does not represent the optimal system configuration. It is the responsibility of the system initialization software (usually BIOS) to properly determine the DRAM configurations, operating parameters, and optional system features that are applicable, and to program the GMCH registers accordingly.
Reserved Registers
Default Value Upon Reset
Datasheet
37
82815 GMCH
R
3.2.
PCI Configuration Space Access
The GMCH and the I/O Controller Hub are physically connected via the hub interface. From a configuration standpoint, the hub interface connecting the GMCH and the I/O Controller Hub is logically PCI bus #0. All devices internal to the GMCH and I/O Controller Hub appear to be on PCI bus #0. The system primary PCI expansion bus is physically attached to the I/O Controller Hub and, from a configuration standpoint, appears as a hierarchical PCI bus behind a PCI-to-PCI bridge. The primary PCI expansion bus connected to the I/O Controller Hub has a programmable PCI Bus number. Note: Even though the primary PCI expansion bus is referred to as PCI0 in this document it is not PCI bus #0 from a configuration standpoint. The GMCH contains three PCI devices within a single physical component. The configuration registers for Devices 0, 1, and 2 are mapped as devices residing on PCI bus #0. • Device 0: Host-hub interface Bridge/DRAM Controller. Logically this appears as a PCI device residing on PCI bus #0. Physically, Device 0 contains the PCI registers, DRAM registers, and other GMCH specific registers. • Device 1: AGP Bridge supporting 1X/2X/4X transactions. Logically this appears as a PCI device residing on PCI bus #0. • Device 2: GMCH internal graphics device. These registers contain the PCI registers for the GMCH internal graphics device. Logically this appears as a PCI device residing on PCI bus #0. Note: A physical PCI bus #0 does not exist. The hub interface and the internal devices in the GMCH and I/O Controller Hub logically constitute PCI Bus #0 to configuration software.
3.2.1.
PCI Bus Configuration Mechanism
The PCI Bus defines a slot based “configuration space” that allows each device to contain up to 8 functions with each function containing up to 256 8-bit configuration registers. The PCI specification defines two bus cycles to access the PCI configuration space: Configuration Read and Configuration Write. Memory and I/O spaces are supported directly by the processor. Configuration space is supported by a mapping mechanism implemented within the GMCH. The PCI specification defines two mechanisms to access configuration space, Mechanism #1 and Mechanism #2.
The GMCH supports only Mechanism #1
The configuration access mechanism makes use of the CONF_ADDR Register and CONF_DATA Register. To reference a configuration register a DWord I/O write cycle is used to place a value into CONF_ADDR that specifies the PCI bus, the device on that bus, the function within the device, and a specific configuration register of the device function being accessed. CONF_ADDR[31] must be 1 to enable a configuration cycle. CONF_DATA then becomes a window into the four bytes of configuration space specified by the contents of CONF_ADDR. Any read or write to CONF_DATA results in the GMCH translating the CONF_ADDR into the appropriate configuration cycle. The GMCH is responsible for translating and routing the processor I/O accesses to the CONF_ADDR and CONF_DATA registers to internal GMCH configuration registers, the internal graphic device, or the hub interface.
38
Datasheet
82815 GMCH
R
3.2.2.
Logical PCI Bus #0 Configuration Mechanism
The GMCH decodes the Bus Number (bits 23:16) and the Device Number fields of the CONF_ADDR register. If the Bus Number field of CONF_ADDR is 0, the configuration cycle is targeting a PCI Bus #0 device. • Device #0: The Host-hub interface Bridge/DRAM Controller entity within the GMCH is hardwired as Device #0 on PCI Bus #0.
• Device #1: The AGP interface entity within the GMCH is hardwired as Device #1 on PCI Bus #0. • Device #2: The internal graphics device entity within the GMCH is hardwired as Device #1 on PCI
Bus #0. Note: Configuration cycles to one of the GMCH internal devices are confined to the GMCH and not sent over the hub interface. Note that accesses to devices #3 to #31 on PCI Bus #0 are forwarded over the hub interface.
3.2.3.
Primary PCI (PCI0) and Downstream Configuration Mechanism
If the Bus Number in the CONF_ADDR is non-zero, the GMCH generates a configuration cycle over the hub interface. The I/O Controller Hub compares the non-zero Bus Number with the Secondary Bus Number and Subordinate Bus Number registers of its P2P bridges to determine if the configuration cycle is meant for Primary PCI expansion bus (PCI0), or a downstream PCI bus.
3.2.4.
Internal Graphics Device Configuration Mechanism
From the chipset configuration perspective, the internal graphics device is seen as a PCI device (device 2) on PCI Bus #0. Configuration cycles that target device 2 on PCI Bus #0 are claimed by the internal graphics device and are not forwarded via hub interface to the I/O Controller Hub.
3.2.5.
GMCH Register Introduction
The GMCH contains two sets of software accessible registers, accessed via the Host I/O address space: • Control registers I/O mapped into the host I/O space that control access to PCI configuration space (see section entitled I/O Mapped Registers) • Internal configuration registers residing within the GMCH are partitioned into three logical device register sets (“logical” since they reside within a single physical device). The first register set is dedicated to Host-hub interface Bridge/DRAM Controller functionality (controls PCI bus 0 such as DRAM configuration, other chip-set operating parameters, and optional features). The second register block is dedicated to the AGP interface and the third block is dedicated to the internal graphics device in the GMCH. The GMCH supports PCI configuration space accesses using the mechanism denoted as Configuration Mechanism #1 in the PCI specification. The GMCH internal registers (both I/O Mapped and Configuration registers) are accessible by the host. The registers can be accessed as Byte, Word (16-bit), or DWord (32-bit) quantities, with the exception of CONF_ADDR which can only be accessed as a DWord. All multi-byte numeric fields use “little-endian” ordering (i.e., lower addresses contain the least significant parts of the field).
Datasheet
39
82815 GMCH
R
3.3.
I/O Mapped Registers
The GMCH contains two registers that reside in the processor I/O address space − the Configuration Address (CONF_ADDR) Register and the Configuration Data (CONF_DATA) Register. The Configuration Address Register enables/disables the configuration space and determines what portion of configuration space is visible through the Configuration Data window.
3.3.1.
CONF_ADDRConfiguration Address Register
I/O Address: Default Value: Access: Size: 0CF8h Accessed as a DWord 00000000h Read/Write 32 bits
CONF_ADDR is a 32 bit register accessed only when referenced as a DWord. A Byte or Word reference will “pass through” the Configuration Address Register onto the PCI0 bus as an I/O cycle. The CONF_ADDR register contains the Bus Number, Device Number, Function Number, and Register Number for which a subsequent configuration access is intended.
31 CFGE 30 Reserved (0) 24 23 Bus Number 24
15 Device Number
11
10 Function Number
8
7 Register Number
2
1 Reserved
0
Bit 31
Descriptions Configuration Enable (CFGE). This bit enables/disables accesses to PCI configuration space. 1 = Enabled. 0 = Disable.
30:24 23:16
Reserved. These bits are read-only and have a value of 0. Bus Number. W hen the Bus Number is programmed to 00h the target of the Configuration Cycle is one of the three devices in the GMCH or the PCI Bus (the hub interface is logically a PCI bus) that is directly connected to the GMCH, depending on the Device Number field. A type 0 Configuration Cycle is generated on the hub interface if the Bus Number is programmed to 00h and the GMCH is not the target. If the Bus Number is non-zero and matches the value programmed into the Secondary Bus Number Register a Type 0 PCI configuration cycle will be generated on the AGP bridge. If the Bus Number is non-zero, greater than the value in the Secondary Bus Number Register (Device 1) and less than or equal to the value programmed into the Subordinate Bus Number Register (Device 1) a Type 1 PCI configuration cycle will be generated on the AGP bridge. If the Bus Number is non-zero, and is less than the value programmed into the Secondary Bus Number or is greater than the value programmed into the Subordinate Bus Number Register a Type 1 hub interface configuration cycle is generated.
40
Datasheet
82815 GMCH
R
Bit 15:11
Descriptions Device Number. This field selects one agent on the PCI bus selected by the Bus Number. During a Type 1 Configuration cycle, this field is mapped to AD[15:11]. During a Type 0 Configuration Cycle, this field is decoded and one bit among AD[31:11] is driven to a 1. The GMCH is always Device Number 0 for the Host bridge (GMCH) entity, Device Number 1 for the AGP bridge entity, and Device Number 2 for the Internal Graphics Device entity. If the Bus Number is non-zero and matches the value programmed into the Secondary Bus Number Register, a Type 0 PCI configuration cycle is generated on the AGP bridge. The Device Number field is decoded and the GMCH asserts one and only one GADxx signal as an IDSEL. GAD16 is asserted to access Device 0, GAD17 for Device 1, GAD18 for Device 2 and so forth up to Device 15 which asserts AD31. All device numbers higher than 15 cause a type 0 configuration access with no IDSEL asserted, which results in a Master Abort reported in the GMCH’s “virtual” PCI-PCI bridge registers. For Bus Numbers resulting in hub interface configuration cycles the GMCH propagates the Device Number field as A[15:11]. For Bus Numbers resulting in AGP bridge Type 1 Configuration cycles the Device Number is propagated as GAD[15:11].
10:8
Function Number. This field is mapped to AD[10:8] during PCIx configuration cycles. This allows the configuration registers of a particular function in a multi-function device to be accessed. The GMCH only responds to configuration cycles with a function number of 000b; all other function number values attempting access to the GMCH (Device Number = 0, 1 or 2, Bus Number = 0) will generate a master abort. Register Number. This field selects one register within a particular Bus, Device, and Function as specified by the other fields in the Configuration Address Register. This field is mapped to AD[7:2] during PCI configuration cycles. Reserved.
7:2
1:0
3.3.2.
CONF_DATAConfiguration Data Register
I/O Address: Default Value: Access: Size: 0CFCh 00000000h Read/Write 32 bits
CONF_DATA is a 32 bit read/write window into configuration space. The portion of configuration space that is referenced by CONF_DATA is determined by the contents of CONF_ADDR.
Bit 31:0 Descriptions Configuration Data Window (CDW). If bit 31 of CONF_ADDR is 1, any I/O reference that falls in the CONF_DATA I/O space is mapped to configuration space using the contents of CONF_ADDR.
Datasheet
41
82815 GMCH
R
3.4.
Host-Hub Interface Bridge/DRAM Controller Device Registers (Device 0)
Table 2 shows the GMCH configuration space for device #0.
Table 2. GMCH PCI Configuration Space (Device 0)
Address Offset 00–01h 02–03h 04–05h 06–07h 08h 09h 0Ah 0Bh 0Ch 0Dh 0Eh 0Fh 10–13h 14–2Bh 2C–2Dh 2E–2Fh 30–33h 34h 35–4Fh 50h 51h 52h 53h 54h 55–57h 58h 59–5Fh Mnemonic VID DID PCICMD PCISTS RID SUBC BCC MLT HDR APBASE SVID SID CAPPTR GMCHCFG APCONT DRP DRAMT DRP2 FDHC PAM Register Name Vendor Identification Device Identification PCI Command PCI Status Revision Identification Reserved Sub-Class Code Base Class Code Reserved Master Latency Timer Header Type Reserved Aperture Base Configuration Reserved Subsystem Vendor Identification Subsystem Identification Reserved Capabilities Pointer Reserved GMCH Configuration Aperture Control DRAM Row Population DRAM Timing Register DRAM Row Population Register 2 Reserved Fixed DRAM Hole Control Programmable Attributes Map Registers Default Value 8086h 1130h 0006h 0090h (AGP) 0080h (GFX) 02h (see note) 00h 00h 06h 00h 00h 00h 00000008h (AGP) 00000000h (GFX) 0000h 0000h 00h (GFX) A0h (AGP) 40h 00h 00h 00h 00h 00h 00h Access RO RO R/W RO, R/WC RO RO RO RO RO R/W, RO R/WO R/WO RO R/W R/WO/RO R/W R/W R/W R/W R/W
42
Datasheet
82815 GMCH
R
Address Offset 60–6Fh 70h 71h 72–73h 74–87h 88–8Bh 8C–91h 92–93h 94–95h 96–9Fh A0–A3h A4–A7h A8–Abh AC–Afh B0–B3h B4h B5–B7h B8–BBh BCh BDh BEh BF–CAh CBh CC–FFh
Mnemonic SMRAM MISCC CAPID BUFF_SC BUFF_SC2 ACAPID AGPSTAT AGPCMD AGPCTRL APSIZE ATTBASE AMTT LPTT MCHCFG ERRCMD Reserved
Register Name
Default Value 00h 0000h F104A009h FFFFh FFFFh 00200002h 1F000207h 00000000h 00000000h 00h 00000000h 00h 00h 0000 x000b 00h
Access R/W R/W,RO RO R/W R/W RO RO R/W R/W R/W R/W R/W R/W R/W, RO R/W
System Management RAM Control Reserved Miscellaneous Control Register Reserved Capability Identification Reserved Buffer Strength Control Buffer Strength Control 2 Reserved AGP Capability Identifier AGP Status AGP Command Reserved AGP Control Aperture Size Reserved Aperture Translation Table Base AGP Multi-Transaction Timer Low Priority Transaction Timer MCH Configuration Reserced Error Command Reserved
Note: See Specification Update document for latest information.
Datasheet
43
82815 GMCH
R
3.4.1.
VID—Vendor Identification Register (Device 0)
Address Offset: Default Value: Attribute: Size: 00–01h 8086h Read-Only 16 bits
The VID Register contains the vendor identification number. This 16-bit register combined with the Device Identification Register uniquely identify any PCI device. Writes to this register have no effect.
Bit 15:0 Description Vendor Identification Number. This is a 16-bit value assigned to Intel. Intel VID = 8086h.
3.4.2.
DID—Device Identification Register (Device 0)
Address Offset: Default Value: Attribute: Size: 02–03h 1130h Read-Only 16 bits
This 16-bit register combined with the Vendor Identification register uniquely identifies any PCI device. Writes to this register have no effect.
Bit 15:0 Description Device Identification Number. This is a 16 bit value assigned to the GMCH Host-Hub Interface Bridge / DRAM Controller Device 0. 1130h = Device ID for Device 0.
44
Datasheet
82815 GMCH
R
3.4.3.
PCICMD—PCI Command Register (Device 0)
Address Offset: Default: Access: Size: 04–05h 0006h Read/Write 16 bits
This register provides basic control over the PCI0 interface (hub interface) ability to respond to PCI cycles. The PCICMD Register enables and disables the SERR# signal, parity checking (PERR# signal), GMCH’s response to PCI special cycles, and enables and disables PCI0 bus master accesses to main memory.
15 Reserved (0) 10 9 FB2B (Not Impl) 8 SERR En
7 Addr/Data Stepping (Not Impl)
6 Parity Error En (Not Impl)
5 VGA Pal Sn (Not Impl)
4 Mem WR & Inval En (Not Impl)
3 Special Cycle En (Not Impl)
2 Bus Master En (Not Impl)
1 Mem Acc En (Not Impl)
0 I/O Acc En (Not Impl)
Bit 15:10 9 8 Reserved.
Descriptions
Fast Back-to-Back. (Not implemented). Hardwired to 0. Selects whether the GMCH can generate fast back-to-back transactions to different PCI targets. SERR Enable (SERRE). This bit is a global enable bit for Device 0 SERR messaging. The GMCH does not have an SERR# signal. The GMCH communicates the SERR# condition by sending an SERR message to the I/O Controller Hub. 1 = Enable. GMCH is enabled to generate SERR messages over the Hub interface for specific Device 0 error conditions 0 = Disable. SERR message is not generated by the GMCH for Device 0. NOTE: This bit only controls SERR messaging for Device 0. Device 1 has its own SERRE bit to control error reporting for error conditions occurring on Device 1. The two control bits are used in a logical OR manner to enable the SERR hub interface message mechanism.
7 6 5 4 3 2 1 0
Address/Data Stepping. (Not implemented). Hardwired to 0. Parity Error Enable (PERRE). (Not implemented). Hardwired to 0. PERR# is not implemented by GMCH. Writes to this bit position have no affect. VGA Palette Snoop. (Not implemented). Hardwired to 0. Writes to this bit position have no affect. Memory Write and Invalidate Enable. The GMCH will never use this command and this bit is hardwired to 0. Writes to this bit position will have no affects. Special Cycle Enable. (Not implemented). Hardwired to 0. The GMCH ignores all special cycles generated on the PCI. Bus Master Enable (BME). (Not implemented). Hardwired to 1. The GMCH is always allowed to be a Bus Master. . Writes to this bit position have no affect. Memory Access Enable (MAE). (Not implemented). Hardwired to 1. The GMCH always allows access to main memory. Writes to this bit position have no affect. I/O Access Enable (IOAE). (Not implemented). Hardwired to 0. Writes to this bit position have no affect.
Datasheet
45
82815 GMCH
R
3.4.4.
PCISTS—PCI Status Register (Device 0)
Address Offset: Default Value: Access: Size: 06–07h 0090h Read-Only, Read/Write Clear 16 bits
PCISTS is a 16-bit status register that reports the occurrence of a PCI master abort and PCI target abort on the PCI0 bus. PCISTS also indicates the DEVSEL# timing that has been set by the GMCH hardware for target responses on the PCI0 bus. Bits [15:12] and bit 8 are read/write clear and bits [10:9] are readonly.
15 Detected Par Error (HW=0) 14 Sig Sys Error 13 Recog Mast Abort Sta 12 Rec Target Abort Sta 11 Sig Target Abort Sta (HW=0) 10 DEVSEL# Timing (HW=00) 9 8 Data Par Detected (HW=0)
7 FB2B (HW=1)
6 Reserved
5
4 Cap List (HW=1)
3 Reserved
0
Bit 15 14
Descriptions Detected Parity Error (DPE). This bit is hardwired to a 0. Writes to this bit position have no affect. Signaled System Error (SSE). 1 = GMCH Device 0 generates an SERR message over the hub interface for any enabled Device 0 error condition. Device 0 error conditions are enabled in the PCICMD register. Device 0 error flags are read/reset from the PCISTS register. 0 = Software sets SSE to 0 by writing a 1 to this bit.
13
Received Master Abort Status (RMAS). 1 = GMCH generates a hub interface request that receives a Master Abort completion packet. 0 = Software clears this bit by writing a 1 to it.
12
Received Target Abort Status (RTAS). 1 = GMCH generates a hub interface request that receives a Target Abort completion packet. 0 = Software clears this bit by writing a 1 to it.
11 10:9
Signaled Target Abort Status (STAS). (Not implemented). Hardwired to a 0. Writes to this bit position have no affect. DEVSEL# Timing (DEVT). These bits are hardwired to 00. Writes to these bit positions have no affect. Device 0 does not physically connect to PCI0. These bits are set to 00 (fast decode) so that optimum DEVSEL timing for PCI0 is not limited by the GMCH. Data Parity Detected (DPD). This bit is hardwired to a 0. Writes to this bit position have no affect. Fast Back-to-Back (FB2B). This bit is hardwired to 1. Writes to these bit positions have no affect. Device 0 does not physically connect to PCI. This bit is set to 1 (indicating fast back-to-back capability) so that the optimum setting for PCI is not limited by the GMCH. Reserved. Capability List (CLIST). This bit is hardwired to 1 to indicate that the GMCH always has a capability list. The list of capabilities is accessed via register CAPPTR at configuration address offset 34h. Register CAPPTR contains an offset pointing to the address of the first of a linked list of capability registers. Writes to this bit position have no affect. Reserved.
8 7
6:5 4
3:0
46
Datasheet
82815 GMCH
R
3.4.5.
RID—Revision Identification Register (Device 0)
Address Offset: Default Value: Access: Size: 08h 02h (see Spec. Update document for latest information.) Read-Only 8 bits
This register contains the revision number of the Device 0. These bits are read-only and writes to this register have no effect.
Bit 7:0 Description Revision Identification Number. This is an 8-bit value that indicates the revision identification number for Device 0. 02h = A-2 Stepping
3.4.6.
SUBC—Sub-Class Code Register (Device 0)
Address Offset: Default Value: Access: Size: 0Ah 00h Read-Only 8 bits
This register contains the Sub-Class Code for the GMCH Function #0. The register is read-only.
Bit 7:0 Description Sub-Class Code (SUBC). This is an 8-bit value that indicates the category of Bridge into which GMCH falls. 00h = Host Bridge.
3.4.7.
BCC—Base Class Code Register (Device 0)
Address Offset: Default Value: Access: Size: 0Bh 06h Read-Only 8 bits
This register contains the Base Class Code of the GMCH Function #0. This register is read-only.
Bit 7:0 Description Base Class Code (BASEC). This is an 8-bit value that indicates the Base Class Code for the GMCH. 06h = Bridge device.
Datasheet
47
82815 GMCH
R
3.4.8.
MLT—Master Latency Timer Register (Device 0)
Address Offset: Default Value: Access: Size: 0Dh 00h Read-Only 8 bits
Device 0 is not a PCI master; therefore, this register is not implemented.
Bit 7:0 Descriptions Master Latency Timer Value. This read-only field always returns 0 when read and writes have no affect.
3.4.9.
HDR—Header Type Register (Device 0)
Address Offset: Default: Access: Size: 0Eh 00h Read-Only 8 bits
This register identifies the header layout of the configuration space. No physical register exists at this location.
Bit 7:0 Descriptions Header Type. This read-only field always returns 0 when read and writes have no affect.
3.4.10.
APBASE—Aperture Base Configuration Register (Device 0: AGP Mode Only)
Address Offset: Default Value (AGP Mode): Default Value (GFX Mode): Access: Size: 10–3h 00000008h 00000000h Read/Write, Read-Only 32 bits
The APBASE is a standard PCI Base Address register that is used to set the base of the AGP aperture. The standard PCI Configuration mechanism defines the base address configuration register such that only a fixed amount of space can be requested (dependent on which bits are hardwired to “0” or behave as hardwired to “0”). To allow for flexibility (of the aperture) an additional register called APSIZE is used as a “back-end” register to control which bits of the APBASE will behave as hardwired to “0”. This register is programmed by the GMCH specific BIOS code that runs before any of the generic configuration software is run. Note: Bit 1 of the APCONT register is used to prevent accesses to the aperture range before this register is initialized by the configuration software and the appropriate translation table structure has been established in the main memory.
48
Datasheet
82815 GMCH
R
31 Upper Prog. Base Address Bits
26
25 Lower “HW”/Prog Base Address
24 Hardwired to 0s
16
15 Hardwired to 0s
4
3 Prefetch able
2 Type
0 Mem Space Indicator
Bit 31:26
Description Upper Programmable Base Address bits—R/W. These bits are used to locate the range size selected via lower bits 25:4. Default = 0000
25
Lower “Hardwired”/Programmable Base Address bit . This bit behaves as “hardwired” or as programmable depending on the contents of the APSIZE register as defined below: Aperture Size = 32 MB # r/w Aperture Size = 64 MB # 0 (default) Bit 25 is controlled by the bit 3 of the APSIZE register in the following manner: • If bit APSIZE[3]=0 (indicating 64 MB aperture size), then APBASE[25]=0. If APSIZE[3]=1, then APBASE[25]=r/w (read/write) allowing 32 MB aperture size if desired. • Default for APSIZE[3]=0b forces default APBASE[25] = 0b (bit responds as “hardwired” to 0). This provides a default to the maximum aperture size of 64 MB. The GMCH specific BIOS is responsible for selecting smaller size (if required) before PCI configuration software runs and establishes the system address map.
24:4 3
Hardwired to 0. This forces minimum aperture size selected by this register to be 32 MB. Prefetchable—RO. This bit is hardwired to 1 to identify the Graphics Aperture range as a prefetchable (i.e., There are no side effects on reads, the device returns all bytes on reads regardless of the byte enables, and the GMCH may merge processor writes into this range without causing errors). Type—RO. These bits determine addressing type and they are hardwired to 00 to indicate that address range defined by the upper bits of this register can be located anywhere in the 32-bit address space. Memory Space Indicator—RO. Hardwired to 0 to identify aperture range as a memory range.
2:1 0
Datasheet
49
82815 GMCH
R
3.4.11.
SVID—Subsystem Vendor Identification Register (Device 0)
Address Offset: Default: Access: Size:
Bit 15:0
2C–2Dh 0000h Read/Write-Once 16 bits
Description
Subsystem Vendor ID—R/WO. This value is used to identify the vendor of the subsystem. The default value is 0000h. This field should be programmed by BIOS during boot-up. Once written, this register becomes read-only. This Register can only be cleared by a Reset.
3.4.12.
SID—Subsystem Identification Register (Device 0)
Address Offset: Default: Access: Size:
Bit 15:0
2E–2Fh 0000h Read/Write-Once 16 bits
Description
Subsystem ID—R/WO. This value is used to identify a particular subsystem. The default value is 0000h. This field should be programmed by BIOS during boot-up. Once written, this register becomes read-only. This Register can only be cleared by a Reset.
3.4.13.
CAPPTR—Capabilities Pointer (Device 0)
Address Offset: Default Value: Access: Size: 34h 88h Read-Only 8 bits
The CAPPTR provides the offset that is the pointer to the location where the capability identification register is located.
Bit 7:0 Pointer to Start of CAPPTR Linked List. 88h = Points to the CAPID register that provides capability information regarding the GMCH. The capabilities are determined by which fuses are blown. Description
50
Datasheet
82815 GMCH
R
3.4.14.
GMCHCFG—GMCH Configuration Register (Device 0)
Address Offset: Default: Access: Size:
7 Mem Arb Gnt Win Enable 6 CPU Latency Timer 5 Reserved
50h 01ss0s00 Read/Write, Read-Only 8 bits
4 Local Memory Frequency Select 3 DRAM Page Closing Policy 2 System Memory Frequency Select 1 Reserved 0
Bit 7
Description Memory Arbiter Grant Window Enable (MAGWE). This bit controls the Host vs Low Priority Graphics timeslice regulation in the arbiter for the System DRAM. At pre-arbitration (aka, stage 1) 0 = Disabled. Enforce fixed priority. 1 = Limit grant to host-to-graphics stream to 6 consecutive packets. At main-arbitration (aka, stage 2) 0 = Disabled. Enforce fixed priority. 1 = 24 clocks limiting host, 24 clocks guaranteed to low priority graphics stream. In fixed mode arbitration (MAGWE=0) the host stream always has higher priority over the low priority graphics stream for accesses to system memory. In timeslice mode, the host stream and the low priority graphics stream are both regulated by a time window to provide fairness to the graphics stream. Fixed priority mode, where the host stream is always favored, is the recommended mode of operation; this setting gives highest system performance without adversely affecting graphics performance under real life applications workload.
6
CLT (CPU Latency Timer). 0 = Deferrable processor cycle will be Deferred immediately after receiving another ADS# 1 = Deferrable processor cycle will only be Deferred after in has been held in a “Snoop Stall” for 31 clocks and another ADS# has arrived (default).
5 4
Reserved. Local Memory Frequency Select (LMFS). This bit selects the operating frequency for the Local Memory Controller. Default is set by sampling the LM_FREQ_SEL strap (AGP SBA[7] pin) at reset. It has a weak internal pull-up enabled during reset. This is a reserved bit in the UMA Only and No Internal Graphics SKUs. A 0 is read back in these SKUs. The output of the register bit in these SKUs is also forced to 0 such that a customer cannot effectively program the part for 133 MHz local memory. In the Fully-Featured and 100 MHz FSB & SM SKUs, either 1 or 0 can be programmed by the customer. 1 = 133 MHz, (default). This is a reflection of LM_FREQ_SEL strap being pulled up (default). 0 = 100 MHz. This is a reflection of LM_FREQ_SEL strap being pulled down. Note. The value of this bit should only be changed when the Internal Graphics device is disabled (i.e., GMS = 00).
Datasheet
51
82815 GMCH
R
Bit 3
Description DRAM Page Closing Policy (DPCP). W hen this bit is a 0, the GMCH will tend to leave the DRAM pages open. In this mode the only times that the GMCH will close memory pages are: 0 = Precharge Bank during service of a “Page Miss” access. Precharge All when changing from one Row to another if any Pages are open. Precharge All at leadin to a Refresh operation When this bit is a 1, the GMCH will tend to leave the DRAM pages closed. In this the GMCH will: 1 = Precharge All during the service of any “Page Miss” access. Precharge All when changing from one Row to another if any Pages are open. Precharge All at leadin to a Refresh operation.
2
System Memory Frequency Select (SMFS). This bit selects the operating frequency for the main system memory. Default is set by sampling SBS0# pin at reset. 0 = 100 MHz. 1 = 133 MHz. The default Is determined by SBS0# reset strap.
1:0
Reserved.
52
Datasheet
82815 GMCH
R
3.4.15.
APCONT—Aperture Control (Device 0)
Address Offset: Default Value: Access: Size: 51h 00h Read/Write, Write-Once, Read-Only 8 bits
The Aperture Control Register controls selection and access to aperture space.
7 Reserved 3 2 AGP Select Lock 1 Aperture Access Global EN 0 AGP Select
Bit 7:3 2 Reserved.
Description
GFX AGP Select Lock—WO. This GFX AGP Select (bit 0) can be made read-only by this bit. This is a write-once bit. After it is written, this bit can not be changed without a system reset. 0 = GFX AGP Select remains writeable. 1 = GFX AGP Select is read-only.
1
Aperture Access Global Enable–R/W. This bit is used to prevent access to the aperture from any port (processor, PCI0, or AGP/PCI1) before the aperture range is established by the configuration software and appropriate translation table in the main DRAM has been initialized. It must be set after system is fully configured for aperture accesses. Default is 0. GFX AGP Select—R/W. This field selects the graphics device to be either AGP or Internal Graphics (GFX). 0 = AGP Mode. AGP interface device is enabled. All registers in device 0 and device 1 are visible. No device 2 registers are visible; reads from those addresses return 1s. 1 = GFX Mode. Internal Graphics device is enabled. All non-AGP related device 0 registers and all device 2 registers are visible. No device 1 registers are visible; reads from those addresses return 1s. Reads from AGP related device 0 registers return 0s. The internal graphics device does not respond to any configuration cycles unless SMRAM[7:6] (@ 70h) are NOT 00 AND APCONT[0] (@ 51h) is 1. R/W, RO if GFX AGP Select Lock (bit 2 =1) GFX AGP Select must be programmed before any other access is made to the configuration space. The two possible modes are mutually exclusive. This bit determines whether other configuration registers are enabled or disabled. This bit must be set as part of the initialization sequence. See Software Start-Up Sequence section.
0
Datasheet
53
82815 GMCH
R
3.4.16.
DRP—DRAM Row Population Register (Device 0)
Address Offset: Default Value: Access: Size: 52h 00h Read/Write (Read-Only if D_LCK = 1) 8 bits
The GMCH supports 6 physical rows of DRAM in 3 DIMMs. The width of a row is 64 bits. The DRAM Row Population Register defines the population of each side of each DIMM. Note that this entire register becomes read-only when the D_LCK bit is set to 1. For D_LCK bit description, see SMRAM register (Device 0, address offset 70h). If the system memory interface is configured to run at 133 MHz, the system BIOS must use the DRP register (offset 52h) along with the DRP2 register (offset 52h) to detect whether the memory configuration exceeds 2 double-sided DIMMs or 3 single-sided DIMMs. If so, the system BIOS must down-shift the clock generator to 100 MHz to guarantee electrical integrity and timings.
7 DIMM 1 Population 4 3 DIMM 0 Population 0
Bit 7:4 3:0
Description DIMM 1 Population. This field indicates the population of DIMM 1. (See table below) DIMM 0 Population. This field indicates the population of DIMM 0. (See table below)
Table 3. Supported System Memory DIMM Configurations
Register Code DIMM Capacity # of Devices / DIMM # of Sides DRAM Tech. Front Side Population Count 0 1 2 3 4 5 5 6 6 7 7 9 A B B C D E F 0 32 MB 32 MB 48 MB 64 MB 64 MB 64 MB 96 MB 96 MB 128 MB 128 MB 128 MB 128 MB 192 MB 192 MB 256 MB 256 MB 256 MB 512 MB 16 4 12 8 8 4 12 8 16 8 8 4 12 16 16 8 8 16 DS SS DS DS SS SS DS DS DS DS SS SS DS DS DS DS SS DS N/A 16 Mb 64 Mb 64/16 Mb 64 Mb 64 Mb 128 Mb 64 Mb 128/64 Mb 64 Mb 128 Mb 128 Mb 256 Mb 128 Mb 128/64 Mb 128 Mb 256 Mb 256 Mb 256 Mb 844484848484888488Config Empty 2 Mb x8 8Back Side Population Count Config Empty 2 Mb x8 N/A 11 12 842 Mb x8 12 12 12 12 44844 Mb x 16 4 Mb x 16 8 Mb x8 12 12 12 12 12 13 48848 Mb x 16 8 Mb x8 12 12 12 13 13 832 Mb x 8 13 N/A 1 2 2/1 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 N/A 9 8 8 8 9 9 9/8 9/8 9 9 10 9 10/9 10/9 10 9 10 10 Row Bank Column
4 Mb x 16 4 Mb x 16 4 Mb x 16 8 Mb x8
4 Mb x 16
8 Mb x 16 8 Mb x8
8 Mb x 16 8 Mb x8
8 Mb x 16 16 Mb x 8 16 Mb x 16 16 Mb x 8 16 Mb x 8 16 Mb x 8 16 Mb x 16 32 Mb x 8 32 Mb x 8
8 Mb x 16
16 Mb x 8 16 Mb x 16
54
Datasheet
82815 GMCH
R
3.4.17.
DRAMT—DRAM Timing Register (Device 0)
Address Offset: Default Value: Access: Size: 53h 00h Read/Write 8 bits
This register controls the operating mode and the timing of the DRAM Controller.
7 SDRAM Mode Select 5 4 DRAM Cycle Time 3 Intel Reserved 2 CAS# Latency 1 SDRAM RAS# to CAS# Dly 0 SDRAM RAS# Precharge
Bit 7:5
Description SDRAM Mode Select (SMS). These bits select the operational mode of the GMCH DRAM interface. The special modes are intended for initialization at power up. 000 = DRAM in Self-Refresh Mode, Refresh Disabled (Default) 001 = Normal Operation, 100 MHz System memory – Refresh interval 15.6 uSec 133 MHz System memory – Refresh interval 11.7 uSec 010 = Normal Operation, 100 MHz System memory – Refresh interval 7.8 133 MHz System memory – Refresh interval 5.85 uSec 011 = Normal Operation, 100 MHz System memory – Refresh interval 1.28 uSec 133 MHz System memory – Refresh interval 0.96 uSec 100 = NOP Command Enable. In this mode all processor cycles to SDRAM result in a NOP Command on the SDRAM interface. 101 = All Banks Precharge Enable. In this mode all processor cycles to SDRAM result in an All Banks Precharge Command on the SDRAM interface. 110 = Mode Register Set Enable. In this mode all processor cycles to SDRAM result in a mode register set command on the SDRAM interface. The Command is driven on the MA[12:0] lines. MA[2:0] must always be driven to 010 for burst of 4 mode. MA3 must be driven to 1 for interleave wrap type. MA4 needs to be driven to the value programmed in the CAS# Latency bit. MA[6:5] should always be driven to 01. MA[12:7] must be driven to 00000. BIOS must calculate and drive the correct host address for each row of memory such that the correct command is driven on the MA[12:0] lines. Note that MAB[7:4]# are inverted from MAA[7:4]; BIOS must account for this. 111 = CBR Enable. In this mode all processor cycles to SDRAM result in a CBR cycle on the SDRAM interface.
4
DRAM Cycle Time (DCT). This bit controls the number of SCLKs for an access cycle. 0 = Tras = 5 SCLKs and Trc = 7 SCLKs (Default) 1 = Tras = 7 SCLKs and Trc = 9 SCLKs.
3 2
Intel Reserved. CAS# Latency (CL). This bit controls the number of CLKs between when a read command is sampled by the SDRAMs and when GMCH samples read data from the SDRAMs. 0 = CAS# latency is 3 SCLKs. 1 = CAS# latency is 2 SCLKs.
Datasheet
55
82815 GMCH
R
Bit 1
Description SDRAM RAS# to CAS# Delay (SRCD). This bit controls the number of SCLKs from a Row Activate command to a read or write command. 0 = 3 clocks are inserted between a row activate command and either a read or write command. 1 = 2 clocks are inserted between a row activate and either a read or write command.
0
SDRAM RAS# Precharge (SRP). This bit controls the number of SCLKs for RAS# precharge. 0 = 3 clocks of RAS# precharge are provided. 1 = 2 clocks of RAS# precharge are provided
3.4.18.
DRP2—DRAM Row Population Register 2 (Device 0)
Address Offset: Default Value: Access: Size: 54h 00h Read/Write (Read-Only if D_LCK = 1) 8 bits
This register extends support to 6 physical rows of DRAM in 3 DIMMs. The width of a row is 64 bits. This second DRAM Row Population Register (DRP2) defines the population of each side of DIMM 2. Note that this entire register becomes read-only when the D_LCK bit is set. For D_LCK bit description, see SMRAM register (Device 0, address offset 70h). If the system memory interface is configured to run at 133 MHz, the system BIOS must use the DRP register (offset 52h) along with the DRP2 register (offset 52h) to detect whether the memory configuration exceeds 2 double-sided DIMMs or 3 single-sided DIMMs. If so, the system BIOS must down-shift the clock generator to 100 MHz to guarantee electrical integrity and timings.
7 Reserved 4 3 DIMM 2 Population 0
Bit 7:4 3:0 Reserved.
Description
DIMM 2 Population. This field indicates the population of DIMM 2. Refer to the Supported System Memory DIMM Configurations table located with the DRP register definition. Note that some of the larger capacity DIMMs may not be supported in DIMM 2 based on the capacities of DIMM 0 and DIMM 1. The maximum supported main memory capacity is 512 MB.
56
Datasheet
82815 GMCH
R
3.4.19.
FDHC—Fixed DRAM Hole Control Register (Device 0)
Address Offset: Default Value: Access: Size: 58h 00h Read/Write 8 bits
This 8-bit register controls a single fixed DRAM hole: 15 MB–16 MB.
7 Hole EN 6 Reserved 0
Bit 7
Description Hole Enable (HEN). This field enables a memory hole in DRAM space. Host cycles matching an enabled hole are passed on to the I/O Controller Hub through the hub interface. Hub interface and PCI cycles matching an enabled hole are ignored by the GMCH. Note that a selected hole is not re-mapped. 0 = No Hole Enabled 1 = 15 MB–16 MB (1MB) Hole Enabled
6:0
Reserved.
3.4.20.
PAM—Programmable Attributes Map Registers (Device 0)
Address Offset: Default Value: Attribute: Size: 59–5Fh 00h Read/Write 4 bits/register
The GMCH allows programmable memory attributes on 13 Legacy memory segments of various sizes in the 640 KB to 1 MB address range. Seven Programmable Attribute Map (PAM) Registers are used to support these features. Cacheability of these areas is controlled via the MTRR registers in the P6 processor. Two bits are used to specify memory attributes for each memory segment. These bits apply to both host, AGP/PCI, and hub interface initiator accesses to the PAM areas. These attributes are: • Read Enable (RE). When RE = 1, the processor read accesses to the corresponding memory segment are claimed by the GMCH and directed to main memory. Conversely, when RE = 0, the host read accesses are directed to the hub interface/PCI0. • Write Enable (WE). When WE = 1, the host write accesses to the corresponding memory segment are claimed by the GMCH and directed to main memory. Conversely, when WE = 0, the host write accesses are directed to the hub interface/PCI0. The RE and WE attributes permit a memory segment to be Read-Only, Write Only, Read/Write, or disabled. For example, if a memory segment has RE = 1 and WE = 0, the segment is Read-Only. Each PAM Register controls two regions, typically 16 KB in size. Each of these regions has a 4-bit field. The four bits that control each region have the same encoding and are defined in the following table.
Datasheet
57
82815 GMCH
R
Table 4. Attribute Bit Assignments
Bits [7, 3] Reserved X Bits [6, 2] Reserved X Bits [5, 1] WE 0 Bits [4, 0] RE 0 Description Disabled. DRAM is disabled and all accesses are directed to the hub interface. The GMCH does not respond as a AGP/PCI or hub interface target for any read or write access to this area. Read-Only. Reads are forwarded to DRAM and writes are forwarded to the hub interface for termination. This write protects the corresponding memory segment. The GMCH responds as a AGP/PCI or hub interface target for read accesses but not for any write accesses. Write Only. Writes are forwarded to DRAM and reads are forwarded to the hub interface for termination. The GMCH responds as a AGP/PCI or hub interface target for write accesses but not for any read accesses. Read/Write. This is the normal operating mode of main memory. Both read and write cycles from the host are claimed by the GMCH and forwarded to DRAM. The GMCH responds as a AGP/PCI or hub interface target for both read and write accesses.
X
X
0
1
X
X
1
0
X
X
1
1
As an example, consider a BIOS that is implemented on the expansion bus. During the initialization process, BIOS can be shadowed in main memory to increase the system performance. When BIOS is shadowed in main memory, it should be copied to the same address location. To shadow the BIOS, the attributes for that address range should be set to write only. BIOS is shadowed by first doing a read of that address. This read is forwarded to the expansion bus. The host then does a write of the same address, which is directed to main memory. After BIOS is shadowed, the attributes for that memory area are set to read-only so that all writes are forwarded to the expansion bus. The table above and the figure below show the PAM registers and the associated attribute bits.
58
Datasheet
82815 GMCH
R
Figure 3. PAM Registers
Offset PAM 6 PAM5 PAM4 PAM3 PAM2 PAM1 PA M0 7 R Reserved Reserved Write Enable (R/W) 1=Enable 0=Disable Read Enable (R/W) 1=Enable 0=Disable 6 R 5 4 3 R 2 R 1 0 5Fh 5Eh 5Dh 5Ch 5Bh 5Ah 59h
WE RE
WE RE Read Enable (R/W 1=Enable 0=Disable
Write Enable (R/W) 1=Enable 0=Disable Reserved Reserved
pam
Table 5. PAM Registers and Associated Memory Segments
PAM Reg PAM0[3:0] PAM0[7:4] PAM1[3:0] PAM1[7:4] PAM2[3:0] PAM2[7:4] PAM3[3:0] PAM3[7:4] PAM4[3:0] PAM4[7:4] PAM5[3:0] PAM5[7:4] PAM6[3:0] PAM6[7:4] R R R R R R R R R R R R R Attribute Bits Reserved R R R R R R R R R R R R R WE WE WE WE WE WE WE WE WE WE WE WE WE RE RE RE RE RE RE RE RE RE RE RE RE RE 0F0000h–0FFFFFh 0C0000h–0C3FFFh 0C4000h–0C7FFFh 0C8000h–0CBFFFh 0CC000h– 0CFFFFh 0D0000h– 0D3FFFh 0D4000h– 0D7FFFh 0D8000h– 0DBFFFh 0DC000h– 0DFFFFh 0E0000h– 0E3FFFh 0E4000h– 0E7FFFh 0E8000h– 0EBFFFh 0EC000h– 0EFFFFh BIOS Area ISA Add-on BIOS ISA Add-on BIOS ISA Add-on BIOS ISA Add-on BIOS ISA Add-on BIOS ISA Add-on BIOS ISA Add-on BIOS ISA Add-on BIOS BIOS Extension BIOS Extension BIOS Extension BIOS Extension Memory Segment Comments Offset 59h 59h 5Ah 5Ah 5Bh 5Bh 5Ch 5Ch 5Dh 5Dh 5Eh 5Eh 5Fh 5Fh
Datasheet
59
82815 GMCH
R
DOS Area (00000h–9FFFFh)
The DOS area is 640 KB in size is always mapped to the main memory controlled by the GMCH.
Video Buffer Area (A0000h–BFFFFh)
The 128 KB graphics adapter memory region is normally mapped to a legacy video device on the hub interface/PCI (typically VGA controller). This area is not controlled by attribute bits and processor – initiated cycles in this region are forwarded to either the hub interface or the AGP/Internal Graphics Device for termination. This region is also the default region for SMM space. Accesses to this range are directed to either the hub interface or the AGP/internal Graphics Device based on the configuration. The configuration is specified by: 1. AGP on/off configuration bit 2. AGP off: GMS bits of the SMRAM register in the GMCH Device 0 configuration space. There is additional steering information coming from the Device 2* configuration registers and from some of the VGA registers in the Graphics device. 3. AGP on: GMCHCFG (Device 0, bit 5, PCI-PCI Command) and BCTRL (Device 1, bit 3, PCI-PCI Bridge Control) configuration registers Control is applied for accesses initiated from any of the system interfaces; that is, processor bus, the hub interface, or AGP (if enabled). Note that for the hub interface to AGP/PCI accesses, only memory write operations are supported. Any AGP/PCI initiated VGA accesses targeting the GMCH will master abort. For more details, see the descriptions in the configuration registers specified above. The SMRAM Control register controls how SMM accesses to this space are treated.
Monochrome Adapter (MDA) Range (B0000h–B7FFFh)
Legacy support requires the ability to have a second graphics controller (monochrome) in the system. In an AGP system, accesses in the standard VGA range are forwarded to the AGP bus (depending on configuration bits). Since the monochrome adapter may be on the hub interface/PCI (or ISA) bus, the GMCH must decode cycles in the MDA range and forward them to the hub interface. This capability is controlled by a configuration bit (MDA bit – Device 0, BEh). In addition to the memory range B0000h to B7FFFh, the GMCH decodes I/O cycles at 3B4h, 3B5h, 3B8h, 3B9h, 3Bah and 3BFh and forwards them to the hub interface. In an internal graphics system, the GMS bits of the SMRAM register in Device 0, bits in the Device 2 PCICMD register, and bits from some of the VGA registers control this functionality.
60
Datasheet
82815 GMCH
R
Expansion Area (C0000h–DFFFFh)
This 128 KB ISA Expansion region is divided into eight 16 KB segments. Each segment can be assigned one of four Read/Write states: read-only, write-only, read/write, or disabled. Typically, these blocks are mapped through GMCH and are subtractively decoded to ISA space. Memory that is disabled is not remapped.
Extended System BIOS Area (E0000h–EFFFFh)
This 64 KB area is divided into four 16 KB segments. Each segment can be assigned independent read and write attributes so it can be mapped either to main DRAM or to the hub interface. Typically, this area is used for RAM or ROM. Memory segments that are disabled are not remapped elsewhere.
System BIOS Area (F0000h–FFFFFh)
This area is a single 64 KB segment. This segment can be assigned read and write attributes. It is by default (after reset) read/write disabled and cycles are forwarded to the hub interface. By manipulating the read/write attributes, the GMCH can “shadow” BIOS into the main DRAM. When disabled, this segment is not remapped.
Datasheet
61
82815 GMCH
R
3.4.21.
SMRAM—System Management RAM Control Register (Device 0)
Address Offset: Default Value: Access: Size: 70h 00h Read/Write, Read-Only 8 bits
The SMRAM register controls how accesses to Compatible and Extended SMRAM spaces are treated, and how much (if any) memory is “Stolen” from the system to support both SMRAM and graphics local memory needs.
7 Graphics Mode Select 6 5 Upper SMM Select 4 3 Lower SMM Select 2 1 SMM Space Locked 0 E_SMRA M_ERR
Bit 7:6
Description Graphics Mode Select (GMS). This field is used to enable/disable the Internal Graphics device and select the amount of main memory that is “Stolen” to support the internal graphics device in VGA (nonlinear) mode only. These 2 bits only have meaning if we are not in AGP mode. 00 = Internal graphics device Disabled, No memory “Stolen” 01 = Internal graphics device Enabled, No memory “Stolen” 10 = Internal graphics device Enabled, 512 KB of memory “Stolen” for frame buffer. 11 = Internal graphics device Enabled, 1 MB of memory “Stolen” for frame buffer. Notes: • W hen the internal graphics device is disabled (00), the graphics device and all of its memory and I/O functions are disabled and the clocks to this logic are turned off; memory accesses to the VGA range (A0000–BFFFF) are forwarded on to the hub interface and the graphics local memory space is NOT “stolen” from main memory. Any change to the SMRAM register will not affect AGP mode or cause the controller to go into AGP mode. When this field is non-zero, the internal graphics device and all of its memory and I/O functions are enabled; all non-SMM memory accesses to the VGA range will be handled internally and the selected amount of graphics local memory space (0, 512 KB or 1 MB) is “stolen” from the main memory. Graphics memory is “stolen” AFTER TSEG memory is “stolen”. • Once D_LCK is set, these bits becomes read-only. • GMCH does not support VGA on local memory. Software must not use the 01 mode for VGA.
62
Datasheet
82815 GMCH
R
Bit 5:4
Description Upper SMM Select (USMM). This field is used to enable/disable the various SMM memory ranges above 1 MB. TSEG is a block of memory (“Stolen” from Main Memory at [TOM-Size] : [TOM]) that is only accessable by the processor and only while operating in SMM mode. HSEG is a remap of the AB segment at FEEA0000 : FEEBFFFF. Both of these areas, when enabled, are usable as SMM RAM. 00 = TSEG and HSEG are both disabled 01 = TSEG is disabled, HSEG is conditionally enabled 10 = TSEG is enabled as 512 KB and HSEG is conditionally enabled 11 = TSEG is enabled as 1 MB and HSEG is conditionally enabled Note: • Non-SMM Operations (SMM processor accesses and all other access) that use these address ranges are forwarded to the hub interface. • Once D_LCK is set, these bits becomes read-only. • HSEG is ONLY enabled if LSMM = 00.
3:2
Lower SMM Select (LSMM). This field controls the definition of the AB segment SMM space. 00 = AB segment disabled (no one can write to it). 01 = AB segment enabled as general system RAM (anyone can write to it). 10 = AB segment enabled as SMM Code RAM shadow. Only SMM code reads can access DRAM in the AB segment (processor code reads only). SMM Data operations and all Non-SMM Operations go to either the internal graphics device or are broadcast on the hub interface. 11 = AB segment enabled as SMM RAM. All SMM operations to the AB segment are serviced by DRAM, all Non-SMM operations go to either the internal graphics device or are broadcast on the hub interface (processor SMM R/W can access SMM space). When D_LCK is set, bit 3 becomes read-only, and bit 2 is writable ONLY if bit 3 is a 1. When bit 3 is set, only the processor can access it.
1
SMM Space Locked (D_LCK). W hen D_LCK is set to 1 then D_LCK, GMS, USMM, and the most significant bit of LSMM become read-only. D_LCK can be set to 1 via a normal configuration space write but can only be cleared by a reset. The combination of D_LCK and LSMM provide convenience with security. The BIOS can use LSMM=01 to initialize SMM space and then use D_LCK to “lock down” SMM space in the future so that no application software (or BIOS itself) can violate the integrity of SMM space, even if the program has knowledge of the LSMM function. This bit also Locks the DRP and DRP2 registers. E_SMRAM_ERR (E_SMERR). 1 = This bit is set when processor accesses the defined memory ranges in Extended SMRAM (HSEG or TSEG) while not in SMM mode. This bit is Not set for the case of an explicit write-back operation. 0 = It is software’s responsibility to clear this bit. Software must write a 1 to this bit to clear it.
0
Datasheet
63
82815 GMCH
R
3.4.22.
MISCC—Miscellaneous Control Register (Device 0)
Address Offset: Default Value: Access: Size: 72–73h 0000h Read/Write, Read-Only 16 bits
This register holds all of the miscellaneous control bits for the GMCH .
15 SM GFX 133 Enable 14 Reserved 12 11 CPC Mask 10 Reserved 8
7
6
5
4
3 Throttle Lock
2 Reserved
1 BNR Looka head
0 GFX LM Win Size Sel
Read PWR Throttle Cntl
Write PWR Throttle Cntl
Bit 15
Description System Memory Graphics PC133 Enable—R/W. This bit allows the GMCH to operate in Graphics Mode with Enhanced System Memory (PC133). Normally, SM frequency is locked to 100 MHz in Internal Graphics mode, and GMCHCFG[2] (SMFS) is read-only. Setting this bit allows the SM frequency to be changed by writing to GMCHCFG[2]. This bit has no effect in AGP mode. 0 = Normal Operation. GMCHCFG[2] hardwired to 0 when GMCH is in Graphics Mode (i.e., APCONT[0] = 1) 1 = Allow 133 MHz System Memory when the GMCH is in Graphics Mode. Note that this just enables PC133. To actually run graphics with 133 MHz SM, GMCHCFG[2] must be set to 1. Also, this bit should be set by BIOS before GMCH is changed from AGP to Graphics mode via APCONT[0].
14 13
Reserved. SM Transmit Stage Bypass—R/W. 0 = Normal Operation (Default). Bypass if SM=100 MHz; No bypass if SM=133 MHz. 1 = Always bypass, regardless of SM frequency. System BIOS should set this bit to 1 to enable the bypass and optimize system memory latency by one clock for 133 MHz operation (has no affect on 100 MHz operation).
12 11
Reserved. CPC Mask Enable—R/W. 0 = Normal Operation (default). 1 = Never perform command per clock accesses to system memory. Mask command per clock. Note: This bit must be set to 1 if using 133 MHz system memory.
10:8
Reserved.
64
Datasheet
82815 GMCH
R
Bit 7:6
Description Read Power Throttle Control—R/W. These bits select the Power Throttle Bandwidth Limits for read operations to system memory. R/W, RO if Throttle Lock (bit 3 =1). These bits are locked (read-only) when bit 3 (Throttle Lock) is 1. 00 = No Limit 01 = Limit at 87 ½ % 10 = Limit at 75 % 11 = Limit at 62 ½ % (800 MB/Sec) (Default) (700 MB/Sec) (600 MB/Sec) (500 MB/Sec)
5:4
Write Power Throttle Control—R/W. These bits select the Power Throttle Bandwidth Limits for Write operations to System Memory. R/W, RO if Throttle Lock (bit 3 =1). These bits are locked (read-only) when bit 3 (Throttle Lock) is 1. 00 = No Limit 01 = Limit at 62 ½ % 10 = Limit at 50 % 11 = Limit at 37 ½ % (800 MB/Sec) (Default) ( 500 MB/Sec) ( 400 MB/Sec) ( 300 MB/Sec)
Note: These bits must be set to ‘01’ if using 100 MHz system memory and ‘10’ if using 133 MHz system memory. 3 Throttle Lock—R/W. R/W, RO if Throttle Lock (bit 3 =1). Once set, this bit can only be cleared by a reset. 0 = Bits [7:3] remain writeable 1 = Block writes to bits [7:3] 2 1 Reserved—RO. BNR Lookahead—R/W. This enables the HT unit to look further up the data path to optimize the BNR (Block New Requests) signal to increase our effective IOQ (In Order Queue) depth. 0 = Normal Behavior (default) 1 = BNR Lookahead Enable 0 Graphics Translation Window Size Select—R/W. In GFX mode this would be the size of the GTT (Graphics Translation Table). Not a valid bit in AGP mode. 0 = 64 MB (default) 1 = 32 MB.
Datasheet
65
82815 GMCH
R
3.4.23.
CAPID—Capability Identification (Device 0: AGP Mode Only)
Address Offset: Default Value: Access: Size: 88–8Bh F104 A009h Read-Only 32 bits
This register uniquely identifies chipset capabilities as defined in the table
below. Writes to this register have no effect.
31 133 MHz Capability 30 Display Cache Capability 29 AGP Capability 28 Internal Graphics Capability 27 CAPID Version 24
23 CAPID Length
16
15 Next Capability Pointer
8
7 CAP_ID
0
Bit 31 133 MHz Capability—RO.
Description
0 = Component is capable of up to 100 MHz front side bus and system memory. 1 = Component is capable of up to 133 MHz front side bus and system memory. 30 Display Cache Capability—RO. 0 = Only supports UMA mode (no local memory). 1 = Component is local memory (Display Cache) and UMA capable. 29 AGP Capability—RO. 0 = AGP mode not supported. Note that the AGP interface may still be active through the addition of an AIMM card if bits 28 and 30 are both 1. 1 = AGP mode supported. 28 Internal Graphics Capability—RO. 0 = Internal graphic controller not supported. 1 = Internal graphic controller supported. 27:24 23:16 CAPID Version—RO. This field has the value 0001b to identify the first revision of the CAPID register definition. CAPID Length—RO. This field has the value 04h to indicate the structure length.
66
Datasheet
82815 GMCH
R
Bit 15:8
Description Next Capability Pointer—RO. This field has two possible values based on APCONT[0] at offset 51h: A0h when APCONT[0] = 0 (AGP Mode) meaning the next capability pointer is ACAPID. 00h when APCONT[0] = 1 (GFX Mode) meaning that this was the last capability pointer in the list.
7:0
CAP_ID—RO. This field has the value 1001b to identify the CAP_ID assigned by the PCI SIG for vendor dependent capability pointers.
3.4.24.
BUFF_SC—System Memory Buffer Strength Control Register (Device 0)
Address Offset: Default Value: Access: Size: 92–93h FFFFh Read/Write 16 bits
This register programs the system memory DRAM interface signal buffer strengths, with the exception of the CKEs. The programming of these bits should be based on DRAM density (x8 or x16), DRAM technology (16Mb, 64Mb, 128Mb or 256 Mb), rows populated, etc.. Note that x4 & x32 DRAMs are not supported. Registered DIMMs and DIMMS with ECC are also not supported and BIOS upon detection of ECC via SPD, should report to the user that ECC DIMM timings are not supported by the GMCH. In the descriptions below, the term “Row” is equivalent to one side of one DIMM. In other words, a “single-sided” DIMM contains one populated row (always an odd numbered), and one empty row (even numbered). A “double-sided” DIMM contains two populated rows. All buffer strengths are based on the number of “loads” connected to each pin of a given signal group. A “load” represents one pin of one SDRAM Device. The GMCH pin is implied and not counted in the load equations. The number of loads on a given signal for a given configuration can be determined entirely from the width of the SDRAM devices that populate each row in the configuration. This information is readily available for each row via the Serial Presence Detect mechanism.
15 SCS[5]# Buffer Strength 14 SCS[4]# Buffer Strength 13 SCS[3]# Buffer Strength 12 SCS[2]# Buffer Strength 11 SCS[1]# Buffer Strength 10 SCS[0]# Buffer Strength 9 SMAC[7:4]# Buffer Strength 8
7 SMAB[7:4]# Buffer Strength
6
5 SMAA[7:4] Buffer Strength
4
3 MD and DQM Buffer Strengths
2
1
0
Control Buffer Strengths
Datasheet
67
82815 GMCH
R
Bit 15 SCS[5]# Buffer Strength (Row 5). 0 = Reserved 1 = 1.0x 0 or 2 load or 4 loads
Description
Each Row is actually selected by a pair of chip select signals (SCSA[n]# and SCSB[n]#). The number of SCS# loads for a given row can be determined from SPD data using the following equation: Loads = 32 / (width of SDRAM devices in row) 14 SCS[4]# Buffer Strength (Row 4). 0 = Reserved 1 = 1.0x 0 or 2 load or 4 loads 13 SCS[3]# Buffer Strength (Row 3). 0 = Reserved 1 = 1.0x 0 or 2 load or 4 loads 12 SCS[2]# Buffer Strength (Row 2). 0 = Reserved 1 = 1.0x 0 or 2 load or 4 loads 11 SCS[1]# Buffer Strength (Row 1). 0 = Reserved 1 = 1.0x 0 or 2 load or 4 loads 10 SCS[0]# Buffer Strength (Row 0). 0 = Reserved 1 = 1.0x 0 or 2 load or 4 loads 9:8 SMAC[7:4]# Buffer Strength (Rows 4/5). 00 = 2.7x > 8 loads 01 = 1.7x 8 loads 10 = 1.0x 0 or 4 loads 11 = 1.0x 0 or 4 loads Separate copies of these SMA*[7:4] “Command-Per-Clock” signals are provided for each DIMM. So the loads for each copy are determined by the number of SDRAM devices on the corresponding DIMM (4, 8, 12, or 16 loads). The number of loads for each SMA*[7:4] signal group can be determined from SPD data using the following equation: Loads = (64 / (SDRAM Device Width for 1st row)) + (64 / (SDRAM Device Width for 2nd row)) 7:6 SMAB[7:4]# Buffer Strength (Rows 2/3). 00 = 2.7x > 8 loads 01 = 1.7x 8 loads 10 = 1.0x 0 or 4 loads 11 = 1.0x 0 or 4 loads
68
Datasheet
82815 GMCH
R
Bit 5:4 SMAA[7:4] Buffer Strength (Rows 0/1). 00 = 2.7x > 8 loads 01 = 1.7x 8 loads 10 = 1.0x 0 or 4 loads 11 = 1.0x 0 or 4 loads 3:2
Description
SMD[63:0] and SDQM[7:0] Buffer Strengths (All Rows). 00 = Reserved (1.7x) 01 = Reserved (0.7x) 10 = Reserved (1.0x) 11 = 1.0x 1-6 loads The load on the SMD and SDQM signals is a function only of the number of populated rows in the system (range 1 to 6 loads): Loads = Number of populated rows.
1:0
SWE#, SCAS#, SRAS#, SMAA[11:8, 3:0], SBS[1:0] Control Buffer Strengths (All Rows). 00 = 1.7x > 16 loads 01 = 0.7x < 8 loads 10 = 1.0x 8-16 loads 11 = 1.0x 8-16 loads The load on the address and control signals (other than SMA*[7:4] above) is simply the number of devices populated in ALL rows (range from 4 to 48 loads!). Loads = (64 / Row 0 Device Width) + (64 / Row 1 Device Width) + (64 / Row 2 Device Width) + (64 / Row 3 Device Width) + (64 / Row 4 Device Width) + (64 / Row 5 Device Width)
Datasheet
69
82815 GMCH
R
3.4.25.
BUFF_SC2—System Memory Buffer Strength Control Register 2 (Device 0)
Address Offset: Default Value: Access: Size: 94–95h FFFFh Read/Write 16 bits
This register programs the system memory DRAM interface CKE signal buffer strengths. See BUFF_SC register for the remainder of the buffer strength controls.
15 Reserved (R/W) 8
7 Reserved (R/W)
6
5 CKE5 Buffer Strength
4 CKE4 Buffer Strength
3 CKE3 Buffer Strength
2 CKE2 Buffer Strength
1 CKE1 Buffer Strength
0 CKE0 Buffer Strength
Bit 15:6 5 Reserved. SCKE[5] Buffer Strength (Row 5). 0 = 2.7x 8 loads 1 = 1.7x 0 or 4 loads
Description
The load on a given SCKE signal is equal to the number of SDRAM devices for that particular row (either 4 or 8 loads). Loads = (64 / SDRAM Device Width for this row) 4 SCKE[4] Buffer Strength (Row 4). 0 = 2.7x 8 loads 1 = 1.7x 0 or 4 loads 3 SCKE[3] Buffer Strength (Row 3). 0 = 2.7x 8 loads 1 = 1.7x 0 or 4 loads 2 SCKE[2] Buffer Strength (Row 2). 0 = 2.7x 8 loads 1 = 1.7x 0 or 4 loads 1 SCKE[1] Buffer Strength (Row 1). 0 = 2.7x 8 loads 1 = 1.7x 0 or 4 loads 0 SCKE[0] Buffer Strength (Row 0). 0 = 2.7x 8 loads 1 = 1.7x 0 or 4 loads
70
Datasheet
82815 GMCH
R
3.4.26.
SM_RCOMP—System Memory R Compensation Control Register (Device 0)
Address Offset: Default Value: Access: Size: 98–9Bh XXXXXXXXh Read/Write, Read-Only 32 bits
This register controls the system memory Rcomp buffers (both horizontally and vertically oriented).
31 V Override Enable 30 Reserved 23 22 SRCOMP_VP 20 19 Reserved 18 SRCOMP_VN 16
15 H Override Enable
14 Reserved
7
6 SRCOMP_HP
4
3 Reserved
2 SRCOMP_HN
0
Bit 31 SRCOMP_V Override Enable—R/W.
Description
0 = SM Rcomp is active for vertically oriented buffers (Default). 1 = SM Rcomp is NOT-active for vertically oriented buffers. 30:23 22:20 Reserved. SRCOMP_VP—RO or R/W. P-Channel Compensation Value for Vertical Buffers. This value is generated by the Rcomp logic to control the drive characteristics of the vertically oriented P-channel devices in the SM buffers. In Normal operation, field is read-only and reflects current compensation. In Override Mode (see bit 31), field is written with desired compensation value which is loaded via software when SM Rcomp operation is disabled. 19 18:16 Reserved. SRCOMP_VN—RO or R/W. N-Channel Compensation Value for Vertical Buffers. This value is generated by the Rcomp logic to control the drive characteristics of the vertically oriented N-channel devices in the SM buffers. In Normal operation, field is read-only and reflects current compensation. In Override Mode (see bit 31), field is written with desired compensation value which is loaded via software when SM Rcomp operation is disabled. 15 SRCOMP_H Override Enable—R/W. 0 = SM Rcomp is active for horizontally oriented buffers (Default). 1 = SM Rcomp is NOT-active for horizontally oriented buffers. 14:7 Reserved.
Datasheet
71
82815 GMCH
R
Bit 6:4
Description SRCOMP_HP—RO or R/W. P-Channel Compensation Value for Horizontal Buffers. This value is generated by the Rcomp logic to control the drive characteristics of the horizontally oriented P-channel devices in the SM buffers. In Normal operation, field is read-only and reflects current compensation. In Override Mode (see bit 15), field is written with desired compensation value which is loaded via software when SM Rcomp operation is disabled.
3 2:0
Reserved. SRCOMP_HN—RO or R/W. N-Channel Compensation Value for Horizontal Buffers. This value is generated by the Rcomp logic to control the drive characteristics of the horizontally oriented N-channel devices in the SM buffers. In Normal operation, field is read-only and reflects current compensation. In Override Mode (see bit 15), field is written with desired compensation value which is loaded via software when SM Rcomp operation is disabled.
3.4.27.
SM—System Memory Control Register
Address Offset: Default Value: Access: Size: 9C–9Fh XXXXXXXXh Read/Write, Read-Only 32 bits
This register controls the two System Memory Delay Locked Loop (DLL) blocks that offset the transmit and receive clocks used to interface with the external SDRAM devices. The Transmit DLL provides an early version of SCLK to provide additional setup margin to the external SDRAM devices. The Receive DLL provides a late version of SCLK to provide additional setup time on read data driven by the SDRAM devices back to the GMCH. By default, the Transmit DLL is enabled (whether the operating frequency is 100 MHz or 133 MHz). The Receive DLL is always bypassed, regardless of operating frequency. When the RDLL is bypassed, the RDLL Bias field, instead, controls a buffer delay chain with programmable tap points. This chain has 8 tap points each with approximately 200 ps of incremental delay at the slow corner (total delay range 0 to 1.4 ns) and about 80 ps of incremental delay at the “fast” corner (0 to 0.56 ns total range).
31 Reserved 16 15 TDLL Bypass 14 Reserved 0
Bit 31:16 15 Reserved. Transmit DLL Enable (TDLLE)—R/W. 0 = TDLL Enabled (Default) 1 = TDLL Disabled and bypassed 14:0 Reserved.
Description
72
Datasheet
82815 GMCH
R
3.4.28.
ACAPID—AGP Capability Identifier Register (Device 0: AGP Mode Only)
Address Offset: Default Value: Access: Size: A0–A3h 00200002h Read-Only 32 bits
This register provides standard identifier for AGP capability.
31 Reserved 24
23 Major AGP Revision Number
20
19 Minor AGP Revision Number
16
15 Next Capability Pointer
8
7 AGP Capability ID
0
Bit 31:24 23:20 19:16 Reserved.
Description
Major AGP Revision Number. These bits provide a major revision number of AGP specification that this version of GMCH conforms. These bits are set to the value 0010b to indicate AGP Rev. 2.x. Minor AGP Revision Number. These bits provide a minor revision number of AGP specification that this version of GMCH conforms. This number is hardwired to a value of “0000” (i.e., implying Rev x.0). Together with major revision number this field identifies GMCH as an AGP REV 2.0 compliant device.
15:8
Next Capability Pointer. AGP capability is the first and the last capability described via the capability pointer mechanism; therefore, these bits are hardwired to 0s to indicate the end of the capability linked list. AGP Capability ID. This field identifies the linked list item as containing AGP registers. This field has the value 0000_0010b as assigned by the PCI SIG.
7:0
Datasheet
73
82815 GMCH
R
3.4.29.
AGPSTAT—AGP Status Register (Device 0: AGP Mode Only)
Address Offset: Default Value: Access: Size: A4–A7h 1F000207h Read-Only 32 bits
This register reports AGP device capability/status.
31 Request Queue (RQ) (HW=1Fh) 23 Reserved 15 Reserved 10 1 SBA (HW=1) 8 Reserved 16 24
7 Reserved
6
5 >4 GB Support (HW=0)
4 Fast Writes (HW=0)
3 Reserved
2
0
Data Transfer Rate (HW=111; 1x,2x,4x modes supported)
Bit 31:24
Description Request Queue (RQ). This field is hardwired to 1Fh to indicate a maximum of 32 outstanding AGP command requests can be handled by the GMCH. This field contains the maximum number of AGP command requests the GMCH is configured to manage. The lower 6 bits of this field reflect the value programmed in AGPCTRL[12:10]. Only discrete values of 32, 16, 8, 4 , 2 and 1 can be selected via AGPCTRL. Upper bits are hardwired to 0. Default =1Fh to allow a maximum of 32 outstanding AGP command requests.
23:10 9 8:6 5 4 3 2:0
Reserved SideBand Addressing (SBA). Indicates the GMCH supports sideband addressing. Hardwired to 1. Reserved Greater Than 4 GB Address Support (4GB). This bit indicates that the GMCH does not support addresses greater than 4 GB. It is hardwired to 0. Fast Writes (FW). This bit indicates that the GMCH does not support Fast Writes from the processor to the AGP master. It is hardwired to a 0. Reserved Data Transfer Rate Capability (RATE). After reset the GMCH reports its data transfer rate capability. Note that the selected data transfer mode applies to both AD bus and SBA bus. Bit 0 = 1 = 1x data transfer mode Bit 1 = 1 = 2x data transfer mode Bit 2 = 1 = 4x data transfer mode. This bit can be masked by the AGPCTRL register bit 0 (AGP 4X Override). 1x , 2x , and 4x data transfer modes are supported by the GMCH; therefore, this bit field has a Default Value = 111.
74
Datasheet
82815 GMCH
R
3.4.30.
AGPCMD—AGP Command Register (Device 0: AGP Mode Only)
Address Offset: Default Value: Access: Size: A8–Abh 00000000h Read/Write 32 bits
This register provides control of the AGP operational parameters.
31 Reserved 10 9 SBA EN 8 AGP EN
7 Reserved
6
5 4 GB (HW=0)
4 FW EN
3 Reserved
2 Data Rate
0
Bit 31:10 9 Reserved. Sideband Address Enable (SBA).
Description
1 = Enable. The sideband addressing mechanism is enabled. 0 = Disable 8 AGP Enable. W hen this bit is reset to 0, the GMCH ignores all AGP operations, including the sync cycle. Any AGP operations received while this bit is set to 1 will be serviced, even if this bit is reset to 0. If this bit transitions from a 1 to a 0 on a clock edge in the middle of an SBA command being delivered in 1X mode, the command is issued. When this bit is set to 1 the GMCH will respond to AGP operations delivered via PIPE#, or to operations delivered via SBA, if the AGP Side Band Enable bit is also set to 1. Reserved. Greater Than 4 GB Support (4GB). Hardwired to 0. The GMCH as an AGP target does not support addressing greater than 4 GB. Fast Writes Enable (FW). This bit must always be programmed to 0. The chipset will behave unpredictably if this bit is programmed with 1. Reserved. Data Rate Capability. The settings of these bits determines the AGP data transfer rate. One (and only one) bit in this field must be set to indicate the desired data transfer rate. The same bit must be set on both master and target. Configuration software will update this field by setting only one bit that corresponds to the capability of AGP master (after that capability has been verified by accessing the same functional register within the AGP master’s configuration space.) Bit 0 = 1= 1X Bit 1 = 1 = 2X Bit 2 = 1 = 4x Bit 2 becomes reserved (but will still read 4x, erroneously) when the 4x Override bit in the AGP CTRL register is set to 1 because this bit will not be updated in 4x Override mode. When the 4x Override bit is set writes to Data Rate[2] have no functional impact. Note: This field applies to AD and SBA buses.
7:6 5 4 3 2:0
Datasheet
75
82815 GMCH
R
3.4.31.
AGPCTRL—AGP Control Register (Device 0: AGP Mode Only)
Address Offset: Default Value: Access: Size: B0–B3h 00000000h Read/Write 32 bits
This register provides for additional control of the AGP interface.
31 Reserved 8 7 GTLB_EN 6 Reserved 1 0 4X Override
Bit 31:8 7 Reserved
Description
GTLB Enable ( and GTLB Flush Control)—R/W. 1 = Enables normal operations of the Graphics Translation Lookaside Buffer. 0 = Disable (default). The GTLB is flushed by clearing the valid bits associated with each entry. In this mode of operation all accesses that require translation bypass the GTLB. All requests that are positively decoded to the graphics aperture force the GMCH to access the translation table in main memory before completing the request. Translation table entry fetches are not cached in the GTLB. NOTE: • W hen an invalid translation table entry is read, this entry is still cached in the GTLB (ejecting the least recently used entry). • The GMCH flushes the GWB when software sets or clears this bit to ensure coherency between the GTLB and main memory. • This bit can be changed dynamically (i.e., while an access to GTLB occurs).
6:1 0
Reserved 4X Override. W hen this bit is set to 1 the Rate[2] bit in the AGPSTAT register will be read as a 0. This “back-door” register bit allows BIOS to disable AGP 4X mode. The introduction of universal AGP cards and universal motherboards has raised some potential problems that this bit alleviates. AGP 2X can operation at 1.5V or 3.3V. AGP 4X can operate only at 1.5V. In a system that is supporting 3.3V operation, and therefore cannot support a 4X transfer rate, it is the responsibility of the BIOS to make sure that 4X mode is not selected.
76
Datasheet
82815 GMCH
R
3.4.32.
APSIZE—Aperture Size (Device 0: AGP Mode Only)
Address Offset: Default Value: Access: Size: B4h 00h Read/Write 8 bits
This register determines the effective size of the graphics aperture used for a particular GMCH configuration. This register can be updated by the GMCH-specific BIOS configuration sequence before the PCI standard bus enumeration sequence takes place. If the register is not updated, a default value will select an aperture of maximum size (i.e., 64 MB).
7 Reserved 4 3 GFX Aperture Size 2 Reserved 0
Bit 7:4 3 Reserved.
Description
Graphics Aperture Size (GASIZE). Bit 3 operates on bit 25 of the Aperture Base (APBASE) configuration register. When this bit is 0, it forces bit 25 in APBASE to behave as “hardwired” to 0. When this bit is 1, it forces bit 25 in APBASE to be read/write accessible. Only the following combinations are allowed: 0 = 64 MB Aperture Size 1 = 32 MB Aperture Size Default for APSIZE[3]=0b forces default APBASE[25] =0b (responds as “hardwired” to 0). This provides maximum aperture size of 64 MB. Programming APSIZE[3]=1b enables APBASE[25] as read/write programmable.
2:0
Reserved.
Datasheet
77
82815 GMCH
R
3.4.33.
ATTBASE—Aperture Translation Table Base Register (Device 0: AGP Mode Only)
Address Offset: Default Value: Access: Size: B8–BBh 00000000h Read/Write 32 bits
This register provides the starting address of the Graphics Aperture Translation Table Base located in the main DRAM. This value is used by the GMCH’s Graphics Aperture address translation logic (including the GTLB logic) to obtain the appropriate address translation entry required during the translation of the aperture address into a corresponding physical DRAM address. The ATTBASE register may be dynamically changed. Note: The address provided via ATTBASE is 4 KB aligned.
31 Reserved 29 28 ATT Base Address 12 11 Reserved 0
Bit 31:29 28:12 11:0 Reserved.
Description
ATT Base Address. This field contains a pointer to the base of the translation table used to map memory space addresses in the aperture range to addresses in main memory. Reserved.
78
Datasheet
82815 GMCH
R
3.4.34.
AMTT—AGP Multi-Transaction Timer (Device 0: AGP Mode Only)
Address Offset: Default Value: Access: Size: BCh 00h Read/Write 8 bits
AMTT controls the amount of time that the GMCH’s arbiter allows AGP/PCI master to perform multiple back-to-back transactions. The GMCH’s AMTT mechanism is used to optimize the performance of the AGP master (using PCI semantics) that performs multiple back-to-back transactions to fragmented memory ranges (and as a consequence it can not use long burst transfers). The AMTT mechanism applies to the processor — AGP/PCI transactions as well and it guarantees to the processor a fair share of the AGP/PCI interface bandwidth. The number of clocks programmed in the AMTT represents the guaranteed time slice (measured in 66 MHz clocks) allotted to the current agent (either AGP/PCI master or Host bridge) after which the AGP arbiter grants the bus to another agent. The default value of AMTT is 00h and disables this function. The AMTT value can be programmed with 8-clock granularity. For example, if the AMTT is programmed to 18h, the selected value corresponds to the time period of 24 AGP (66 MHz) clocks.
7 Multi-Transaction Timer Count Value 3 2 Reserved 0
Bit 7:3
Description Multi-Transaction Timer Count Value. The number programmed in these bits represents the guaranteed time slice (measured in eight 66 MHz clock granularity) allotted to the current agent (either AGP/PCI master or Host bridge) after which the AGP arbiter will grant the bus to another agent. Reserved.
2:0
Datasheet
79
82815 GMCH
R
3.4.35.
LPTT—AGP Low Priority Transaction Timer Register (Device 0: AGP Mode Only)
Address Offset: Default Value: Access: Size: BDh 00h Read/Write 8 bits
LPTT is similar in function to AMTT. This register is used to control the minimum tenure on the AGP for low priority data transaction (both reads and writes) issued using PIPE# or SB mechanisms. The number of clocks programmed in the LPTT represents the guaranteed time slice (measured in 66 MHz clocks) allotted to the current low priority AGP transaction data transfer state. This does not necessarily apply to a single transaction but it can span over multiple low-priority transactions of the same type. After this time expires, the AGP arbiter may grant the bus to another agent if there is a pending request. The LPTT does not apply in the case of high-priority request where ownership is transferred directly to high-priority requesting queue. The default value of LPTT is 00h and disables this function. The LPTT value can be programmed with 8-clock granularity. For example, if the LPTT is programmed to 10h, the selected value corresponds to the time period of 16 AGP (66 MHz) clocks.
7 Low Priority Transaction Timer Count Value 3 2 Reserved 0
Bit 7:3
Description Low Priority Transaction Timer Count Value. The number of clocks programmed in these bits represents the guaranteed time slice (measured in eight 66 MHz clock granularity) allotted to the current low priority AGP transaction data transfer state. Reserved.
2:0
80
Datasheet
82815 GMCH
R
3.4.36.
GMCHCFG—GMCH Configuration Register (Device 0: AGP Mode Only)
Address Offset: Default: Access: Size:
7 Reserved 6 5 MDA Present (R/W)
BEh 0000 X000b Read/Write, Read-Only 8 bits
4 Reserved 3 AGP_BUF Mode (RO) 2 Reserved 0
Bit 7:6 5 Reserved.
Description
MDA Present (MDAP)—R/W. This bit works with the VGA Enable bit in the BCTRL register (3Eh, bit 3) of device 1 to control the routing of processor-initiated transactions targeting MDA compatible I/O and memory address ranges. This bit should not be set when the VGA Enable bit is not set. If the VGA enable bit is set, accesses to IO address range x3BCh–x3BFh are forwarded to the hub interface. If the VGA enable bit is not set, accesses to IO address range x3BCh–x3BFh are treated just like any other IO accesses (i.e., the cycles are forwarded to AGP if the address is within IOBASE and IOLIMIT, and the ISA enable bit is not set; otherwise, they are forwarded to the hub interface). MDA resources are defined as the following: • Memory: • I/O: 0B0000h–0B7FFFh 3B4h, 3B5h, 3B8h, 3B9h, 3BAh, 3BFh, (including ISA address aliases, A[15:10] are not used in decode)
Any I/O reference that includes the I/O locations listed above, or their aliases, will be forwarded to the hub interface, even if the reference includes I/O locations not listed above. The following table shows the behavior for all combinations of MDA and VGA: VGA 0 0 1 1 4 3 Reserved. AGP I/O Buffer Mode (AGP_BUF)—RO. The GMCH has an internal circuit that detects the voltage level on the AGP I/O buffer VDDQ rail. The voltage level information is latched 500 us after the deasserting edge of RSTIN# and stored in this register bit. 1 = AGP VDDQ is sensed at 3.3V. 0 = AGP VDDQ is sensed at 1.5V. 2:0 Reserved. MDA 0 1 0 1 Behavior All references to MDA and VGA go to hub interface Illegal combination (DO NOT USE) All references to VGA go to AGP/PCI. MDA-only references (I/O address 3BFh and aliases) will go to the hub interface. VGA references go to AGP/PCI; MDA references go to the hub interface.
Datasheet
81
82815 GMCH
R
3.4.37.
ERRCMD—Error Command Register (Device 0: AGP Mode Only)
Address Offset: Default Value: Access: Size: CBh 00h Read/Write 8 bits
This register enables various errors to generate a SERR hub interface special cycle. Since the GMCH does not have an SERR# signal, SERR messages are passed from the GMCH to the I/O Controller Hub over the hub interface. The actual generation of the SERR message is globally enabled for Device 0 via the PCI Command register. Note: An error can generate one and only one hub interface error special cycle. It is software’s responsibility to make sure that when an SERR error message is enabled for an error condition, SMI and SCI error messages are disabled for that same error condition.
7 Reserved 6 5 SRMMRO 4 SRTA 3 SLNDM 2 SAAOGA 1 SIAA 0 SAIGATTE
Bit 7:6 5 Reserved.
Description
SERR on Receiving Main Memory Refresh Overrun Enable. Identical functionality in Device 2 memory mapped space @ 020B8h. This bit allows use of this same functionality in AGP Mode. 1 = Enable. GMCH generates a SERR hub interface special cycle when a main memory refresh overrun occurs. 0 = Disable. Reporting of this condition is disabled.
4
SERR on Receiving Target Abort on the hub interface. 1 = Enable. GMCH generates a SERR hub interface special cycle when a GMCH-originated hub interface cycle is terminated with a Target Abort. 0 = Disable. Reporting of this condition is disabled.
3
SERR on LOCK to non-DRAM Memory. 1 = Enable. GMCH generates a SERR hub interface special cycle when a processor-initiated LOCK transaction targeting non-DRAM memory space occurs. 0 = Disable. Reporting of this condition is disabled.
2
SERR on AGP Access Outside of Graphics Aperture. 1 = Enable. GMCH generates a SERR hub interface special cycle when an AGP access occurs to an address outside of the graphics aperture. 0 = Disable. Reporting of this condition is disabled.
1
SERR on Invalid AGP Access. 1 = Enable. GMCH generates a SERR hub interface special cycle when an AGP access occurs to an address outside of the graphics aperture and either to the 640 KB–1 MB range or above the top of memory. 0 = Disable.
0
SERR on Access to Invalid Graphics Aperture Translation Table Entry. 1 = Enable. GMCH generates a SERR hub interface special cycle when an invalid translation table entry was returned in response to a AGP access to the graphics aperture. 0 = Disable. Reporting of this condition via SERR messaging is disabled.
82
Datasheet
82815 GMCH
R
Table 6. Summary of GMCH Error Sources, Enables and Status Flags
Error Event Processor LOCK to non-DRAM memory Received Hub Interface Target Abort Hub Interface Message SERR Enable Bits Required to be Set PCICMD bit 8 ERRCMD bit 3 SERR PCICMD bit 8 ERRCMD bit 4 AGP Access Outside of Graphics Aperture Invalid AGP Access SERR PCICMD bit 8 ERRCMD bit 2 SERR PCICMD bit 8 ERRCMD bit 1 Access to Invalid GTLB Entry SERR PCICMD bit 8 ERRCMD bit 0 AGP/PCI Parity Error Detected SERR PCICMD1 bit 8 BCTRL bit 2 AGP/PCI Received Target Abort SERR PCICMD1 bit 8 ERRCMD1 bit 0 PCISTS1 bit 14 PCISTS1 bit 15 PCISTS1 bit 14 PCISTS1 bit 12 PCISTS bit 14 PCISTS bit 14 PCISTS bit 14 PCISTS bit 12 PCISTS bit 14 Status Flags Set PCISTS bit 14
Datasheet
83
82815 GMCH
R
3.5.
AGP/PCI Bridge Registers (Device 1: Visible in AGP Mode Only)
These registers are accessible through the configuration mechanism defined in an earlier section of this document.
Table 7. GMCH Configuration Space (Device 1)
Address Offset 00–01h 02–03h 04–05h 06–07h 08 09 0Ah 0Bh 0Ch 0Dh 0Eh 0F–17h 18h 19h 1Ah 1Bh 1Ch 1Dh 1E–1Fh 20–21h 22–23h 24–25h 26–27h 28–3Dh 3Eh 3Fh 40h 41–FFh Mnemonic VID1 DID1 PCICMD1 PCISTS1 RID1 SUBC1 BCC1 MLT1 HDR1 PBUSN SBUSN SUBUSN SMLT IOBASE IOLIMIT SSTS MBASE MLIMIT PMBASE PMLIMIT BCTRL ERRCMD1 Register Name Vendor Identification Device Identification PCI Command PCI Status Revision Identification Reserved Sub-Class Code Base Class Code Reserved Master Latency Timer Header Type Reserved Primary Bus Number Secondary Bus Number Subordinate Bus Number Secondary Bus Master Latency Timer I/O Base Address I/O Limit Address Secondary Status Memory Base Address Memory Limit Address Prefetchable Memory Base Address Prefetchable Memory Limit Address Reserved Bridge Control Reserved Error Command Reserved Default Value 8086h 1131h 0000h 0020h 02h (see note) 00h 04h 06h 00h 00h 01h 00h 00h 00h 00h 00h F0h 00h 02A0h FFF0h 0000h FFF0h 0000h 00h 00h 00h 00h 00h Access Type RO RO RO, R/W RO, R/WC RO RO RO R/W RO RO R/W R/W R/W R/W R/W RO, R/WC R/W R/W R/W R/W R/W R/W
Note: See Specification Update document for latest information.
84
Datasheet
82815 GMCH
R
3.5.1.
VID1—Vendor Identification Register (Device 1)
Address Offset: Default Value: Attribute: Size: 00–01h 8086h Read-Only 16 bits
The VID1 Register contains the vendor identification number. This 16-bit register combined with the Device Identification Register uniquely identify any PCI device. Writes to this register have no effect.
Bit 15:0 Description Vendor Identification Number. This is a 16-bit value assigned to Intel. Intel VID = 8086h.
3.5.2.
DID1—Device Identification Register (Device 1)
Address Offset: Default Value: Attribute: Size: 02–03h 1131h Read-Only 16 bits
This 16-bit register combined with the Vendor Identification register uniquely identifies any PCI device. Writes to this register have no effect.
Bit 15:0 Description Device Identification Number. This is a 16 bit value assigned to the GMCH AGP interface device. 1131h = Device ID for Device 1.
3.5.3.
PCICMD1—PCI-PCI Command Register (Device 1)
Address Offset: Default: Access: Size
15 Reserved (0)
04–05h 0000h Read/Write, Read-Only 16 bits
10 9 FB2B (Not Impl) 8 SERR En
7 Addr/Data Stepping (Not Impl)
6 Parity Error En (Not Impl)
5 Reserved
4 Mem WR & Inval En (Not Impl)
3 Special Cycle En (Not Impl)
2 Bus Master En
1 Mem Acc En
0 I/O Acc En
Datasheet
85
82815 GMCH
R
Bit 15:10 9 8 Reserved.
Descriptions
Fast Back-to-Back. (Not Applicable). Hardwired to 0. SERR Message Enable (SERRE1). This bit is a global enable bit for Device 1 SERR messaging. The GMCH does not have an SERR# signal. The GMCH communicates the SERR# condition by sending an SERR message to the I/O Controller Hub. If this bit is set to a 1, the GMCH is enabled to generate SERR messages over the hub interface for specific Device 1 error conditions that are individually enabled in the ERRCMD1 and BCTRL registers. The error status is reported in the PCISTS1 register. If SERRE1 is reset to 0, the SERR message is not generated by the GMCH for Device 1. 1 = Enable. 0 = Disable. NOTE: This bit only controls SERR messaging for the Device 1. Device 0 has its own SERRE bit to control error reporting for error conditions occurring on Device 0. The two control bits are used in a logical OR manner to enable the SERR hub interface message mechanism.
7 6 5 4 3 2
Address/Data Stepping. (Not Applicable). Hardwired to 0. Parity Error Enable (PERRE1). Hardwired to 0. PERR# is not supported on AGP/PCI1. Reserved. Memory Write and Invalidate Enable—RO. This bit is implemented as read-only and returns a value of 0 when read. Special Cycle Enable—RO. This bit is implemented as read-only and returns a value of 0 when read. Bus Master Enable (BME1)—R/W. 1= 0= Enable. AGP Master-initiated FRAME# cycles are accepted by the GMCH if they hit a valid address decode range. This bit has no affect on AGP Master originated SBA or PIPE# cycles. Disable (default). AGP Master-initiated FRAME# cycles are ignored by the GMCH resulting in a Master Abort. Ignoring incoming cycles on the secondary side of the P2P bridge effectively disables the bus master on the primary side.
1
Memory Access Enable (MAE1)—R/W. 1 = Enable. Enables the Memory and Prefetchable memory address ranges defined in the MBASE, MLIMIT, PMBASE, and PMLIMIT registers, as well as the VGA window. 0 = Disable. All of the memory space for Device 1 is disabled.
0
I/O Access Enable (IOAE1)—R/W. 1 = Enable. Enables the I/O address range defined in the IOBASE and IOLIMIT registers. 0 = Disable. All of I/O space for Device 1 is disabled.
86
Datasheet
82815 GMCH
R
3.5.4.
PCISTS1—PCI-PCI Status Register (Device 1)
Address Offset: Default Value: Access: Size: 06–07h 0020h Read-Only, Read/Write Clear 16 bits
PCISTS1 reports the occurrence of error conditions associated with the primary side of the “virtual” PCI-PCI bridge embedded in the GMCH. Since this device does not physically reside on PCI0, it reports the optimum operating conditions so that it does not restrict the capability of PCI0.
15 Detected Par Error (HW=0) 14 Sig Sys Error 13 Recog Mast Abort Sta (HW=0) 12 Rec Target Abort Sta (HW=0) 11 Sig Target Abort Sta (HW=0) 10 DEVSEL# Timing (HW=00) 9 8 Data Par Detected (HW=0)
7 FB2B (HW=1)
6 Reserved
5
4 Cap List (HW=1)
3 Reserved
0
Bit 15 14
Descriptions Detected Parity Error (DPE1). (Not Applicable). Hardwired to 0. Signaled System Error (SSE1). 1 = GMCH Device 1 generated an SERR message over hub interface for any enabled Device 1 error condition. Device 1 error conditions are enabled in the PCICMD1, ERRCMD1 and BCTRL registers. Device 1 error flags are read/reset from the SSTS register. 0 = Software clears this bit by writing a 1 to it.
13 12 11 10:9 8 7 6 5 4:0
Received Master Abort Status (RMAS1). (Not Applicable). Hardwired to 0. Received Target Abort Status (RTAS1). (Not Applicable). Hardwired to 0. Signaled Target Abort Status (STAS1). (Not Applicable). Hardwired to 0. DEVSEL# Timing (DEVT1). (Not Applicable). Hardwired to 00b. Data Parity Detected (DPD1). (Not Applicable). Hardwired to 0. Fast Back-to-Back (FB2B1). (Not Applicable). Hardwired to 0. Reserved. 66/60 MHz Capability. (Not Applicable). Hardwired to 1. Reserved.
Datasheet
87
82815 GMCH
R
3.5.5.
RID1—Revision Identification Register (Device 1)
Address Offset: Default Value: Access: Size: 08h 02h (see Spec. Update document for latest information.) Read-Only 8 bits
This register contains the revision number of the GMCH Device 1. These bits are read-only and writes to this register have no effect.
Bit 7:0 Description Revision Identification Number. This 8-bit value indicates the revision identification number for the GMCH Device 1. 02h = A-2 Stepping
3.5.6.
SUBC1—Sub-Class Code Register (Device 1)
Address Offset: Default Value: Access: Size: 0Ah 04h Read-Only 8 bits
This register contains the Sub-Class Code for the GMCH Device 1. This code is 04h indicating a PCI-PCI Bridge device. The register is read-only.
Bit 7:0 Description Sub-Class Code (SUBC1). This 8-bit value indicates the category of Bridge of the GMCH. 04h = Host Bridge.
3.5.7.
BCC1—Base Class Code Register (Device 1)
Address Offset: Default Value: Access: Size: 0Bh 06h Read-Only 8 bits
This register contains the Base Class Code of the GMCH Device 1. This code is 06h indicating a Bridge device. This register is read-only.
Bit 7:0 Description Base Class Code (BASEC). This 8-bit value indicates the Base Class Code for the GMCH Device 1. 06h = Bridge device.
88
Datasheet
82815 GMCH
R
3.5.8.
MLT1—Master Latency Timer Register (Device 1)
Address Offset: Default Value: Access: Size: 0Dh 00h Read/Write 8 bits
This functionality is not applicable. It is described here since these bits should be implemented as a read/write to prevent standard PCI-PCI bridge configuration software from getting “confused”.
Bit 7:3 2:0 Description Not applicable but supports read/write operations. (Reads return previously written data.) Reserved.
3.5.9.
HDR1—Header Type Register (Device 1)
Address Offset: Default: Access: Size: 0Eh 01h Read-Only 8 bits
This register identifies the header layout of the configuration space. No physical register exists at this location.
Bit 7:0 Descriptions This read-only field always returns 01h when read. Writes have no effect.
3.5.10.
PBUSN—Primary Bus Number Register (Device 1)
Address Offset: Default: Access: Size: 18h 00h Read-Only 8 bits
This register identifies that the “virtual” PCI-PCI bridge is connected to bus #0.
Bit 7:0 Bus Number. Hardwired to 0. Descriptions
Datasheet
89
82815 GMCH
R
3.5.11.
SBUSN—Secondary Bus Number Register (Device 1)
Address Offset: Default: Access: Size: 19h 00h Read /Write 8 bits
This register identifies the bus number assigned to the second bus side of the “virtual” PCI-PCI bridge (i.e., to PCI1/AGP). This number is programmed by the PCI configuration software to allow mapping of configuration cycles to PCI1/AGP.
Bit 7:0 Bus Number. Programmable Descriptions
3.5.12.
SUBUSN—Subordinate Bus Number Register (Device 1)
Address Offset: Default: Access: Size: 1Ah 00h Read /Write 8 bits
This register identifies the subordinate bus (if any) that resides at the level below PCI1/AGP. This number is programmed by the PCI configuration software to allow mapping of configuration cycles to PCI1/AGP.
Bit 7:0 Bus Number. Programmable Descriptions
90
Datasheet
82815 GMCH
R
3.5.13.
SMLT—Secondary Master Latency Timer Register (Device 1)
Address Offset: Default Value: Access: Size: 1Bh 00h Read/Write 8 bits
This register controls the bus tenure of the GMCH on AGP/PCI. SMLT is an 8-bit register that controls the amount of time the GMCH, as a AGP/PCI bus master, can burst data on the AGP/PCI Bus. The count value is an 8-bit quantity; however, SMLT[2:0] are reserved and assumed to be 0 when determining the count value. The GMCH’s SMLT is used to guarantee to the AGP master a minimum amount of the system resources. When the GMCH begins the first PCI bus cycle after being granted the bus, the counter is loaded and enabled to count from the assertion of FRAME#. If the count expires while the GMCH’s grant is removed (due to AGP master request), the GMCH will lose the use of the bus and the AGP master agent may be granted the bus. If the GMCH’s bus grant is not removed, the GMCH continues to own the AGP/PCI bus, regardless of the SMLT expiration or idle condition. Note that the GMCH must always properly terminate a AGP/PCI transaction, with FRAME# negation prior to the final data transfer. The number of clocks programmed in the SMLT represents the guaranteed time slice (measured in 66 MHz PCI clocks) allotted to the GMCH, after which it must complete the current data transfer phase and then surrender the bus as soon as its bus grant is removed. For example, if the SMLT is programmed to 18h, the value is 24 AGP clocks. The default value of SMLT is 00h and disables this function. When the SMLT is disabled, the burst time for the GMCH is unlimited (i.e., the GMCH can burst forever).
7 Secondary MLT Counter Value 3 2 Reserved 0
Bit 7:3 2:0
Description Secondary MLT Counter Value. Default=0 (i.e., SMLT disabled) Reserved.
Datasheet
91
82815 GMCH
R
3.5.14.
IOBASE—I/O Base Address Register (Device 1)
Address Offset: Default Value: Access: Size: 1Ch F0h Read/Write 8 bits
This register control the processor to PCI1/AGP I/O access routing based on the following formula:
IO_BASE ≤ address ≤ IO_LIMIT
Only the upper 4 bits are programmable. For the purpose of address decode, address bits A[11:0] are treated as 0. Thus, the bottom of the defined I/O address range will be aligned to a 4-KB boundary. Note: BIOS must not set this register to 00h; otherwise, 0CF8h/0CFCh accesses will be forwarded to AGP.
7 I/O Address Base 4 3 I/O Addressing Capability 0
Bit 7:4 3:0
Description I/O Address Base. Corresponds to A[15:12] of the I/O address. (Default=Fh) I/O Addressing Capability. Hardwired to 0h indicating that only 16 bit I/O addressing is supported. Bits [31:16] of the I/O base address are assumed to be 0000h.
92
Datasheet
82815 GMCH
R
3.5.15.
IOLIMIT—I/O Limit Address Register (Device 1)
Address Offset: Default Value: Access: Size: 1Dh 00h Read/Write 8 bits
This register controls the processor to PCI1/AGP I/O access routing based on the following formula:
IO_BASE ≤ address ≤ IO_LIMIT
Only upper 4 bits are programmable. For the purpose of address decode address bits A[11:0] are assumed to be FFFh. Thus, the top of the defined I/O address range will be at the top of a 4-KB aligned address block.
7 I/O Address Limit 4 3 Reserved 0
Bit 7:4 3:0
Description I/O Address Limit. Corresponds to A[15:12] of the I/O address. (Default=0) Reserved. (Only 16 bit addressing supported.)
Datasheet
93
82815 GMCH
R
3.5.16.
SSTS—Secondary PCI-PCI Status Register (Device 1)
Address Offset: Default Value: Access: Size: 1E–1Fh 02A0h Read-Only, Read/Write Clear 16 bits
SSTS is a 16-bit status register that reports the occurrence of error conditions associated with the secondary side (i.e., PCI1/AGP side ) of the “virtual” PCI-PCI bridge embedded within GMCH.
15 Det. Parity Error 14 Rec Sys Error (HW=0) 13 Rec Master Abort 12 Rec Target Abort 11 Sig Target Abort (HW=0) 10 DEVSEL Timing (HW=01b; medium) 9 8 Data Parity Det. (HW=0)
7 FB2B (HW=1)
6 Reserved
5 66/60 MHz Cap (HW=1)
4 Reserved
0
Bit 15
Descriptions Detected Parity Error (DPE1). Note that the function of this bit is not affected by the PERRE1 bit. Also note that PERR# is not implemented in the GMCH. 1 = GMCH detected a parity error in the address or data phase of PCI1/AGP bus transactions. 0 = Software sets DPE1 to 0 by writing a 1 to this bit.
14 13
Received System Error (SSE1). Hardwired to 0. The GMCH does not have an SERR# signal pin. Received Master Abort Status (RMAS1). 1 = GMCH terminated a Host-to-PCI1/AGP with an unexpected master abort. 0 = Software resets this bit to 0 by writing a 1 to it.
12
Received Target Abort Status (RTAS1). 1 = GMCH-initiated transaction on PCI1/AGP is terminated with a target abort. 0 = Software resets RTAS1 to 0 by writing a 1 to it.
11 10:9
Signaled Target Abort Status (STAS1). Hardwired to 0. The GMCH does not generate target abort on PCI1/AGP. DEVSEL# Timing (DEVT1). This 2-bit field indicates the timing of the DEVSEL# signal when the GMCH responds as a target on PCI1/AGP, and is hard-wired to the value 01b (medium) to indicate the time when a valid DEVSEL# can be sampled by the initiator of the PCI cycle. Data Parity Detected (DPD1). Hardwired to 0. GMCH does not implement G_PERR# function. However, data parity errors are still detected and reported using SERR hub interface special cycles (if enabled by SERRE1 and the BCTRL register, bit 0). Fast Back-to-Back (FB2B1). Hardwired to 1. The GMCH as a target supports fast back-to-back transactions on PCI1/AGP. Reserved. 66/60 MHz Capability. Hardwired to 1. Reserved.
8
7 6 5 4:0
94
Datasheet
82815 GMCH
R
3.5.17.
MBASE—Memory Base Address Register (Device 1)
Address Offset: Default Value: Access: Size: 20–21h FFF0h Read/Write 16 bits
This register controls the processor to PCI1 non-prefetchable memory access routing based on the following formula:
MEMORY_BASE ≤ address ≤ MEMORY_LIMIT
The upper 12 bits of the register are read/write and correspond to the upper 12 address bits A[31:20] of the 32 bit address. The bottom 4 bits of this register are read-only and return zeroes when read. The configuration software must initialize this register. For the purpose of address decode, address bits A[19:0] are assumed to be 0. Thus, the bottom of the defined memory address range will be aligned to a 1 MB boundary.
15 Memory Address Base 4 3 Reserved 0
Bit 15: 4 3:0
Description Memory Address Base (MEM_BASE). Corresponds to A[31:20] of the memory address. Reserved.
Datasheet
95
82815 GMCH
R
3.5.18.
MLIMIT—Memory Limit Address Register (Device 1)
Address Offset: Default Value: Access: Size: 22–23h 0000h Read/Write 16 bits
This register controls the processor to PCI1 non-prefetchable memory access routing based on the following formula:
MEMORY_BASE ≤ address ≤ MEMORY_LIMIT
The upper 12 bits of the register are read/write and correspond to the upper 12 address bits A[31:20] of the 32 bit address. The bottom 4 bits of this register are read-only and return zeroes when read. The configuration software must initialize this register. For the purpose of address decode, address bits A[19:0] are assumed to be FFFFFh. Thus, the top of the defined memory address range will be at the top of a 1 MB aligned memory block.
15 Memory Address Limit 4 3 Reserved 0
Bit 15: 4 3:0
Description Memory Address Limit (MEM_LIMIT). Corresponds to A[31:20] of the memory address. (Default=0) Reserved.
Note:
Memory range covered by MBASE and MLIMIT registers are used to map non-prefetchable PCI1/AGPaddress ranges (typically, where control/status memory-mapped I/O data structures of the graphics controller will reside) and PMBASE and PMLIMIT are used to map prefetchable address ranges (typically, graphics local memory). This segregation allows application of USWC space attribute to be performed in a true plug-and-play manner to the prefetchable address range for improved processor –AGP memory access performance. Configuration software is responsible for programming all address range registers (prefetchable, nonprefetchable) with the values that provide exclusive address ranges (i.e., prevent overlap with each other and/or with the ranges covered with the main memory). There is no provision in the GMCH hardware to enforce prevention of overlap and operations of the system in the case of overlap are not guaranteed.
Note:
96
Datasheet
82815 GMCH
R
3.5.19.
PMBASE—Prefetchable Memory Base Address Register (Device 1)
Address Offset: Default Value: Access: Size: 24–25h FFF0h Read/Write 16 bits
This register controls the processor to PCI1 prefetchable memory accesses routing based on the following formula:
PREFETCHABLE_MEMORY_BASE ≤ address ≤ PREFETCHABLE_MEMORY_LIMIT
The upper 12 bits of the register are read/write and correspond to the upper 12 address bits A[31:20] of the 32 bit address. The bottom 4 bits of this register are read-only and return zeroes when read. The configuration software must initialize this register. For the purpose of address decode, address bits A[19:0] are assumed to be 0. Thus, the bottom of the defined memory address range will be aligned to a 1 MB boundary.
15 Prefetchable Memory Address Base 4 3 Reserved 0
Bit 15: 4 3:0
Description Prefetchable Memory Address Base(PMEM_BASE). Corresponds to A[31:20] of the memory address. (Default=FFFh) Reserved.
Datasheet
97
82815 GMCH
R
3.5.20.
PMLIMIT—Prefetchable Memory Limit Address Register (Device 1)
Address Offset: Default Value: Access: Size: 26–27h 0000h Read/Write 16 bits
This register controls the processor to PCI1 prefetchable memory accesses routing based on the following formula.
PREFETCHABLE_MEMORY_BASE ≤ address ≤ PREFETCHABLE_MEMORY_LIMIT
The upper 12 bits of the register are read/write and correspond to the upper 12 address bits A[31:20] of the 32 bit address. The bottom 4 bits of this register are read-only and return zeroes when read. The configuration software must initialize this register. For the purpose of address decode, address bits A[19:0] are assumed to be FFFFFh. Thus, the top of the defined memory address range will be at the top of a 1 MB aligned memory block.
15 Prefetchable Memory Address Limit 4 3 Reserved 0
Bit 15: 4 3:0
Description Prefetchable Memory Address Limit (PMEM_LIMIT). Corresponds to A[31:20] of the memory address. (Default=0) Reserved.
Note:
Prefetchable memory range is supported to allow segregation by the configuration software between the memory ranges that must be defined as UC and the ones that can be designated as a USWC (i.e., prefetchable) from the processor perspective.
98
Datasheet
82815 GMCH
R
3.5.21.
BCTRL—PCI-PCI Bridge Control Register (Device 1)
Address Offset: Default: Access: Size 3Eh 00h Read/Write 8 bits
This register provides extensions to the PCICMD1 register that are specific to PCI-PCI bridges. The BCTRL provides additional control for the secondary interface (i.e., PCI1/AGP) as well as some bits that affect the overall behavior of the “virtual” PCI-PCI bridge embedded in GMCH (e.g., VGA compatible address ranges mapping).
7 FB2B EN 6 Sec Bus Reset 5 Reserved 4 Reserved 3 VGA EN 2 1 SERR# EN 0 Parity Err Response EN
Bit 7 6
Description Fast Back to Back Enable. Hardwired to 0. Since there is only one target allowed on AGP, this bit is meaningless. Secondary Bus Reset. Hardwired to 0. The GMCH does not support generation of reset via this bit on the AGP. Note that the only way to perform a hard reset of the AGP is via the system reset, either initiated by software or hardware via the I/O Controller Hub. Master Abort Mode. Hardwired to 0. This means that when acting as a master on AGP/PCI1, the GMCH will drop writes on the “floor” and return all 1s during reads when a Master Abort occurs. Reserved.
5 4
Datasheet
99
82815 GMCH
R
Bit 3
Description VGA Enable. This bit works with the MDA present bit (GMCHCFG[3]) of device 0 to control the routing of processor-initiated transactions targeting VGA compatible I/O and memory address ranges. When this bit is set, the GMCH forwards the following processor accesses to the AGP: • Memory accesses in the range 0A0000h to 0BFFFFh • I/O addresses where A[9:0] are in the ranges 3B0h to 3BBh and 3C0h to 3DFh (inclusive of ISA address aliases – A[15:10] are not decoded) 1 = Enable. Forwarding of these accesses issued by the processor is independent of the I/O address and memory address ranges defined by the previously defined Base and Limit registers. Forwarding of these accesses is also independent of the settings of bit 2 (ISA Enable) of this register if this bit is 1. If the VGA enable bit is set, accesses to IO address range x3BCh–x3BFh are forwarded to the hub interface. If the VGA enable bit is not set, accesses to IO address range x3BCh–x3BFh are treated just like any other IO accesses (i.e., cycles are forwarded to AGP, if the address is within IOBASE and IOLIMIT and ISA enable bit is not set; otherwise, they are forwarded to hub interface). 0 = Disable (default). VGA compatible memory and I/O range accesses are not forwarded to AGP; rather, they are mapped to primary PCI unless they are mapped to AGP via I/O and memory range registers defined above (IOBASE, IOLIMIT, MBASE, MLIMIT, PMBASE, PMLIMIT). The following table shows the behavior for all combinations of MDA and VGA: VGA 0 0 1 1 MDA 0 1 0 1 Behavior All references to MDA and VGA Go To hub interface Illegal combination (DO NOT USE) All references To VGA Go To AGP MDA-only references (I/O Address 3BF and aliases) will go to hub interface. VGA references go to AGP/PCI; MDA references go to the hub interface
2
ISA Enable. Modifies the response by the GMCH to an I/O access issued by the processor that targets ISA I/O addresses. This applies only to I/O addresses that are enabled by the IOBASE and IOLIMIT registers. 1 = Enable. GMCH will not forward to PCI1/AGP any I/O transactions addressing the last 768 bytes in each 1 KB block, even if the addresses are within the range defined by the IOBASE and IOLIMIT registers. Instead of going to PCI1/AGP, these cycles are forwarded to the hub interface where they can eventually be subtractively or positively claimed by the ISA bridge. 0 = Disable (default). All addresses defined by the IOBASE and IOLIMIT for processor I/O transactions are mapped to PCI1/AGP.
1
SERR# Enable. Hardwired to 0. This bit normally controls forwarding SERR# on the secondary interface to the primary interface. The GMCH does not support the SERR# signal on the AGP/PCI1 bus. Parity Error Response Enable. Controls GMCH’s response to data phase parity errors on PCI1/AGP. G_PERR# is not implemented by the GMCH. 1 = Enable. Address and data parity errors on PCI1 are reported via SERR messaging, if enabled by SERRE1. 0 = Disable. Address and data parity errors on PCI1/AGP are not reported via SERR messaging. Other types of error conditions can still be signaled via SERR messaging independent of this bit’s state.
0
100
Datasheet
82815 GMCH
R
3.5.22.
ERRCMD1—Error Command Register (Device 1)
Address Offset: Default: Access: Size
7 Reserved
40h 00h Read/Write 8 bits
1 0 SERR on Rec Targ. Abort on AGP/PCI
Bit 7:1 0 Reserved.
Descriptions
SERR on Receiving Target Abort on AGP/PCI. 1 = Enable. The GMCH generates an SERR hub interface special cycle when an GMCH-originated AGP/PCI cycle is terminated with a Target Abort. 0 = Disable. Reporting of this condition is disabled.
Datasheet
101
82815 GMCH
R
3.6.
Graphics Device Registers (Device 2: VISIBLE IN GFX Mode Only)
These registers are accessible through the configuration mechanism defined in an earlier section of this document.
Table 8. Device 2 Configuration Space Address Map (Internal Graphics)
Address Offset 00–01h 02–03h 04–05h 06–07h 08h 09h 0Ah 0Bh 0Ch 0Dh 0Eh 0Fh 10–13h 14–17h 18–2Bh 2C–2Dh 2E–2Fh 30–33h 34h 35–3Bh 3Ch 3Dh 3Eh 3Fh 40–DBh DC–DDh DE–DFh E0–E1h E2–FFh Register Symbol VID2 DID2 PCICMD2 PCISTS2 RID2 PI SUBC2 BCC2 CLS MLT2 HDR2 BIST GMADR MMADR SVID SID ROMADR CAPPOINT INTRLINE INTRPIN MINGNT MAXLAT PM_CAPID PM_CAP PM_CS Register Name Vendor Identification Device Identification PCI Command PCI Status Revision Identification Programming Interface Sub-Class Code Base Class Code Cache Line Size Master Latency Timer Header Type BIST Register Graphics Memory Range Address Memory Mapped Range Address Reserved Subsystem Vendor ID Subsystem ID Video Bios ROM Base Address Capabilities Pointer Reserved Interrupt Line Interrupt Pin Minimum Grant Maximum Latency Reserved Power Management Capabilities Power Management Capabilities Power Management Control Reserved Default Value 8086h 1132h 0004h 02B0h 02h (see note) 00h 00h 03h 00h 00h 01h 00h 00000008h 00000000h 00h 0000h 0000h 00000000h DCh 00h 00h 01h 00h 00h 00h 0001h 0022h 0000h 00h Access Type RO RO R/W RO RO RO RO RO RO RO RO RO R/W R/W R/WO R/WO RO RO R/W RO RO RO RO RO R/W
Note: See Specification Update document for latest information.
102
Datasheet
82815 GMCH
R
3.6.1.
VID2—Vendor Identification Register (Device 2)
Address Offset: Default Value: Attribute: Size: 00h−01h 8086h Read-Only 16 bits
The VID Register contains the vendor identification number. This 16-bit register combined with the Device Identification Register uniquely identify any PCI device. Writes to this register have no effect.
Bit 15:0 Description Vendor Identification Number. This 16-bit value is assigned to Intel.
3.6.2.
DID2—Device Identification Register (Device 2)
Address Offset: Default Value: Attribute: Size: 02h−03h 1132h Read-Only 16 bits
This 16-bit register combined with the Vendor Identification register uniquely identifies any PCI device. Writes to this register have no effect.
Bit 15:0 Description Device Identification Number. This 16 bit value is assigned to the internal graphics device of the GMCH. 1132h = Device ID for Device 2.
Datasheet
103
82815 GMCH
R
3.6.3.
PCICMD2—PCI Command Register (Device 2)
Address Offset: Default: Access: Size: 04h−05h 0004h Read-Only, Read/Write 16 bits
This 16-bit register provides basic control over the chipset’s ability to respond to PCI cycles. The PCICMD Register in the GMCH disables PCI compliant master accesses to main memory.
15 Reserved (0) 10 9 FB2B (Not Impl) 8 SERR En (Not Impl)
7 Addr/Data Stepping (Not Impl)
6 Parity Error En (Not Impl)
5 VGA Pal Sn (Not Impl)
4 Mem WR & Inval En (Not Impl)
3 Special Cycle En (Not Impl)
2 Bus Master En (Enabled)
1 Mem Acc En
0 I/O Acc En
Bits 15:10 9 8 7 6 Reserved.
Description
Fast Back-to-Back (FB2B)RO. (Not Implemented). Hardwired to 0. SERR# Enable (SERRE) RO. (Not Implemented). Hardwired to 0. Address/Data SteppingRO. (Not Implemented). Hardwired to 0. Parity Error Enable (PERRE) RO. (Not Implemented). Hardwired to 0. Since the GMCH belongs to the category of devices that does not corrupt programs or data in system memory or hard drives, the GMCH ignores any parity error that it detects and continues with normal operation. Video Palette Snooping (VPS) RO. Hardwired to 0. Disables snooping. Memory Write and Invalidate Enable (MWIE) RO. Hardwired to 0. GMCH does not support memory write and invalidate commands. Special Cycle Enable (SCE) RO. Hardwired to 0. GMCH ignores Special cycles. Bus Master Enable (BME) RO. Hardwired to 1 to enable GMCH to function as a PCI compliant master. Memory Access Enable (MAE) R/W. This bit controls the GMCH’s response to memory space accesses. 0 = Disable (default). 1 = Enable.
5 4 3 2 1
0
I/O Access Enable (IOAE) R/W. This bit controls the GMCH’s response to I/O space accesses. 0 = Disable (default). 1 = Enable.
104
Datasheet
82815 GMCH
R
3.6.4.
PCISTS2—PCI Status Register (Device 2)
Address Offset: Default Value: Access: Size: 06h−07h 02B0h Read-Only 16 bits
PCISTS2 reports the occurrence of a PCI compliant master abort and PCI compliant target abort. PCISTS2 also indicates the DEVSEL# timing that has been set by the GMCH hardware.
15 Detected Par Error (HW=0) 14 Sig Sys Error (HW=0) 13 Recog Mast Abort Sta (HW=0) 12 Rec Target Abort Sta (HW=0) 11 Sig Target Abort Sta (HW=0) 10 DEVSEL# Timing (HW=01) 9 8 Data Par Detected (HW=0)
7 FB2B (HW=1)
6 User Def Format (HW=0)
5 66 MHz PCI Cap (HW=1)
4 Cap List (HW=1)
3 Reserved
0
Bits 15 14 13 12 11 10:9
Description Detected Parity Error (DPE) RO. Hardwired to 0. The chipset does not detect parity. Signaled System Error (SSE) RO. Hardwired to 0. The chipset’s graphics device never asserts SERR#. Received Master Abort Status (RMAS) RO. Hardwired to 0. The chipset’s graphics device never gets a Master Abort. Received Target Abort Status (RTAS) RO.. Hardwired to 0. The chipset’s graphics device never gets a Target Abort. Signaled Target Abort Status (STAS). Hardwired to 0. The chipset does not use target abort semantics. DEVSEL# Timing (DEVT) RO. This 2-bit field indicates the timing of the DEVSEL# signal when GMCH responds as a target. 01 = Medium decode device (hardwired).
8 7 6 5 4 3:0
Data Parity Detected (DPD) RO. Hardwired to 0. Since Parity Error Response is hardwired to disabled (and GMCH does not do any parity detection), this bit is not used. Fast Back-to-Back (FB2B). Hardwired to 1. The chipset accepts fast back-to-back when the transactions are not to the same agent. User Defined Format (UDF). Hardwired to 0. 66 MHz PCI Capable (66C). Hardwired to 1. This indicates that the chipset is 66 MHz PCI capable. CAP LISTRO. This bit is set to 1 to indicate that the register at 34h provides an offset into the function’s PCI Configuration Space containing a pointer to the location of the first item in the list. Reserved.
Datasheet
105
82815 GMCH
R
3.6.5.
RID2—Revision Identification Register (Device 2)
Address Offset: Default Value: Access: Size: 08h 02h (see Spec. Update document for latest information.) Read-Only 8 bits
This register contains the revision number of the chipset. These bits are read-only and writes to this register have no effect.
Bits 7:0 Description Revision Identification Number. This is an 8-bit value that indicates the revision identification number for the GMCH. The four MSBs are for process differentiation and the four LSBs indicate stepping.
3.6.6.
PI—Programming Interface Register (Device 2)
Address Offset: Default Value: Access: Size: 09h 00h Read-Only 8 bits
This register contains the device programming interface for the GMCH.
Bits 7:0 Description Programming Interface (PI). Hardwired to 00h. 00h = Display controller.
3.6.7.
SUBC2—Sub-Class Code Register (Device 2)
Address Offset: Default Value: Access: Size: 0Ah 00h Read-Only 8 bits
This register contains the Sub-Class Code for the GMCH Device 2.
Bit 7:0 Description Sub-Class Code (SUBC). This is an 8-bit value that indicates the category of display controller of the GMCH. 00h = VGA compatible device.
106
Datasheet
82815 GMCH
R
3.6.8.
BCC2—Base Class Code Register (Device 2)
Address Offset: Default Value: Access: Size: 0Bh 03h Read-Only 8 bits
This register contains the Base Class Code of the GMCH Function #1.
Bit 7:0 Description Base Class Code (BASEC). This is an 8-bit value that indicates the Base Class Code for GMCH. 03h = Display controller.
3.6.9.
CLS—Cache Line Size Register (Device 2)
Address Offset: Default Value: Access: Size: 0Ch 00h Read-Only 8 bits
The GMCH does not support this register as a PCI slave.
Bits 7:0 Description Cache Line Size (CLS). This field is hardwired to 0s. The GMCH, as a PCI compliant master, does not use the Memory Write and Invalidate command and, in general, does not perform operations based on cache line size.
3.6.10.
MLT2—Master Latency Timer Register (Device 2)
Address Offset: Default Value: Access: Size: 0Dh 00h Read-Only 8 bits
The GMCH does not support the programmability of the master latency timer because it does not perform bursts.
Bits 7:0 Description Master Latency Timer Count Value. Hardwired to 0s.
Datasheet
107
82815 GMCH
R
3.6.11.
HDR2—Header Type Register (Device 2)
Address Offset: Default Value: Access: Size: 0Eh 00h Read-Only 8 bits
This register contains the Header Type of the GMCH .
Bits 7:0 Description Header Type (HTYPE). This is an 8-bit value that indicates the Header Type for the chipset. 00h = Indicating a basic (i.e., single function) configuration space format.
3.6.12.
BIST—BIST Register (Device 2)
Address Offset: Default Value: Access: Size: 0Fh 00h Read-Only 8 bits
This register is used for control and status of Built In Self Test (BIST).
7 BIST Supported (HW=0) 6 Reserved 0
Bits 7 6:0
Description BIST Supported. BIST is not supported. This bit is hardwired to 0. Reserved.
108
Datasheet
82815 GMCH
R
3.6.13.
GMADR—Graphics Memory Range Address Register (Device 2)
Address Offset: Default Value: Access: Size: 10−13h 00000008h Read/Write, Read-Only 32 bits
This register requests allocation for the GMCH graphics memory. The allocation is for either 32 MB or 64 MB of memory space (selected by bit 0 of the Device 0 MISCC Register) and the base address is defined by bits [31:25,24].
31 Memory Base Address 26 25 64 MB Addr. Mask 24 Address Mask (HW=0; 32MB addr range) 16
15 Address Mask (cont) (HW=0; 32MB addr range)
4
3 Prefetch Mem En (HW=1)
2 Memory Type (HW=0; 32MB addr)
1
0 Mem/IO Space (HW=0)
Bit 31:26 25
Description Memory Base AddressR/W. Set by the operating system, these bits correspond to address signals [31:26]. 64 MB Address MaskRO , R/W. 64 MB = If Device 0 MISCC Reg bit 0 = 0, then this bit is read-only with a value of 0, indicating a memory range of 64 MB. 32 MB = If Device 0 MISCC Reg bit 0 = 1, this bit is R/W, indicating a memory range of 32 MB.
24:4 3 2:1 0
Address MaskRO. Hardwired to 0s to indicate 32 MB address range. Prefetchable MemoryRO. Hardwired to 1 to enable prefetching. Memory TypeRO. Hardwired to 0 to indicate 32-bit address. Memory/IO SpaceRO. Hardwired to 0 to indicate memory space.
Datasheet
109
82815 GMCH
R
3.6.14.
MMADR—Memory Mapped Range Address Register (Device 2)
Address Offset: Default Value: Access: Size: 14−17h 00000000h Read/Write, Read-Only 32 bits
This register requests allocation for the GMCH registers and instruction ports. The allocation is for 512 KB and the base address is defined by bits [31:19].
31 Memory Base Address (addr bits [31:19]) 19 18 16
Address Mask (HW=0; 512 KB addr range)
15 Address Mask (cont) (HW=0; 512 KB addr range)
4
3 Prefetch Mem En (HW=0)
2 Memory Type (HW=0; 32 Mb addr)
1
0 Mem/IO Space (HW=0)
Bit 31:19 18:4 3 2:1 0
Description Memory Base AddressR/W. Set by the operating system, these bits correspond to address signals [31:19]. Address MaskRO. Hardwired to 0s to indicate 512 KB address range. Prefetchable MemoryRO. Hardwired to 0 to prevent prefetching. Memory TypeRO. Hardwired to 0s to indicate 32-bit address. Memory / IO SpaceRO. Hardwired to 0 to indicate memory space.
3.6.15.
SVID—Subsystem Vendor Identification Register (Device 2)
Address Offset: Default Value: Access: Size:
Bit 15:0
2C−2Dh 0000h Read/Write-Once 16 bits
Description
Subsystem Vendor ID—R/WO. This value is used to identify the vendor of the subsystem. The default value is 0000h. This field should be programmed by BIOS during boot-up. Once written, this register becomes read-only. This Register can only be cleared by a Reset.
110
Datasheet
82815 GMCH
R
3.6.16.
SID—Subsystem Identification Register (Device 2)
Address Offset: Default Value: Access: Size:
Bit 15:0
2E−2Fh 0000h Read/Write-Once 16 bits
Description
Subsystem ID—R/WO. This value is used to identify a particular subsystem. The default value is 0000h. This field should be programmed by BIOS during boot-up. Once written, this register becomes Read only. This Register can only be cleared by a Reset.
3.6.17.
ROMADR—Video BIOS ROM Base Address Register (Device 2)
Address Offset: Default Value: Access: Size: 30−33h 00000000h Read Only 32 bits
The GMCH does not use a separate BIOS ROM; therefore, this is hardwired to 0s.
31 ROM Base Address (addr bits [31:18]) 18 17 16
Address Mask (HW=0; 256 KB addr range)
15 Address Mask (cont) (HW=0; 256 KB addr range)
11
10 Reserved
1
0 ROM BIOS En (HW=0)
Bit 31:18 17:11 10:1 0 ROM Base AddressRO. Hardwired to 0s.
Description
Address MaskRO. Hardwired to 0s to indicate 256 KB address range. Reserved. Hardwired to 0s. ROM BIOS EnableRO. 0 = ROM not accessible.
3.6.18.
CAPPOINT—Capabilities Pointer Register (Device 2)
Address Offset: Default Value: Access: Size:
Bit 7:0
34h DCh Read Only 8 bits
Description
Pointer to the start of AGP standard register block. Since there is no AGP bus on the GMCH , the value of this field is DCh. DCh = Points to the Power Management Capabilities ID Register
Datasheet
111
82815 GMCH
R
3.6.19.
INTRLINE—Interrupt Line Register (Device 2)
Address Offset: Default Value: Access: Size:
Bit 7:0
3Ch 00h Read/Write 8 bits
Descriptions
Interrupt Connection. Used to communicate interrupt line routing information. POST software writes the routing information into this register as it initializes and configures the system. The value in this register indicates which input of the system interrupt controller that the device’s interrupt pin is connected.
3.6.20.
INTRPIN—Interrupt Pin Register (Device 2)
Address Offset: Default Value: Access: Size:
Bit 7:0
3Dh 01h Read Only 8 bits
Descriptions
Interrupt Pin. As a single function device, the GMCH specifies INTA# as its interrupt pin. 01h = INTA#.
3.6.21.
MINGNT—Minimum Grant Register (Device 2)
Address Offset: Default Value: Access: Size:
Bit 7:0
3Eh 00h Read Only 8 bits
Descriptions
Minimum Grant Value. The GMCH does not burst as a PCI compliant master. (Default=00h).
3.6.22.
MAXLAT—Maximum Latency Register (Device 2)
Address Offset: Default Value: Access: Size:
Bit 7:0
3Fh 00h Read Only 8 bits
Descriptions
Maximum Latency Value. The GMCH has no specific requirements for how often it needs to access the PCI bus. (Default=00h).
112
Datasheet
82815 GMCH
R
3.6.23.
PM_CAPID—Power Management Capabilities ID Register (Device 2)
Address Offset: Default Value: Access: Size:
15 NEXT_PTR
DCh−DDh 0001h Read Only 16 bits
8 7 CAP_ID 0
Bits 15:8 7:0
Description Next Pointer (NEXT_PTR). This contains a pointer to next item in the capabilities list. This the final capability in the list and must be set to 00h. Capability Identificaiton (CAP_ID). SIG defines this ID is 01h for power management.
3.6.24.
PM_CAP—Power Management Capabilities Register (Device 2)
Address Offset: Default Value: Access: Size:
15 PME Support (HW=0)
DEh−DFh 0022h Read Only 16 bits
11 10 D2 (HW=0) 9 D1 (HW=0) 8 Reserved
7 Reserved
6
5 Dev Specific Init (HW=1)
4 Aux Pwr Src (HW=0)
3 PME Clock (HW=0)
2 Version
0
Bits 15:11 10 9 8:6 5 4 3 2:0
Description PME Support. This field indicates the power states in which the GMCH may assert PME#. Hardwired to 0 to indicate that the GMCH does not assert the PME# signal. D2. Hardwired to 0 to indicate D2 power management state is not supported. D1. Hardwired to0 to indicate that D1 power management state is NOT supported. Reserved. Read as 0s. Device Specific Initialization (DSI). Hardwired to 1 to indicate that special initialization of the GMCH is required before generic class device driver is to use it. Auxiliary Power Source. Hardwired to 0. PME Clock. Hardwired to 0 to indicate the GMCH does not support PME# generation. Version. Hardwired to 010b to indicate there are 4 bytes of power management registers implemented and that this device complies with revision 1.1 of the PCI Power Management Interface Specification.
Datasheet
113
82815 GMCH
R
3.6.25.
PM_CS—Power Management Control/Status Register (Device 2)
Address Offset: Default Value: Access: Size:
15 PME Sta (HW=0) 14 13
E0h−E1h 0000h Read/Write 16 bits
12 Data_Select (Reserved) 9 8 PME En
Data Scale (Reserved)
7 Reserved
2
1 PowerState
0
Bits 15 14:13 12:9 8 7:2 1:0
Description PME_Status RO. This bit is 0 to indicate that the GMCH does not support PME# generation from D3 (cold). Data Scale (Reserved) RO. The GMCH does not support data register. This bit always returns 0 when read; write operations have no effect. Data_Select (Reserved) RO. The GMCH does not support data register. This bit always returns 0 when read; write operations have no effect. PME_EnR/W. This bit is 0 to indicate that PME# assertion from D3 (cold) is disabled. Reserved. Always returns 0s when read; write operations have no effect. PowerStateR/W. This field indicates the current power state of the GMCH and can be used to set the GMCH into a new power state. If software attempts to write an unsupported state to this field, write operation must complete normally on the bus; data is discarded and no state change occurs. 00 = D0 01 = D1 (Not supported in the GMCH ) 10 = D2 (Not supported in the GMCH ) 11 = D3
114
Datasheet
82815 GMCH
R
3.7.
Display Cache Interface
The Display Cache (DC) interface control registers are located in Memory Space. This section describes the DC interface registers. These registers are accessed using [MMADR+Offset]. These registers are memory-mapped only.
3.7.1.
DRT—DRAM Row Type
Memory Offset Address: Default value: Access: Size: 3000h 00h Read / write 8 bit
This 8-bit register identifies whether or not the display cache is populated. Memory mapped only.
7 Reserved 1 0 DRAM Populated
Bit 7:1 0 Reserved
Description
DRAM Populated (DP). The bit in this register indicates whether or not the display cache is populated. 0 = No Display Cache 1 = 4 MB Display Cache
Datasheet
115
82815 GMCH
R
3.7.2.
DRAMCL—DRAM Control Low
Memory Offset Address: Default value: Access: Size:
7 Reserved
3001h 17h Read / write 8 bit
5 4 Paging Mode Control 3 RAS-toCAS Override 2 CAS# Latency 1 RAS# Riming 0 RAS# Precharge Timing
Bit 7:5 4 Reserved Paging Mode Control (PMC).
Description
0 = Page Open Mode. In this mode the GMCH memory controller tends to leave pages open. 1 = Page Close Mode. In this mode the GMCH memory controller tends to leave pages closed. 3 RAS-to-CAS Override (RCO). In units of display cache clock periods indicates the RAS#-to-CAS# delay (tRCD). (i.e., row activate command to read/write command) 0 = Determined by CL bit (default) 1=2 2 CAS# Latency (CL). In units of local memory clock periods. Bit 0 1 1 CL 2 3 RAS#-to-CAS# delay (tRCD) 2 3 (default)
RAS# Timing (RT). This bit controls RAS# active to precharge, and refresh to RAS# active delay (in local memory clocks). Bit 0 1 RAS# act. To precharge (tRAS) 5 7 Refresh to RAS# act. (tRC) 8 10 (default)
0
RAS# Precharge Timing (RPT). This bit controls RAS# precharge (in local memory clocks). 0=2 1 = 3 (default)
116
Datasheet
82815 GMCH
R
3.7.3.
DRAMCH—DRAM Control High
Memory Offset Address: Default value: Access: Size:
7 Reserved
3002h 08h Read / write 8 bit
5 4 DRAM Refresh Rate 3 2 Special Mode Select 0
Bit 7:5 4:3 Reserved
Description
DRAM Refresh Rate (DRR). DRAM refresh is controlled using this field. Disabling refresh results in the eventual loss of DRAM data; refresh can be briefly disabled without data loss. The field must be set to normal refresh as soon as possible once DRAM testing is completed. 00 = Refresh Disabled 01 = Refresh Enabled (default) 10 = Reserved 11 = Reserved
2:0
Special Mode Select (SMS). These bits select special SDRAM modes used for testing and initialization. The NOP command must be programmed first before any other command can be issued. 000 = Normal SDRAM mode (Normal, default). 001 = NOP Command Enable (NCE). This state forces cycles to DRAM to generate SDRAM NOP commands. 010 = All Banks Precharge Command Enable (ABPCE). This state forces cycles to DRAM to generate an all banks precharge command. 011 = Mode Register Command Enable (MRCE). This state forces all cycles to DRAM to be converted into MRS commands. The command is driven on the LMA[11:0] lines. LMA[2:0] correspond to the burst length, LMA[3] corresponds to the wrap type, and LMA[6:4] correspond to the latency mode. LMA[11:7] are driven to 00000 by the GMCH, BIOS must select an appropriate host address for each row of memory such that the right commands are generated on the LMA[6:0] lines, taking into account the mapping of host addresses to display cache addresses. 100 = CBR Cycle Enable (CBRCE). This state forces cycles to DRAM to generate SDRAM CBR refresh cycles. 101 = Reserved. 11X = Reserved.
Datasheet
117
82815 GMCH
R
3.8.
Display Cache Detect and Diagnostic Registers
The following registers are used for display cache detection and diagnostics. These registers can be accessed via either I/O space or memory space. The memory space addresses listed are offsets from the base memory address programmed into the MMADR register (Device 2, PCI configuration offset 14h). For each register, the memory-mapped address offset is the same address value as the I/O address.
3.8.1.
GRX—GRX Graphics Controller Index Register
I/O (and Memory Offset) Address: Default: Access: Size:
7 Reserved (0000)
3CEh 0Uh (U=Undefined) Read/Write 8 bits
4 3 Graphics Controller Register Index 0
Bit 7:4 3:0 Reserved. Read as 0s.
Description
Sequencer Register Index. This field selects any one of the graphics controller registers (GR[00:08]) to be accessed via the data port at I/O location 3CFh.
118
Datasheet
82815 GMCH
R
3.8.2.
MSRMiscellaneous Output
I/O (and Memory Offset) Address: Default: Access: Size:
7 Reserved
3C2h W rite; 3CCh Read 00h See Address above 8 bits
2 1 A0000h− BFFFFh Acc En 0 Reserved
Bit 7:2 1 Reserved
Descriptions
A0000−BFFFFh Access Enable. VGA Compatibility bit enables access to the display cache at A0000h−BFFFFh. When disabled, accesses to system memory are blocked in this region (by not asserting DEVSEL#). This bit does not block processor access to the video linear frame buffer at other addresses. 0 = Prevent processor access to the display cache (default). 1 = Allow processor access to display cache.
0
Reserved
3.8.3.
GR06Miscellaneous Register
I/O (and Memory Offset) Address: Default: Access: Size:
7 Reserved
3CFh (Index=06h) 0Uh (U=Undefined) Read/Write 8 bits
4 3 Memory Map Mode 2 1 Reserved 0
Bit 7:4 3:2 Reserved
Description
Memory Map Mode. These 2 bits control the mapping of the VGA frame buffer into the processor address space as follows: 00 = A0000h − BFFFFh 01 = A0000h − AFFFFh 10 = B0000h − B7FFFh 11 = B8000h − BFFFFh Note: This function is both in standard VGA modes and in extended modes that do not provide linear frame buffer accesses.
1:0
Reserved
Datasheet
119
82815 GMCH
R
3.8.4.
GR10Address Mapping
I/O (and Memory Offset) Address: Default: Access: Size:
7 Reserved 5
3CFh (Index=10h) 00h R/W 8 bits
4 Paging to display cache 3 VGA Buffer /Memory Map 2 Packed Mode Enbl 1 Linear Mapping 0 Page Mapping
Bit 7:5 4 Reserved Page to Display Cache Enable. 0 = Page to VGA Buffer. 1 = Page to Display Cache. 3 VGA Buffer/Memory Map Select. 0 = VGA Buffer (default) 1 = Memory Map. 2 Packed Mode Enable. 0 = Disable (default) 1 = Enable 1 Linear Mapping (PCI). 0 = Disable (default) 1 = Enable 0
Description
Page Mapping Enable. This mode allows the mapping of the vga space allocated in main memory (non local video memory) mode or all of local memory space through the A0000:AFFFF window which is a 64 KB page. 0 = Disable (default) 1 = Enable
3.8.5.
GR11Page Selector
I/O (and Memory Offset) Address: Default : Attributes:
Bit 7:0
3CFh (Index=11h) 00h R/W
Description
Page Select. Selects a 64 KB window within the display cache when Page Mapping is enabled to the display cache.
120
Datasheet
82815 GMCH
R
4.
Functional Description
This chapter describes the Graphics and Memory Controller Hub (GMCH) interfaces, and boot sequencing.. The “System Address Map” provides a system-level address memory map and describes the memory space controls provided by the GMCH.
4.1.
System Address Map
An Intel Pentium III processor, Intel Pentium II processor, or Intel CeleronTM processor system based on the GMCH, supports 4 GB of addressable memory space and 64 KB+3 of addressable I/O space. (The P6 bus I/O addressability is 64KB + 3). There is a programmable memory address space under the 1 MB region which can be controlled with programmable attributes of write-only, or read-only. Attribute programming is described in the Configuration Register Description section. This section focuses on how the memory space is partitioned and what these separate memory regions are used for. The I/O address space is explained at the end of this section. The Intel Pentium III processor, Intel Pentium II processor, and Intel CeleronTM processor supports addressing of memory ranges larger than 4 GB. The GMCH Host Bridge claims any access over 4 GB by terminating transaction (without forwarding it to the hub interface). Writes are terminated by dropping the data and for reads the GMCH returns all zeros on the host bus. In the following sections, it is assumed that all of the compatibility memory ranges reside on the hub interface. The exceptions to this rule are the VGA ranges which may be mapped to the internal Graphics Device. Note: The GMCH memory map includes a number of programmable ranges. All of these ranges MUST be unique and NON-OVERLAPPING. There are NO Hardware Interlocks to prevent problems in the case of overlapping ranges. Accesses to overlapped ranges may produce indeterminate results.
Datasheet
121
82815 GMCH
R
4.1.1.
Memory Address Ranges
Figure 4 shows a high-level representation of the system memory address map. Figure 5 provides additional details on mapping specific memory regions as defined and supported by the GMCH.
Figure 4. System Memory Address Map
4 GB PCI Memory Address Range
Local Memory Range
Memory Mapped Range
Top of the Main Memory Main Memory Address Range 0
Independently Programmable NonOverlapping Memory Windows
mem_map_s
Figure 5. Detailed Memory System Address Map
System Memory Space
Extended P6 Memory 4 GB Max TOM
64 GB
AGP Graphics Window Aperture 0FFFFFh PCI Memory Range 512 MB 0F0000h 0EFFFFh Upper BIOS Area (64 KB) 960 KB 1 MB
Lower BIOS Area (64 KB; 16 KB x 4) 0E0000h 0DFFFFh 16 MB Optional ISA Hole 15 MB Main Memory Range 0C0000h 0BFFFFh Optionally mapped to the internal AGP Expansion Card BIOS and Buffer Area (128 KB; 16 KB x 8) 768 KB Std PCI/ISA Video Mem (SMM Mem) 128 KB 640 KB DOS Area (640 KB) 0 MB 000000h 0 KB
mem_map
896 KB
1 MB
DOS Compatibility Memory
640 KB
0A0000h 09FFFFh
122
Datasheet
82815 GMCH
R
4.1.2.
Compatibility Area
This area is divided into the following address regions: • 0–640 KB DOS Area • 640–768 KB Video Buffer Area • 768–896 KB in 16KB sections (total of 8 sections) – Expansion Area • 896–960 KB in 16KB sections (total of 4 sections) – Extended System BIOS Area • 960 KB–1 MB Memory (BIOS Area) – System BIOS Area The GMCH supports all sixteen memory segments of interest in the compatibility area. Thirteen of the memory ranges can be enabled or disabled independently for both read and write cycles.
Table 9. Memory Segments and Their Attributes
Memory Segments 000000h–09FFFFh 0A0000h–0BFFFFh 0C0000h–0C3FFFh 0C4000h–0C7FFFh 0C8000h–0CBFFFh 0CC000h–0CFFFFh 0D0000h–0D3FFFh 0D4000h–0D7FFFh 0D8000h–0DBFFFh 0DC000h–0DFFFFh 0E0000h–0E3FFFh 0E4000h–0E7FFFh 0E8000h–0EBFFFh 0EC000h–0EFFFFh 0F0000h–0FFFFFh Attributes Fixed; always mapped to main DRAM mapped to the hub interface or (AGP or internal graphics) – configurable as SMM space WE RE WE RE WE RE WE RE WE RE WE RE WE RE WE RE WE RE WE RE WE RE WE RE WE RE Comments 0 to 640K: DOS Region Video Buffer (physical DRAM configurable as SMM space) Add-on BIOS Add-on BIOS Add-on BIOS Add-on BIOS Add-on BIOS Add-on BIOS Add-on BIOS Add-on BIOS BIOS Extension BIOS Extension BIOS Extension BIOS Extension BIOS Area
DOS Area (00000h–9FFFh)
The DOS area is 640 KB and is always mapped to the main memory controlled by the GMCH.
Datasheet
123
82815 GMCH
R
Video Buffer Area (A0000h–BFFFFh)
The 128 KB graphics adapter memory region is normally mapped to a legacy video device on the hub interface/PCI (typically VGA controller). This area is not controlled by attribute bits and processor – initiated cycles in this region are forwarded to either the hub interface or the AGP/internal graphics device for termination. This region is also the default region for SMM space. Accesses to this range are directed to either the hub interface or the AGP/internal graphics device based on the configuration. The configuration is specified by: 1. AGP on/off configuration bit 2. AGP off: GMS bits of the SMRAM register in the GMCH Device #0 configuration space. There is additional steering information coming from the Device #2 configuration registers and from some of the VGA registers in the Graphics device. 3. AGP on: PCICMD1 (PCI-PCI Command) and BCTRL (PCI-PCI Bridge Control) registers in Device #1 configuration registers The control is applied for accesses initiated from any of the system interfaces; that is, processor bus, the hub interface, or AGP(if enabled). Note that for hub interface to AGP/PCI accesses, only memory write operations are supported. Any AGP/PCI initiated VGA accesses targeting the GMCH will master abort. For more details, see the descriptions in the configuration registers specified above. The SMRAM Control register controls how SMM accesses to this space are treated.
Monochrome Adapter (MDA) Range (B0000h–B7FFFh)
Legacy support requires the ability to have a second graphics controller (monochrome) in the system. In an AGP system, accesses in the standard VGA range are forwarded to the AGP bus (depending on configuration bits). Since the monochrome adapter may be on the hub interface/PCI (or ISA) bus, the GMCH must decode cycles in the MDA range and forward them to the hub interface. This capability is controlled by a configuration bit (MDA bit – Device 0, BEh). In addition to the memory range B0000h to B7FFFh, the GMCH decodes IO cycles at 3B4h, 3B5h, 3B8h, 3B9h, 3Bah and 3BFh and forwards them to the hub interface bus In an internal graphics system, the GMS bits of the SMRAM register in Device #0, bits in the Device 2 PCICMD2 register and bits from some of the VGA registers control this functionality.
Expansion Area (C0000h–DFFFFh)
This 128 KB ISA Expansion region is divided into eight 16 KB segments. Each segment can be assigned one of four read/write states: read only, write-only, read/write, or disabled. Typically, these blocks are mapped through GMCH and are subtractively decoded to ISA space. Memory that is disabled is not remapped.
Extended System BIOS Area (E0000h–EFFFFh)
This 64 KB area is divided into four 16 KB segments. Each segment can be assigned independent read and write attributes so it can be mapped either to main DRAM or to the hub interface. Typically, this area is used for RAM or ROM. Memory segments that are disabled are not remapped elsewhere.
124
Datasheet
82815 GMCH
R
System BIOS Area (F0000h–FFFFFh)
This area is a single 64 KB segment. This segment can be assigned read and write attributes. It is by default (after reset) read/write disabled and cycles are forwarded to the hub interface. By manipulating the read/write attributes, the GMCH can “shadow” BIOS into the main DRAM. When disabled, this segment is not remapped.
4.1.3.
Extended Memory Area
This memory area covers 100000h (1 MB) to FFFFFFFFh (4 GB-1) address range and it is divided into the following regions: • Main DRAM Memory from 1 MB to the Top of Memory; maximum of 512 MB using 128M technology • PCI Memory space from the Top of Memory to 4 GB with two specific ranges: • APIC Configuration Space from FEC0_0000h (4 GB-20 MB) to FECF_FFFFh and FEE0_0000h to FEEF_FFFFh • High BIOS area from 4 GB to 4 GB–2 MB
Main DRAM Address Range (0010_0000h to Top of Main Memory)
The address range from 1 MB to the top of main memory (TOM) is mapped to main DRAM address range. The Top of memory is limited to 512 MB. All accesses to addresses within this range will be forwarded to the DRAM unless a hole in this range is created.
15 MB–16 MB Hole
A hole can be created at 15 MB–16 MB as controlled by the fixed hole enable (FDHC register) in Device 0 space. Accesses within this hole are forwarded to the hub interface. The range of physical DRAM memory disabled by opening the hole is not remapped to the Top of the memory – that physical DRAM space is not accessible. This 15 MB–16 MB hole is an optionally enabled ISA hole. Video accelerators originally used this hole. It is also used by validation and customer SV teams for some of their test cards. This is why it is being supported. There is no inherent BIOS request for the 15–16 MB hole.
Extended SMRAM Address Range (Top of Main Memory–TSEG)
The HSEG and TSEG SMM transaction address spaces reside in this extended memory area.
HSEG
SMM-mode processor accesses to enabled HSEG are remapped to 000A0000h–000BFFFFh. Non-SMMmode processor accesses to enabled HSEG are considered invalid are terminated immediately on the FSB. The exception to this is non-SMM-mode write-back cycles. They are remapped to SMM space to maintain cache coherency. AGP and hub interface originated cycles to enabled SMM space are not allowed. Physical DRAM behind the HSEG transaction address is not remapped and is not accessible.
Datasheet
125
82815 GMCH
R
TSEG
TSEG can be up to 1 MB and is at the top of memory. SMM-mode processor accesses to enabled TSEG access the physical DRAM at the same address. Non-SMM-mode processor accesses to enabled TSEG are considered invalid and are terminated immediately on the FSB. The exception is non-SMM-mode write-back cycles. They are directed to the physical SMM space to maintain cache coherency. AGP and hub interface originated cycle to enabled SMM space are not allowed. The size of the SMRAM space is determined by the USMM value in the SMRAM register. When the extended SMRAM space is enabled, non-SMM processor accesses and all other accesses in this range are forwarded to the hub interface. When SMM is enabled, the amount of memory available to the system is equal to the amount of physical DRAM minus the value in the TSEG register. Note that there is potential for cache corruption if illegal accesses are requested to TSEG. Originally, TSEG was intended for additional data storage for non-cached solutions. As such, it added protection as direct reads and writes to TSEG are not allowed to occur outside of SMM. However, when the region is enabled as cacheable, this protection can cause problems if improperly used. The reason is that, if any piece of software (including ITP) is to read TSEG outside of SMM, the read can cause corruption of the cached version of the code in the processor and result in a SMM “hang”. Example of Problem Manifestation: 1. SMM handler initialized and SMM code/data is written to TSEG 2. Processor cache emptied of TSEG data sometime later as cache lines are evicted and replaced 3. Rogue application requests illegal memory read to TSEG (illegal because processor is not in SMM) 4. Processor runs memory read cycles to GMCH to perform read from TSEG 5. GMCH realizes processor is NOT in SMM and blocks the reads from targeting actual memory. Instead it runs the cycle down the hub interface, which ICH2 then converts to a PCI cycle. This typically gets master aborted and returns a floating bus (FFFFFFFFh). 6. Processor read cycles complete and FFFFFFFFh is pulled into processor cache lines. 7. Processor thinks it has valid TSEG code/data in its cache, when it really has incorrect data (FFFFFFFFh) 8. Processor runs other system level code, evicting cache lines as needed, but some lines of FFFFFFFFh remain 9. Eventually, an SMI is generated and this puts the processor into SMM and calls for execution of the SMM handler stored in TSEG. 10. Processor begins fetching TSEG and hits a line in its cache read by the rogue application (FFFFFFFFh). 11. This code is corrupted and a “hang” is eminent The result is that the TSEG protection built into the chipset could potentially cause a system to “hang” for cached operations, if not properly used. In fact, an application that only reads from the TSEG region can cause SMRAM corruption by causing the SMM handler to execute bogus code fetched from the PCI bus. An alternative is to not use TSEG chipset features at all when running cached. Simply reserve a piece of system memory at the top of memory region, indicate a lower actual top of memory to the operating system (through E820h/E801h function calls), and use this region as SMRAM. As there is no restriction that this memory cannot be accessed when not in SMM mode, then the GMCH will not block accesses to it. When it is cached, a read to the region (whether performed inside or outside of SMRAM) will return the correct data and this coherency issue is avoided.
126
Datasheet
82815 GMCH
R
PCI Memory Address Range (Top of Main Memory to 4 GB)
The address range from the top of main DRAM to 4 GB (top of physical memory space supported by the GMCH) is normally mapped via the hub interface to PCI. As an internal graphics configuration, there are two exceptions to this rule. Both exception cases are forwarded to the internal graphics device. • The first exception is addresses decoded to the local memory range. • The second exception is addresses decoded to the memory mapped range of the internal graphics device. As an AGP configuration, there are two exceptions to this rule. • Addresses decoded to the AGP memory window defined by the MBASE, MLIMIT, PMBASE, and PMLIMIT registers are mapped to AGP. • Addresses decoded to the graphics aperture range defined by the APBASE and APSIZE registers are mapped to the main DRAM. There are two sub-ranges within the PCI memory address range defined as APIC Configuration Space and High BIOS Address Range. As an internal graphics device, the Local Memory Range and the Memory Mapped Range of the internal Graphics Device MUST NOT overlap with these two ranges. Similarly, as an AGP device, the AGP memory window and Graphics Aperture Window MUST NOT overlap with these two ranges. These ranges are described in detail in the following paragraphs.
Datasheet
127
82815 GMCH
R
APIC Configuration Space (FEC0_0000h –FECF_FFFFh, FEE0_0000h– FEEF_FFFFh)
This range is reserved for APIC configuration space, which includes the default I/O APIC configuration space. The default Local APIC configuration space is FEE0_0000h to FEEF_0FFFh. Processor accesses to the local APIC configuration space do not result in external bus activity since the local APIC configuration space is internal to the processor. However, a MTRR must be programmed to make the local APIC range uncacheable (UC). The local APIC base address in each processor should be relocated to the FEC0_0000h (4 GB – 20 MB) to FECF_FFFFh range so that one MTRR can be programmed to 64 KB for the local and I/O APICs. The I/O APIC(s) usually reside in the I/O Bridge portion (I/O Controller Hub) of the chipset or as a stand-alone component(s). I/O APIC units will be located beginning at the default address FEC0_0000h. The first I/O APIC will be located at FEC0_0000h. Each I/O APIC unit is located at FEC0_x000h where x is I/O APIC unit number 0 through F(hex). This address range will be normally mapped via the hub interface to PCI. Note: There is no provision to support an I/O APIC device on AGP The address range between the APIC configuration space and the High BIOS (FED0_0000h to FFDF_FFFFh) is always mapped via the hub interface to PCI.
High BIOS Area (FFE0_0000h –FFFF_FFFFh)
The top 2 MB of the extended memory region is reserved for system BIOS (High BIOS), extended BIOS for PCI devices, and the A20 alias of the system BIOS. The processor begins execution from the High BIOS after reset. This region is mapped via the hub interface to PCI so that the upper subset of this region aliases to 16 MB–256 MB range. The actual address space required for the BIOS is less than 2 MB but the minimum processor MTRR range for this region is 2 MB so that full 2 MB must be considered. The I/O Controller Hub supports a maximum of 1 MB in the High BIOS range.
4.1.3.1.
System Management Mode (SMM) Memory Range
The GMCH supports the use of main memory as System Management RAM (SMRAM) enabling the use of System Management Mode (SMM). The GMCH supports three SMM options: Compatible SMRAM (AB segment enabled), High Segment (HSEG), and Top of Memory Segment (TSEG). System Management RAM (SMRAM) space provides a memory area that is available for the SMI handler’s code and data storage. This memory resource is normally hidden from the operating system so that the processor has immediate access to this memory space upon entry to SMM. The GMCH provides three SMRAM options: • • • Below 1 MB option that supports compatible SMI handlers. Above 1 MB option that allows new SMI handlers to execute with write-back cacheable SMRAM. Optional larger write-back cacheable T_SEG area of either 512 KB or 1MB in size above 1 MB that is reserved from the highest area in system DRAM memory. The above 1 MB solutions require changes to compatible SMRAM handler’s code to properly execute above 1 MB.
Refer to the Power Management section for more details on SMRAM support. Note: The hub interface and AGP masters are not allowed to access the SMM space. This must be insured even for the GTLB translation.
128
Datasheet
82815 GMCH
R
4.2.
Memory Shadowing
Any block of memory that can be designated as read only or write-only can be “shadowed” into GMCH DRAM memory. Typically, this is done to allow ROM code to execute more rapidly out of main DRAM. ROM is used as a read-only during the copy process while DRAM at the same time is designated writeonly. After copying, the DRAM is designated read-only so that ROM is shadowed. Processor bus transactions are routed accordingly.
4.3.
I/O Address Space
• The GMCH never responds to I/O cycles initiated on AGP. • The GMCH does not support the existence of any other I/O devices other than itself on the processor bus. The GMCH generates either hub interface or AGP/PCI (if enabled) bus cycles for all processor I/O accesses. If internal graphics is enabled, the GMCH routes the access to hub interface or legacy I/O registers supported by the internal graphics device. The GMCH contains two internal registers in the processor I/O space, Configuration Address Register (CONF_ADDR) and the Configuration Data Register (CONF_DATA). These locations are used to implement PCI configuration space access mechanism and as described in this document. • The processor allows 64K+3 bytes to be addressed within the I/O space. The GMCH propagates the processor I/O address without any translation on to the destination bus and, therefore, provides addressability for 64K+3 byte locations. Note that the upper 3 locations can be accessed only during I/O address wrap-around when processor bus A16# address signal is asserted. A16# is asserted on the processor bus when an I/O access is made to 4 bytes from address 0FFFDh, 0FFFEh, or 0FFFFh. A16# is also asserted when an I/O access is made to 2 bytes from address 0FFFFh. • The I/O accesses, other than ones used for PCI configuration space access or ones that target the internal graphics device (or AGP/PCI) are forwarded to the hub interface. The GMCH will not post I/O write cycles to IDE. The PCICMD1 or PCICMD2 register can disable the routing of I/O cycles to the AGP. • The GMCH never responds to I/O cycles initiated on AGP.
4.3.1.
GMCH Decode Rules and Cross-Bridge Address Mapping
The GMCH’s address map applies globally to accesses arriving on any of the three interfaces (i.e., Host bus, hub interface or from the internal graphics device).
Datasheet
129
82815 GMCH
R
4.3.2.
Address Decode Rules
The GMCH accepts all memory read and write accesses from the hub interface to both system memory and graphics memory. The hub interface accesses that fall elsewhere within the PCI memory range will not be accepted. The GMCH never responds to hub interface initiated I/O read or write cycles. The GMCH accepts accesses from the hub interface to the following address ranges: • All memory read and write accesses to main DRAM including PAM region (except SMM space) • All memory read/write accesses to the graphics aperture (DRAM) defined by APBASE and APSIZE. • All hub interface memory write accesses to AGP memory range defined by MBASE, MLIMIT, PMBASE, and PMLIMIT. • Memory writes to VGA range on AGP, if enabled. The hub interface memory accesses that fall elsewhere within the memory range are considered invalid and will be remapped to a translated memory address, snooped on the host bus, and dispatched to DRAM. Reads will return all 1s with Master Abort completion. Writes will have byte enables deasserted and will terminate with Master Abort, if completion is required. I/O cycles will not be accepted. They are terminated with Master Abort completion packets.
The Hub Interface Accesses to GMCH that Cross Device Boundaries
The hub interface accesses are limited to 256 bytes but have no restrictions on crossing address boundaries. A single hub interface request may, therefore, span device boundaries (AGP, DRAM) or cross from valid addresses to invalid addresses (or vica versa). The GMCH does not support transactions that cross device boundaries. For reads and for writes requiring completion, the GMCH provides separate completion status for each naturally-aligned 32 or 64 byte block. If the starting address of a transaction hits a valid address, the portion of a request that hits that target device (AGP or DRAM) will complete normally. The remaining portion of the access that crosses a device boundary (targets a different device than that of the starting address) or hits an invalid address will be remapped to memory address 0h, snooped on the host bus, and dispatched to DRAM. Reads will return all 1s with Master Abort completion. Writes will have byte enables deasserted and will terminate with Master Abort if completion is required. If the starting address of a transaction hits an invalid address, the entire transaction will be remapped to memory address 0h, snooped on the host bus, and dispatched to DRAM. Reads will return all 1s with Master Abort completion. Writes will have byte enables deasserted and will terminate with Master Abort if completion is required.
130
Datasheet
82815 GMCH
R
4.3.2.1.
AGP Interface Decode Rules
Cycles Initiated Using PCI Protocol
The GMCH does not support any AGP/PCI access targeting the hub interface. The GMCH will claim AGP/PCI initiated memory read and write transactions decoded to the main DRAM range or the graphics Aperture range. All other memory read and write requests will be master-aborted by the AGP/PCI initiator as a consequence of the GMCH not responding to a transaction. Under certain conditions, the GMCH restricts access to the DOS compatibility ranges governed by the PAM registers by distinguishing access type and destination bus. The GMCH accepts AGP/PCI write transactions to the compatibility ranges if the PAM designates DRAM as write-able. If accesses to a range are not write enabled by the PAM, the GMCH does not respond and the cycle results in a masterabort. AGP/PCI read transactions to the compatibility ranges are accepted if the PAM designates DRAM as readable. If accesses to a range are not read enabled by the PAM, the GMCH does not respond and the cycle will result in a master-abort. If agent on AGP/PCI issues an I/O or PCI Special Cycle transaction, the GMCH does not respond and cycle results in a master-abort. The GMCH does not accept PCI configuration cycles to the internal GMCH devices.
Cycles Initiated Using AGP Protocol
All cycles must reference main memory—main DRAM address range (excluding PAM) or graphics aperture range (also physically mapped within DRAM but using different address range). AGP accesses to the PAM region from 640 KB –to- 1 MB are not allowed. AGP accesses to SMM space are not allowed. AGP-initiated cycles that target DRAM are not snooped on the host bus, even if they fall outside of the AGP aperture range. If a cycle is outside of a valid main memory range, then it will terminate as follows: • Reads: Remap to memory address 0h, return data from address 0h, and set the IAAF error flag. • Writes: Remapped to memory address 0h with byte enables deasserted (effectively dropped “on the floor”) and set the IAAF error flag.
AGP Accesses to GMCH that CrosbvDevice Boundaries
For FRAME# accesses, when an AGP or PCI master gets disconnected, it will resume at the new address that allows the cycle to be routed to or claimed by the new target. Therefore, accesses should be disconnected by the target on potential device boundaries. The GMCH disconnects AGP/PCI transactions on 4 KB boundaries. AGP PIPE# and SBA accesses are limited to 256 bytes and must hit DRAM. AGP accesses are dispatched to DRAM on naturally aligned 32-byte block boundaries. The portion of the request that hits a valid address completes normally. The portion of a read access that hits an invalid address is remapped to address 0h, returns data from address 0h, and sets the IAAF error flag. The portion of a write access that hits an invalid address is remapped to memory address 0h with byte enables deasserted (effectively dropped “on the floor”) and set the IAAF error flag.
Datasheet
131
82815 GMCH
R
4.3.2.2.
Legacy VGA Ranges
The legacy VGA memory range A0000h–BFFFFh is mapped either to the hub interface or to AGP/PCI1 depending on the programming of the VGA Enable bit in the BCTRL configuration register in GMCH Device #1 configuration space, and the MDAP bit in the GMCHCFG configuration register in Device #0 configuration space. The same register controls mapping VGA I/O address ranges. The VGA I/O range is defined as addresses where A[9:0] are in the ranges 3B0h to 3BBh and 3C0h to 3DFh (inclusive of ISA address aliases: A[15:10] are not decoded). The function and interaction of these two bits is described below: MDA Present (MDAP): This bit works with the VGA Enable bit in the BCTRL register of device 1 to control the routing of processor-initiated transactions targeting MDA compatible I/O and memory address ranges. This bit should not be set when the VGA Enable bit is not set. If the VGA enable bit is set, accesses to IO address range x3BCh–x3BFh are forwarded to the hub interface. If the VGA enable bit is not set, I/O address range accesses x3BCh–x3BFh are treated like other I/O accesses (the cycles are forwarded to AGP if the address is within IOBASE and IOLIMIT and ISA enable bit is not set); otherwise, they are forwarded to the hub interface. MDA resources are defined as the following: Memory: I/O: 0B0000h–0B7FFFh 3B4h, 3B5h, 3B8h, 3B9h, 3BAh, 3BFh, (including ISA address aliases, A[15:10] are not used in decode)
Any I/O reference that includes the I/O locations listed above, or their aliases, are forwarded to the hub interface, even if the reference includes I/O locations not listed above. VGA Enable: Controls the routing of processor-initiated transactions targeting VGA compatible I/O and memory address ranges. When this bit is set, the GMCH forwards the following processor accesses to AGP: • Memory accesses in the range 0A0000h to 0BFFFFh • I/O addresses where A[9:0] are in the ranges 3B0h to 3BBh and 3C0h to 3DFh (inclusive of ISA address aliases: A[15:10] are not decoded) When this bit is set , forwarding of these accesses issued by the processor is independent of the I/O address and memory address ranges defined by the previously defined Base and Limit registers. Forwarding of these accesses is also independent of the settings of bit 2 (ISA Enable) of BCTRL if this bit is 1. If the VGA enable bit is set, accesses to I/O address range x3BCh–x3BFh are forwarded to the hub interface. If the VGA enable bit is not set, I/O address range accesses x3BCh–x3BFh are treated like other I/O accesses (the cycles are forwarded to AGP, if the address is within IOBASE and IOLIMIT and ISA enable bit is not set); otherwise, they are forwarded to the hub interface. If this bit is 0 (default), VGA compatible memory and I/O range accesses are not forwarded to AGP; rather, they are mapped to the hub interface, unless they are mapped to AGP via I/O and memory range registers defined above (IOBASE, IOLIMIT, MBASE, MLIMIT, PMBASE, PMLIMIT). The following table shows the behavior for all combinations of MDA and VGA:
VGA 0 0 1 1 MDA 0 1 0 1 Behavior All references to MDA and VGA go to the hub interface Illegal combination (DO NOT USE) All references to VGA Go To AGP/PCI. MDA-only references (I/O Address 3BFh and aliases) will go to the hub interface. VGA references go to AGP/PCI; MDA references go to the hub interface.
132
Datasheet
82815 GMCH
R
4.4.
Host Interface
The host interface of the GMCH is optimized to support the Intel Pentium III processor, Intel Pentium II processor, and Intel CeleronTM processor. The GMCH implements the host address, control, and data bus interfaces within a single device. The GMCH supports a 4-deep in-order queue (i.e., supports pipelining of up to 4 outstanding transaction requests on the host bus) . Host bus addresses are decoded by the GMCH for accesses to system memory, PCI memory ane PCI I/O (via hub interface), PCI configuration space, and graphics memory. The GMCH takes advantage of the pipelined addressing capability of the processor to improve the overall system performance. The GMCH supports the 370-pin socket processor connector.
4.4.1.
Host Bus Device Support
The GMCH recognizes and supports a large subset of the transaction types that are defined for the Intel Pentium III processor, Intel Pentium II processor, or Intel CeleronTM processor bus interface. However, each of these transaction types have a multitude of response types, some of which are not supported by this controller. All transactions are processed in the order that they are received on the processor bus.
Table 10. Summay of Transactions Supported By GMCH
Transaction Deferred Reply Reserved Interrupt Acknowledge Special Transactions Reserved Reserved Branch Trace Message Reserved Reserved Reserved I/O Read REQa[4:0]# 00000 00001 01000 01000 01000 01000 01001 01001 01001 01001 10000 REQb[4:0]# XXXXX XXXXX 00000 00001 0001x 001xx 00000 00001 0001x 001xx 0 0 x LEN# GMCH Support The GMCH will initiate a deferred reply request for a previously deferred transaction. Reserved Interrupt acknowledge cycles are forwarded to the hub interface. See separate table in special cycles section. Reserved Reserved The GMCH will terminate a branch trace message without latching data. Reserved Reserved Reserved I/O read cycles are forwarded to hub interface. I/O cycles that are in the GMCH configuration space are not forwarded to the hub interface. I/O write cycles are forwarded to hub interface. I/O cycles that are in the GMCH configuration space are not forwarded to the hub interface. Reserved Host initiated memory read cycles are forwarded to DRAM or the hub interface. Reserved
I/O Write
10001
0 0 x LEN#
Reserved Memory Read & Invalidate Reserved
1100x 00010 00011
00xxx 0 0 x LEN# 0 0 x LEN#
Datasheet
133
82815 GMCH
R
Transaction Memory Code Read Memory Data Read Memory Write (no retry) Memory Write (can be retried)
REQa[4:0]# 00100 00110 00101 00111
REQb[4:0]# 0 0 x LEN# 0 0 x LEN# 0 0 x LEN# 0 0 x LEN#
GMCH Support Memory code read cycles are forwarded to DRAM or the hub interface. Host-initiated memory read cycles are forwarded to DRAM or the hub interface. This memory write is a writeback cycle and cannot be retried. The GMCH forwards the write to DRAM. The standard memory write cycle is forwarded to DRAM or the hub interface.
NOTES: 1. For Memory cycles, REQa[4:3]# = ASZ#. GMCH only supports ASZ# = 00 (32 bit address). 2. REQb[4:3]# = DSZ#. DSZ# = 00 (64 bit data bus size). 3. LEN# = data transfer length as follows: LEN# Data length 00