## Permedia3® Reference Guide ## PROPRIETARY AND CONFIDENTIAL INFORMATION 3Dlabs® # Permedia3® Reference Guide<sup>TM</sup> PROPRIETARY AND CONFIDENTIAL INFORMATION **Issue 8** #### **Proprietary Notice** The material in this document is the intellectual property of **3D***labs*. It is provided solely for information. You may not reproduce this document in whole or in part by any means. While every care has been taken in the preparation of this document, **3D***labs* accepts no liability for any consequences of its use. Our products are under continual improvement and we reserve the right to change their specification without notice. **3D***labs* may not produce printed versions of each issue of this document. The latest version will be available from the **3D***labs* web site. **3D***labs* products and technology are protected by a number of worldwide patents. Unlicensed use of any information contained herein may infringe one or more of these patents and may violate the appropriate patent laws and conventions. **3D***labs* is the worldwide trading name of **3D***labs* Inc. Ltd. **3D***labs*, GLINT and PERMEDIA are registered trademarks of **3D***labs* Inc. Ltd. Microsoft, Windows and Direct3D are either registered trademarks or trademarks of Microsoft Corp. in the United States and/or other countries. OpenGL is a registered trademark of Silicon Graphics, Inc. All other trademarks are acknowledged and recognized. © Copyright **3D***labs* Inc. Ltd. 1999. All rights reserved worldwide. Email: info@3dlabs.com Web: http://www.3dlabs.com **3D***labs* Ltd. Meadlake Place Thorpe Lea Road, Egham Surrey, TW20 8HE United Kingdom Tel: +44 (0) 1784 470555 Fax: +44 (0) 1784 470699 **3D**labs K.K Shiroyama JT Mori Bldg 16F 40301 Toranomon Minato-ku, Tokyo, 105, Japan Tel: +81-3-5403-4653 Fax: +91-3-5403-4646 **3D**labs Inc. 480 Potrero Avenue Sunnyvale, CA 94086, United States Tel: (408) 530-4700 Fax: (408) 530-4701 ### **Change History** | Document | Issue | Date | Change | |----------|-------|----------------------|-----------------------------------------------------------------------------------------------------------| | 157.2.0 | 1 | 19 October 1998 | Creation | | 157.2.0 | 2 | 22 November 98 | Engineering updates throughout, format corrections | | 157.2.0 | 3 | 10 March 1999 | Engineering updates throughout, format corrections | | 157.2.0 | 4 | 10 April 1999 | Engineering updates, remove chap. 11 Electrical. | | 157.2.0 | 5 | 10 June 1999 | Minor updates, reinstate chap. 12 Electrical, add<br>FBData, FBSourceData,<br>TextureCacheReplacementMode | | 157.2.0 | 6 | 15 September<br>1999 | PCIPIlStatus Offset and PostScale reset value corrected, typographical errors, display resolutions | | 157.2.0 | 7 | 02 February 2000 | Download Address, download data replaced; corrected FBSourceReadBufferOffset | | 157.2.0 | 8 | 15 April 2000 | Added unusued terminations to Pinlist, power-up sequence to Reset. | ### **Table of Contents** | AGP/PCI Interface 1-3 Unified 2D/3D/Video Integrated Graphics Processor 1-4 Memory Interface 1-4 SVGA 1-5 RAMDAC 1-7 Video Overlay 1-7 DMA1DMA3 1-8 Video Streams 1-8 ROM support 1-8 | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Address Maps and Regions 2-1 PCI Configuration Region 2-1 Region Zero Address Map 2-3 PCI Address Regions 2-4 | | Video Unit and RAMDAC 3-1 Display Timing Values 3-1 | | Hardware Registers 4-1 PCI Configuration Region (0x00-0x30) 4-2 Region 0 Control Status (0x000-0x02FF) 4-20 Region 0 Bypass Controls (0x0300-0x03FF) 4-36 Region 0 Memory Control (0x1000-0x1FFF) 4-47 Region 0 GP FIFO (0x2000-0x2FFF) 4-52 Region 0 Video Control (0x3000-0x3FFF) 4-52 Region 0 RAMDAC 4-67 Direct RAMDAC Registers (0x4000-0x4FFF) 4-67 Indirect RAMDAC Registers (0x200-0xFFF) 4-69 Region 0 Video Stream Processing (0x5000-0x5FFF) 4-97 | | | | | Region 0 VGA Control (0x6000-0x6FFF)4-117Region 0 Texture Data FIFO (0x7000-0x7FFF)4-128Region 3 Indirect Addressing4-128 | |---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | Graphics Registers5-1 | | 6 | Register Cross Reference6-1Registers Alphabetically Sorted6-1Registers Sorted by Offset6-20 | | 7 | Package Diagrams7-1 | | 8 | Pin Assignment8-7Pinlist by Number8-2Pinlist by Name8-18 | | 9 | Memory System9-6System Parameters9-2Addressing9-2Functionality and Optimizations9-5Timing and Mode9-6Example Parameter Values9-8100 MHz/Samsung KM4132G271A-10 SGRAM /total<br>SGRAM 12MB9-9125MHz/SIEMENS9-10125MHz /MICRON9-11Timing Diagrams9-12Single Read with Precharge9-12Multiple Reads to Same Bank9-13Single Write with Precharge9-14Multiple Writes to Same Bank9-15Refresh Followed by Access9-16Multiple Reads From Different Banks9-16Multiple Reads From Different Banks9-16Multiple Reads From Different Banks9-16Mask Load Followed by Masked Write9-20Read Followed by Write9-20Read Followed by Write9-20 | | Read Followed by PreCharge | 9-22 | |-------------------------------|---------| | 10 Reset Controls | 10-1 | | 11 Thermal Characteristics | 11-1 | | Device Characteristics | 11-1 | | Thermal Model | 11-1 | | Cooling | 11-2 | | Operation with Heatsink | 11-2 | | Heatsink Attachment | 11-3 | | Preferred Attachment Method | 11-3 | | Alternative Attachment Method | 11-3 | | 12 Electrical Characteristics | 12-1 | | 13 Index | INDEX-1 | ## **List of Figures** | Figure 1-1 | Chip Level Block Diagram | 1-3 | |-------------|----------------------------------------------------------------|------| | Figure 2-1 | PCI Configuration Region | 2-2 | | Figure 7-1 | Package Diagram (Bottom View) | 7-1 | | Figure 7-2 | Package Diagram (Top View) | 7-2 | | Figure 8-1 | Package Diagram (Bottom View) | 8-1 | | Figure 9-1 | Organization of memory devices | 9-1 | | Figure 9-2 | Single Read with Precharge @ CL = 2, PTA = 2, ATC = 1 | 9-11 | | Figure 9-3 | Multiple Reads to Same Bank @ $CL = 2$ , $PTA = 2$ , $ATC = 1$ | 9-12 | | Figure 9-4 | Single Write with Precharge @ PTA = 2, ATC = 1 | 9-13 | | Figure 9-5 | Multiple Writes to Same Bank @ PTA = 2, ATC = 1 | 9-14 | | Figure 9-6 | Refresh Followed by Access @ RC = 4, PTA = 2, ATC = 1 | 9-15 | | Figure 9-7 | Multiple Reads From Different Banks @ TurnOn = 0, | | | | CL = 3 | 9-16 | | Figure 9-8 | Multiple Reads From Different Banks @ TurnOn = 1, | | | | CL = 3 | 9-17 | | Figure 9-9 | RAS Minimum Access Timing @ ATP = 4 | 9-18 | | Figure 9-10 | Mask Load Followed by Masked Write @ RL = 1 | 9-19 | | Figure 9-11 | Read Followed by Write @ TurnOff = 1, CL = 2 | 9-20 | | Figure 9-12 | Read Followed by PreCharge @ NoPrechargeOpt = 0 , | | | | CL = 3 | 9-21 | | Figure 9-13 | Read Followed by PreCharge @ NoPrechargeOpt = 1, | | | | CI = 3 | 9-22 | vi ## **List of Tables** | Table 1-1 | Permedia 3 Enhancement Summary | 1-1 | |-------------------|------------------------------------------------|------| | Table 1-2 | VESA VBE Graphics Modes | 1-6 | | Table 1-3 | VESA VBE Text Modes | 1-7 | | Table 2-1 | Region Zero Address Map | 2-3 | | Table 2-2 | Permedia 3 PCI Address Regions | 2-4 | | Table 3-1 | Timing Values for 640x480 16 BPP 75Hz | 3-1 | | Table 3-2 | Timing Values for 800x600 32 BPP 75Hz | 3-1 | | Table 8-1 | Pinlist by Number | 8-2 | | Table 8-2 | Pinlist by Name | 8-18 | | Table 9-1 | 100 MHz/Samsung KM4132G271A-10 SGRAM /total | | | | SGRAM 12MBz | 9-8 | | Table 9-2 | 125MHz/Siemens HYB 39S16320-7 SGRAM / total | | | | SGRAM 16MB | 9-9 | | Table 9-3 | 125MHz/MICRON MT48LC1M16A1-8A SDRAM/total 16MB | 9-10 | | Table 10-1 | Reset Signal Pins | 10-1 | | <b>Table 10-2</b> | Hard Configuration Pin | 10-2 | 1 #### **Functional Overview** #### 1.1 Introduction PERMEDIA 3 is a high performance PCI/AGP graphics processor that balances high quality 3D polygon and textured graphics acceleration, windows acceleration and state-of-the-art MPEG1/MPEG2 playback with a fast integrated SVGA core, integrated RAMDAC and video ports. PERMEDIA 3 offers significant advances over earlier members of the PERMEDIA product family in both raw performance and functionality. Specific enhancements include: Table 1-1 Permedia 3 Enhancement Summary | Memory Interface and Core | | | | | |--------------------------------------------------------|-----|--|--|--| | Memory bus width (bits) | 128 | | | | | Core clock speed (MHz) - Provisional | 125 | | | | | Max. memory (MB) | 32 | | | | | AGP | 2x | | | | | RAMDAC speed (MHz) | 270 | | | | | 3D | | | | | | Max. Z-buffer depth (bits) | 32 | | | | | Non-Linear 16 or 24-bit Z-buffer (Direct3D and OpenGL) | V | | | | | W-Buffer Emulation with Non-Linear Z-buffer (Direct3D) | V | | | | | 3D (cont'd) | | | | | |-----------------------------------------------|------------|--|--|--| | Texture read units | 2 | | | | | Texture compositing units | ✓ | | | | | Single-pass dual texturing | V | | | | | Single-pass bump mapping with surface texture | V | | | | | Hardware texture paging | V | | | | | Mip mapping (single pass) | Tri-linear | | | | | Destination Alpha | V | | | | | Supports all OpenGL and Direct3D blend modes | V | | | | | Native support for D3D vertex formats | V | | | | | OpenGL | 1.2 | | | | | Fog table | V | | | | | Full hardware edge anti-aliasing | V | | | | | Video/DVD | | | | | | Hardware video overlay | V | | | | | Hardware scaling and filtering | V | | | | | MPEG Motion compensation | V | | | | | Memory to DVD accelerator DMA | V | | | | | Flat panel LCD support | V | | | | | Software | | | | | | SoftImage Compliant | V | | | | #### 1.2 Functional Blocks The major functional blocks are shown in Figure 1-1. SGRAM / SDRAM Memory Interface Unit BIOS ROM Video Overlav General Purpose Bus Digital Unified Video Video 2D, 3D, and Video Digital Stream Encoder Data Out Graphics Processor 270MHz Interface Port RAMDAC Transmitter DDC2AB Block Stereo 4 LCD Pipeline Set-up Processor DMA 1 PCI / AGP Interface PCI / AGP Bus Connector Figure 1-1 Chip Level Block Diagram SVGA DMA 2 #### 1.2.1 AGP/PCI Interface The PCI interface conforms to the PCI Local Bus standard Revision 2.1. PERMEDIA 3 is a PCI Local Bus Target, a PCI Local Bus Read Master, and a PCILocal Bus Write Master. It is also an AGP read master with support for pipe lined reads and sideband addressing. The PCI interface has an input FIFO for passing data to the Graphics Core, and an output FIFO for buffering up data to be read from the Graphics Core. The input FIFO is 256 words deep, the output FIFO is 8 words deep. A DMA controller is provided in the PCI interface to allow PERMEDIA 3 to read data directly into the Graphics Core input FIFO or directly out of the output FIFO. AGP 2X is Intel's high performance, component level interconnect targeted at 3D display applications, which uses a 66MHz PCI specification as an operation baseline and provides three significant performance extension to the PCI specification. The specification for PERMEDIA 3's AGP implementation is: - 133 MHz transfer rate (528 Mbytes/s) - DMA and execute mode support - Sideband addressing Implementing these features enables PERMEDIA 3 to achieve 528 Mbytes per second bandwidth from the host for instructions, textures, video data (limited by the host system throughput). The add-in slot defined for AGP uses a connector body, which is not compatible with the PCI connector, therefore boards designed for use in an AGP slot are not mechanically interchangeable with PCI boards. #### 1.2.2 Unified 2D/3D/Video Integrated Graphics Processor The graphics core in PERMEDIA 3 accelerates the key operations for 3D and 2D applications. For further information on the functionality of the graphics processor (GP), refer to the *PERMEDIA 3 Programmer's Manual* and chapter 5, Graphics Registers, in this manual. #### 1.2.3 Memory Interface The local memory is used to store color, depth, stencil, and texture data. For more information on the different data types and usage refer to Chapter 9 - Memory System. 1-5 The memory is organized as 1 to 4 blocks (blocks 0-3) of SGRAM or SDRAM. The memory interface is 128 bits wide with control lines for 4 blocks of memories (0-3). Block zero must always be fitted as the SVGA uses this area for local storage. Any other combination of banks may be fitted, but for contiguous memory banks should be added from 1 to 3. PERMEDIA 3 will make use of special SGRAM features including block fill and write-per-bit masking. SDRAM may be used in place of SGRAM if it is identical to SGRAM except for missing block write and write per bit masks. #### 1.2.4 SVGA and Display Resolutions The on-chip SVGA unit is register level compatible with standard VGA devices and requires no software emulation. It natively supports all standard VGA modes and certain VESA VBE extended modes. The standard VESA VBE extended video modes shown below are supported. Those not supportable by the SVGA unit may be supported using the Graphics Processor. Resolution constraints are driver and memory dependant: 1920x1200 is currently supported, but the limits for a 32MByte framebuffer are for example 2048x1200 at 32bit colors, 32bit Z or 2048x1536 at 32bit colors, 16bit Z. At 16bit color, 16bit Z it should be able to display 2400x2400, but this is untested. Table 1-2 VESA VBE Graphics Modes | Mode<br>(hex) | Pixels | Colors | Window-<br>ed | Lin-<br>ear | Support-<br>able in<br>SVGA | Support-<br>able in<br>GP | |---------------|-----------|------------------|---------------|-------------|-----------------------------|---------------------------| | 0x100 | 640x400 | 256 | ✓ | ✓ | ✓ | 1 | | 0x101 | 640x480 | 256 | ✓ | ✓ | ✓ | 1 | | 0x102 | 800x600 | 16 | ✓ | X | ✓ | X | | 0x103 | 800x600 | 256 | ✓ | ✓ | X | 1 | | 0x104 | 1024x768 | 16 | ✓ | X | ✓ | X | | 0x105 | 1024x768 | 256 | ✓ | ✓ | X | 1 | | 0x106 | 1280x1024 | 16 | ✓ | X | ✓ | X | | 0x107 | 1280x1024 | 256 | 1 | 1 | X | 1 | | 0x109 | 320x200 | 32K<br>(5:5:5:1) | ✓ | 1 | X | ✓ | | 0x10D | 320x200 | 64K (5:6:5) | 1 | 1 | X | 1 | | 0x10F | 320x200 | 16.8M<br>(8:8:8) | 1 | 1 | × | 1 | | 0x110 | 640x480 | 32K<br>(5:5:5:1) | 1 | 1 | × | 1 | | 0x111 | 640x480 | 64K (5:6:5) | 1 | 1 | X | 1 | | 0x112 | 640x480 | 16.8M<br>(8:8:8) | ✓ | 1 | X | ✓ | | 0x113 | 800x600 | 32K<br>(5:5:5:1) | ✓ | 1 | X | ✓ | | 0x114 | 800x600 | 64K (5:6:5) | ✓ | 1 | X | 1 | | 0x115 | 800x600 | 16.8M<br>(8:8:8) | 1 | 1 | × | 1 | | 0x116 | 1024x768 | 32K<br>(5:5:5:1) | 1 | 1 | × | 1 | | 0x117 | 1024x768 | 64K (5:6:5) | 1 | ✓ | X | 1 | | 0x118 | 1024x768 | 16.8M<br>(8:8:8) | 1 | 1 | × | 1 | | 0x119 | 1280x1024 | 32K<br>(5:5:5:1) | 1 | 1 | × | 1 | | 0x11A | 1280x1024 | 64K (5:6:5) | 1 | 1 | X | 1 | | 0x11B | 1280x1024 | 16.8M<br>(8:8:8) | 1 | 1 | × | 1 | The following VESA VBE text modes are supportable in the SVGA: **Table 1-3 VESA VBE Text Modes** | Mode (hex) | Characters (col/row) | |------------|----------------------| | 0x108 | 80x60 | | 0x109 | 132x25 | | 0x10A | 132x43 | | 0x10B | 132x50 | | 0x10C | 132x60 | PERMEDIA 3 allows VESA bankswitching to be done through the bypass to enable additional VESA mode support. ModeX is also supported. #### 1.2.5 **RAMDAC** PERMEDIA 3 incorporates a high performance 270MHz RAMDAC. Its characteristics include a high resolution 270 MHz 128-bit RAMDAC. It supports screen resolutions up to 1600x1200 with refresh rates of 96Hz or 1920x1080 with refresh rates of 90Hz. It supports packed pixel formats, with color depths of 8, 16, and 32 bits per pixel. It has dot-clock phase locked loops (PLLs) and triple 8-bit D/A converters. The RAMDAC contains a 64x64x2 bit cursor array to support a 2, 4, or 16 color hardware cursor with cursor shapes cache. #### 1.2.6 Video Overlay The video overlay is used to display incoming video data on screen. the overlay selection is based on a transparent color, the overlay key, which can be any RGB color or alpha value. Optionally, the overlay can be blended with the main image by using a 2-bit blend factor. A filter process supports zooming and shrinking at any rate. It combines four pixels into one by using bilinear filtering to achieve best results. Furthermore the filtered output is optionally converted from YUV to RGB color space format. #### 1.2.7 DMA1..DMA3 - 1.2.7.1 DMA1 Controller System to Graphics Core and Graphics Core to System - Autonomous Setup-Fetch parallelism - No Wait State maximum transfer rate - Programable Block Size large DMA buffers - Separate DMA Controllers for Upload and Download which can run concurrently - 1.2.7.2 DMA2 Controller System to Memory and Memory to System - Fast texture image uploads and downlands - Separate DMA Controllers for Upload and Download which can run concurrently - DMA controller supports scatter/gather - Fast software MPEG2 download fast frame capture - 1.2.7.3 DMA3 Controller System Memory to DVD accelerator - Compressed video to DVD accelerator chip Input FIFO - Fetch/draw parallelism - Burst mode bursts for programmed I/O - DMA controller supports scatter/gather #### 1.2.8 Video Streaming PERMEDIA 3 supports digital video output. The 24-bit streamed output is designed to work with common PAL/NTSC encoders or flat panel controllers. #### 1.2.9 ROM support PERMEDIA 3 supports a Flash ROM. This ROM may store code needed for device-specific initialization and the SVGA BIOS. 2 ## **Address Maps and Regions** #### 2.1 PCI Configuration Region The PCI Configuration Region provides information that satisfies the needs of current and anticipated system configuration mechanisms. 0 31 16 Device ID 0 x 0 0Vendor ID Status Command 0x08 Revision ID Class Code 0x0C Header Type Cache Line Size Latency Timer 0x100x14 0x18 Base Address Registers 0x1C 0x20 0x24CardBus CIS Pointer 0x28Subsystem ID Subsystem 0x2CVendor ID Expansion ROM Base Address 0x30Capabilities Ptr 0x34Reserved 0x38 Interrupt Pin Interrupt Line 0x3C Max Latency Min Grant AGP Cap ID Next Ptr 0x40AGP Status 0x440x48AGP Command PM Cap ID PM Capability PM Next Ptr 0x4C PM Data PM Bridge PM Control/Status 0x500xF4 Indirect Data Indirect Address 0xF8 0xFC Indirect Access Trigger Figure 2-1 PCI Configuration Region 2-3 #### 2.2 Region Zero Address Map The PERMEDIA 3 region zero address map is shown in Table 2-1. Table 2-1 Region Zero Address Map | Address Range | Region Select | Byte Swap/<br>Write Combined | |------------------------|------------------------------------------|------------------------------| | 0000.0000 -> 0000.02FF | Control Status | No | | 0000.0300 -> 0000.03FF | Bypass Control | No | | 0000.0400 -> 0000.0FFF | Repeat of the Control and Bypass Decodes | No | | 0000.1000 -> 0000.1FFF | Memory Control | No | | 0000.2000 -> 0000.2FFF | GP FIFO Access | No | | 0000.3000 -> 0000.30FF | Video Control | No | | 0000.3100 -> 0000.3FFF | Video Overlay Control | No | | 0000.4000 -> 0000.4FFF | RAMDAC | No | | 0000.5000 -> 0000.57FF | VS GP | No | | 0000.5800 -> 0000.5FFF | VSCtl | No | | 0000.6000 -> 0000.6FFF | VGA Control | No | | 0000.7000 -> 0000.7FFF | TextureData FIFO | No | | 0000.8000 -> 0000.FFFF | GP Registers | No | | 0001.0000 -> 0001.01FF | Control Status | Yes | | 0001.0300 -> 0001.03FF | Bypass Control | Yes | | 0001.0400 -> 0001.0FFF | Repeat of the Control and Bypass Decodes | Yes | | 0001.1000 -> 0001.1FFF | Memory Control | Yes | | 0001.2000 -> 0001.2FFF | GP FIFO Access | Yes | | 0001.3000 -> 0001.37FF | Video Control | Yes | | 0001.3800 -> 0001.3FFF | Video Overlay Control | Yes | | 0001.4000 -> 0001.4FFF | RAMDAC | Yes | | 0001.5000 -> 0001.57FF | VS GP | Yes | | 0001.5800 -> 0001.5FFF | VSCtl | Yes | | 0001.6000 -> 0001.6FFF | VGA Control | Yes | | 0001.7000 -> 0001.7FFF | TextureData FIFO | Yes | | 0001.8000 -> 0001.FFFF | GP Registers | Yes | #### 2.3 PCI Address Regions PERMEDIA 3 has seven base address regions, as shown in Table 2-2. Table 2-2 PERMEDIA 3 PCI Address Regions | Region | Address Space | Bytes | Description | Comments | |--------|---------------|-------|---------------------|--------------------------| | Config | Configuration | 256 | PCI Configuration | PCI special | | Zero | Memory | 128 K | Control Registers | Relocatable | | One | Memory | 64M | Memory Aperture One | Relocatable | | Two | Memory | 64M | Memory Aperture Two | Relocatable | | Three | I/O | 16 | Indirect Access I/O | Optional and Relocatable | | ROM | Memory | 64 K | Expansion ROM | Relocatable | | VGA | Memory & I/O | - | VGA Access | Optional and Fixed | 3 #### **Video Unit and RAMDAC** The video unit and RAMDAC should be configured to display the framebuffer data with the format, resolution, and refresh frequency required. #### 3.1 Display Timing Values Table 3-1 Timing Values for 640x480 16 BPP 75Hz | Parameter | Hex | Decimal | |--------------|-------|---------| | HTotal | 0x065 | 101 | | HsStart | 0x003 | 3 | | HsEnd | 0x00B | 11 | | HbEnd | 0x016 | 22 | | HgEnd | 0x016 | 22 | | VTotal | 0x1F5 | 501 | | VsStart | 0x000 | 0 | | VsEnd | 0x003 | 3 | | VbEnd | 0x016 | 22 | | ScreenStride | 0x050 | 80 | | ScreenBase | 0x000 | 0 | | VideoControl | 0x029 | 41 | Table 3-2 Timing Values for 800x600 32 BPP 75Hz | Parameter | Hex | Decima<br>1 | |-----------|-------|-------------| | HTotal | 0x103 | 259 | | HsStart | 0x00A | 10 | | HsEnd | 0x01E | 30 | | HbEnd | 0x03C | 60 | | Parameter | Hex | Decima<br>1 | |--------------|-------|-------------| | HgEnd | 0x03C | 60 | | VTotal | 0x272 | 626 | | VsStart | 0x000 | 0 | | VsEnd | 0x003 | 3 | | VbEnd | 0x01B | 27 | | ScreenStride | 0x0C8 | 200 | | Screen Base | 0x000 | 0 | | VideoControl | 0x029 | 41 | Permedia3 Reference Guide Hardware Registers 4 ## Hardware Registers This chapter lists PERMEDIA 3 hardware registers by region and functional offset group. Within each group, the registers are listed alphanumerically. Exceptionally, graphics core "software" registers (offset 8000-9FFF) are shown in chapter 5. Global cross-reference listings in alphanumeric and offset order are available in chapter 6. Register details have the following format information: **Name** The register's name. **Type** The region in which the register functions. **Offset** The offset of this register from the base address of the region. **Format** Can be bitfield or integer. Bit Bit Name **Read** Indicates whether the register bit can be read from. A ✓ mark indicates the register can be read from, a $\times$ indicates the register bit is not readable. Write Indicates whether the register bit can be written to. A ✓ mark indicates the register can be written to, a $\times$ indicates the register bit is not writable. **Reset** The value of the register following hardware reset. **Description** In the register descriptions: **Reserved** Indicates bits that may be used in future members of the PERMEDIA family. To ensure upwards compatibility, any software should not assume a value for these bits when read, and should always write them as zeros. Not Used/ Indicates bits that are adjacent to numeric fields. These may be used in future Unused members of the PERMEDIA family, but only to extend the dynamic range of these fields. The data returned from a read of these bits is undefined. When a Not Used field resides in the most significant position, a good convention to follow is to sign extend the numeric value, rather than masking the field to zero before writing the register. This will ensure compatibility if the dynamic range is increased in future members of the PERMEDIA family. For enumeration fields that do not specify the full range of possible values, only the specified values should be used. An example of an enumeration field is the comparison field in the DepthMode register. Future members of the PERMEDIA family may define a meaning for the unused values. Register Descriptions Permedia3 Reference Guide #### 4.1 PCI Configuration Region (0x00-0x30) #### **CFGAGPCommand** NameTypeOffsetFormatCFGAGPCommandConfig0x48Bitfield Control register | Bits | Name | Read | Write | Reset | Desci | iption | |------|-----------|----------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------| | 02 | DataRate | <b>√</b> | <b>√</b> | 0 | 0 = AGP disabled<br>2 = 2X transfer rate<br>Setting this field to any other<br>mastering. | 1 = 1X transfer rate<br>4 = 4X transfer rate<br>er value will disable AGP | | 3 | Reserved | ✓ | × | 0 | | | | 4 | FWEnable | ✓ | ✓ | 0 | 0 = Fast Write disabled | 1 = Fast Write enabled | | 5 | 4GEnable | 1 | 1 | 0 | 0 = 4G Addressing disabled | 1 = 4G Addressing<br>enabled | | 67 | Reserved | ✓ | ✓ | 0 | | | | 8 | AGPEnable | 1 | 1 | 0 | 0 = AGP Mastering<br>disabled | 1 = AGP Mastering<br>enabled | | 9 | SBAEnable | 1 | 1 | 0 | 0 = sideband addressing disabled | 1 = sideband addressing enabled | | 1023 | Reserved | ✓ | × | 0 | | | | 2431 | RQDepth | <b>√</b> | √ | 0 | Maximum number of AGF queued. The RQDepth set exceed the value in the CFC maximum RQDepth used these two RQDepth fields programmed incorrectly. | in this field should never<br>GAGPStatus register. The<br>internally is the lower of | Notes: This register controls the operation of the AGP interface. - If AGP Capable is not set, writes to this register will be discarded. - If SBACapable is not set and SBAEnable is set, AGP accesses will be disabled. - AGP Capable is a term used to express the logical OR of AGP1X Capable with AGP2X Capable with AGP4X Capable. Permedia3 Reference Guide Hardware Registers #### **CFGACGRev** NameTypeOffsetFormatCFGACGRevConfiguration0x042Bitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|-------|-------|-----------------------------| | | | | | | | | 015 | | | | | See CFGCapID and CFGNextPtr | | 1619 | Minor Rev | ✓ | X | 0 | Configured by AGP Capbable | | | | | | | 0 when AGP Capable = 0 or 1 | | 2023 | Major Rev | ✓ | × | See | Configured by AGP Capable | | | | | | Desc. | • 0 when AGP Capable = $0$ | | | | | | | • 0x2 when AGP Capable = 1 | | 2431 | Reserved | ✓ | × | 0 | - | Notes: This register reports the revision of the AGP specification to which the device conforms. AGP Capable is a term used to express the logical OR of AGP1XCapable with AGP2XCapable with AGP4XCapable. #### **CFGAGPStatus** NameTypeOffsetFormatCFGAGPStatusConfiguration0x044Bitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 02 | Rate | ✓ | × | see<br>Desc. | Configured by AGP 1X Capable, Configured by AGP 2X Capable, Configured by AGP 4X Capable 0 = Configured by AGP 1X Capable 1 = Configured by AGP 2X Capable 2 = Configured by AGP 4X Capable | | 3 | Reserved | ✓ | × | 0 | | | 4 | FW | ✓ | ✓ | 0 | | | 5 | 4G | ✓ | ✓ | 0 | | | 9 | SBA | 1 | × | see<br>Desc. | Configured by AGP Capable Side Band Addressing<br>0 when AGP Capable = 0 or SBACapable = 0<br>1 when AGP Capable = 1 and SBACapable = 1 | | 1023 | Reserved | ✓ | × | 0 | Î | | 2431 | RQ | 1 | × | see<br>Desc. | Maximum number of AGP requests supported Configured by AGP Capable 0 if AGP Capable = 0 0x1F if AGP Capable = 1, = 32 outstanding requests | Notes: This register describes the AGP capabilities of the device. AGP Capable is a term used to express the logical OR of AGP1XCapable with AGP2XCapable with AGP4XCapable. Register Descriptions Permedia3 Reference Guide #### CFGBaseAddr0 NameTypeOffsetFormatCFGBaseAddr0Configuration0x10Bitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|---------------------------|------|----------|-------|----------------------------------------------------------------------------| | 0 | Memory Space<br>Indicator | 1 | × | 0 | 0 = Region is in PCI memory space. | | 12 | Address Type | 1 | × | 0 | 0 = Memory Space, not prefetchable, in 32 bit address space | | 3 | Prefetchable | ✓ | × | 0 | 0 = Region is not prefetchable. | | 416 | Size Indication | 1 | × | 0 | 0 = Control registers must be mapped into 128 Kbytes. | | 1731 | Base Offset | 1 | <b>√</b> | 0 | Loaded at boot time to set offset of the control register space (region 0) | Notes: Base Address 0 Register contains the PERMEDIA 3 control space offset. The control registers are in memory space. They are prefetchable and can be located anywhere in 32 bit address space. #### CFGBaseAddr1 NameTypeOffsetFormatCFGBaseAddr1Configuration0x14Bitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|-----------------|----------|-------|-------|------------------------------------------------------| | | | | | | | | 0 | Memory Space | ✓ | × | 0 | 0 Region is in PCI memory space. | | | Indicator | | | | | | 12 | Address Type | ✓ | × | 0 | 0 Locate anywhere in 32 bit address space | | 3 | Prefetchable | <b>√</b> | X | 0 | 0 = Region is not prefetchable if PrefetchEnable =0. | | | | | | | 1= Region is prefetchable if PrefetchEnable = 1. | | 425 | Size Indication | ✓ | × | 0 | 0 = Region size of 64Mbytes. | | 2631 | Base Offset | ✓ | ✓ | 0 | Loaded at boot time to set offset of the memory | | | | | | | space for aperture one. | Notes: The Base Address 1 Register contains the PERMEDIA 3 aperture one memory offset. It is prefetchable and can be located anywhere in 32 bit address space Permedia3 Reference Guide Hardware Registers #### CFGBaseAddr2 NameTypeOffsetFormatCFGBaseAddr2Configuration0x18Bitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|---------------------------|----------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------| | 0 | Memory Space<br>Indicator | <b>√</b> | × | 0 | 0 = Region is in PCI memory space. | | 12 | Address Type | ✓ | × | 0 | 0 = Locate anywhere in 32 bit address space | | 3 | Prefetchable | 1 | × | 0 | <ul> <li>0 = Region is not prefetchable if PrefetchEnable =0.</li> <li>1 = Region is prefetchable if PrefetchEnable = 1.</li> </ul> | | 422 | Size Indication | ✓ | X | 0 | 0 = Region size of 64Mbytes. | | 2631 | Base Offset | 1 | <b>√</b> | 0 | Loaded at boot time to set offset of the memory space for aperture two. | Notes: - The Base Address 2 Register contains the PERMEDIA 3 aperture 2 memory offset. It is prefetchable and can be located anywhere in 32 bit address space - The Base Address 3 Register contains the base address of the PERMEDIA 3 Indirect IO aperture, and defines the size and type of this region. #### **CFGBIST** NameTypeOffsetFormatCFGBISTConfiguration0x0FIntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------------------------------------------| | 023 | | | | | See CFGLatTimer and CFGCacheLine | | 2431 | BIST | ✓ | X | 0 | 0 = BIST unsupported by PERMEDIA 3 over the PCI | | | | | | | interface | Notes: Optional register used for control and status of Built-In Self Test (BIST). Register Descriptions Permedia3 Reference Guide #### **CFGCacheLine** NameTypeOffsetFormatCFGCacheLineConfiguration0x0CInteger Control register | Bits | Name | Read | Write | Reset | Description | |------|-----------------|------|-------|-------|---------------------------------------------| | 015 | Cache Line Size | ✓ | × | 0 | 0= Cache line size unsupported | | 831 | | | | | See CFGBist, CFGHeaderType, and CFGLatTimer | Notes: This register specifies the cache line size in units of 32 bit words. It is only implemented for PCI bus masters that use the "memory write and invalidate" command. PERMEDIA 3 does not use this command. #### **CFGCapID** NameTypeOffsetFormatCFGCapIDConfiguration0x040Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|---------------|----------|-------|--------------|--------------------------------------------------| | 07 | Capability ID | <b>√</b> | × | see<br>desc. | Configured by AGP Capable | | | | | | | 0 when AGP Capable = 0<br>2 when AGP Capable = 1 | | 823 | | | | | See CFGNextPtr, CFGAGPRev and Reserved | | 2431 | Reserved | X | X | 0 | | Notes: This register specifies that the device has AGP capability. AGP Capable is a term used to express the logical OR of AGP1XCapable with AGP2XCapable with AGP4XCapable Permedia3 Reference Guide Hardware Registers #### **CFGCapPtr** NameTypeOffsetFormatCFGCapPtrConfiguration0x34Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|----------------|------|-------|-------|-------------------------------------------------------| | 07 | Capability Ptr | ✓ | × | 0x4C | Pointer to Power Management capability, address 0x4C. | | 831 | Reserved | × | × | 0 | | Notes: This register is an eight bit register used to provide an offset into the configuration space for the first item in a capabilities list. It is used to point to the Power Management Capability that commences at offset 0x48 #### **CFGCardBus** NameTypeOffsetFormatCFGCardBusConfiguration0x28Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|------------------------|------|-------|-------|---------------------| | 031 | CardBus CIS<br>Pointer | × | × | 0 | 0 = Not implemented | Notes: #### **CFGClassCode** NameTypeOffsetFormatCFGClassCodeConfiguration0x09Bitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-------|-------------------------------|-------------------| | 07 | | | | | See CFGRevisionId | | 815 | DeviceClass | 1 | × | from<br>Configuration<br>data | see table below | | 1623 | SubClass | 1 | × | from<br>Configuration<br>data | see table below | | 2431 | BaseClass | 1 | × | from<br>Configuration<br>data | see table below | Notes: This device is used to identify the generic function of the PERMEDIA 3 device. This is determined by setting the BaseClassZero and FixedVGAAddressing pins. A more detailed description of the generic function types can be found in Appendix D of the PCI Specification (revisions 2.1 or 2.2). | Configuratio | | | | | | |----------------------------------------------|----------|---------------|--------------|-----------------|-------------------------------| | BaseClass Fixed SVGA (Config Bit) Addressing | | Base<br>Class | Sub<br>Class | Device<br>Class | Generic Function | | 0 | Disabled | 0x03 | 0x80 | 0x00 | "Other" display controller | | 0 | Enabled | 0x03 | 0x00 | 0x00 | VGA Compatible Controller | | 1 | Disabled | 0x00 | 0x00 | 0x00 | Non-VGA Compatible Controller | | 1 | Enabled | 0x00 | 0x1 | 0x00 | VGA Compatible Device | ## **CFGCommand** NameTypeOffsetFormatCFGCommandConfiguration0x04Bitfield Control register | Bits | Name | Read | Write | Reset | Description | | |------|------------------------------------------|------|-------|-------|-----------------------------------------------------------------|--------------------------------------------------------------| | 0 | I/O Space<br>Enable | 1 | × | 0 | 0 = Disable I/O Space<br>Accesses<br>If fixed SVGA addressing i | 1 = Enable I/O Space<br>Accesses<br>s disabled, and indirect | | 1 | Memory Space | 1 | 1 | 0 | I/O region is disabled, this 0 = Disable memory | bit will be 0 1 = Enable memory | | - | Enable | · | • | | Space Accesses | Space Accesses | | 2 | Bus Master<br>Enable | ✓ | 1 | 0 | 0 = Disable master access | access | | 3 | Special Cycle<br>Enable | 1 | × | 0 | 0 = Permedia3 never responses | 1 0 | | 4 | Memory Write<br>and Invalidate<br>Enable | 1 | × | 0 | 0 = "Memory Write and Invalidate" is never generated. | | | 5 | SVGA Palette<br>Snoop Enable | ✓ | × | 0 | 0 = Treat palette accesses<br>like all other SVGA<br>accesses | 1 = Enable SVGA<br>Palette snooping | | 6 | Parity Error<br>Response<br>enable | 1 | × | 0 | 0 = Permedia3 does not support parity error reporting | | | 7 | Address/Data stepping enable | 1 | × | 0 | 0 = Permedia3 does not perform stepping | | | 8 | SERR driver<br>enable | 1 | × | 0 | 0 = Permedia3 does not support parity error reporting | | | 9 | Master Fast<br>Back-to-Back<br>Enable | ✓ | X | 0 | 0 = Permedia3 master does not do fast back-to-back accesses | | | 1015 | Reserved | ✓ | X | 0 | C CECC . | | | 1631 | | | | | See CFGStatus | | Notes: The command register provides control over a device's ability to generate and respond to PCI cycles. It contains sufficient control bits to fulfill the PERMEDIA 3 PCI functionality. Writing 0 to this register disconnects the device from the PCI for all except configuration accesses #### **CFGDeviceID** | Name | Туре | Offset | Format | |-------------|-----------------------------------|--------|---------| | CFGDeviceID | Configuration<br>Control register | 0x02 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|---------------------------------------------------------------------------------------------| | 015 | | | | | See CFGVendorID | | 1631 | DeviceID | ✓ | × | 0xA | Device identification number:<br>0x000A = 3Dlabs PERMEDIA 3 device identification<br>number | ## **CFGHeaderType** | Name | Туре | Offset | Format | |---------------|------------------|--------|---------| | CFGHeaderType | Configuration | 0x0E | Integer | | | Control register | • | | | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|--------------------------------------------| | 015 | | | | | See CFGLatTimer and CFGCacheLine | | 1623 | Header Type. | ✓ | × | 0 | PCI Definition: 0 = Single Function Device | | 2431 | | | | | See CFGBist | #### **CFGIndirectAddress** | Name | <b>Type</b> | Offset | <b>Format</b> | |--------------------|------------------|--------|---------------| | CFGIndirectAddress | Configuration | 0x0F8 | Bitfield | | | Control register | • | | | Bits | Name | Read | Write | Reset | Descr | ription | |------|------------------------|----------|----------|-------|------------------------------------------------------------|--------------------------------------| | 025 | Offset | <b>√</b> | <b>√</b> | 0 | Offset within the region. | | | 2627 | Reserved | ✓ | × | 0 | | | | 2931 | Base Address<br>Select | 1 | <b>√</b> | 0 | 0 = Base Address 0<br>2 = Base Address 2<br>7 = ROM Region | 1 = Base Address 1<br>3-6 = Reserved | Notes: 1. The Reserved Base Address Select values can be written to or read from the register, but in this case, indirect accesses are treated as if to Base Address 0. Reading the indirect trigger register CFGIndirectTrigger returns the value at the location pointed to by the indirect address register. Indirect data register CFGIndirectData will be written to the location pointed to by the indirect address register CFGIndirectAddress when the indirect trigger register is written. #### **CFGIndirectData** | Name | Type | Offset | Format | |-----------------|---------------|--------|---------| | CFGIndirectData | Configuration | 0x0F4 | Integer | | | ~ | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------------------------| | 031 | Data | ✓ | ✓ | 0 | Data to be written indirectly | Notes: - . This register is used to access regions 0 to 3 and the ROM region directly through the config space. The region to be accessed and the offset into that region are programmed into the CFGIndirectAddress register. Data written to the CFGIndirectData register will be written to the location pointed to by the CFGIndirectAddress register when the CFGIndirectTrigger register is written. - Reading the CFGIndirectTrigger register returns the value at the location pointed to by the CFGIndirectAddress register. # CFGIndirectTrigger | Name | Туре | Offset | Format | |--------------------|------------------|--------|---------| | CFGIndirectTrigger | Configuration | 0xFC | Integer | | | Control register | • | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|-------------| | 031 | Trigger | ✓ | ✓ | 0 | | Notes: This register is used to trigger indirect accesses as specified by the indirect address and data registers, CFGIndirectAddress and CFGIndirectData #### **CFGIntLine** | Name | Туре | Offset | Format | |------------|------------------|--------|---------| | CFGIntLine | Configuration | 0x3C | Integer | | | Control register | | Ü | | Bits | Name | Read | Write | Reset | Description | |------|----------------|------|-------|-------|------------------------------------------------------| | 07 | Interrupt Line | ✓ | ✓ | 0 | Not read or written by the PERMEDIA 3 device itself. | | 831 | - | | | | See CFGMinGrant, CFGIntPin and CFGMaxLat | Notes: The Interrupt Line register in an 8-bit register used to communicate interrupt line routing information ## **CFGIntPin** NameTypeOffsetFormatCFGIntPinConfiguration0x3DInteger Control register | Bits | Name | Read | Write | Reset | Description | |------|---------------|------|-------|-------|--------------------------------------------| | 07 | | | | | See CFGIntLine | | 815 | Interrupt Pin | ✓ | × | 0x1 | 0x01 = PERMEDIA 3 uses Interrupt pin INTAN | | 1631 | | | | | See CFGMinGrant and CFGMaxLat | Notes: The Interrupt Pin register specifies the interrupt line that PERMEDIA 3 uses. ## **CFGLatTimer** NameTypeOffsetFormatCFGLatTimerConfiguration0x0DInteger Control register | Bits | Name | Read | Write | Reset | Description | |------|------------------------|------|-------|-------|------------------------------------------------------------------------| | | | | | | | | 07 | | | | | See CFGCacheLine | | 815 | Latency Timer<br>Count | ✓ | × | 0 | Sets the maximum number of PCI clock cycles for master burst accesses. | | 1631 | | | | | See CFGBist and CFGHeaderType | Notes: This register specifies, in PCI bus clocks, the value of the latency timer for this PCI bus master ## **CFGMaxLat** NameTypeOffsetFormatCFGMaxLatConfiguration0x3FInteger Control register | Bits | Name | Read | Write | Reset | Description | |-------|--------------------|----------|-------|-------|-------------------------------------------| | 0-23 | | | | | See CFGMinGrant, CFGIntPin and CFGIntLine | | 24-31 | Maximum<br>Latency | <b>√</b> | × | 0xC0 | | Notes: This register specifies how often the PCI device needs to gain access to the PCI bus. ## **CFGMinGrant** NameTypeOffsetFormatCFGMinGrantConfiguration0x3EInteger Control register | Bits | Name | Read | Write | Reset | Description | |-------|--------------|------|-------|-------|------------------------------| | 0-15 | | | | | See CFGIntPin and CFGIntLine | | 1623 | MinimumGrant | ✓ | × | 0xC0 | | | 24-31 | | | | | See CFGMaxLat | Notes: This register specifies how long a burst period the PCI device needs. ## **CFGNextPtr** NameTypeOffsetFormatCFGNextPtrConfiguration0x041Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------------------| | | | | | | | | 07 | | | | | See CFGCapID | | 8-15 | Next Ptr | ✓ | × | 0 | 0 = no further capabilities in list | | 1623 | | | | | See CFGAGPRev | | 2431 | Reserved | ✓ | × | 0 | | Notes: This register points to the next capability data structure. However as there are no more, it is set to zero. ## **CFGPMC** NameTypeOffsetFormatCFGPMCConfiguration0x4EBitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|------------------|------|-------|-------|---------------------------------------------------------------------------------------------------| | 07 | | | | | see CFGPMCapID | | 815 | | | | | see CFGPMNextPtr | | 1618 | Version | 1 | × | 0x1 | 1 = complies with Revision 1.0 of the PCI Power Management Interface spec. | | 19 | PME clock | ✓ | × | 0 | 0 = PME# is not supported in any state | | 20 | Aux Power source | 1 | × | 0 | 0 = PME# is not supported in D3(cold) | | 21 | DSI | 1 | × | 1 | 1 = PERMEDIA 3 requires special initialization following transition to the D0 uninitialized state | | 2224 | Reserved | ✓ | X | 0 | - | | 25 | D1_Support | ✓ | × | 0x1 | 1 = D1 power level is supported | | 26 | D2_Support | ✓ | X | 0 | 0 = D2 power level is not supported | | 2731 | PME_Support | ✓ | × | 0 | 0 = PME# signal is not asserted in any power state | Notes: ## **CFGPMCapID** NameTypeOffsetFormatCFGPMCapIDConfiguration0x4CBitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|--------------------------------------|----------|-------|-------|------------------------------------| | 07 | Power<br>Management<br>Capability ID | <b>√</b> | × | 0x1 | 0x01 = Power Management Capability | | 815 | | | | | See CFGPMNextPtr | | 1631 | | | | | See CFGPMC | Notes: This register specifies that the device has Power Management capability ## **CFGPMCS** NameTypeOffsetFormatCFGPMCSConfiguration0x50Bitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|-------------|----------|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 01 | PowerState | <b>/</b> | ✓ | 0 | Valid values are 0,1 and 3. If 2 is written to the register, the write is discarded (D2 is not supported) $0 = D0$ $1 = D1$ (This drives the "Low Power" bit internally) $3 = D3(hot)$ | | 27 | Reserved | ✓ | × | 0 | | | 8 | PME_EN | ✓ | × | 0 | 0 = PME# signal is not asserted in D3(cold) | | 912 | Data_Select | ✓ | × | 0 | 0 = Data register not supported | | 1314 | Data_scale | <b>√</b> | × | 0 | 0 = Data register not supported | | 15 | PME_Status | ✓ | × | 0 | 0 = PME# signal is not asserted in D3(cold) | | 815 | | | | | See CFGPMCSR_BSE | | 1631 | | | | | See CFGPMData | Notes: ## CFGPMCSR\_BSE NameTypeOffsetFormatCFGPMCSR\_BSEConfiguration0x52Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|---------------------------------------|------|-------|-------|---------------------------------| | 015 | | | | | See CFGPCMS | | 1623 | Power<br>Management<br>Bridge support | 1 | × | 0 | 0 = PERMEDIA 3 is not a bridge. | | 2431 | | | | | See CFGPMData | Notes: This register specifies the Power Management PCI-PCI bridge support ## **CFGPMData** NameTypeOffsetFormatCFGPMDataConfiguration0x53Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|--------|------|-------|-------|---------------------------------------| | 015 | | | | | See CFGPCMS | | 1623 | | | | | See CFGPMSR_BSE | | 2431 | PMData | ✓ | X | 0 | 0 = This capability is not supported. | Notes: This register is the optional Power Management Data register ## **CFGPMNextPtr** NameTypeOffsetFormatCFGPMNextPtrConfiguration0x4D Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|--------------------------------------------------------| | | | | | | | | 07 | | | | | See CFGPMCapID | | 815 | Next Ptr | ✓ | X | See | 0 = no further capabilities in list if AGP Capable = 0 | | | | | | Desc. | 0x40 = point to ÂGP Capability if AGP Capable = 1 | | 1631 | | | | | See CFGPMC | Notes: This register specifies the device has next capability item. This register reports the revision of the AGP specification to which the device conforms. AGP Capable is a term used to express the logical OR of AGP1XCapable with AGP2XCapable with AGP4XCapable. ## **CFGRevisionID** NameTypeOffsetFormatCFGRevisionIDConfiguration0x08Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|--------------------------------| | 07 | RevisionID | ✓ | × | 0x1 | Revision Identification Number | | 831 | | | | | See CFGClassCode | Notes: ## **CFGRomAddr** NameTypeOffsetFormatCFGRomAddrConfiguration0x30Bitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|-------------------------|----------|----------|-------|----------------------------------------------------------------| | 0 | Access Decode<br>Enable | <b>√</b> | <b>√</b> | 0 | 0= Expansion ROM accesses disabled | | | | | | | 1= Expansion ROM accesses enabled | | 110 | Reserved | ✓ | X | 0 | 0 = PCI Reserved register bits | | 1115 | Size Indication | 1 | × | 0 | 0 = Indicates that Expansion ROM must be mapped into 64Kbytes. | | 1631 | Base Offset | 1 | <b>√</b> | 0 | Loaded at boot time to set offset of the expansion ROM. | Notes: The expansion ROM base register is the offset address for the expansion ROM. ## **CFGStatus** NameTypeOffsetFormatCFGStatusConfiguration0x06Bitfield Control register | Bits | Name | Read | Write | Reset | Description | | |------|-------------------------------|----------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------|--| | 015 | | | | | See CFGCommand | | | 1619 | Reserved | X | X | 0 | | | | 20 | Cap_List | 1 | × | 0x1 | 1 = PERMEDIA 3 can accept additional capabilities<br>beyond PCI2.1. These are power management and<br>AGP (if AGP Capable is set in CFGCapID) | | | 21 | 66MHz<br>Capable | 1 | × | X | 0 = Permedia3 is 33MHz 1 = Permedia3 is capable only 1 = Permedia3 is 66MHz capable | | | 22 | UDF<br>Supported | 1 | × | 0 | 0 = Permedia3 does not support user-definable configurations | | | 23 | Fast back-to-<br>back capable | 1 | × | 0x1 | 1 = Permedia3 can accept fast back-to-back PCI transactions | | | 24 | Data Parity<br>Error Detected | 1 | × | 0 | 0 = Parity checking not implemented on Permedia3 | | | 2526 | DEVSEL<br>Timing | 1 | × | 0x1 | 1 = Permedia3 asserts DEVSEL# at medium speed | | | 27 | Signaled Target<br>Abort | 1 | × | 0 | 0 = Permedia3 never signals Target-Abort | | | 28 | Received<br>Target Abort | 1 | 1 | 0 | This bit is set by the Permedia3 bus master whenever its transaction is terminated with Target-Abort | | | 29 | Received<br>Master Abort | 1 | 1 | 0 | This bit is set by the Permedia3 bus master whenever its transaction is terminated with Master-Abort | | | 30 | Signalled<br>System Error | 1 | × | 0 | 0 = Permedia3 never asserts a system error | | | 31 | Detected Parity<br>Error | <b>√</b> | × | 0 | 0 = Parity checking is not implemented by Permedia3 | | Notes: Writes to this register causes bits to be reset, but not set. A bit is reset whenever the register is loaded with the corresponding bit position set to one. AGP Capable is a term used to express the logical OR of AGP1XCapable with AGP2XCapable with AGP4XCapable ## **CFGSubsystemId** NameTypeOffsetFormatCFGSubsystemIdConfiguration0x02EInteger Control register | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-----------|-------------|--------------------------| | 015 | | | | | See CFGSubsystemVendorID | | 1631 | SubsystemId | × | ✓<br>once | see<br>text | | Notes: This register is used to identify the add-in board on which the PERMEDIA 3 device resides. It has two possible reset states: the value may be loaded from the ROM byte addresses 0xFFFE and 0xFFFF, or reset to the Device ID and then written to once before it becomes read only. The option is controlled by a configuration register ## **CFGSubsystemVendorld** NameTypeOffsetFormatCFGSubsystemVendorIdConfiguration<br/>Control register0x02CInteger | Bits | Name | Read | Write | Reset | Description | |------|--------------------|------|-----------|-------------|--------------------| | 015 | SubsystemVend orID | × | ✓<br>once | see<br>text | | | 1631 | | | | | See CFGSubsystemId | Notes: This register is used to identify the vendor of the add-in board on which the PERMEDIA 3 device resides. It has two possible reset states: The value may be loaded from the ROM byte addresses 0xFFFC and 0xFFFD, or reset to the vendor ID and then written to once before it becomes read-only. The option is controlled by a configuration register #### **CFGVendorID** NameTypeOffsetFormatCFGVendorIDConfiguration0x00IntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|-----------|----------|-------|------------|---------------------| | 015 | Vendor ID | <b>√</b> | × | 0x3D3<br>D | 3Dlabs Company Code | | 1631 | | | | | See CFGDeviceID | # 4.2 Region 0 Control Status (0x0000-0x02FF) ## **AGPControl** | Name | Туре | Offset | Format | |------------|------------------|--------|----------| | AGPControl | Control Status | 0x078 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | | |------|---------------------------|------|-------|-------|------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------| | 02 | Reserved | ✓ | × | 0 | | | | 3 | AGP Long<br>Read Disable | ✓ | ✓ | 0 | 0 = AGP Long Read<br>Requests may be<br>generated. | 1 = AGP Long Read<br>Requests disabled. | | 4 | Reserved | ✓ | × | 0 | | | | 5 | AGP Data Fifo<br>throttle | ✓ | ✓ | 0 | 0 = RBF# throttle start<br>of data transfer for low<br>priority reads. | 1 = Only request data<br>when space is available<br>in AGP data fifo to start<br>receiving the burst<br>(RBF# never asserted) | | 6 | AGP High<br>Priority | 1 | 1 | 0 | 0 = Use AGP Low<br>Priority reads. | 1 = Use AGP High<br>Priority reads | | 731 | Reserved | ✓ | × | 0 | | | Notes: The AGP control register sets up the AGP master. # ApertureOne ApertureTwo | Name | Type | Offset | Format | |-------------|------------------------------------|--------|----------| | ApertureOne | Control Status | 0x50 | Bitfield | | ApertureTwo | Control Status<br>Control register | 0x58 | Bitfield | | Bits | Name | Read | Write | Reset | Description | | |------|------------|------|-------|-------|----------------------------------------------------------|----------------------------------------------------| | 07 | Reserved | 1 | × | 0 | | | | 8 | VGA Access | 1 | 1 | 0 | 0 = Address memory controller directly. | 1 = Address memory<br>through SVGA<br>subsystem. | | 9 | ROM Access | 1 | 1 | 0 | 0 = Use this aperture to access memory (SVGA or direct). | 1 = Use this aperture to access the Expansion ROM. | | 1031 | Reserved | 1 | × | 0 | | | Notes: Two memory apertures are provided, each being a PCI region with a fixed size of 64 MBytes. A variety of different access modes are possible - these are now controlled in the Bypass controller registers. The ApertureOne and ApertureTwo registers allow the Apertures to be used to access the SVGA or the ROM instead of the memory controller # ChipConfig | Name | Туре | Offset | Format | |------------|------------------|--------|----------| | ChipConfig | Control Status | 0x70 | Bitfield | | _ | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------------|------|-------|-------|-----------------------------------------------------------------------------------------------------------------------| | 0 | BaseClassZero | 1 | 1 | X | 0 = Use the correct PCI Base Class Code<br>1 = Force PCI Base Class Code to be zero | | 1 | VGAEnable | ✓ | 1 | X | 0 = Disable internal SVGA subsystem<br>1 = Enable internal SVGA subsystem | | 2 | VGAFixed | 1 | 1 | X | 0 = Disable SVGA fixed address decoding<br>1 = Enable SVGA fixed address decoding | | 34 | Reserved | 1 | × | X | | | 5 | RetryDisable | 1 | ✓ | X | 0 = Enable PCI Retry using "Disconnect-Without-<br>Data"<br>1 = Disable PCI Retry using "Disconnect-Without-<br>Data" | | 6 | Reserved | 1 | × | X | | | 7 | ShortReset | ✓ | <b>√</b> | X | 0 = Generate normal "AReset" pulse to rest of the | |------|---------------|-----|----------|-------|--------------------------------------------------------| | | | | | | chip | | | | | | | 1 = Generate short "AReset" pulse (BusReset+ 64 | | | | | | | clocks) | | 8 | SBA Capable | ✓ | ✓ | X | 0 = AGP sideband Addressing Disable | | | | | | | 1 = AGP sideband Addressing Enable | | 9 | AGP 1X | 1 | 1 | X | 0 = Not AGP 1X Capable | | | Capable | • | ` | | 1 = AGP 1X Capable | | 10 | AGP 2X | 1 | 1 | Х | 0 = Not 2X Capable | | | Capable | * | * | 71 | 1 = 2X Capable | | 11 | AGP 4X | 1 | 1 | X | 0 = Not 4X Capable | | | Capable | • | * | 1 | 1 = 4X Capable | | 12 | SubsystemFro | 1 | 1 | X | 0 = Leave subsystem registers with reset values | | | mRom | * | • | | 1 = Load subsystem registers from ROM after reset | | 13 | IndirectIOEna | 1 | 1 | X | 0 = Base Address 3 disabled - Indirect IO accesses | | | ble | * | • | ** | cannot be performed | | | | | | | 1 = IndirectIO accesses enabled | | 14 | WC Enable | 1 | 1 | X | 0 = Upper half of region zero is a byte swapped | | | | * | • | Λ | version of lower half | | | | | | | 1 = Upper half of region zero is flagged as a Write | | | | | | | combined version of the lower half | | 15 | Prefetch | 1 | 1 | X | 0 = Regions 1 and 2 marked as not prefetchable | | | Enable | • | <b>'</b> | ^ | 1 = Regions 1 and 2 marked as prefetchable | | 1627 | Reserved | 1 | × | X | (all bits zero) | | 2831 | Mask rev | + - | | See | Value gives the Mask Revision. The initial revision is | | ۵٥۵1 | WIGH IEV | ✓ | × | Desc. | 0x0. | | | | | | Desc. | UAU. | Notes: Most of the sampled values from the configuration pins are loaded into the ChipConfig register on the trailing edge of reset. This register can then be read back over the PCI bus, to allow the host to determine how the Permedia 3 chip has been configured, and to modify various fields of the configuration if required. ## **ControlDMAAddress** | Name | Туре | Offset | Format | | |-------------------|------------------|--------|---------|--| | ControlDMAAddress | Control Status | 0x28 | Integer | | | | Control register | | _ | | | Bits | Name | Read | Write | Reset | Description | |------|------------------------------|------|-------|-------|--------------------------------------------------------------------------------------| | 031 | Control DMA<br>Start Address | ✓ | ✓ | 0 | PCI start address for PCI master read transfer to the graphics processor input fifo. | Notes: When using the GPIn FIFO DMA controller to load the graphics processor, the Control DMA Start Address register should be loaded with the PCI address of the first word in the buffer to be transferred. Writing to the Control DMA Start Address register loads the address into the Control DMA address counter. Once a DMA has been set off, the next Control DMA start address may be loaded. A read of this register returns the last start value loaded even if the DMA is already underway. #### **ControlDMAControl** | Name | Туре | Offset | Format | |-------------------|------------------|--------|----------| | ControlDMAControl | Control Status | 0x60 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------------------------------------|----------|----------|-------|----------------------------------------------------------------------------------------------------------------------------| | 0 | ControlDMA<br>Byte Swap<br>Control | <b>√</b> | <b>√</b> | 0 | This field should only be changed when the ControlDMA controller $0 = \text{Standard}.$ $1 = \text{Byte Swapped is idle}.$ | | 1 | ControlDMA using AGP | 1 | 1 | 0 | 0 = DMA uses PCI Master<br>1 = DMA uses AGP Master | | 231 | Reserved | 1 | × | 0 | | Notes: The DMA control register sets up the data transfer modes for the DMA controller. Data transfer can be set to byte swapped for big endian hosts. #### ControlDMACount | Name | Туре | Offset | Format | |-----------------|------------------|--------|---------| | ControlDMACount | Control Status | 0x30 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------------------|------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 015 | Control DMA<br>Count | 1 | 1 | 0 | Number of words to be transferred in the DMA operation. The valid range for this register is 0 to 65535. The register behaviour is undefined if it is written to while non-zero and Mastering is enabled. Mastering is enabled if ControlDMAUseAGP = 0 and PCI Bus Master Enabled or ControlDMAUseAGP = 1 and AGP Master is enabled. See DMAControlRegister. | | 1631 | Reserved | ✓ | × | 0 | | - Notes: 1. When using the GPIn FIFO DMA controller to load the graphics processor, the Control DMA Start Address register should be loaded with the PCI address of the first word in the buffer to be transferred. Writing to the Control DMA Start Address register loads the address into the Control DMA address counter. Once a DMA has been set off, the next Control DMA start address may be loaded. A read of this register returns the last start value loaded even if the DMA is already underway. - Some bits in this register are set during operation and cleared by writing to the register with those bits set. The bits are DataValid, Start and Stop. # **ErrorFlags** NameTypeOffsetFormatErrorFlagsControl Status<br/>Control register0x38Bitfield | Bits | Name | Read | Write | Reset | Description | |------|-------------------------------------------|----------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Input FIFO<br>Error Flag | ✓ | 1 | 0 | Flag set on write to full input FIFO. 0 = No error. | | 1 | Output FIFO<br>Error Flag | ✓ | 1 | 0 | Flag set on read from empty output FIFO. 0 = No error. | | 2 | Reserved | 1 | × | 0 | | | 3 | Control DMA<br>Error Flag | ✓ | ✓ | 0 | Flag set for direct or register access to input FIFO while DMA is in progress (i.e. when the Control DMACount register is not zero). 0 = No error. 1 = Error outstanding. | | 4 | Video Fifo<br>Underflow<br>Error Flag | ✓ | ✓ | 0 | Flag set when video FIFO underflows $0 = \text{No error}$ $1 = \text{Error outstanding}$ | | 5 | Video Stream B<br>Underflow<br>Error Flag | <b>√</b> | ✓ | 0 | Flag set when video stream B FIFO underflows $0 = \text{No error}.$ $1 = \text{Error outstanding}.$ | | 6 | Video Stream A<br>Overflow Error<br>Flag | ✓ | ✓ | 0 | Flag set when video stream A FIFO Overflows $0 = \text{No error}.$ $1 = \text{Error outstanding}.$ | | 7 | PCI Master<br>Error Flag | ✓ | ✓ | 0 | Flag set when either Master abort or Target abort occurs while PCI Master access in progress The CFGStatus register can be read to determine the type of error. 0 = No error. 1 = Error outstanding. | | 8 | GPOutDMA<br>Error Flag | J | 1 | 0 | Flag set for slave access to output FIFO while DMA is in progress $0 = \text{No error}.$ $1 = \text{Error outstanding}.$ | | 9 | Control DMA Count Overwrite Error Flag | ✓ | ✓ | 0 | Flag set if an attempt is made to write the Control DMACount register when it is not zero. 0 = No error. 1 = Error outstanding. | | 10 | GPOutDMA<br>Feedback Error<br>Flag | <b>√</b> | 1 | 0 | Flag set if a feedback error occurs. $0 = \text{No error}$ . $1 = \text{Error outstanding}$ . | | 11 | VSA Invalid<br>Interlace Error<br>Flag | ✓ | ✓ | 0 | Flag set if invalid interlace is detected on video stream A. 0 = No error. | | 12 | VSB Invalid<br>Interlace Error<br>Flag | ✓ | ✓ | 0 | Flag set if invalid interlace is detected on video stream B. 0 = No error. | | 1 | 3 | HostIn DMA<br>Error Flag | 1 | 1 | 0 | Flag set if HostIN DMA error occurs $0 = \text{No error} \qquad 1 = \text{Error Outstanding}$ | |---|-----|--------------------------|---|---|---|-----------------------------------------------------------------------------------------------| | 1 | 431 | Reserved | 1 | × | 0 | | Notes: The Error Flags register shows which errors are outstanding in Permedia3. Flag bits are reset by writing to this register with the corresponding bit set to a one. Flags at positions where the bits are set to zero will be unaffected by the write. #### **FIFODiscon** | Name | Туре | Offset | Format | |------------|------------------------------------|--------|----------| | FIFODiscon | Control Status<br>Control register | 0x68 | Bitfield | | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|--------------| | | | | | | | | 0 | Input FIFO | ✓ | ✓ | 0 | 0 = Disabled | | | Disconnect | | | | 1 = Enabled | | | Enable | | | | | | 1 | Output FIFO | ✓ | ✓ | 0 | 0 = Disabled | | | Disconnect | | | | 1 = Enabled | | | Enable | | | | | | 2 | Texture FIFO | 1 | ✓ | 0 | 0 = Disabled | | | Disconnect | | | | 1 = Enabled | | | Enable | | | | | | 331 | Reserved | 1 | × | 0 | | Notes: The FIFODiscon register enables the input and output FIFO disconnect signals, which drive two physical pins on the PERMEDIA 3. Disconnects are disabled at reset. It also allows protocol disconnects to be enabled for the Texture FIFO. #### **GPOutDMAAddress** NameTypeOffsetFormatGPOutDMAAddressControl Status<br/>Control register0x080Integer | Bits | Name | Read | Write | Reset | Description | |------|---------------------|------|-------|-------|-----------------------------------------------| | 031 | GPOutDMAA<br>ddress | 1 | × | 0 | Next address to be issued to the DMA Arbiter. | Notes: The *GPOutDMA* Address register can be used to monitor the progress of the GPOutDMA controller. It returns the next address to be issued to the DMA arbiter. #### **HostTextureAddress** | Name | Туре | Offset | Format | |--------------------|------------------------------------|--------|---------| | HostTextureAddress | Control Status<br>Control register | 0x0100 | Integer | | Bits | Name | Read | Write | Reset | Description | |------|---------------|------|-------|-------|-------------| | 03 | Reserved | ✓ | × | 0 | | | 431 | HostTextureAd | 3 | 3 | X | | | | dress | | | | | Notes: Used in "Slave Download Mode" to supply the address of the first word of a texture ## **InFIFOSpace** | Name | Туре | Offset | Format | |-------------|------------------|--------|---------| | InFIFOSpace | Control Status | 0x18 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------------------|------|-------|-------|-----------------------------------------------------------------------------------------| | 031 | Input FIFO<br>Space | 1 | × | 128 | The number of empty words in the input FIFO. This number of words can be updated before | | | | | | | checking "InFIFOSpace" again. | Notes: The InFIFOSpace register shows the number of words that can currently be written to the input FIFO. This register can be read at any time. If the DMA controller for the FIFO is in use, the value read is a snapshot of the current FIFO status. ## IntEnable | Name | Туре | Offset | Format | |-----------|------------------|--------|----------| | IntEnable | Control Status | 0x08 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------------------------------------|------|-------|-------|-------------------------------------------------| | 0 | Control DMA<br>Interrupt<br>Enable | ✓ | ✓ | 0 | 0 = Disable interrupt.<br>1 = Enable interrupt. | | 1 | Sync Interrupt<br>Enable | ✓ | 1 | 0 | 0 = Disable interrupt.<br>1 = Enable interrupt | | 2 | Reserved | | 1., | 10 | | |------|------------------|---|-------|----------|------------------------| | | | ✓ | X | _ | | | 3 | Error Interrupt | ✓ | ✓ | 0 | 0 = Disable interrupt. | | | Enable | | | | 1 = Enable interrupt. | | 4 | Vertical Retrace | ✓ | 1 | 0 | 0 = Disable interrupt. | | | Interrupt | | | | 1 = Enable Interrupt | | | Enable | | | | | | 5 | Scanline | 1 | 1 | 0 | 0 = Disable interrupt. | | | Interrupt | | | | 1 = Enable Interrupt | | | Enable | | | | | | 6 | Texture | ✓ | 1 | 0 | 0 = Disable interrupt. | | | DownLoad | | | | 1 = Enable interrupt | | | Interrupt | | | | | | | Enable | | | | | | 7 | Bypass DMA | ✓ | 1 | 0 | 0 = Disable interrupt. | | | Read Interrupt | | | | 1 = Enable interrupt | | | Enable | | | | | | 8 | VSB Interrupt | 1 | 1 | 0 | 0 = Disable interrupt. | | | Enable | | | | 1 = Enable interrupt | | 9 | VSA Interrupt | 1 | 1 | 0 | 0 = Disable interrupt. | | | Enable | | | | 1 = Enable interrupt | | 10 | VS Serial | 1 | 1 | 0 | 0 = Disable interrupt. | | | Interrupt | | | | 1 = Enable interrupt. | | | Enable | | | | | | 11 | VidDDC | ✓ | 1 | 0 | 0 = Disable interrupt. | | | Interrupt | | | | 1 = Enable interrupt | | | Enable | | | | | | 12 | VS External | 1 | 1 | 0 | 0 = Disable interrupt. | | | Interrupt | | | | 1 = Enable interrupt | | | Enable | | | | - | | 13 | Bypass DMA | 1 | 1 | 0 | 0 = Disable interrupt. | | | Write | • | * | | 1 = Enable interrupt | | | Interrupt | | | | | | | Enable | | | | | | 14 | HostIn | 1 | 1 | 0 | 0 = Disable interrupt. | | | Command | • | * | | 1 = Enable interrupt. | | | Interrupt | | | | _ | | | Enable | | | | | | 15 | VS DMA | 1 | 1 | 0 | 0 = Disable interrupt | | | Interrupt | • | * | | 1 = Enable interrupt | | | enable | | | | 1 | | 1631 | Reserved | 1 | × | 0 | Read Only. | | | 1 | | 1 . , | <u> </u> | 1 | Notes: The IntEnable register selects which internal conditions are permitted to generate a bus interrupt. At reset all interrupt sources are disabled ## **IntFlags** NameTypeOffsetFormatIntFlagsControl Status0x10BitfieldControl register | Bits | Flag Name | Read | Write | Reset | Description | | |------|--------------------------|------|-------|-------|---------------------------------------------|--------| | 0 | Control DMA | ✓ | ✓ | 0 | 0 = No interrupt. $1 = Interrupt outstar$ | nding. | | 1 | Sync | ✓ | ✓ | 0 | 0 = No interrupt. $1 = Interrupt outstands$ | ding | | 2 | Reserved | ✓ | × | 0 | | | | 3 | Error | ✓ | ✓ | 0 | 0 = No interrupt. $1 = Interrupt outstar$ | nding. | | 4 | Vertical Retrace | ✓ | ✓ | 0 | 0 = No interrupt. $1 = Interrupt outstand$ | ıding. | | 5 | Scanline | ✓ | ✓ | 0 | 0 = No interrupt. $1 = Interrupt outstands$ | ding | | 6 | Texture<br>Download | ✓ | ✓ | 0 | 0 = No interrupt. $1 = Interrupt outstan$ | ding | | 7 | Bypass Read<br>DMA | ✓ | ✓ | 0 | 0 = No interrupt. $1 = Interrupt outstar$ | nding. | | 8 | VSB | ✓ | ✓ | 0 | 0 = No interrupt. $1 = Interrupt outstar$ | nding. | | 9 | VSA | ✓ | ✓ | 0 | 0 = No interrupt. $1 = Interrupt outstands$ | ding | | 10 | VS Serial | ✓ | ✓ | 0 | 0 = No interrupt. $1 = Interrupt outstand$ | ding | | 11 | VidDDC | ✓ | 1 | 0 | 0 = No interrupt. $1 = Interrupt outstands$ | ding | | 12 | VS External | ✓ | ✓ | 0 | 0 = No interrupt. $1 = Interrupt outstand$ | ıding. | | 13 | Bypass Write<br>DMA | ✓ | ✓ | 0 | 0 = No interrupt. $1 = Interrupt outstar$ | nding. | | 14 | HostIn<br>Command<br>DMA | ✓ | 1 | 0 | 0 = No interrupt. $1 = Interrupt outstan$ | ding | | 15 | VS DMA | ✓ | ✓ | 0 | 0 = No interrupt $1 = Interrupt Outstands$ | nding | | 1630 | Reserved | ✓ | × | 0 | | | | 31 | VGA Interrupt<br>Line | ✓ | × | 0 | 0 = No interrupt. $1 = Interrupt asserted$ | d. | Notes: The IntFlags register shows which interrupts are outstanding. Flag bits are reset by writing to this register with the corresponding bit set to a one. Flags at positions where the bits are set to zero will be unaffected by the write. (The exception is bit 31, which is read-only and reflects the state of the interrupt line from the VGA. The VGA Interrupt must be enabled and reset by accessing the VGA directly, but is visible in this register for convenience.) # LogicalTexturePage | Name | Туре | Offset | Format | |--------------------|----------------------------------|--------|---------| | LogicalTexturePage | Control Status Control register | 0x118 | Integer | | Bits | Name | Read | Write | Reset | Description | |------|------------------------|------|-------|-------|-------------| | 015 | LogicalTexture<br>Page | 3 | 5 | X | | | 1631 | Reserved | 3 | 5 | 0 | | Notes: Used with Slave Download Mode to complete the Texture FIFO protocol.. ## **OutFIFOWords** | Name | Туре | Offset | Format | |--------------|------------------|--------|---------| | OutFIFOWords | Control Status | 0x0020 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------------------|------|-------|-------|----------------------------------------------------------------------------------------------------------------------| | 031 | Output FIFO<br>Words | ✓ | × | 0 | The number of valid words in the output FIFO. This number of words can be read before checking "OutFIFOWords" again. | Notes: The OutFIFOWords register shows the number of words currently in the output FIFO. This register can be read at any time. ## **PCIAbortAddress** | <b>Name</b> | <b>Type</b> Control Status Control register | Offset | <b>Format</b> | |-----------------|---------------------------------------------|--------|---------------| | PCIAbortAddress | | 0x098 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------------------|------|-------|-------|-------------| | 031 | PCIAbortAddr<br>ess | 1 | × | 0 | | Notes: The PCIAbortAddress register contains the first PCI Address issued by the PCI Master to cause an Abort. ## **PCIAbortStatus** | Name | Туре | Offset | Format | |----------------|------------------|--------|----------| | PCIAbortStatus | Control Status | 0x090 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-------|-------|-------------------------------------------------------------| | 06 | ReadSource | 1 | × | 0 | The read source in the DMA Arbiter that caused the Abort. | | 7 | ReadStatus | 1 | × | 0 | 0 = No read abort 1 = Read abort | | 814 | WriteSource | 1 | × | 0 | The Write source in the DMA Arbiter which caused the Abort. | | 15 | WriteStatus | 1 | × | 0 | 0 = No Write abort $1 = Write abort.$ | | 1631 | Reserved | 1 | × | 0 | | Notes: The PCIAbortStatus register reports whether a PCI Master read or write operation has caused an abort (either a Master Abort or Target Abort.). The PCIAbortAddress register can be read to determine the first PCI Address issued which caused an abort. The PCIAbortStatus register can be cleared by writing any value to the register. #### **PCIFeedbackCount** | Name | Туре | Offset | Format | | |------------------|------------------|--------|---------|--| | PCIFeedbackCount | Control Status | 0x088 | Integer | | | | Control register | | _ | | | Bits | Name | Read | Write | Reset | Description | |------|-----------------------|------|-------|-------|------------------------------------------------------------------| | 031 | PCI Feedback<br>Count | ✓ | × | 0 | Number of words that have been transferred in the DMA operation. | Notes: The PCIFeedbackCount register can be read to monitor the progress of a Feedback DMA. The value returned is the number of double words transferred in the current DMA ## **PCIPLLStatus** | Name | Туре | Offset | Format | |--------------|------------------|--------|----------| | PCIPLLStatus | Control Status | 0x00F0 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------------------|------|-------|------------|----------------------------------------------| | 08 | PCIPLLSetup | 1 | ✓ | 0x<br>1327 | Provides 9 bits of setup for the deskew PLL. | | 911 | PCIPLL<br>PostScale | ✓ | ✓ | 0x1 | Divide by 2 | | 12 | PCIPLL Enable | ✓ | ✓ | 0x1 | | | 1330 | Reserved | 1 | × | 0 | 0 | | 31 | Reserved | × | × | 0 | Deskew lock | Notes: The PCIPLLStatus register controls the PCI deskew PLL status bits. ## ResetStatus | Name | Туре | Offset | Format | |-------------|------------------|--------|---------| | ResetStatus | Control Status | 0x00 | Integer | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------------|------|-------|-------|---------------------------| | | _ | | | | | | 030 | Reserved | ✓ | × | 0 | | | 31 | Software Reset | 1 | 1 | 0 | 0 = GP is ready for use. | | | Flag | | | | 1 = GP is being reset and | | | | | | | must not be used | Notes: Writing to the reset status register causes a software reset of the graphics processor (GP). The software reset does not reset the bus interface. The reset takes a number of cycles to complete during which the graphics processor should not be used. A flag in the register shows that the software reset is still in progress. ## **TexDMAAddress** NameTypeOffsetFormatTexDMAAddressControl Status<br/>Control register0x120Integer | Bits | Name | Read | Write | Reset | Description | |------|-------------------|------|-------|-------|-------------| | 031 | TexDMA<br>Address | ✓ | × | X | | Notes: This register returns the address of the last data returned in response to a texture read operation. ## **TexFIFOSpace** NameTypeOffsetFormatTexFIFOSpaceControl Status0x128IntegerControl register Bits Name Read Write Reset Description 0...31 TexFIFOSpace ✓ × 0x10 Notes: This register returns number of 128-bit spaces in the Texture Data FIFO. space is decremented by 1 after four 32-bit writes to the FIFO region. Software must always write in multiples of four 32-bit words. ## **TextureDownloadControl** NameTypeOffsetFormatTextureDownloadControlControl Status<br/>Control register0x108Bitfield | Bits | Name | Read | Write | Reset | Description | |------|-------------------------------|------|-------|-------|-----------------------------------------------------------------------------| | 0 | Texture<br>Download<br>Enable | ✓ | ✓ | X | | | 1 | Texture<br>Download Busy | 1 | × | X | | | 2 | Texture<br>MemType | ✓ | ✓ | X | 0 = PCI, 1 = AGP Download | | 37 | TextureGranula rity | ✓ | ✓ | X | | | 812 | TextureThresh old | ✓ | ✓ | X | | | 13 | SlaveTextureD<br>ownload | ✓ | ✓ | X | 0 = Use Texture DMA for downloads - Slave Writes to the FIFO are discarded. | | | | | | | 1 = Use Slave writes into the FIFO. (slave Reads of FIFO return zero) | | 1431 | Reserved | ✓ | × | 0 | | | Motos. | | | |--------|--|--| # **TextureOperation** | Name | Туре | Offset | Format | |------------------|------------------|--------|---------| | TextureOperation | Control Status | 0x110 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-------|-------|-------------| | 08 | Length | 1 | × | X | | | 910 | Memory Pool | 1 | × | X | | | 11 | Host Virt | 1 | × | X | | | 1231 | Reserved | 1 | × | X | | Notes: Required in Slave Download Mode to complete the Texture FIFO protocol. ## **VCIkRDacCtI** | Name | Туре | Offset | Format | |-------------|------------------|--------|----------| | VClkRDacCtl | Control Status | 0x40 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------------|------|-------|-------|-------------| | 0 | VidCtl(0) pin | ✓ | ✓ | 0 | | | 1 | VidCtl(1) pin | 1 | ✓ | 0 | | Notes: This 2 bit register is used to select which set of RAMDAC control registers is used to control the DClk PLL. # 4.3 Region 0 Bypass Controls (0x0300-0x03FF) # ByAperture1Mode ByAperture2Mode NameTypeOffsetFormatByAperture1ModeBypass Control0x0300BitfieldByAperture2ModeBypass Control0x0328BitfieldControl register | Bits | Name | Read | Write | Reset | Description | |------|-----------------|----------|----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 01 | ByteSwap | <b>√</b> | <b>√</b> | 0 | Controls byte swapping on writing to or reading from local memory. | | | | | | | 0 = ABCD (no swap)<br>1 = BADC (byte (half word swapped)<br>swapped) 3 = DCBA | | 2 | PatchEnable | 1 | ✓ | 0 | Organizes accesses to local memory to fit 2 dimensional patch. $0 = Off 1 = On$ | | 34 | Format | <b>√</b> | ✓ | 0 | Pixel format. YUV formats are converted from planar 420 to 422 format on writing, and from 422 to planar 420 on reads: 0 = Raw | | 56 | PixelSize | 1 | 1 | 0 | 0 = 8 bits<br>1 = 16 bits<br>2 = 32 bits<br>3 = Reserved | | 78 | EffectiveStride | <b>√</b> | ✓ | 0 | Stride used to calculate patched address. Should always be bigger or equal to the real stride of the display" $0 = 1024 \qquad 1 = 2048$ $2 = 4096 \qquad 3 = 8192$ | | 915 | PatchOffsetX | ✓ | ✓ | 0 | Adjusts X position within patch. | | 1620 | PatchOffsetY | ✓ | ✓ | 0 | Adjusts Y position within patch. | | 21 | Buffer | ✓ | ✓ | 0 | 0 = Framebuffer $1 = Localbuffer$ | | 2224 | DoubleWrite | ✓<br> | <b>√</b> | 0 | Do two writes for every one received. Defines the boundary on which the second write occurs. A write to an odd multiple of the segment specified causes a write to the corresponding even segment; a write to an even segment causes a write to the odd segment. $0 = Off$ $1 = 1 \text{ Mbyte}$ $2 = 2 \text{ Mbytes}$ $3 = 4 \text{ Mbytes}$ $4 = 8 \text{ Mbytes}$ $5 = 16 \text{ Mbytes}$ $6 = 32 \text{ Mbytes}$ $7 = \text{Reserved}$ | | 2531 | Reserved | <b>√</b> | × | 0 | * | Notes: # ByAperture1UStart ByAperture2UStart | Name | Type | Offset | Format | |-------------------|------------------------------------|--------|---------| | ByAperture1UStart | Bypass Control | 0x0318 | Integer | | ByAperture2UStart | Bypass Control<br>Control register | 0x0340 | Integer | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------------------------------| | 023 | UStart | ✓ | ✓ | X | Number of 128 bit transfers before interpreting data as U. | | 2431 | Reserved | ✓ | × | X | | Notes: Used to control the conversion of planar YUV to packed YUV, this register sets the number of transfers to do before interpreting the data as U. # ByAperture1VStart ByAperture2VStart | Name | Туре | Offset | Format | |-------------------|------------------|--------|---------| | ByAperture1VStart | Bypass Control | 0x0320 | Integer | | ByAperture2VStart | Bypass Control | 0x0348 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------------------------------| | 023 | VStart | 1 | ✓ | X | Number of 128 bit transfers before interpreting data as V. | | 2431 | Reserved | 1 | × | X | | Notes: Used to control the conversion of planar YUV to packed YUV, this register sets the number of transfers to do before interpreting the data as V. # ByAperture1YStart ByAperture2YStart | Name | Туре | Offset | Format | |-------------------|------------------------------------|--------|---------| | ByAperture1YStart | Bypass Control | 0x0310 | Integer | | ByAperture2YStart | Bypass Control<br>Control register | 0x0338 | Integer | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------------------------------| | 023 | YStart | 1 | ✓ | X | Number of 128 bit transfers before interpreting data as Y. | | 2431 | Reserved | 1 | × | X | | Notes: Used to control the conversion of planar YUV to packed YUV, this register sets the number of transfers to do before interpreting the data as Y. # ByAperture1Stride ByAperture2Stride | Name | Type | Offset | Format | |-------------------|------------------|--------|---------| | ByAperture1Stride | Bypass Control | 0x0308 | Integer | | ByAperture2Stride | Bypass Control | 0x0330 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|----------------------------| | 011 | Stride | ✓ | ✓ | X | Number of pixels per line. | | 1231 | Reserved | ✓ | × | X | | Notes: Sets the stride of the buffer in local memory. Only used when patching or doing YUV format conversions. # **ByDMAReadCommandBase** | Name | Туре | Offset | Format | |----------------------|------------------|--------|---------| | ByDMAReadCommandBase | Bypass Control | 0x0378 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------| | 03 | Reserved | 1 | × | X | | | 431 | Address | ✓ | ✓ | X | Base address of command buffer for DMA transfers from system memory to local memory. Always in system memory. Address is 128 bit aligned. | Notes: # ByDMAReadCommandCount | Name | Type | Offset | Format | |------------------|----------------|--------|---------| | ByDMAReadCommand | Bypass Control | 0x0380 | Integer | | Count | | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|----------------------------------------| | 031 | Count | 1 | 1 | X | Number of command packets to transfer. | Notes: # **ByDMAReadMode** NameTypeOffsetFormatByDMAReadModeBypass Control<br/>Control register0x0350Bitfield | Bits | Name | Read | Write | Reset | Description | | | | |------|-----------------|------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|------------------------------------|---------------| | 01 | ByteSwap | 1 | <b>√</b> | 0 | Controls byt | | n writing to o | r reading | | | | | | | 0 = ABCD<br>(no swap) | , , | 2 = CDAB<br>(half word<br>swapped) | 3 = DCBA | | 2 | PatchEnable | 1 | 1 | 0 | Organizes ac dimensional 0 = Off | cesses to local | memory to fi | t 2 | | 34 | Format | 1 | ✓ | 0 | Pixel format. YUV formats are converted from plana. 420 to 422 format on writing, and from 422 to planar 420 on reads. 0 = Raw 1 = YUYV | | | | | 56 | PixelSize | 1 | ✓ | 0 | 0 = 8 bits | 1 = 1 | 6 bits | | | 78 | EffectiveStride | ✓ | ✓ | 0 | 2 = 4096 | | | | | 915 | PatchOffsetX | ✓ | ✓ | 0 | Adjusts X po | osition within | patch. | | | 1620 | PatchOffsetY | 1 | ✓ | 0 | Adjusts Y po | sition within | patch. | | | 21 | Buffer | 1 | ✓ | 0 | 0 = Framebu | ıffer | 1 = Local | buffer | | 22 | Active | 1 | ✓ | 0 | Indicates the | e status of the<br>lle 1 = D | DMA.<br>MA Running | | | 23 | MemType | 1 | ✓ | 0 | Type of bus | protocol to us | se for DMA. | | | | | | | | 0 = PCI | 1 = A | GP | | | 2426 | Burst | 1 | ✓ | 0 | Size of burst | defined as lo | g2 of burst siz | e. | | 27 | Align | 1 | ✓ | 0 | Enables align<br>0 = Off | nment of trans | efers to 64 byte | e boundaries. | | 2831 | Reserved | 1 | × | 0 | | | | | Notes: Controls the operation of the DMA controller reading data from system memory and writing it to local memory. ## **ByDMAReadStride** NameTypeOffsetFormatByDMAReadStrideBypass Control<br/>Control register0x0358Integer | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|----------------------------| | 011 | Stride | ✓ | ✓ | X | Number of pixels per line. | | 1231 | Reserved | ✓ | × | X | | Notes: Sets the stride of the buffer in local memory. Only used when patching or doing YUV format conversions. ## **ByDMAReadUStart** NameTypeOffsetFormatByDMAReadUStartBypass Control<br/>Control register0x0368Integer | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------------------------------| | 023 | UStart | ✓ | 1 | X | Number of 128 bit transfers before interpreting data as U. | | 2431 | Reserved | ✓ | × | X | | Notes: Used to control the conversion of planar YUV to packed YUV, this register sets the number of transfers to do before interpreting the data as U. PERMEDIA3 Reference Guide Hardware Registers ## **ByDMAReadVStart** | Name | Туре | Offset | Format | |-----------------|------------------|--------|---------| | ByDMAReadVStart | Bypass Control | 0x0370 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------------------------------| | 023 | VStart | 1 | ✓ | X | Number of 128 bit transfers before interpreting data as V. | | 2431 | Reserved | ✓ | × | X | | Used to control the conversion of planar YUV to packed YUV, this register sets the number of transfers to do before interpreting the data as V. ## **ByDMAReadYStart** | Name | Туре | Offset | Format | |-----------------|------------------|--------|---------| | ByDMAReadYStart | Bypass Control | 0x0360 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------------------------------| | 023 | YStart | 1 | ✓ | X | Number of 128 bit transfers before interpreting data as Y. | | 2431 | Reserved | 1 | × | X | | Used to control the conversion of planar YUV to packed YUV, this register sets the number of transfers to do before interpreting the data as Y. # **ByDMAWriteCommand Base** | Name | Туре | Offset | Format | |-------------------|----------------|--------|---------| | ByDMAWriteCommand | Bypass Control | 0x03B0 | Integer | | Base | | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------------------------------------------------------------------| | 03 | Reserved | 1 | × | X | | | 431 | Address | ✓ | 1 | X | Base address of command buffer for DMA transfers from local memory to system memory. Always in | | | | | | | local memory. Address is 128 bit aligned. | | | | from focal memory to system memory. | |--|--|----------------------------------------| | | | local memory. Address is 128 bit align | | | | | | | | | Notes: # **ByDMAWriteCommandCount** NameTypeOffsetFormatByDMAWriteCommandBypass Control0x03B8IntegerCount Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|----------------------------------------| | 031 | Count | ✓ | ✓ | X | Number of command packets to transfer. | Notes: # **ByDMAWriteMode** NameTypeOffsetFormatByDMAWriteModeBypass Control<br/>Control register0x0388Bitfield | Bits | Name | Read | Write | Reset | Description | |------|-----------------|----------|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | 01 | ByteSwap | ✓ | 1 | 0 | Controls byte swapping on writing to or reading from local memory. 0 = ABCD (no swap) 1 = BADC (byte swapped) 2 = CDAB (half word swapped) 3 = DCBA | | 2 | PatchEnable | 1 | ✓ | 0 | Organizes accesses to local memory to fit 2 dimensional patch. $0 = Off$ $1 = On$ | | 34 | Format | <b>√</b> | ✓ | 0 | Pixel format. YUV formats are converted from planar 420 to 422 format on writing, and from 422 to planar 420 on reads. 0 = Raw | | 56 | PixelSize | 1 | <b>√</b> | 0 | 0 = 8 bits $1 = 16$ bits $2 = 32$ bits $3 = $ Reserved | | 78 | EffectiveStride | <b>√</b> | ✓ | 0 | Stride used to calculate patched address. Should always be bigger or equal to the real stride of the display. $0 = 1024$ $1 = 2048$ $2 = 4096$ $3 = 8192$ | | 915 | PatchOffsetX | ✓ | ✓ | 0 | Adjusts X position within patch. | | 1620 | PatchOffsetY | ✓ | ✓ | 0 | Adjusts Y position within patch. | | 21 | Buffer | <b>√</b> | ✓ | 0 | 0 = Framebuffer $1 = Localbuffer$ | | 22 | Active | 1 | 1 | 0 | Indicates the status of the DMA. 0 = DMA Idle | | 23 | MemType | ✓ | ✓ | 0 | Type of bus protocol to use for DMA. $0 = PCI$ $1 = AGP$ | | 2426 | Burst | ✓ | ✓ | 0 | Size of burst defined as log2 of burst size. | | 27 | Align | ✓ | ✓ | 0 | Enables alignment of transfers to 64 byte boundaries. | | 2831 | Reserved | ✓ | × | 0 | | Notes: Controls the operation of the DMA controller reading data from local memory and writing it to system memory. ## **ByDMAWriteStride** NameTypeOffsetFormatByDMAWriteStrideBypass Control<br/>Control register0x0390Integer | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|----------------------------| | 011 | Stride | ✓ | ✓ | X | Number of pixels per line. | | 1231 | Reserved | ✓ | X | X | | Notes: Sets the stride of the buffer in local memory. Only used when patching or doing YUV format conversions. ## **ByDMAWriteUStart** NameTypeOffsetFormatByDMAWriteUStartBypass Control<br/>Control register0x03A0Integer | Bits | Name | Read | Write | Reset | Description | |------|----------|------|----------|-------|------------------------------------------------------------| | 023 | UStart | 1 | <b>√</b> | X | Number of 128 bit transfers before interpreting data as U. | | 2431 | Reserved | ✓ | X | X | | Notes: Used to control the conversion of planar YUV to packed YUV, this register sets the number of transfers to do before interpreting the data as U. # **ByDMAWriteVStart** NameTypeOffsetFormatByDMAWriteVStartBypass Control<br/>Control register0x03A8Integer | Bits | Name | Read | Write | Reset | Description | |------|----------|------|----------|-------|------------------------------------------------------------| | 023 | VStart | 1 | <b>√</b> | X | Number of 128 bit transfers before interpreting data as V. | | 2431 | Reserved | 1 | X | X | | Notes: Used to control the conversion of planar YUV to packed YUV, this register sets the number of transfers to do before interpreting the data as V. # **ByDMAWriteYStart** | Name | Туре | Offset | Format | |------------------|------------------------------------|--------|---------| | ByDMAWriteYStart | Bypass Control<br>Control register | 0x0398 | Integer | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|------------------------------------------------------------| | 023 | YStart | 1 | <b>√</b> | X | Number of 128 bit transfers before interpreting data as Y. | | 2431 | Reserved | <b>√</b> | X | X | | Notes: Used to control the conversion of planar YUV to packed YUV, this register sets the number of transfers to do before interpreting the data as Y. #### 4.4 Region 0 Memory Control (0x1000-0x1FFF) #### LocalMemCaps Name Type Offset Format LocalMemCaps Memory Control 0x1018 Bitfield Command register | Bits | Name | Read | Write | Reset | Description | |------|-----------------------|----------|----------|-------|--------------------------------------------------------------------------------| | 03 | Column<br>Address | <b>√</b> | <b>√</b> | 0 | Address bits to use for column address. | | 47 | RowAddress | ✓ | ✓ | 0 | Address bits to use for row address. | | 811 | BankAddress | ✓ | ✓ | 0 | Address bits to use for bank address. | | 1215 | ChipSelect | ✓ | ✓ | 0 | Address bits to use for chip select. | | 1619 | PageSize | 1 | 1 | 0 | Page size (units = full width of memory)<br>0 = 32 units $1 = 64$ units, etc | | 2023 | RegionSize | 1 | 1 | 0xF | Region size (units = full width of memory)<br>0 = 32 units $1 = 64$ units, etc | | 24 | NoPrecharge<br>Opt | × | 1 | 0 | 0 = off $1 = onNote that this bit is not readable$ | | 25 | SpecialMode<br>Opt | 1 | 1 | 0 | 0 = off $1 = on$ | | 26 | TwoColorBloc<br>kFill | ✓ | ✓ | 0 | 0 = off $1 = on$ | | 27 | CombineBanks | ✓ | ✓ | 0 | 0 = off $1 = on$ | | 28 | NoWriteMask | ✓ | ✓ | 0x1 | 0 = off $1 = on$ | | 29 | NoBlockFill | ✓ | ✓ | 0x1 | 0 = off $1 = on$ | | 30 | HalfWidth | <b>√</b> | <b>√</b> | 0x1 | 0 = off $1 = on$ | | 31 | NoLookAhead | ✓ | ✓ | 0x1 | 0 = off $1 = on$ | # Notes: 1. The ColumnAddress, RowAddress, BankAddress, and ChipSelect fields select the bits of the absolute physical address that are to be used to define corresponding parameters. Each value follows on from the previous one, so the ChipSelect value starts at ColumnAddress + RowAddress + BankAddress and continues for ChipSelect bits. 2. The PageSize field defines the size of the page, and the RegionSize field defines the size of the region of memory that each of the four page detectors should be assigned to (so that it is set to one quarter of the memory size). #### LocalMemControl Name Type Offset Format LocalMemControl Memory Control 0x1028 Bitfield Command register | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|------------------------------------------------| | 02 | CASLatency | 1 | 1 | 0x3 | 0 = 0 clocks $1 = 1$ clock | | | | | | | 2 = 2 clocks $3 = 3$ clocks | | | | | | | 4 = 4 clocks $5 = 5$ clocks | | | | | | | 6 = 6 clocks $7 = 7$ clocks | | 3 | Interleave | ✓ | ✓ | 0 | 0 = off | | | | | | | 1 = on | | 421 | Reserved | ✓ | × | 0 | | | 2231 | Mode | ✓ | ✓ | 0x030 | Mode register value used to configure memory. | | | | | | | Bit 22 coresponds to bit 0 of register, bit 31 | | | | | | | corresponds to bit 9 of register. | Notes: 1. Values are for delays from the current operation to the next. If the delay is set to zero the next operation can follow the current one in the next CLK cycle. This generally means that the value loaded into the register is the corresponding data sheet value minus one. For example, the data sheet may specify the block write cycle time to be 2 clocks, so the register value would be one because there has to be a one clock delay between block writes. 2. Bits 22 and 31 of LocalMemControl register correspond respectively to bits 0 and 9 of the mode register in the memory device. #### LocalMemPowerDown Name Type Offset Format LocalMemPowerDown Memory Control 0x1038 Bitfield Command register | Bits | Name | Read | Write | Reset | Desci | iption | |------|----------|------|-------|-------|---------------------------|--------| | 0 | Enable | ✓ | ✓ | 0 | 0 = Off | 1 = On | | 116 | Reserved | ✓ | × | 0 | | | | 1731 | Delay | ✓ | ✓ | 0 | Timeout in 32 clock units | | Notes: Timeout between reseting memory to low power mode in 32 clock units. #### LocalMemRefresh Name Type Offset Format LocalMemRefresh Memory Control 0x1030 Bitfield Command register | Bits | Name | Read | Write | Reset | Descr | ription | |------|--------------|------|-------|-------|-------------------------|---------| | 0 | Enable | ✓ | ✓ | 1 | 0 = Off | 1 = On | | 17 | RefreshDelay | ✓ | ✓ | 0 | | | | 831 | Reserved | ✓ | X | 0 | Delay in 32 clock units | | Notes: Delay between refresh cycles in 32 clock units. # LocalMemTiming Name Type Offset Format LocalMemTiming Memory Control 0x1020 Bitfield Command register | Bits | Name | Read | Write | Reset | | Description | |------|----------------------------|----------|----------|-------|--------------------------------------------------------------|-------------------------------------------------------------| | 01 | TurnOn | ✓ | <b>√</b> | 0x3 | 0 = 0 clocks<br>3 = 3 clock | 2 = 2 clocks<br>1 = 1 clock | | 23 | TurnOff | ✓ | <b>√</b> | 0x3 | 0 = 0 clocks<br>2 = 2 clocks | 1 = 1 clock<br>1 = 1 clock<br>3 = 3 clock | | 45 | RegisterLoad | 1 | 1 | 0x3 | 0 = 0 clocks<br>2 = 2 clocks | 1 = 1 clock<br>3 = 3 clock | | 67 | BlockWrite | <b>√</b> | <b>√</b> | 0x3 | 0 = 0 clocks<br>2 = 2 clocks | 1 = 1 clock<br>3 = 3 clock | | 810 | ActivateToCom<br>mand | ✓ | ✓ | 0x7 | 0 = 0 clocks<br>2 = 2 clocks<br>4 = 4 clocks<br>6 = 6 clocks | 1 = 1 clock<br>3 = 3 clocks<br>5 = 5 clocks<br>7 = 7 clocks | | 1113 | PrechargeToAc<br>ti vate | ✓ | ✓ | 0x7 | 0 = 0 clocks<br>2 = 2 clocks<br>4 = 4 clocks<br>6 = 6 clocks | 1 = 1 clock<br>3 = 3 clocks<br>5 = 5 clocks<br>7 = 7 clocks | | 1416 | BlockWriteTo<br>Pr echarge | <b>√</b> | 1 | 0x7 | 0 = 0 clocks<br>2 = 2 clocks<br>4 = 4 clocks<br>6 = 6 clocks | 1 = 1 clock<br>3 = 3 clocks<br>5 = 5 clocks<br>7 = 7 clocks | | 1719 | WriteTo<br>Precharg e | ✓ | ✓ | 0x7 | 0 = 0 clocks<br>2 = 2 clocks<br>4 = 4 clocks<br>6 = 6 clocks | 1 = 1 clock<br>3 = 3 clocks<br>5 = 5 clocks<br>7 = 7 clocks | | 2023 | ActivateTo | ✓ | ✓ | 0xF | 0 = 0 clocks | $1 = 1 \operatorname{clock}$ | |------|--------------|---|---|-----|----------------|------------------------------| | | Precharge | | | | 2 = 2 clocks | 3 = 3 clocks | | | o o | | | | 4 = 4 clocks | 5 = 5 clocks | | | | | | | 6 = 6 clocks | 7 = 7 clocks | | | | | | | 8 = 8 clocks | 9 = 9 clocks | | | | | | | 10 = 10 clocks | 11 = 11 clocks | | | | | | | 12 = 12 clocks | 13 = 13 clocks | | | | | | | 14 = 14 clocks | 15 = 15 clocks | | 2427 | RefreshCycle | ✓ | ✓ | 0xF | 0 = 0 clocks | 1 = 1 clock | | | | | | | 2 = 2 clocks | 3 = 3 clocks | | | | | | | 4 = 4 clocks | 5 = 5 clocks | | | | | | | 6 = 6 clocks | 7 = 7 clocks | | | | | | | 8 = 8 clocks | 9 = 9 clocks | | | | | | | 10 = 10 clocks | 11 = 11 clocks | | | | | | | 12 = 12 clocks | 13 = 13 clocks | | | | | | | 14 = 14 clocks | 15 = 15 clocks | | 2831 | Reserved | ✓ | × | 0 | | | Notes: Values are for delays from the current operation to the next. If the delay is set to zero the next operation can follow the curent one in the next clock cycle. This generally means that the value loaded into the register is the corresponding data sheet value minus one. For example, the data sheet may specify the block write cycle time to be 2 clocks, so the register value would be 1 because there has to be a one clock delay between block writes. # **MemBypassWriteMask** | Name | Туре | Offset | Format | |--------------------|------------------|--------|---------| | MemBypassWriteMask | Memory Control | 0x1008 | Integer | | | Command register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|--------------------|-----------------------------------------------------| | 031 | Mask | <b>√</b> | <b>√</b> | 0xFFF<br>FFFF<br>F | Per bit control:<br>0 = mask write, 1 = allow write | Notes: This register determines the bits that get written to memory by way of the bypass. #### **MemCounter** | Name | Туре | Offset | Format | |------------|------------------|--------|---------| | MemCounter | Memory Control | 0x1000 | Integer | | | Command register | | · · | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|-------------| | 031 | Count | ✓ | × | 0 | | #### **MemScratch** NameTypeOffsetFormatMemScratchMemory Control0x1010IntegerCommand register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|----------------| | 031 | | ✓ | ✓ | | Scratch memory | Notes: Scratch memory #### RemoteMemControl NameTypeOffsetFormatRemoteMemControlMemory Control<br/>Command register0x1100Integer | Bits | Name | Read | Write | Reset | Descr | iption | |------|------------|------|-------|-------|---------|---------| | 0 | TxReadType | ✓ | ✓ | 0 | 0 = PCI | 1 = AGP | | 131 | Reserved | ✓ | X | 0 | | | | Motor: | | | |---------|--|--| | TNOTES. | | | | | | | # 4.5 Region 0 GP FIFO (0x2000-0x2FFF) No 0x2000 series registers are listed. # 4.6 Region 0 Video Control (0x3000-0x3FFF) # **DisplayData** NameTypeOffsetFormatDisplayDataVideo Control<br/>Control register0x3068Bitfield | Bits | Name | Read | Write | Reset | Description | |------|----------------|----------|-------|-------|-------------------------------------------------------------| | 0 | DataIn | <b>√</b> | X | X | 0 = Data line is low $1 = Data line is high$ | | 1 | ClkIn | 1 | × | X | 0 = Clock line is low $1 = $ Clock line is high | | 2 | DataOut | ✓ | ✓ | 1 | 0 = Drive data line low $1 = $ Tri-state data line | | 3 | ClkOut | ✓ | ✓ | 1 | 0 = Drive clock line low | | | | | | | 1 = Tri-state clock line | | 4 | LatchedData | ✓ | × | 0 | $0 = Data \ latched \ at \ 0$ $1 = Data \ latched \ at \ 1$ | | 5 | DataValid | ✓ | ✓ | 0 | 0 = DataIn not valid $1 = DataIn valid$ | | 6 | Start | ✓ | ✓ | 0 | 0 = Has not passed through start state | | | | | | | 1 = Has passed through start state | | 7 | Stop | ✓ | ✓ | 0 | 0 = Has not passed through stop state | | | | | | | 1 = Has passed through stop state | | 8 | Wait | ✓ | ✓ | 0 | 0 = Do not insert wait states | | | | | | | 1 = Insert wait states | | 9 | UseMonitorID | ✓ | ✓ | 0 | 0 = Use DDC $1 = $ Use MonitorID | | 1011 | MonitorIDIn[1. | ✓ | X | X | 0 = Data line is low, clock line is low | | | .0] | | | | 1 = Data line is high, clock is high | | | | | | | 2 = clock is high, data is low | | | | | | | 3 = both high | | 12 | Reserved | ✓ | × | 0 | | | 1314 | MonitorIDOut | × | ✓ | 0x3 | 0 = Drive data line low | | | [10] | | | | 1 = Tri-state data line | | 1531 | Reserved | ✓ | × | 0 | | Notes: Some bits in this register are set during operation and cleared by writing to the register with those bits set. The bits are DataValid, Start and Stop # **FifoControl** | Name | Туре | Offset | Format | |-------------|------------------|--------|----------| | FifoControl | Video Control | 0x3078 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------------|----------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------| | 04 | LowThreshold | <b>√</b> | <b>√</b> | 0x10 | Request data from memory with low priority when there are this many spaces in the fifo. | | 57 | Reserved | ✓ | X | 0 | | | 812 | High Threshold | ✓ | 1 | 0x10 | Request data from memory with high priority when there are this many spaces in the fifo. | | 1315 | Reserved | ✓ | X | 0 | | | 16 | Underflow | 1 | 1 | 0 | This bit is set by the by the behavioural code. It is cleared by writing a 1 to this bit. 0 = underflow has not occurred 1 = underflow has occured | | 1731 | Reserved | ✓ | × | 0 | | # **HbEnd** | Name | Type | Offset | Format | |-------|------------------|--------|---------| | HbEnd | Video Control | 0x3020 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|----------|-------|--------------------------------------------| | 010 | HbEnd | ✓ | <b>√</b> | X | First 128 bit unit out of horizontal blank | | 1131 | Reserved | ✓ | × | 0 | | # **HgEnd** | <b>Name</b><br>HgEnd | <b>Type</b><br>Video Control | <b>Offset</b> 0x3018 | Format | | |----------------------|------------------------------|----------------------|---------|--| | rigena | Control register | 0x3010 | Integer | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|----------------------------------| | 110 | HgEnd | ✓ | ✓ | X | Last 128 bit unit in gate period | | 1131 | Reserved | ✓ | × | 0 | | | Notes: | | • | |--------|--|---| PERMEDIA3 Reference Guide Hardware Registers #### **HsEnd** Name Offset **Format Type** Video Control HsEnd 0x3030 Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|--------------------------------------------| | 010 | HsEnd | ✓ | ✓ | X | First 128 bit unit out of horizontal sync. | | 1131 | Reserved | ✓ | X | 0 | | Notes: #### **HsStart** Name Type Offset **Format** Video Control HsStart 0x3028 Integer Control register Rits Read Write Reset Description | | l l | | | | • | |-----|----------|----------|---|---|----------------------------------------| | 010 | HsStart | <b>√</b> | 1 | X | First 128 bit unit in horizontal sync. | | 113 | Reserved | <b>√</b> | × | 0 | | Notes: # **HTotal** Name Type Offset **Format** HTotal Video Control 0x3010 Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|-------|-------|-----------------------------------------------------------------| | 010 | HTotal | <b>√</b> | 1 | X | Last 128 bit unit (including horizontal blank period) on screen | | 1131 | Reserved | ✓ | X | 0 | | Notes: # InterruptLine NameTypeOffsetFormatInterruptLineVideo Control0x3060Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|---------------|------|-------|-------|------------------------------------------| | 010 | InterruptLine | ✓ | ✓ | X | Generate interrupt at start of this line | | 1131 | Reserved | ✓ | × | 0 | | Notes: #### **MiscControl** NameTypeOffsetFormatMiscControlVideo Control0x3088Bitfield Control register | Bits | Name | Read | Write | Reset | | Description | |------|------------|------|-------|-------|---------------|--------------| | | | | | | | - | | 01 | StripeMode | ✓ | ✓ | 0 | 0 = off | 1 = primary | | | | | | | 2 = secondary | 3 = reserved | | 23 | Reserved | ✓ | × | 0 | | | | 46 | StripeSize | ✓ | ✓ | 0 | 0 = 1 line | 1 = 2 lines | | | | | | | 2 = 4 lines | 3 = 8 lines | | | | | | | 4 = 16 lines | | | 7 | ByteDouble | ✓ | ✓ | 0 | | | #### **ScreenBase** NameTypeOffsetFormatScreenBaseVideo Control0x3000Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|------------------------------------------| | 020 | ScreenBase | ✓ | ✓ | X | Base address of screen in 128 bit units. | | 2131 | Reserved | × | × | 0 | | Notes: # ScreenBaseRight Name Type Offset Format ScreenBaseRight Video Control 0x3080 Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|---------------------|------|-------|-------|------------------------------------------------| | 020 | ScreenBase<br>Right | 1 | 1 | X | Base address of right screen in 128 bit units. | | 2131 | Reserved | X | X | 0 | | Notes: **ScreenBaseRight** updates may not take effect unless they are followed by a write to **ScreenBase**. This affects secondary chips in Striped mode only. #### **ScreenStride** Name Type Offset Format ScreenStride Video Control 0x3008 Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|--------------------------------------------| | 010 | ScreenStride | ✓ | ✓ | X | Stride between scanlines in 128 bit units. | | 1119 | Reserved | ✓ | ✓ | X | Mask to 0 | | 2031 | Reserved | × | × | 0 | | Notes: #### **VbEnd** NameTypeOffsetFormatVbEndVideo Control0x3040IntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|-------|-------|--------------------------------------| | 010 | VbEnd | ✓ | ✓ | X | First scanline out of vertical blank | | 1131 | Reserved | <b>√</b> | X | 0 | | | Notes: | | | |--------|--|--| # **VerticalLineCount** | Name | Туре | Offset | Format | |-------------------|------------------|--------|---------| | VerticalLineCount | Video Control | 0x3070 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------------|------|-------|-------|------------------------| | 010 | VerticalLineCo | ✓ | × | X | Current vertical line. | | | unt | | | | | | 1131 | Reserved | ✓ | × | 0 | | | Notes: | |--------| |--------| # **VideoControl** NameTypeOffsetFormatVideo ControlVideo Control0x3058BitfieldControl register | Bits | Name | Read | Write | Reset | Description | |------|----------------|----------|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | <b>√</b> | 1 | 0 | 0 = GP video disabled<br>1 = GP video enabled | | 1 | BlankCtl | 1 | 1 | 0 | 0 = Active High $1 = $ Active Low | | 2 | LineDouble | 1 | ✓ | 0 | 0 = Off 1 = On | | 34 | HSyncCtl | 1 | <b>√</b> | 0 | 0 = Forced High $1 = $ Active High | | | 3 | | | | 2 = Forced Low 3 = Active Low | | 56 | VSyncCtl | 1 | <b>√</b> | 0 | 0 = Forced High $1 = $ Active High | | | , | | | | 2 = Forced Low 3 = Active Low | | 7 | BypassPending | <b>√</b> | × | 0 | Read only bit set when ScreenBase register is loaded.<br>It is cleared when new value in ScreenBase has been used (i.e. during VBlank) | | | | | | | 0 = ScreenBase register data from bypass used<br>1 = ScreenBase register data from bypass not used<br>yet. | | 8 | Reserved | ✓ | X | 0 | | | 910 | BufferSwap | ✓ | ✓ | 0 | 0 = SyncOnFrameBlan k $1 = FreeRunning.$ | | | | | | | 2 = LimitToFrameRate 3 = Reserved | | 11 | Stereo | ✓ | ✓ | 0 | 0= Disabled 1 = Enabled. | | 12 | RightEyeCtl | ✓ | ✓ | 0 | 0=Active high $1$ = Active low | | 13 | RightFrame | 1 | × | 0 | 0 = Displaying left frame 1 = Displaying right frame | | 14 | VideoExtCtrl | 1 | 1 | 0 | 0 = low, 1 = high. This bit drives the PADVideo ExternalControl pin directly for use in controlling external devices. | | 15 | Reserved | X | X | 0 | Reserved | | 1617 | SyncMode | ✓ | ✓ | 0 | 0 = Independent 1 = SyncToVSA | | | - | | | | 2 = SyncToVSB $3 = Reserved$ | | 18 | PatchEnable | 1 | <b>√</b> | 0 | 0 = Off 1 = On | | 1920 | PixelSize | 1 | 1 | 0 | 0 = 8 bits 1 = 16 bits | | | | | | | 2 = 32 bits $3 = $ Reserved | | 21 | DisplayDisable | 1 | 1 | 0 | 0 = Off 1 = On | | 2227 | PatchOffsetX | 1 | <b>√</b> | 0 | | | 2831 | PatchOffsetY | 1 | 1 | 0 | | Notes: # VideoOverlayBase0 VideoOverlayBase1 VideoOverlayBase2 | Name | Туре | Offset | Format | |-------------------|------------------|--------|----------| | VideoOverlayBase0 | Video Overlay | 0x3120 | Bitfield | | | Control | | | | VideoOverlayBase1 | Video Overlay | 0x3128 | Bitfield | | · | Control | | | | VideoOverlayBase2 | Video Overlay | 0x3130 | Bitfield | | - | Control | | | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | | |------|------------|------|-------|-------|-----------------|-----------------| | | | | | | | | | 025 | Address | ✓ | ✓ | X | Pixel address. | | | 2629 | Reserved | ✓ | × | 0 | | | | 3031 | MemoryType | ✓ | ✓ | X | 0 = Framebuffer | 1 = Localbuffer | | | | | | | 2 = Reserved | 3 = Reserved | Notes: # VideoOverlayFieldOffset Name Type Offset Format VideoOverlayFieldOffset Video Overlay 0x3170 Integer Control Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|-------|-------|---------------------------------------------------------| | 03 | Reserved | <b>√</b> | X | 0 | | | 427 | Offset | ✓ | 1 | X | Scale factor as 12.12 2's complement fixed point value. | | 2831 | Reserved | ✓ | X | 0 | | | Notes: | | | |--------|--|--| # **VideoOverlayFIFOControl** NameTypeOffsetFormatVideoOverlayFIFOControlVideo Overlay0x3110Bitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|----------------| | 015 | Low | 1 | ✓ | 0 | Low threshold | | 1631 | High | 1 | 1 | 0xFF | High threshold | Notes: # VideoOverlayHeight NameTypeOffsetFormatVideoOverlayHeightVideo Overlay0x3148Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------| | 011 | Height | ✓ | ✓ | X | Height of overlay buffer in lines. | | 1231 | Reserved | ✓ | × | 0 | | Notes: # VideoOverlayIndex NameTypeOffsetFormatVideo Overlay IndexVideo Overlay0x3118Bitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------------------------------------| | 01 | Index | ✓ | ✓ | X | Base address register to use when BufferSync is<br>Manual | | 230 | Reserved | ✓ | × | 0 | | | 31 | Field | ✓ | ✓ | X | 0 = Odd $1 = Even$ | Notes: # VideoOverlayMode NameTypeOffsetFormatVideo Overlay ModeVideo Overlay0x3108Bitfield Control register | Bits | Name | Read | Write | Reset | Description | | |------|----------------|----------|----------|----------|------------------|------------------| | 0 | Enable | <b>√</b> | <b>√</b> | 0 | 0 = Off | 1 = On | | 13 | BufferSync | ✓ | ✓ | 0 | 0 = Manual | 1 = VideoStreamA | | | , | | | | 2 = VideoStreamB | 37 = Reserved | | 4 | FieldPolarity | ✓ | ✓ | 0 | 0 = Normal | 1 = Invert | | 56 | PixelSize | ✓ | ✓ | 0 | 0 = 8 bits | 1 = 16 bits | | | | | | | 2 = 32 bits | 3 = Reserved | | 79 | ColorFormat | ✓ | ✓ | 0 | 67 = Reserved | | | 1011 | YUV | ✓ | ✓ | 0 | 0 = RGB | 1 = YUV422 | | | | | | | 2 = YUV444 | 3 = Reserved | | 12 | ColorOrder | ✓ | ✓ | 0 | 0 = BGR | 1 = RGB | | 13 | LinearColorExt | ✓ | ✓ | 0 | 0 = Off | 1 = On | | | e nsion | | | | | | | 1415 | Filter | ✓ | ✓ | 0 | 0 = Off | 1 = Full | | | | | | | 2 = Partial | 3 = Reserved | | | | | | | (X with zoom) | | | 1617 | DeInterlace | ✓ | ✓ | 0 | 0 = Off | 1 = Bob | | | | | | | 23 = Reserved | | | 1819 | PatchMode | ✓ | ✓ | 0 | 0 = Off | 1 = On | | | | | | | 23 = Reserved | | | | Flip | ✓ | ✓ | 0 | 0 = Video | 1 = VideoStreamA | | 2022 | | | | <u> </u> | | | | | | | | | 2 = VideoStreamB | 37 = Reserved | | 23 | MirrorX | ✓ | ✓ | 0 | 0 = Off | 1 = On | | 24 | MirrorY | ✓ | ✓ | 0 | 0 = Off | 1 = On | | 2531 | Reserved | ✓ | X | 0 | | | Notes: The following table shows the bit positions of each component in each color format. | | | | Internal | Color C | hannels | |-----------------|----------------|---------|------------|------------|-------------| | Color<br>Format | Color<br>Order | Name | R | G | В | | 0 | 0 | 8:8:8:8 | 8@0 | 8@8 | <u>8@16</u> | | 1 | 0 | 4:4:4:4 | <u>4@0</u> | <u>4@4</u> | <u>4@8</u> | | 2 | 0 | 5:5:5:1 | <u>5@0</u> | <u>5@5</u> | <u>5@10</u> | | 3 | 0 | 5:6:5 | <u>5@0</u> | <u>6@5</u> | <u>5@11</u> | | 4 | 0 | 3:3:2 | <u>3@0</u> | 3@3 | <u>2@6</u> | |---|---|---------|-------------|------------|------------| | 0 | 1 | 8:8:8:8 | <u>8@16</u> | 8@8 | <u>8@0</u> | | 1 | 1 | 4:4:4:4 | <u>4@8</u> | <u>4@4</u> | <u>4@0</u> | | 2 | 1 | 5:5:5:1 | <u>5@10</u> | <u>5@5</u> | <u>5@0</u> | | 3 | 1 | 5:6:5 | <u>5@11</u> | <u>6@5</u> | <u>5@0</u> | | 4 | 1 | 3:3:2 | <u>3@5</u> | <u>3@2</u> | <u>2@0</u> | | 5 | 1 | C18 | <u>8@0</u> | <u>8@0</u> | <u>8@0</u> | In YUV422 or YUV444 mode the ColorFormat field is ignored. The following bit positions are used: | | | | Internal Color Channels | | | | |-----|----------------|----------|-------------------------|------------|-------------|--| | YUV | Color<br>Order | Name | Y | U | V | | | 0 | 0 | RGB | - | - | - | | | 1 | 0 | YUV444 | 8@0 | 8@8 | <u>8@16</u> | | | 2 | 0 | YUV422 | <u>8@0</u> | 8@8 | 8@8 | | | 3 | 0 | Reserved | - | - | - | | | 0 | 1 | RGB | - | - | - | | | 1 | 1 | YUV444 | <u>8@16</u> | 8@8 | <u>8@0</u> | | | 2 | 1 | YUV422 | 8@8 | <u>8@0</u> | <u>8@0</u> | | | 3 | 1 | Reserved | - | - | - | | In YUV422 mode the U and V components share the same bits in alternate pixels; U is always in the lower 16 bits and V in the upper 16 bits. # VideoOverlayOrigin | <b>Name</b> | <b>Type</b> Video Overlay Control | Offset | <b>Format</b> | |--------------------|-----------------------------------|--------|---------------| | VideoOverlayOrigin | | 0x3150 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|---------------------------------------------------| | | | | | | | | 011 | XOrigin | ✓ | ✓ | X | X origin of data to display within source buffer. | | 1215 | Reserved | ✓ | × | 0 | | | 1627 | YOrigin | ✓ | ✓ | X | Y origin of data to display within source buffer. | | 2831 | Reserved | ✓ | × | 0 | | | Notes: | | | |--------|--|--| # VideoOverlayShrinkXDelta NameTypeOffsetFormatVideo OverlayVideo Overlay0x3158Bitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|---------------------------------------------------------| | 03 | Reserved | 1 | X | 0 | | | 427 | Delta | ✓ | 1 | X | Scale factor as 12.12 2's complement fixed point value. | | 2831 | Reserved | ✓ | × | 0 | | Notes: # **VideoOverlayStatus** NameTypeOffsetFormatVideoOverlayStatusVideo Overlay0x3178Bitfield Control Control register | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|--------------------------------------------| | | | | | | | | 0 | FIFOUnderflo | ✓ | ✓ | 0 | Set by overlay unit, cleared by writing 1. | | | W | | | | | | 13 | Reserved | X | × | 0 | | | 428 | Reserved | ✓ | X | X | | | 2931 | Reserved | ✓ | × | 0 | | Notes: # VideoOverlayStride NameTypeOffsetFormatVideoOverlayStrideVideo Overlay0x3138Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------------------| | 011 | Stride | ✓ | ✓ | X | Stride of overlay buffer in pixels. | | 1231 | Reserved | ✓ | X | 0 | | | Notes: | | | |--------|--|--| # VideoOverlayUpdate | Name | Туре | Offset | Format | |--------------------|---------------|--------|---------| | VideoOverlayUpdate | Video Overlay | 0x3100 | Integer | Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------------------------| | 0 | Enable | ✓ | ✓ | 0 | Set to 1 to enable update, cleared following update. | | 131 | Reserved | ✓ | × | 0 | | | Notes: | | | |--------|--|--| # VideoOverlayWidth | Name | Туре | Offset | Format | |-------------------|------------------|--------|---------| | VideoOverlayWidth | Video Overlay | 0x3140 | Integer | | - | Control | | _ | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------| | 011 | Width | ✓ | ✓ | X | Width of overlay buffer in pixels. | | 1231 | Reserved | ✓ | X | 0 | | | Notes: | | | |--------|--|--| # VideoOverlayYDelta | Name | Туре | Offset | Format | |--------------------|------------------|--------|---------| | VideoOverlayYDelta | Video Overlay | 0x3168 | Integer | | | Control | | | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|---------------------------------------------------------| | 03 | Reserved | 1 | X | 0 | | | 427 | Delta | 1 | 1 | X | Scale factor as 12.12 2's complement fixed point value. | | 2831 | Reserved | ✓ | X | 0 | | # VideoOverlayZoomXDelta | Name | Type | Offset | Format | |------------------------|---------------|--------|---------| | VideoOverlayZoomXDelta | Video Overlay | 0x3160 | Integer | | | Control | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------------| | 03 | Reserved | 1 | X | 0 | | | 416 | Delta | ✓ | ✓ | X | Scale factor as 1.12 unsigned | | 1731 | Reserved | ✓ | × | 0 | | Notes: #### **VsEnd** | Name | Туре | Offset | Format | |-------|------------------|--------|---------| | VsEnd | Video Control | 0x3050 | Integer | | | Control register | | _ | Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------------------| | 100 | VsEnd | ✓ | ✓ | X | First scanline out of vertical sync - 1 | | 3111 | Reserved | ✓ | X | 0 | | Notes: #### **VsStart** | <b>Name</b><br>VsStart | <b>Type</b> Video Control | <b>Offset</b> 0x3048 | <b>Format</b><br>Integer | |------------------------|---------------------------|----------------------|--------------------------| | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|--------------------------------------| | 010 | VsStart | ✓ | ✓ | X | First scanline in vertical sync – 1. | | 1131 | Reserved | ✓ | × | 0 | | | Notes: | | | | |---------|--|--|--| | INUICS. | | | | # **VTotal** NameTypeOffsetFormatVTotalVideo Control0x3038IntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|----------|-------|-----------------------------------------------------------| | 010 | VTotal | ✓ | <b>√</b> | X | Last scanline on screen, including vertical blank period. | | 1131 | Reserved | ✓ | × | 0 | | | Notes: | | | |--------|--|--| #### 4.7 Region 0 RAMDAC Direct and Indirect RAMDAC registers are listed separately. #### 4.7.1 Direct RAMDAC Registers (0x4000-0x4FFF) #### **RDIndexControl** | Name | Туре | Offset | Format | |----------------|------------------|--------|---------| | RDIndexControl | RAMDAC | 0x4038 | Integer | | | Control | | _ | | | Control register | | | | Bits | Name | Read | Write | Reset | Descri | ption | |------|---------------|------|-------|-------|--------------|-------------| | 0 | AutoIncrement | ✓ | ✓ | 0 | 0 = Disabled | 1 = Enabled | | 17 | Reserved | ✓ | × | 0 | | | Notes: The register is accessed directly by reading or writing to the defined address. It is a byte wide and set on an 8 byte boundary in the PCI address range. When accessed from the SVGA it is set on a byte boundary. #### **RDIndexedData** | Name | Туре | Offset | Format | |---------------|------------------|--------|---------| | RDIndexedData | RĂMDAC | 0x4030 | Integer | | | Control | | J | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 07 | Data | ✓ | ✓ | X | | - Notes: 1. A read or write to this register will access the register pointed to by the RDIndex register. Following a read or write to this register, the index will be incremented if AutoIncrement is enabled in RDIndexControl. - The register is accessed directly by reading or writing to the defined address. It is a byte wide and set on an 8 byte boundary in the PCI address range. When accessed from the SVGA it is set on a byte boundary # **RDIndexHigh** Name Type Offset Format RDIndexHigh RAMDAC 0x4028 Integer Control Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 02 | Index | ✓ | ✓ | X | | | 37 | Reserved | ✓ | × | 0 | | Notes: 1. This register, with RDIndexLow, selects the register that will be accessed when the RDIndexedData register is written or read. 2. The register is accessed directly by reading or writing to the defined address. It is a byte wide and set on an 8 byte boundary in the PCI address range. When accessed from the SVGA it is set on a byte boundary #### **RDIndexLow** NameTypeOffsetFormatRDIndexLowRAMDAC0x4020IntegerControl Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|-------------| | 07 | Index | ✓ | ✓ | X | | Notes: 1. This register, with RDIndexHigh, selects the register that will be accessed when the RDIndexedData register is written or read. 2. The register is accessed directly by reading or writing to the defined address. It is a byte wide and set on an 8 byte boundary in the PCI address range. When accessed from the SVGA it is set on a byte boundary #### 4.7.2 Indirect RAMDAC Registers (0x200-0xFFF) #### **RDCheckControl** Name Type Offset Format RDCheckControl RAMDAC 0x018 Bitfield Control Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------------------------------------------------------------------| | 0 | Pixel | <b>√</b> | <b>√</b> | 0 | Set to start checksum, cleared when complete. | | | | | | | 0 = Disabled $1 = Enabled$ | | 1 | LUT | 1 | 1 | 0 | Set to start checksum, cleared when complete. 0 = Disabled 1 = Enabled | | 27 | Reserved | ✓ | X | 0 | | Notes: - This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. - You can use this register to tell the RAMDAC to sum the R, G and B values for a scan line. Typically, wait for Vblank, enable checksum before or after LUT, wait for RAMDAC to sum first active scanline (after which enable bits are Reset) then read RDCheckLUT\* or RDCheckPixel\* registers for the corresponding RGB component values. #### **RDCheckLUTBlue** Name Type Offset Format RDCheckLUTBlue RAMDAC 0x01E Integer Control Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|--------------------------------------------------| | 07 | CheckSum | ✓ | × | X | Checksum for blue component after look-up table. | #### **RDCheckLUTGreen** NameTypeOffsetFormatRDCheckLUTGreenRAMDAC<br/>Control0x01DInteger Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|---------------------------------------------------| | 07 | CheckSum | ✓ | X | X | Checksum for green component after look-up table. | #### **RDCheckLUTRed** NameTypeOffsetFormatRDCheckLUTRedRAMDAC0x01CInteger Control Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------------------------------| | 07 | CheckSum | ✓ | X | X | Checksum for red component after look-up table. | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. #### **RDCheckPixelBlue** NameTypeOffsetFormatRDCheckPixelBlueRAMDAC0x01BIntegerControl Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------------------------------| | 07 | CheckSum | ✓ | × | X | Checksum for blue component after pixel processing. | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. #### **RDCheckPixelGreen** NameTypeOffsetFormatRDCheckPixelGreenRAMDAC0x01AIntegerControl Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------------------------| | 07 | CheckSum | 1 | × | X | Checksum for green component after pixel processing. | #### **RDCheckPixelRed** NameTypeOffsetFormatRDCheckPixelRedRAMDAC0x019IntegerControl Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|-------|-------|----------------------------------------------------| | 07 | CheckSum | <b>√</b> | × | X | Checksum for red component after pixel processing. | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. #### **RDColorFormat** NameTypeOffsetFormatRDColorFormatRAMDAC0x004Bitfield Control Control register | Bits | Name | Read | Write | Reset | Description | |------|--------------------------|----------|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | 04 | ColorFormat | <b>√</b> | <b>√</b> | X | See table below | | 5 | RGB | ✓ | ✓ | X | Color ordering, see table below. | | 6 | LinearColorExt<br>ension | ✓ | ✓ | X | 0 = Disabled - pad low order bits of components less than 8 bits with zeros. 1 = Enabled - linearly extend low order bits of components less than 8 bits. | | 7 | Reserved | ✓ | X | 0 | | - Notes: 1. This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. - 2. The table below shows the bit positions for each color format specified. The color format is defined in the form number of bits @ bit position, where the bit position defines the first bit of the component with sucessive bits at incresing bit positions. | | | | Interna | l Color | Chann | els | |-------------|-----|---------------|-------------|-------------|--------------|-------------| | ColorFormat | RGB | Name | R | G | В | 0 | | 0 | 0 | 8:8:8:8 | 8@0 | 8@8 | 8@16 | 8@24 | | 1 | 0 | 5:5:5:1Front | 5@0 | 5@5 | 5@10 | 1@15 | | 2 | 0 | 4:4:4:4 | 4@0 | 4@4 | 4@8 | 4@12 | | 3 | 0 | Reserved | 8@0 | 8@8 | 8@16 | | | 4 | 0 | Reserved | 8@0 | 8@8 | 8@16 | 8@24 | | 5 | 0 | 3:3:2Front | 3@0 | 3@3 | 2@6 | 0 | | 6 | 0 | 3:3:2Back | 3@8 | 3@11 | 2@14 | 0 | | 7 | 0 | Reserved | 8@0 | 8@8 | 8@16 | 8@24 | | 8 | 0 | Reserved | 8@0 | 8@8 | <u>8@16</u> | 8@24 | | 9 | 0 | 2:3:2:1Front | 2@0 | 3@2 | 2@5 | 1@7 | | 10 | 0 | 2:3:2:1Back | 2@8 | 3@10 | 2@13 | 1@15 | | 11 | 0 | 2:3:2FrontOff | 2@0 | 3@2 | <u> 2@5</u> | 0 | | 12 | 0 | 2:3:2BackOff | 2@8 | 3@10 | <u> 2@13</u> | 0 | | 13 | 0 | 5:5:5:1Back | <u>5@16</u> | <u>5@21</u> | <u>5@26</u> | 1@31 | | 14 | 0 | CI8 | - | - | - | - | | 15 | 0 | Reserved | <u>8@0</u> | <u>8@8</u> | <u>8@16</u> | 8@24 | | 16 | 0 | 5:6:5Front | <u>5@0</u> | <u>6@5</u> | <u>5@11</u> | 0 | | 17 | 0 | 5:6:5Back | | <u>6@21</u> | <u>5@27</u> | 0 | | 18 | 0 | Reserved | <u>8@0</u> | <u>8@8</u> | <u>8@16</u> | 8@24 | | 1931 | 0 | Reserved | <u>8@0</u> | <u>8@8</u> | <u>8@16</u> | 8@24 | | 0 | 1 | 8:8:8:8 | | <u>8@8</u> | <u>8@0</u> | 8@24 | | 1 | 1 | 5:5:5:1Front | <u>5@10</u> | | <u>5@0</u> | 1@15 | | 2 | 1 | 4:4:4:4 | <u>4@8</u> | <u>4@4</u> | <u>4@0</u> | 4@12 | | 3 | 1 | Reserved | <u>8@16</u> | <u>8@8</u> | <u>8@0</u> | 8@24 | | 4 | 1 | Reserved | | <u>8@8</u> | <u>8@0</u> | <u>8@24</u> | | 5 | 1 | 3:3:2Front | <u>3@5</u> | <u>3@2</u> | <u>2@0</u> | 0 | | 6 | 1 | 3:3:2Back | | <u>3@10</u> | <u> 2@8</u> | 0 | | 7 | 1 | Reserved | <u>8@16</u> | <u>8@8</u> | <u>8@0</u> | 8@24 | | 8 | 1 | Reserved | | <u>8@8</u> | <u>8@0</u> | 8@24 | | 9 | 1 | 2:3:2:1Front | <u>2@5</u> | <u>3@2</u> | <u>2@0</u> | <u>1@7</u> | | 10 | 1 | 2:3:2:1Back | <u>2@13</u> | | <u>2@8</u> | <u>1@15</u> | | 11 | 1 | 2:3:2FrontOff | <u> 2@5</u> | <u>3@2</u> | <u>2@0</u> | 0 | | 12 | 1 | 2:3:2BackOff | <u>2@13</u> | 3@10 | <u>2@8</u> | 0 | | 13 | 1 | 5:5:5:1Back | <u>5@26</u> | <u>5@21</u> | <u>5@16</u> | <u>1@31</u> | | 14 | 1 | CI8 | - | - | - | - | | 15 | 1 | Reserved | <u>8@16</u> | | <u>8@0</u> | <u>8@24</u> | | 16 | 1 | 5:6:5Front | | <u>6@5</u> | <u>5@0</u> | 0 | | 17 | 1 | 5:6:5Back | <u>5@27</u> | <u>6@21</u> | <u>5@16</u> | 0 | | 1931 | 1 | Reserved | <u>8@1</u> | 8@8 | <u>8@0</u> | 8@2 | | | | | <u>6</u> | | | <u>4</u> | #### **RDCursorControl** | Name | Туре | Offset | Format | |-----------------|---------|--------|----------| | RDCursorControl | RAMDAC | 0x006 | Bitfield | | | Control | | | Control Control register | Bits | Name | Read | Write | Reset | Description | |------|----------------------|------|-------|-------|----------------------------------------------------------------------------------------| | 0 | DoubleX | 1 | 1 | 0 | 0 = Disabled. $1 = E$ nabled. | | 1 | DoubleY | ✓ | ✓ | 0 | 0 = Disabled. $1 = Enabled.$ | | 2 | ReadbackPositi<br>on | ✓ | 1 | 0 | 0 = Disabled - readback last value written.<br>1 = Enabled - readback position in use. | | 37 | Reserved | ✓ | X | 0 | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register #### **RDCursorHotSpotX** | Name | Type | Offset | Format | |------------------|------------------|--------|---------| | RDCursorHotSpotX | RAMDAC | 0x00B | Integer | | - | Control | | _ | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------------| | 05 | X | ✓ | ✓ | X | X position of hot spot in cursor. | | 67 | Reserved | ✓ | X | 0 | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register #### **RDCursorHotSpotY** | Name | Туре | Offset | Format | |------------------|-------------------|--------|---------| | RDCursorHotSpotY | RAMDAC<br>Control | 0x00C | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-----------------------------------| | 05 | Y | <b>√</b> | <b>√</b> | X | Y position of hot spot in cursor. | | 67 | Reserved | ✓ | × | 0 | | #### **RDCursorMode** NameTypeOffsetFormatRDCursorModeRAMDAC0x005BitfieldControl Control register | Bits | Name | Read | Write | Reset | Description | |------|-----------------------|----------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | CursorEnable | <b>√</b> | 1 | 0 | 0 = Disabled. $1 = Enabled.$ | | 13 | Format | 1 | 1 | 0 | 0 = 64x64 (2 bits per entry, partitions 0, 1, 2, and 3). 1 = 32x32 (2 bits per entry, partition 0). 2 = 32x32 (2 bits per entry, partition 1). 3 = 32x32 (2 bits per entry, partition 2). 4 = 32x32 (2 bits per entry, partition 3). 5 = 32x32 (4 bits per entry, partitions 0 and 1). 6 = 32x32 (4 bits per entry, partitions 2 and 3). | | 45 | Туре | 1 | <b>√</b> | 0 | 0 = Microsoft Windows. 1 = X Windows<br>2 = 3 Color 3 = 15 color | | 6 | ReversePixelOr<br>der | <b>√</b> | <b>√</b> | 0 | <ul> <li>0 = Disabled (incrementing pixel index goes left to right on screen).</li> <li>1 = Enabled (incrementing pixel index goes right to left on screen).</li> </ul> | | 7 | Reserved | ✓ | × | 0 | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the *RDIndexedData* register #### RDCursorPalette[0...44] NameTypeOffsetFormatRDCursorPalette[0...44]RAMDAC<br/>Control<br/>Control register0x303 to 0x32FInteger | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|--------------------------------------------------------------------------------------------------| | 07 | Color | ✓ | 1 | X | Stores the red, green, and blue color components for 15 cursor colors. These index from 1 to 15. | PERMEDIA3 Reference Guide Hardware Registers #### RDCursorPattern[0...1023] Offset **Format** Name Type RĂMDAC RDCursorPattern[0...1023] 0x400 to 0x7FF Integer Control Control register | Bits | Name | Read | Write | Reset | Description | |------|---------|------|----------|-------|-----------------------| | 07 | Pattern | ✓ | <b>√</b> | X | Bitmap for the cursor | These registers are accessed indirectly by first loading the indexes into the RDIndexLow and Notes: RDIndexHigh registers, and then reading or writing the RDIndexedData register #### **RDCursorXHigh** Name Offset **Format Type** RDCursortXHigh RAMDAC 0x008 Integer Control Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|-------|-------|-----------------------------------------------| | 03 | XHigh | <b>√</b> | ✓ | X | The high order bits of the cursor X position. | | 47 | Reserved | ✓ | X | 0 | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. Value at readback is determined by the ReadbackPosition field in the RDCursorControl register. #### **RDCursorXLow** 3Dlabs Name Offset **Format Type** RDCursortXLow RAMDAC 0x007Integer Control Control register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|----------------------------------------------| | 07 | XLow | ✓ | ✓ | X | The low order bits of the cursor X position. | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. Value at readback is determined by the ReadbackPosition field in the RDCursorControl register 4-75 #### **RDCursorYHigh** Name Type Offset Format RDCursorYHigh RAMDAC 0x00A Integer Control Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------------------------| | 03 | YHigh | ✓ | ✓ | X | The high order bits of the cursor Y position. | | 47 | Reserved | ✓ | X | 0 | | Notes: 1. This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. 2. Value at readback is determined by the ReadbackPosition field in the RDCursorControl register. #### **RDCursorYLow** NameTypeOffsetFormatRDCursorYLowRAMDAC0x009IntegerControl Control register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|----------------------------------------------| | 07 | YLow | ✓ | ✓ | X | The low order bits of the cursor Y position. | Notes: - 1. This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. - Value at readback is determined by the ReadbackPosition field in the RDCursorControl register. #### **RDDACControl** Name Type Offset Format RDDACControl RAMDAC 0x002 Bitfield Control Control register | Bits | Name | Read | Write | Reset | Description | | |------|-------------|------|-------|-------|------------------------------------|--| | 02 | DACPowerCtl | ✓ | ✓ | 0 | 0 = Normal operation. 1 = LowPower | | | 3 | Reserved | ✓ | ✓ | 0 | [SyncOnGreen] | | | 4 | BlankRedDAC | ✓ | ✓ | 0 | 0 = Disabled. | 1 = Enabled. | |---|---------------|---|---|---|---------------|--------------| | 5 | BlankGreen | ✓ | ✓ | 0 | 0 = Disabled. | 1 = Enabled. | | | DAC | | | | | | | 6 | BlankBlueDAC | ✓ | ✓ | 0 | 0 = Disabled. | 1 = Enabled. | | 7 | BlankPedestal | ✓ | ✓ | 0 | 0 = Disabled. | 1 = Enabled. | | | | | | | | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. #### RDDClk0FeedbackScale Name Type Offset Format RDDClk0FeedbackScale RAMDAC 0x202 Integer Control Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|-------------| | 07 | Value | ✓ | ✓ | 0x7 | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register #### RDDClk0PostScale | Name | Туре | Offset | Format | |------------------|------------------|--------|---------| | RDDClk0PostScale | RĂMDAC | 0x203 | Integer | | | Control | | J | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------| | 02 | Scale | ✓ | ✓ | 0 | 0 = Divide by 1. | | 37 | Reserved | ✓ | X | 0 | | # RDDClk1PostScale **RDDClkPostScale** | Name | Type | Offset | Format | |------------------|-------------------------|--------|---------| | RDDClk1PostScale | RĂMDAC | 0x206 | Integer | | | Control | | · · | | RDKClkPostScale | RAMDAC | 0x210 | Integer | | | Control | | Ü | | | $\alpha$ , 1 , $\alpha$ | | | Control register | Bits | Name | Read | Write | Reset | I | Description | |------|----------|----------|-------|-------|-----------------------------------------------------------|------------------------------------------------------| | 02 | Scale | <b>√</b> | ✓ | X | 0 = Divide by 1.<br>2 = Divide by 4.<br>4 = Divide by 16. | 1 = Divide by 2<br>3 = Divide by 8.<br>57 = Reserved | | 37 | Reserved | ✓ | × | 0 | • | | This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. #### RDDClk2PostScale RDDClk3PostScale | Name | Туре | Offset | Format | |------------------|------------------|--------|---------| | RDDClk2PostScale | RĂMDAC | 0x209 | Integer | | | Control | | _ | | RDDClk3PostScale | RAMDAC | 0x20C | Integer | | | Control | | Ü | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|----------|-------|-------------------------------------| | 02 | Scale | 1 | <b>√</b> | X | 0 = Divide by 1. 1 = Divide by 2. | | | | | | | 2 = Divide by 4. $3 = Divide by 8.$ | | | | | | | 4 = Divide by 16. 57 = Reserved | | 37 | Reserved | ✓ | × | 0 | | #### RDDClk0PreScale NameTypeOffsetFormatRDDClk0PreScaleRAMDAC0x201IntegerControl Control Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|-------------| | 07 | Value | ✓ | ✓ | 0x4 | | Notes: This register is accessed indirectly by first loading the index into the *RDIndexLow* and *RDIndexHigh* registers, and then reading or writing the *RDIndexedData* register. #### RDDClk1FeedbackScale NameTypeOffsetFormatRDDClk1FeedbackScaleRAMDAC0x24FInteger Control register | | Bits | Name | Read | Write | Reset | Description | |---|------|-------|------|-------|-------|-------------| | Ī | 07 | Value | ✓ | ✓ | 0x4F | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. #### RDDClk1PreScale NameTypeOffsetFormatRDDClk1PreScaleRAMDAC0x28Integer Control Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|-------------| | 07 | Value | ✓ | ✓ | 0x28 | | # RDDClk2FeedbackScale RDDClk3FeedbackScale NameTypeOffsetFormatRDDClk2FeedbackScaleRAMDAC0x208Integer Control RDDClk3FeedbackScale RAMDAC 0x20B Integer Control Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|-------------| | 07 | Value | ✓ | ✓ | X | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register # RDDClk2PreScale RDDClk3PreScale NameTypeOffsetFormatRDDClk2PreScaleRAMDAC<br/>Control0x207IntegerRDDClk3PreScaleRAMDAC<br/>Control<br/>Control<br/>Control register0x20AInteger | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|-------------| | 07 | Value | ✓ | ✓ | X | | ### **RDDClkControl** | Name | Type | Offset | Format | |---------------|---------|--------|----------| | RDDClkControl | RĂMDAC | 0x200 | bitfield | | | Control | | | Control register | Bits | Name | Read | Write | Reset | Des | scription | |------|----------|----------|-------|-------|-----------------------------|----------------------------------| | 0 | Clock | <b>√</b> | 1 | 1 | 0 = Disable | 1 = Enable | | 1 | Lock | ✓ | × | X | 0 = Not locked. | 1 = Locked. | | 23 | State | ✓ | 1 | 0x2 | 0 = Drive Low<br>2 = Run | 1 = Drive High<br>3 = Reserved | | 45 | Source | ✓ | 1 | 0 | 0 = PLL<br>2 = VideoStreamB | 1 = VideoStreamA<br>3 = External | | 67 | Reserved | <b>√</b> | X | 0 | | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register # RDDClkSetup1 RDKClkSetup1 | <b>Name</b><br>RDDClkSetup1 | <b>Type</b><br>RAMDAC | Offset<br>0x1F0 | <b>Format</b><br>Integer | |-----------------------------|------------------------------|-----------------|--------------------------| | RDKClkSetup1 | Control<br>RAMDAC<br>Control | 0x1F2 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|-------------| | 07 | Setup | ✓ | ✓ | 0x1C | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. # RDDClkSetup2 RDKClkSetup2 | <b>Name</b><br>RDDClkSetup2 | <b>Type</b><br>RAMDAC<br>Control | Offset<br>0x1F1 | <b>Format</b><br>Integer | |-----------------------------|----------------------------------|-----------------|--------------------------| | RDKClkSetup2 | RAMDAC Control Control register | 0x1F3 | Integer | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0 | Setup | ✓ | ✓ | 1 | | | 17 | Reserved | ✓ | × | 0 | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register ### **RDKClkControl** | Name | Type | Offset | Format | |---------------|------------------|--------|----------| | RDKclkControl | RAMDAC | 0x20D | Bitfield | | | Control | | | | | Control register | | | | Bits | Name | Read | Write | Reset | | Description | |------|----------|------|-------|-------|---------------|----------------| | | | | | | 2 2 1 | | | 0 | Clock | ✓ | ✓ | 1 | 0 = Disable | 1 = Enable | | 1 | Lock | ✓ | X | 0 | 0 = NotLocked | 1 = Locked | | 23 | State | ✓ | ✓ | 0x2 | 0 = Drive Low | 1 = Drive High | | | | | | | 2 = Run | 3 = Low Power | | 46 | Source | ✓ | ✓ | 0 | 0 = PClk | 1 = PClk/2 | | | | | | | 2 = PLL | 37 = Reserved | | 7 | Reserved | ✓ | X | 0 | | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. ### **RDKClkFeedbackScale** NameTypeOffsetFormatRDKClkFeedbackScaleRAMDAC0x20FInteger Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|-------------| | 07 | Value | ✓ | ✓ | 0x20 | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register #### **RDKClkPreScale** NameTypeOffsetFormatRDKClkPreScaleRAMDAC0x20EInteger Control Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|----------|-------|-------|-------------| | 07 | Value | <b>√</b> | ✓ | 0x10 | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register ### **RDMCIkControl** NameTypeOffsetFormatRDMClkControlRAMDAC0x211BitfieldControl Command register | Bits | Name | Read | Write | Reset | | Description | |------|-------------------|----------|----------|-------|--------------------------------------------------------------|---------------------------------| | 0 | Clock<br>Reserved | 1 | ✓<br>× | 1 | 0 = Disable | 1 = Enable | | 23 | State | <b>√</b> | <i>√</i> | 0x2 | 0 = Drive Low<br>2 = Run | 1 = Drive High<br>3 = Low Power | | 46 | Source | <b>√</b> | ✓ | 0x2 | 0 = PClk<br>2 = Reserved<br>4 = ExternalMClk<br>6 = KClk PLL | 5 = KClk PLL/2 | | 7 | Reserved | ✓ | × | 0 | | | Notes: This register is accessed indirectly by first loading the index into the **RDIndexLow** and RDIndexHigh registers, and then reading or writing the **RDIndexedData** register. When sourcing from KClk (Source=5 or Source=6) note that the KClk value is always set to the PLL, not to the value determined by the **KclkControl** register. ### **RDMiscControl** NameTypeOffsetFormatRDMiscControlRAMDAC0x000BitfieldControl Command register | Bits | Name | Read | Write | Reset | Description | |------|-------------------------|----------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | HighColor<br>Resolution | <b>V</b> | <b>√</b> | 0 | Controls the width of the palette data. 0 = Disabled - use 6 bits per entry. 1 = Enabled - use 8 bits per entry. | | 1 | PixelDouble | ✓ | ✓ | 0 | 0 = Disabled. $1 = Enabled.$ | | 2 | LastRead<br>Address | 1 | ✓ | 0 | Controls data returned by read from RDPaletteReadAddress register. 0 = Disabled - return palette access state. 1 = Enabled - return last palette read address. | | 3 | DirectColor | <b>√</b> | ✓ | 0 | 0 = Disabled. $1 = Enabled.$ | | 4 | Overlay | ✓ | ✓ | 0 | 0 = Disabled. $1 = Enabled.$ | | 5 | PixelDouble<br>Buffer | 1 | <b>√</b> | 0 | 0 = Disabled. $1 = Enabled.$ | | 6 | VSBOutput | ✓ | ✓ | 0 | Video Stream Port B Output | | | Ī | | | | 0 = Disabled $1 = Enabled$ | | 7 | StereoDouble<br>Buffer | 1 | <b>√</b> | 0 | Controls per-pixel double buffering in 5551 color format. 0 = Disabled. 1 = Enabled. | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. # **RDOverlayKey** Name Type Offset Format RDOverlayKey RAMDAC 0x00D Integer Control Control register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|--------------------------------------------------------------------------| | 07 | Key | ✓ | ✓ | X | Indicates the overlay bit pattern that should be treated as transparent. | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register #### **RDPaletteData** | Name | Туре | Offset | Format | |---------------|------------------|--------|---------| | RDPaletteData | RĂMDAC | 0x4008 | Integer | | | Control | | _ | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 07 | Data | ✓ | ✓ | X | | Notes: 1. If the color resolution is 6 bits, bits 6 and 7 are returned as zero for reads and ignored for writes. In this mode, bits 0 to 5 are read from, or written to, bits 2 to 7 of the palette. A read auto-increments RDPaletteReadAddress and RDPaletteWriteAddress, whereas a write autoincrements the RDPallettWriteAddress only. The register is accessed directly by reading or writing to the defined address. It is a byte wide and set on an 8 byte boundary in the PCI address range. When accessed from the SVGA it is set on a byte boundary. #### **RDPaletteReadAddress** | Name | Type | Offset | Format | |----------------------|------------------|--------|---------| | RDPaletteReadAddress | RAMDAC | 0x4018 | Integer | | | Control | | _ | | | Control register | | | | | Bits | Name | Read | Write | Reset | Description | |---|------|---------|------|-------|-------|-------------| | ĺ | 07 | Address | ✓ | ✓ | X | | Notes: The register is accessed directly by reading or writing to the defined address. It is a byte wide and set on an 8 byte boundary in the PCI address range. When accessed from the SVGA it is set on a byte boundary. ### **RDPaletteWriteAddress** | Name | Туре | Offset | Format | |-----------------------|-------------------|--------|---------| | RDPaletteWriteAddress | RAMDAC<br>Control | 0x4000 | Integer | | | Control | | | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|-------------| | 07 | Address | ✓ | ✓ | 0 | | Notes: The register is accessed directly by reading or writing to the defined address. It is a byte wide and set on an 8 byte boundary in the PCI address range. When accessed from the SVGA it is set on a byte boundary. #### **RDPan** | Name | Туре | Offset | Format | |-------|---------|--------|----------| | RDPan | RĂMDAC | 0x00E | Bitfield | | | Control | | | Control Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|----------|-------|--------------------------------| | 0 | Enable | 1 | <b>√</b> | X | Delay data by 32 bits. | | 1 | Gate | ✓ | ✓ | X | Discard first 64 bits on line. | | 72 | Reserved | ✓ | × | X | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. ### **RDPixelMask** | Name | Туре | Offset | Format | |-------------|---------|--------|---------| | RDPixelMask | RAMDAC | 0x4010 | Integer | | | Control | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 07 | Mask | ✓ | ✓ | X | | Notes: 1. The contents of this register is ANDed with the index into the color palette. The same mask is applied separately to red, green, and blue components. 2. The register is accessed directly by reading or writing to the defined address. It is a byte wide and set on an 8 byte boundary in the PCI address range. When accessed from the SVGA it is set on a byte boundary ### **RDPixelSize** | Name | Туре | Offset | Format | |-------------|------------------|--------|---------| | RDPixelSize | RĂMDAC | 0x003 | Integer | | | Control | | · · | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------------|----------|-------|-------|-------------------------------------------------------------------------------------| | 02 | Pixel Size | <b>√</b> | ✓ | X | 0 = 8 bits. 1 = 16 bits.<br>2 = 32 bits. 3 = Reserved<br>4 = 24 bits. 57 = Reserved | | 37 | Reserved | ✓ | X | 0 | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register ### **RDSCIkControl** | Name | Туре | Offset | Format | |---------------|------------------|--------|----------| | RDSClkControl | RĂMDAC | 0x215 | Bitfield | | | Control | | | | | Control register | | | | Bits | Name | Read | Write | Reset | | Description | |------|----------|------|-------|-------|------------------|--------------------| | | | | | | | | | 0 | Clock | ✓ | ✓ | 1 | 0 = Disable | 1 = Enable | | 1 | Reserved | ✓ | × | 0 | | | | 23 | State | ✓ | ✓ | 0x2 | 0 = Drive Low | 1 = Drive High | | | | | | | 2 = Run | 3 = Low Power | | 46 | Source | ✓ | ✓ | 0x0 | 0 = PClk | 1 = PClk/2 | | | | | | | 2 = Reserved | 3 = ExternalSClk/2 | | | | | | | 4 = ExternalSClk | 5 = KClk/2 | | | | | | | 6 = KClk | 7 = Reserved | | 7 | Reserved | ✓ | X | 0 | | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register ### **RDScratch** NameTypeOffsetFormatRDScratchRAMDAC0x001FIntegerControl Control register | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------------------------------------| | 07 | Scratch | ✓ | ✓ | X | User definable register for storing state. | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. #### **RDSense** NameTypeOffsetFormatRDSenseRAMDAC0x00FBitfieldControl Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0 | Red | 1 | X | X | | | 1 | Green | ✓ | × | X | | | 2 | Blue | ✓ | × | X | | | 37 | Reserved | ✓ | × | 0 | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register # **RDSyncControl** | Name | Type | Offset | Format | |---------------|------------------|--------|----------| | RDSyncControl | RĂMDAC | 0x001 | Bitfield | | · | Control | | | | | Control register | | | | Bits | Name | Read | Write | Reset | Descrip | tion | |------|---------------|----------|----------|-------|------------------------------------------------------------------------|---------------------------------------------------------------| | 02 | HSyncCtl | <b>√</b> | <b>√</b> | 0 | 0 = Active low at pin.<br>2 = Tri-state at pin.<br>57 = Reserved | 1 = Active high at pin.<br>3 = Force active | | 35 | VSyncCtl | 1 | 1 | 0 | 0 = Active low at pin.<br>2 = Tri-state at pin.<br>4 = Force inactive. | 1 = Active high at pin.<br>3 = Force active.<br>57 = Reserved | | 6 | HSyncOverride | ✓ | ✓ | 0 | 0 = As set by HsyncCtl | 1 = Force high | | 7 | VSyncOverride | ✓ | ✓ | 0 | 0 = As set by VsyncCtl1 = Fo | orce high | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. | Decimal values for | | | | |--------------------|--|--|--| | MSBs used | | | | | 0 = 0% | | | | | 64 = 25% | | | | | 128 = 50% | | | | | 192 = 75% | | | | # **RDVideoOverlayBlend** | Name | Type | Offset | Format | |---------------------|------------------|--------|---------| | RDVideoOverlayBlend | RĂMDAC | 0x002C | Integer | | ū | Control | | · · | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | | | | 05 | Reserved | ✓ | × | 0 | | | 67 | Factor | √ | ✓ | X | Proportion to blend main image and overlay, enabled by BlendSrc field of RDVideoOverlay Control Field register. $0=0\% \qquad 0x1=25\% \\ 0x2=59\% \qquad 0x3=75\%$ | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. ## **RDVideoOverlayControl** | Name | Туре | Offset | Format | |-----------------------|------------------|--------|----------| | RDVideoOverlayControl | RĂMDAC | 0x020 | Bitfield | | · · | Control | | | | | Control register | | | | Bits | Name | Read | Write | Reset | | Description | |------|-------------|----------|----------|-------|---------------|----------------| | 0 | Enable | 1 | <b>√</b> | 0 | 0 = Disabled. | 1 = Enabled. | | 12 | Mode | ✓ | ✓ | X | 0 = MainKey | 1 = OverlayKey | | | | | | | 2 = Always | 3 = Blend | | 3 | DirectColor | ✓ | ✓ | X | 0 = Disabled. | 1 = Enabled. | | 4 | BlendSrc | ✓ | ✓ | X | 0 = Main. | 1 = Register. | | 5 | Key | ✓ | ✓ | X | 0 = Color. | 1 = Alpha. | | 67 | Reserved | <b>√</b> | X | 0 | | - | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. # **RDVideoOverlayKeyB** | <b>Name</b> | <b>Type</b> RAMDAC Control Control register | Offset | <b>Format</b> | |--------------------|---------------------------------------------|--------|---------------| | RDVideoOverlayKeyB | | 0x02B | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------------------------------------| | 07 | Blue | ✓ | ✓ | X | The blue component for color key checking | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register # **RDVideoOverlayKeyG** Name Type Offset Format RDVideoOverlayKeyG RAMDAC 0x02A Integer Control Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|--------------------------------------------| | 07 | Green | ✓ | ✓ | X | The green component for color key checking | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. ## **RDVideoOverlayKeyR** Name Type Offset Format RDVideoOverlayKeyR RAMDAC 0x029 Integer Control Control register Bits Name Read Write Reset Description 0..7 Red ✓ ✓ X The red component for color key checking is also used to hold the alpha value during alpha test. Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register ## RDVideoOverlayXEndHigh Name Type Offset Format RDVideoOverlayXEndHigh RAMDAC 0x026 Integer Control Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------------------------| | 03 | XEndHigh | ✓ | 1 | X | High order bits of right hand edge of video overlay. | | 47 | Reserved | 1 | × | 0 | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. ### **RDVideoOverlayXEndLow** NameTypeOffsetFormatRDVideoOverlayXEndLowRAMDAC0x025IntegerControl Control register | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|-----------------------------------------------------| | 07 | XEndLow | ✓ | ✓ | X | Low order bits of right hand edge of video overlay. | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register ## RDVideoOverlayXStart High | Name | Type | Offset | Format | |----------------------|------------------|--------|---------| | RDVideoOverlayXStart | RĂMDAC | 0x022 | Integer | | High | Control | | o o | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|-----------------------------------------------------| | 03 | XStartHigh | ✓ | ✓ | X | High order bits of left hand edge of video overlay. | | 47 | Reserved | ✓ | × | 0 | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. ## RDVideoOverlayXStartLow | Name | Type | Offset | Format | |-------------------------|---------|--------|---------| | RDVideoOverlayXStartLow | RĂMDAC | 0x021 | Integer | | ű | Control | | Ü | Control register | Bit | Name | Read | Write | Reset | Description | |-----|-----------|------|-------|-------|----------------------------------------------------| | 07 | XStartLow | ✓ | ✓ | X | Low order bits of left hand edge of video overlay. | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. ## **RDVideoOverlayYEndHigh** | Name | Type | Offset | Format | |------------------------|------------------|--------|---------| | RDVideoOverlayYEndHigh | RAMDAC | 0x028 | Integer | | · · | Control | | · · | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------------------| | 03 | YEndHigh | ✓ | ✓ | X | High order bits of last line of video overlay. | | 47 | Reserved | ✓ | X | 0 | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. ### RDVideoOverlayYEndLow | <b>Name</b><br>RDVideoOverlayYEndLow | <b>Type</b><br>RAMDAC<br>Control | Offset<br>0x027 | <b>Format</b><br>Integer | |--------------------------------------|----------------------------------|-----------------|--------------------------| | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|-----------------------------------------------| | 07 | YEndLow | ✓ | ✓ | X | Low order bits of last line of video overlay. | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. # RDVideoOverlayYStartHigh | Name | Type | Offset | Format | |--------------------------|------------------|--------|---------| | RDVideoOverlayYStartHigh | RAMDAC | 0x024 | Integer | | , and a | Control | | S | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|-------------------------------------------------| | 03 | YStartHigh | ✓ | ✓ | X | High order bits of first line of video overlay. | | 47 | Reserved | ✓ | X | 0 | | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register. # RDVideoOverlayYStartLow | Name | Туре | Offset | Format | |-------------------------|------------------|--------|---------| | RDVideoOverlayYStartLow | RAMDAC | 0x023 | Integer | | · | Control | | · · | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-----------|----------|-------------|-------|------------------------------------------------| | 07 | YStartLow | <b>\</b> | <b>&gt;</b> | X | Low order bits of first line of video overlay. | Notes: This register is accessed indirectly by first loading the index into the RDIndexLow and RDIndexHigh registers, and then reading or writing the RDIndexedData register # 4.8 Region 0 Video Stream Processing (0x5000-0x5FFF) ### **VSAControl** Name Type Offset Format VSAControl Video stream 0x5900 Bitfield Control Control register | Bits | Name | Read | Write | Reset | Description | | |------|---------------|-------------|----------|-------|------------------------------------|-----------------------------------| | 0 | Video | | | 0 | 0 = Disable | 1 = Enable | | 1 | VIdeo | <b>√</b> | <b>√</b> | 0 | 0 = Disable<br>0 = Disable | 1 = Enable<br>1 = Enable | | 2 | BufferCtl | √<br>√ | √<br>√ | 0 | 0 = Disable<br>0 = Double buffered | 1 = Enable<br>1 = Triple buffered | | 34 | ScaleX | √<br>√ | 1 | 0 | 0 = Double buffered<br>0 = 1:1 | 1 = 111 pie bullered $1 = 2:1$ | | 34 | Scales | <b>V</b> | <b>'</b> | ١ | 0 = 1.1<br>2 = 4:1 | 3 = 8.1 | | 56 | ScaleY | 1 | 1 | 0 | 0 = 1:1 | 1 = 2:1 | | | | • | | | 2 = 4:1 | 3 = 8:1 | | 7 | MirrorX | ✓ | ✓ | 0 | 0 = Disable | 1 = Enable | | 8 | MirrorY | ✓ | ✓ | 0 | 0 = Disable | 1 = Enable | | 910 | Discard | ✓ | ✓ | 0 | 0 = None | 1 = FieldOne | | | | | | | 2 = FieldTwo | 3 = Reserved | | 11 | CombineFields | <b>&gt;</b> | <b>√</b> | 0 | 0 = Disable | 1 = Enable | | 12 | LockTo | ✓ | ✓ | 0 | 0 = Disable | 1 = Enable | | | StreamB | | | | | | | 13 | Patch | <b>\</b> | ✓ | 0 | 0 = Disable | 1 = Enable | | 1419 | PatchOffsetX | ✓ | ✓ | 0 | | | | 2023 | PatchOffsetY | ✓ | ✓ | 0 | | | | 2425 | PixelSize | ✓ | ✓ | 0 | 0 = 1 byte | 1 = 2 bytes | | | | | | | 2 = 4 bytes | 3 = Reserved | | 26 | LockToVideoO | ✓ | ✓ | 0 | 0 = Disable | 1 = Enable | | | verlay | | | | | | | 27 | LockToVideo | ✓ | ✓ | 0 | 0 = Disable | 1 = Enable | | 2831 | Reserved | ✓ | × | 0 | | | | Notes: | | | |--------|--|--| ### **VSACurrentLine** $\begin{array}{c|cccc} \textbf{Name} & \textbf{Type} & \textbf{Offset} & \textbf{Format} \\ VSACurrentLine & Video stream & 0x5910 & Integer \\ & & & & \\ Control & & & \\ VSBCurrentLine & Video stream & 0x5A10 & Integer \\ & & & & \\ Control & & & \\ \end{array}$ Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|--------------------------------------------------| | 010 | Line | ✓ | × | X | Current line number, reference to start of VRef. | | 1131 | Reserved | ✓ | × | 0 | | Notes: # **VSADroppedFrames** NameTypeOffsetFormatVSADroppedFramesVideo stream0x59D8IntegerControl Control Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|--------------|-------|-------------------------| | 07 | Count | ✓ | ✓ (to reset) | 0 | Count of dropped frames | | 831 | Reserved | ✓ | × | 0 | | Notes: Register Descriptions | Name | Type | Offset | Format | |----------------|--------------|--------|----------| | VSAFifoControl | Video stream | 0x59B8 | Bitfield | | | Control | | | | VSBFifoControl | Video stream | 0x5AB8 | Bitfield | | | Control | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|-------------------------| | | | | | | | | 07 | LP Threshold | ✓ | ✓ | 0x8 | Low Priority Threshold | | 815 | HP Threshold | ✓ | ✓ | 0x8 | High Priority Threshold | | 1631 | Reserved | ✓ | × | 0 | | # **VSAInterruptLine** | Name | Туре | Offset | Format | |------------------|------------------|--------|---------| | VSAInterruptLine | Video stream | 0x5908 | Integer | | - | Control | | J | | VSBInterruptLine | Video stream | 0x5A08 | Integer | | • | Control | | J | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------| | 010 | Line | ✓ | ✓ | X | Line number to generate interrupt. | | 1131 | Reserved | ✓ | X | 0 | | Notes: # VSATimeStamp0 | Name | Туре | Offset | Format | |---------------|-------------------------|--------|---------| | VSATimeStamp0 | Video stream<br>Control | 0x59C0 | Integer | Control register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|--------------------------| | 031 | Time | ✓ | × | 0 | Capture time of buffer 0 | | Notes: | | | |--------|--|--| # VSATimeStamp1 NameTypeOffsetFormatVSATimeStamp1Video stream0x59C8Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|--------------------------| | 031 | Time | ✓ | X | 0 | Capture time of buffer 1 | Notes: # VSATimeStamp2 NameTypeOffsetFormatVSATimeStamp2Video stream0x59D0Integer Control Control register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|--------------------------| | 031 | Time | ✓ | X | 0 | Capture time of buffer 2 | Notes: ### VSAVBIAddress0 | Name | Туре | Offset | Format | |------------------|------------------|--------|---------| | VSAVBIAddress0 | Video stream | 0x5978 | Integer | | | Control | | o o | | VSAVideoAddress0 | Video stream | 0x5928 | Integer | | | Control | | o o | | VSBVBIAddress0 | Video stream | 0x5A78 | Integer | | | Control | | | | VSBVideoAddress0 | Video stream | 0x5A28 | Integer | | | Control | | | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|--------------------------------| | 020 | Base | ✓ | ✓ | X | Base address (128 bit aligned) | | 2131 | Reserved | ✓ | × | 0 | | Notes: ### **VSAVBIAddress1** | Name | Type | Offset | Format | |------------------|------------------|--------|---------| | VSAVBIAddress1 | Video stream | 0x5980 | Integer | | | Control | | · · | | VSAVideoAddress1 | Video stream | 0x5930 | Integer | | | Control | | _ | | VSBVBIAddress1 | Video stream | 0x5A80 | Integer | | | Control | | _ | | VSBVideoAddress1 | Video stream | 0x5A30 | Integer | | | Control | | _ | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|--------------------------------| | 020 | Base | ✓ | ✓ | X | Base address (128 bit aligned) | | 2131 | Reserved | ✓ | × | 0 | | Notes: ### VSAVBIAddress2 | Type | Offset | Format | |------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------| | Video stream | 0x5988 | Integer | | Control | | · · | | Video stream | 0x5938 | Integer | | Control | | · · | | Video stream | 0x5A88 | Integer | | Control | | | | Video stream | 0x5A38 | Integer | | Control | | | | Control register | | | | | Video stream Control Video stream Control Video stream Control Video stream Control Control | Video stream 0x5988 Control Video stream 0x5938 Control Video stream 0x5A88 Control Video stream 0x5A38 Control Control Control | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------------| | 020 | Base | ✓ | ✓ | X | Base address (64 bit aligned) | | 2131 | Reserved | ✓ | × | 0 | | Notes: # **VSAVBIAddressHost** | Name | Туре | Offset | Format | |-------------------|------------------|--------|---------| | VSAVBIAddressHost | Video stream | 0x5968 | Integer | | | Control | | | | VSBVBIAddressHost | Video stream | 0x5A68 | Integer | | | Control | | _ | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------| | 01 | Base | ✓ | ✓ | X | Base address register index | | 231 | Reserved | ✓ | X | 0 | | | Notes: | | | | |--------|--|--|--| ### **VSAVBIAddressIndex** | <b>Name</b><br>VSAVBIAddressIndex | <b>Type</b><br>Video stream<br>Control | <b>Offset</b> 0x5970 | <b>Format</b><br>Integer | |-----------------------------------|----------------------------------------------------|----------------------|--------------------------| | VSAVideoAddressIndex | Video stream<br>Control<br><i>Control register</i> | 0x5920 | Integer | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------| | 01 | Base | ✓ | × | 0 | Base address register index | | 231 | Reserved | ✓ | X | 0 | | Notes: ### **VSAVBIEndData** | Name | Туре | Offset | Format | |---------------|------------------|--------|---------| | VSAVBIEndData | Video stream | 0x59B0 | Integer | | | Control | | | | VSBVBIEndData | Video stream | 0x5AB0 | Integer | | | Control | | | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-------|-------|----------------------------| | 010 | First Clock | ✓ | ✓ | X | First clock after VBI data | | 1131 | Reserved | 1 | × | 0 | | Notes: ### **VSAVBIEndLine** Name Type Offset Format VSAVBIEndLine Video stream 0x59A0 Integer Control VSBVBIEndLine Video stream 0x5AA0 Integer Control Control register | Bits | Name | Read | Write | Reset | Description | |------|------------|------|----------|-------|-------------------------------| | 010 | First Line | 1 | <b>√</b> | X | First scanline after VBI data | | 1131 | Reserved | 1 | × | 0 | | Notes: ### **VSAVBIStartData** Name Type Offset Format VSAVBIStartData Video stream 0x59A8 Integer Control VSBVBIStartData Video stream 0x5AA8 Integer VSBVBIStartData Video stream 0x5AA8 Integer Control Control register Bits Name Read Write Reset Description 0..10 First Data ✓ ✓ X First valid data in VBI line. 11.31 Reserved ✓ × 0 | | <br>• | <br>- | | |---------|-------|-------|--| | | | | | | | | | | | | | | | | | | | | | Notes: | | | | | TAULES. | | | | ### **VSAVBIStartLine** | Name | <b>Type</b> | <b>Offset</b> 0x5998 | <b>Format</b> | |-----------------|------------------------------------|----------------------|---------------| | VSAVBIStartLine | Video stream | | Integer | | VSBVBIStartLine | Control<br>Video stream<br>Control | 0x5A98 | Integer | Control register | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|----------------------------| | 010 | First Line | ✓ | ✓ | X | First scanline of VBI data | | 1131 | Reserved | ✓ | X | 0 | | Notes: ### **VSAVBIStride** | Name | Type | Offset | <b>Format</b> | |----------------|------------------|--------|---------------| | VSAVBIStride | Video stream | 0x5990 | Integer | | | Control | | Ü | | VSAVideoStride | Video stream | 0x5940 | Integer | | | Control | | _ | | VSBVBIStride | Video stream | 0x5A90 | Integer | | | Control | | | | VSBVideoStride | Video stream | 0x5A40 | Integer | | | Control | | | | | Control register | | | | 020 | Stride | 1 | 1 | X | Stride between scanlines (in 128 bit units). | |------|----------|---|---|---|----------------------------------------------| | 2131 | Reserved | ✓ | X | 0 | | Notes: VSAVideoAddress2 see VSAVBIAddress2 VSAVideoAddress1 see VSAVBIAddress1 VSAVideoAddress0 see VSAVBIAddress0 ### VSAVBIAddress0 | Name | Type | Offset | Format | |------------------|------------------|--------|---------| | VSAVBIAddress0 | Video stream | 0x5978 | Integer | | | Control | | _ | | VSAVideoAddress0 | Video stream | 0x5928 | Integer | | | Control | | _ | | VSBVBIAddress0 | Video stream | 0x5A78 | Integer | | | Control | | | | VSBVideoAddress0 | Video stream | 0x5A28 | Integer | | | Control | | | | | Control register | | | | | | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|--------------------------------| | 020 | Base | ✓ | ✓ | X | Base address (128 bit aligned) | | 2131 | Reserved | ✓ | × | 0 | | Notes: # **VSAVBIAddress1** | Name | Type | Offset | Format | |------------------|------------------|--------|---------| | VSAVBIAddress1 | Video stream | 0x5980 | Integer | | | Control | | _ | | VSAVideoAddress1 | Video stream | 0x5930 | Integer | | | Control | | | | VSBVBIAddress1 | Video stream | 0x5A80 | Integer | | | Control | | | | VSBVideoAddress1 | Video stream | 0x5A30 | Integer | | | Control | | _ | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|--------------------------------| | 020 | Base | ✓ | 1 | X | Base address (128 bit aligned) | | 2131 | Reserved | 1 | × | 0 | | | Notes: | | | |--------|--|--| ### VSAVBIAddress2 | Name | Туре | Offset | Format | |------------------|------------------|--------|---------| | VSAVBIAddress2 | Video stream | 0x5988 | Integer | | | Control | | _ | | VSAVideoAddress2 | Video stream | 0x5938 | Integer | | | Control | | _ | | VSBVBIAddress2 | Video stream | 0x5A88 | Integer | | | Control | | | | VSBVideoAddress2 | Video stream | 0x5A38 | Integer | | | Control | | | | | Control register | | | | | | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------------------------| | 020 | Base | <b>√</b> | <b>√</b> | X | Base address (64 bit aligned) | | 2131 | Reserved | 1 | X | 0 | | Notes: ### **VSAVideoAddressHost** | Name<br>VSAVideoAddressHost | <b>Type</b> Video stream | <b>Offset</b> 0x5918 | <b>Format</b><br>Integer | |-----------------------------|----------------------------------------------------------------|----------------------|--------------------------| | VSBVideoAddressHost | Control<br>Video stream<br>Control<br><i>Control reg</i> ister | 0x5A18 | Integer | | Bits | Name | Read | Write | Reset | Description | |------|-----------|----------|-------|-------|----------------------------------| | 01 | Host base | <b>√</b> | 1 | X | Host base address register index | | 231 | Reserved | 1 | × | 0 | | Notes: ### VSAVideoAddressIndex see VSAVBIAddressIndex PERMEDIA3 Reference Guide Hardware Registers ### **VSAVideoEndData** | <b>Name</b><br>VSAVideoEndData | <b>Type</b><br>Video stream<br>Control | Offset<br>0x5960 | <b>Format</b><br>Integer | |--------------------------------|---------------------------------------------|------------------|--------------------------| | VSBVideoEndData | Video stream<br>Control<br>Control register | 0x5A60 | Integer | | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|----------|-------|--------------------------------| | 010 | First Clock | 1 | <b>√</b> | X | First clock after active video | | 1131 | Reserved | 1 | × | 0 | | Notes: ### **VSAVideoEndLine** | Name | Туре | Offset | Format | |-----------------|------------------|--------|---------| | VSAVideoEndLine | Video stream | 0x5950 | Integer | | | Control | | · · | | VSBVideoEndLine | Video stream | 0x5A50 | Integer | | | Control | | O | | | Control mediator | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|---------------------------------| | 010 | First Line | ✓ | ✓ | X | First scanline after Video data | | 1131 | Reserved | 1 | × | 0 | | Notes: ### **VSAVideoStartData** | Name | Туре | Offset | Format | |-------------------|--------------|--------|----------| | VSAVideoStartData | Video stream | 0x5958 | Integer | | | Control | | · · | | VSBVideoStartData | Video stream | 0x5A58 | Integer | | | Control | | <u> </u> | | VSBVideoStartData | Video stream | 0x5A58 | Intege | Control register | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|---------------------------------| | 010 | First Data | ✓ | ✓ | X | First valid data in video line. | | 1131 | Reserved | 1 | X | 0 | | Notes: ### **VSAVideoStartLine** | Name | Туре | Offset | Format | |-------------------|------------------|--------|---------| | VSAVideoStartLine | Video stream | 0x5948 | Integer | | | Control | | | | VSBVideoStartLine | Video stream | 0x5A48 | Integer | | | Control | | | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|------------------------------| | 010 | First Line | 1 | ✓ | X | First scanline of video data | | 1131 | Reserved | 1 | × | 0 | | Notes: VSAVideoStride see VSAVBIAddress0 #### **VSBControl** NameTypeOffsetFormatVSBControlVideo stream0x5A00Bitfield Control register | Bits | Name | Read | Write | Reset | Desc | ription | |------|-------------------|----------|----------|-------|--------------------------|-----------------------------| | 0 | Video | ✓ | <b>√</b> | 0 | 0 = Disable | 1 = Enable | | 1 | VBI | ✓ | ✓ | 0 | 0 = Disable | 1 = Enable | | 2 | BufferCtl | ✓ | ✓ | 0 | 0 = Double buffered | 1 = Triple buffered | | 3 | CombineFields | ✓ | ✓ | 0 | 0 = Disable | 1 = Enable | | 84 | ColorFormat | ✓ | ✓ | 0 | | | | 910 | PixelSize | ✓ | ✓ | 0 | 0 = 1 byte $2 = 4$ bytes | 1 = 2 bytes<br>3 = Reserved | | 11 | RGB Order | ✓ | <b>√</b> | 0 | 0 = BGR | 1 = RGB | | 12 | GammaCorrect | ✓ | <b>√</b> | 0 | 0 = Disable | 1 = Enable | | 13 | LockTo<br>StreamA | <b>√</b> | 1 | 0 | 0 = Disable | 1 = Enable | | 14 | RAMDAC | ✓ | ✓ | 0 | 0 = Disable | 1 = Enable | | 15 | Patch | ✓ | ✓ | 0 | 0 = Disable | 1 = Enable | | 1621 | PatchOffsetX | ✓ | <b>√</b> | 0 | | | | 2225 | PatchOffsetY | ✓ | ✓ | 0 | | | | 26 | LockToOverlay | ✓ | ✓ | 0 | 0 = Disable | 1 = Enable | | 27 | LockToVideo | ✓ | ✓ | 0 | 0 = Disable | 1 = Enable | | 2831 | Reserved | ✓ | × | 0 | | | Notes: VSBCurrentLine see VSACurrentLine VSBFifoControl see VSAFIFOControl VSBInterruptLine see VSAInterruptLine VSBVBIAddress0 see VSAVBIAddress0 VSBVBIAddress1 see VSAVBIAddress1 VSBVBIAddress2 see VSAVBIAddress2 VSBVBIAddressHost see VSAVBIAddressHost #### **VSBVBIAddressIndex** | <b>Name</b><br>VSBVBIAddressIndex | <b>Type</b><br>Video stream | Offset<br>0x5A70 | <b>Format</b><br>Integer | |-----------------------------------|-----------------------------|------------------|--------------------------| | VSBVideoAddressIndex | Control Video stream | 0x5A20 | Integer | | | Control<br>Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|-------|-------|-----------------------------| | 01 | Base | <b>√</b> | × | 0x2 | Base address register index | | 231 | Reserved | ✓ | X | 0x2 | | VSBVBIEndData see VSAVBIEndData VSBVBIEndLine see VSAVBIEndLine VSBVBIStartData see VSAVBIStartData VSBVBIStartLine see VSAVBIStartLine VSBVBIStride see VSAVBIStride VSBVideoAddress0 see VSAVBIAddress0 VSBVideoAddress1 see VSAVBIAddress1 VSBVideoAddress2 see VSAVBIAddress2 VSBVideoAddressHost see VSAVideoAddressHost VSBVideoAddressIndex see VSBVBIAddressIndex VSBVideoEndData see VSAVideoEndData VSBVideoEndLine see VSAVideoEndLine VSBVideoStartData see VSAVideoStartData VSBVideoStartLine see VSAVideoStartline VSBVideoStride see VSAVBIStride # **VSConfiguration** NameTypeOffsetFormatVSConfigurationVideo stream0x5800Bitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|----------------------|----------|----------|-------|----------------------------------------------------------------------------| | | | | | | • | | 02 | Unit mode | ✓ | ✓ | 0 | 0 = ROM Access | | | | | | | 1 = MPEG data to decoder via GP bus, decoded | | | | | | | video into input port. | | | | | | | 2 = Wide output 16 bit. | | | | | | | 3 = Simultaneous input and output, program decode and encoder through I2C. | | | | | | | 4 = Wide input 16 bit. | | | | | | | 5 = VSA/VSB reset removed, use to probe for | | | | | | | external chips. | | | | | | | 6 = Drive flat panels | | | | | | | 7 = Default to mode 0. | | 3 | GPModeA | 1 | <b>√</b> | 0 | 0 = Operate GP bus in Mode B | | | | | | | 1 = Operate GP bus in Mode A | | 4 | VActiveVideoA | 1 | <b>√</b> | 1 | 0 = Ignore VActive for Video data | | | | | | | 1 = Gate Video data with VActive | | 5 | VActiveVideoB | ✓ | ✓ | 1 | 0 = Ignore VActive for Video data | | | | | | | 1 = Gate Video data with VActive | | 6 | GPStopPolarity | ✓ | ✓ | 0 | 0 = Active low at pin | | | | | | | 1 = Active high at pin | | 78 | Reserved | ✓ | × | 0x7 | | | 9 | HRefPolarityA | ✓ | ✓ | 0 | 0 = Active low $1 = $ Active high | | 10 | VRefPolarityA | ✓ | ✓ | 0 | 0 = Active low $1 = Active high$ | | 11 | VActivePolarity<br>A | 1 | ✓ | 0 | 0 = Active low $1 = $ Active high | | 12 | UseFieldA | ✓ | <b>√</b> | 0 | 0 = Disabled $1 = Enabled$ | | 13 | FieldPolarityA | ✓ | ✓ | 0 | 0 = Active low $1 = $ Active high | | 14 | FieldEdgeA | ✓ | ✓ | 0 | 0 = Inactive edge $1 = Active edge$ | | 15 | VActiveVBIA | ✓ | ✓ | 0 | 0 = Ignore VActive for VBI data | | | | | | | 1 = Gate VBI data with VActive | | 16 | InterlaceA | ✓ | ✓ | 0 | 0 = Video is not interlaced | | | | | | | 1 = Video is interlaced | | 17 | ReverseDataA | ✓ | ✓ | 0 | 0 = Disabled $1 = Enabled$ | | 18 | HRefPolarityB | ✓ | ✓ | 0 | 0 = Active low $1 = $ Active high | | 19 | VRefPolarityB | ✓ | ✓ | 0 | 0 = Active low $1 = Active high$ | | 20 | VActivePolarity | ✓ | ✓ | 0 | 0 = Active low $1 = $ Active high | | | В | <u> </u> | | | | | 21 | UseFieldB | ✓ | ✓ | 0 | 0 = Disabled 1 = Enabled | | 22 | FieldPolarityB | ✓ | ✓ | 0 | 0 = Active low 1 = Active high | | 23 | FieldEdgeB | ✓ | ✓ | 0 | 0 = Inactive edge $1 = Active edge$ | | 24 | VActiveVBIB | ✓ | ✓ | 0 | 0 = Ignore VActive for VBI | | |----|---------------|----------|---|---|-----------------------------|-------------| | | | | | | 1 = Gate VBI data with VAct | uve | | 25 | InterlaceB | <b>✓</b> | ✓ | 0 | 0 = Video is not interlaced | | | | | | | | 1 = Video is interlaced | | | 26 | ColorSpaceB | ✓ | ✓ | 0 | 0 = YUV | 1 = RGB | | 27 | ReverseDataB | ✓ | ✓ | 0 | 0 = Disabled | 1 = Enabled | | 28 | DoubleEdgeB | ✓ | ✓ | 0 | 0 = Disabled | 1 = Enabled | | 29 | CCIR656A | ✓ | ✓ | 0 | 0 = Disabled | 1 = Enabled | | 30 | InvertDoubleE | ✓ | ✓ | 0 | 0 = Disabled | 1 = Enabled | | | dgeB | | | | | | | 31 | Reserved | ✓ | X | 0 | | | ### **VSDMACommandBase** NameTypeOffsetFormatVSDMACommandBaseVideo stream0x5AC8Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 03 | Reserved | ✓ | × | X | | | 431 | Address | ✓ | ✓ | 0 | | Notes: ### **VSDMACommandCount** NameTypeOffsetFormatVSDMACommandCountVideo stream0x5AD0Integer Control Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|-------------| | 031 | Count | ✓ | ✓ | 0 | | Notes: ### **VSDMAMode** NameTypeOffsetFormatVSDMAModeVideo stream0x5AC0Bitfield Control Control register | Bits | Name | Read | Write | Reset | Desc | cription | |------|----------|----------|-------|-------|----------------------|-----------------| | | | | | | | _ | | 021 | Reserved | ✓ | × | 0 | | | | 22 | Active | ✓ | ✓ | 0 | 0 = DMA complete | 1 = DMA running | | 23 | MemType | ✓ | ✓ | 0 | 0 = PCI | 1 = AGP | | 2425 | Burst | ✓ | ✓ | 0 | Log2 of burst length | | | 26 | Reserved | ✓ | × | 0 | | | | 27 | Align | ✓ | ✓ | 0 | 0 = Disable | 1 = Enable | | 2831 | Reserved | <b>√</b> | × | 0 | | | Notes: ### **VSSerialBusControl** Name Type Offset Format VSSerialBusControl Video stream 0x5810 Bitfield Control Control register | Bits | Name | Read | Write | Reset | Description | |------|-------------|----------|----------|-------|------------------------------------------------------------------------------| | 0 | DataIn | <b>√</b> | × | X | 0 = Data line is low $1 = Data line is high$ | | 1 | ClkIn | 1 | × | X | 0 = Clock line is low $1 = $ Clock line is high | | 2 | DataOut | ✓ | ✓ | 1 | 0 = Drive data line low $1 = $ Tri-state data line | | 3 | ClkOut | 1 | 1 | 1 | 0 = Drive Clock line low<br>1 = Tri-state clock line | | 4 | LatchedData | ✓ | X | 0 | 0 = Data latched at $0$ $1 = Data$ latched at $1$ | | 5 | DataValid | <b>√</b> | ✓ | 0 | 0 = DataIn not valid $1 = DataIn valid$ | | 6 | Start | 1 | <b>√</b> | 0 | 0 = Has not passed through start state<br>1 = Has passed through start state | | 7 | Stop | 1 | 1 | 0 | 0 = Has not passed through stop state<br>1 = Has passed through stop state | | 8 | Wait | <b>√</b> | ✓ | 0 | 0 = Do not insert wait states $1 = Insert$ wait states | | 931 | Reserved | ✓ | × | 0 | | Notes: Some bits in this register are set during operation and cleared by writing to the register with those bits set. The bits are DataValid, Start and Stop. ### **VSStatus** NameTypeOffsetFormatVSStatusVideo stream0x5808Bitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|-----------------------|------|----------|-------|----------------------| | 0 | GPBusTimeOu<br>t | 1 | <b>√</b> | 0 | cleared by writing 1 | | 17 | Reserved | ✓ | × | 0 | | | 8 | FifoOverflowA | ✓ | ✓ | 0 | cleared by writing 1 | | 9 | FieldOne0A | ✓ | × | 0 | | | 10 | FieldOne1A | ✓ | × | 0 | | | 11 | FieldOne2A | ✓ | X | 0 | | | 12 | InvalidInterlace<br>A | ✓ | × | 0 | | | 13 | BufferFieldA0 | ✓ | × | 0 | | | 14 | BufferFieldA1 | ✓ | × | 0 | | | 15 | BufferFieldA2 | ✓ | × | 0 | | | 16 | FifoUnderflow<br>B | ✓ | 1 | 0 | cleared by writing 1 | | 17 | FieldOne0B | ✓ | X | 0 | | | 18 | FieldOne1B | ✓ | × | 0 | | | 19 | FieldOne2B | ✓ | × | 0 | | | 20 | InvalidInterlace<br>B | ✓ | × | 0 | | | 21 | BufferFieldB0 | ✓ | × | 0 | | | 22 | BufferFieldB1 | ✓ | × | 0 | | | 23 | BufferFieldB2 | ✓ | × | 0 | | | 2431 | Reserved | ✓ | × | 0 | | | Notes: | | | |--------|--|--| VSAVideoStride SeeVSAVBIStride ## 4.9 Region 0 VGA Control (0x6000-0x6FFF) The VGA registers generally follow industry VGA conventions. The registers described below are chip-specific varinats accessible both via VGA I/O and addressable memory (described here), togather with the index registers which support them (*GraphicsIndexReg* and *SequencerIndexReg*.). To read or write an indexed register first write the index value to the indexing register, then read/write the memory-mapped address (or VGA I/O Port). ### 4.9.1 Graphics Index Register ### **GraphicsIndexReg** | Name | Type | Offset | Format | |------------------|------------------|--------|----------| | GraphicsIndexReg | VĜA | 0x63CE | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3:0 | Index | • | 1 | X | This index points to one of the Graphics registers which will get read or written on the next I/O access to the GraphicsPort (0x3cf). The registers and their corresponding indices are: 0x0 | | 7:4 | Reserved | ✓ | × | 0 | Reserved | Notes: Writes to a register denoted 'None' have no effect as the write is simply discarded. Reading from a register denoted 'None' just returns zero. #### Mode640Reg | Name | Type | Offset | Format | |------------|------------------|--------|----------| | Mode640Reg | VĜA | 0x63CF | Bitfield | | - | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------------|------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2:0 | BankA[2:0] | 1 | 1 | 00 | This field provides the additional address bits needed when the horizontal screen resolution is 640 pixels and a host address is being made to the 64K region starting at address 0xa0000. | | 5:3 | BankB[2:0] | 1 | 1 | 00 | This field provides the additional address bits needed when the horizontal screen resolution is 640 pixels and a host address is being made to the 64K region starting at address 0xb0000. | | 6 | StartAddress16 | 1 | 1 | 00 | The most significant bit of the StartAddress when mode 640 is enabled. | | 7 | Enable | 1 | 1 | 00 | 0 No action. 1 The VGA core operates in 640 resolution mode. | Notes: This register supports the 640 horizontal resolution modes used in SVGA. The BankA and BankB parts of this register are now obsolete. Programmers should use the sequencer registers BankALowReg, BankAHighReg, BankBLowReg, BankBHighReg instead. This register may be removed from future hardware #### 4.9.2 Sequencer Registers #### SequencerIndexReg Name Type Offset Format SequencerIndexReg VGA 0x63C4 Bitfield Control Register | which will get read or written on the next I/O access to the SequencerPort (0x3c5). The registers and their corresponding indices are: 0x00 ResetReg 0x01 ClockModeReg 0x02 MapMaskReg 0x03 CharacterMapSelectReg 0x04 MemoryModeReg 0x05 VGAControlReg 0x06 LockExtended1Reg 0x07 LockExtended2Reg 0x08 BankALowReg 0x09 BankAHighReg 0x09 BankBHighReg 0x00 BankBHighReg 0x00 PCIControlReg 0x00 HLockShiftReg 0x00 VLockShiftReg 0x00 VLockShiftReg 0x01 GenLockControlReg 0x10 0x1f ScratchRegs 0x20 0x23 IndirectBaseRegs 0x27 0x3f None | Bits | Name | Read | Write | Reset | Description | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:6 Reserved ✓ × 0 Reserved | 5:0 | | | | | which will get read or written on the next I/O access to the SequencerPort (0x3c5). The registers and their corresponding indices are: 0x00 ResetReg 0x01 ClockModeReg 0x02 MapMaskReg 0x03 CharacterMapSelectReg 0x04 MemoryModeReg 0x05 VGAControlReg 0x06 LockExtended1Reg 0x07 LockExtended2Reg 0x08 BankALowReg 0x09 BankAHighReg 0x0a BankBLowReg 0x0b BankBHighReg 0x0c PCIControlReg 0x0c PCIControlReg 0x0d HLockShiftReg 0x0e VLockShiftReg 0x0f GenLockControlReg 0x10 0x1f ScratchRegs 0x20 0x23 IndirectBaseRegs 0x27 0x3f None | #### Notes: - This register indexes data for the memory mapped VGAControlReg register and others shown below. To write to VGAControlReg first write a 0x05 to this regiater, then write data to VGAControlReg - Writes to a register denoted 'None' have no effect as the write is simply discarded. Reading from a register denoted 'None' just returns zero. #### 4.9.2.1 Sequenced Registers #### **BankAHighReg** Name Type Offset Format BankAHighReg VGA 0x635C index Bitfield 0x09 Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0,1 | BankA9_8 | • | 1 | | This field holds the 2 high order bits of the 10-bit BankA base address. The 8 low order bits can be found in the BankALowReg. The BankA base address is used for bank switching the 0xa0000 region through the bypass (if enabled). The BankA bits provide the HBankA signals to the PCI interface. | | 27 | Reserved | ✓ | × | 0 | | Notes: To read/write this register, first write 0x0F to SequencerIndexReg. Not to be confused with Mode640Reg.BankA, which will become obsolete # **BankALowReg** Name Type Offset Format BankALowReg VGA 0x635C Bitfield index 0x08 Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 07 | BankA7_0 | • | <b>✓</b> | | This field holds the 8 low order bits of the 10-bit BankA base address. The 2 high order bits can be found in the BankAHighReg. The BankA base address is used for bank switching the 0xa0000 region through the bypass (if enabled). The BankA bits provide the HBankA signals to the PCI interface. | Notes: To read/write this register, first write 0x08 to SequencerIndexReg. Not to be confused with Mode640Reg.BankA, which will become obsolete. #### **BankBHighReg** Name Type Offset Format BankBHighReg VGA 0x635C Bitfield index 0x0B Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0,1 | BankB9_8 | • | 1 | | This field holds the 2 high order bits of the 10-bit BankB base address. The 8 low order bits can be found in the BankBLowReg. The BankB base address is used for bank switching the 0xb0000 region through the bypass (if enabled). The BankB bits provide the HBankB signals to the PCI interface. | | 27 | Reserved | ✓ | × | 0 | | Notes: To read/write this register, first write 0x0B to SequencerIndexReg #### **BankBLowReg** Name Type Offset Format VGAControlReg VGA 0x635C Bitfield index 0x0A Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 07 | BankB7_0 | ✓ | ✓ | | This field holds the 8 low order bits of the 10-bit BankB base address. The 2 high order bits can be found in the BankBHighReg. The BankB base address is used for bank switching the 0xb0000 region through the bypass (if enabled). The BankB bits provide the HBankB signals to the PCI interface. | Notes: Not to be confused with Mode640Reg.BankB, which will become obsolete. To read/write this register, first write 0x0A to SequenceIndexReg #### GenLockControlReg Name Type Offset Format VGAControlReg VGA 0x635C Bitfield index 0x0F Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | | If set, allows the VTG to be synchronized to an external video source. This causes the horizontal & vertical sync starts & blank ends to be delayed. Sync starts are delayed until the arrival of the ExtHSync & ExtVSync signals. Blank ends are delayed by the numbers specified in the HLockShiftReg & VLockShiftReg registers. | | 17 | Reserved | ✓ | × | 0 | | Notes: This register is not supported in current releases. Use software Genlock where necessary. ### **HLockShiftReg** Name Type Offset Format HLockShiftReg VGA 0x635C Bitfield index 0x0D Control register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-----------------------------------------------------------------------------------------------------------------------| | 07 | | 1 | 1 | | If genlocking is enabled, this field specifies the number of characters by which the horizontal blank end is delayed. | Notes: This register is not supported in current releases – use software genlock where required. #### IndirectBaseReg[0x0...0x3] Name Type Offset Format IndirectBaseReg[0x0...0x3 VGA 0x635C Bitfield index 0x20 - 0x23 Control register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 07 | | ✓ | × | X | These 4 registers follow the state of the HIndirectBase signals from the PCI interface. IndirectBaseReg[0] returns bits 70, IndirectBaseReg[1] returns bits 158, IndirectBaseReg[2] returns bits 2316, and IndirectBaseReg[3] returns bits 3124. | Notes: To read from this register, first write the index value (0x20 to 0x23) to SequencerIndexReg, then read the required index entries. ### LockExtended1Reg Name Type Offset Format LockExtended1Reg VGA 0x63C5 Bitfield index 0x06 Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 07 | Lock | X | 1 | | These 2 registers act as a lock for the extended registers. On reset extended registers are locked – they cannot be written and read back as 0, and the sequencer index behaves as a 3-bit index. Writing the value 0x3d to LockExtended1Reg followed by 0xdb to LockExtended2Reg unlocks the extended registers. Writing any other values locks them. | | 831 | Reserved | ✓ | × | 0 | | Notes: To read/write this register, first write 0x06 to SequencerIndexReg. #### LockExtended2Reg Name Type Offset Format LockExtended2Reg VGA 0x63C5 Bitfield index 0x07 Control register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 07 | Lock | × | 1 | | Acts as a lock for the extended registers. On reset extended registers are locked - they cannot be written and read back as 0, and the sequencer index behaves as a 3-bit index. Writing the value 0x3d to LockExtended1Reg followed by 0xdb to LockExtended2Reg unlocks the extended registers. Writing any other values locks them. | Notes: To read/write this register, first write 0x07 to SequencerIndexReg. # **PCIControlReg** Name Type Offset Format PCIControlReg VGA 0x635C Bitfield index 0x0C Control register | Bits | Name | Read | Write | Reset | Description | |------|----------------|------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | BankEnable | 1 | 1 | | If set, enables bank switching of the 0xa0000/0xb0000 regions through the bypass, using the 10-bit BankA/BankB base addresses. This bit provides the HBankEnable signal to the PCI interface. | | 1 | IndirectEnable | 1 | 1 | | If set, enables access to chip registers via I/O ports 0x3b0/0x3b1/0x3d0/0x3d1. This bit provides the HIndirectEnable signal to the PCI interface. | | 27 | Reserved | ✓ | X | 0 | Reserved. | Notes: To read/write this register, first write 0x0C to SequencerIndexReg #### ScratchReg[0x0...0xf] $\begin{array}{cccc} Name & Type & Offset & Format \\ ScratchReg[0x0...0xF] & VGA & 0x635C & Bitfield \end{array}$ index 0x10 to 0x1F Control register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|----------------------------------------------------------------------------------------------------| | 07 | | 1 | ✓ | | These registers are available for use as an information store and do not affect the VGA operation. | Notes: To read/write this register first write the index value (0x10 to 0xF) to SequencerIndexReg, then read the required index entries. ## **VGAControlReg** Name Type Offset Format VGAControlReg VGA 0x63C5 Bitfield index 0x05 Control register | Bits | Name | Read | Write | Reset | Description | |------|----------------------------|----------|----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | EnableHost<br>MemoryAccess | 1 | 1 | | Controls access to the display memory by the host. No access to the display memory is made in response to host VGA memory accesses. Writes are ignored and reads always return zero. All the host bus cycles are completed as normal. Normal access to the display memory occurs. This bit is further qualified by the VGAEnable signal which acts as a global disable. | | 1 | EnableHost<br>DacAccess | <b>√</b> | <b>√</b> | | Controls access to the RAMDAC by the host. No access to the RAMDAC is made in response to host Dac accesses. Writes are ignored and reads always return zero. All the host bus cycles are completed as normal. Normal access to the RAMDAC occurs. This bit is further qualified by the VGAEnable signal which acts as a global disable. | | 2 | Enable | 1./ | ./ | | 0 Prevents any interrupts from being generated by | |---|-------------------|-----|----|---|--------------------------------------------------------| | ~ | Interrupts | • | • | | the VGA core. | | | menupis | | | | | | | | | | | 1 Enables interrupt generation from the VGA | | | | | | | core providing the | | | | | | | Vertical Sync End Reg. Disable Vertical Interrupt | | | | | | | field is set to zero. | | | | | | | This bit is further qualified by the VGAEnable signal | | | | | | | which acts as a global disable. This additional enable | | | | | | | bit is provided so the VGA core can be disabled from | | | | | | | one place. | | 3 | EnableVGA | 1 | ✓ | | Controls access to the display memory by the Memory | | | Display | | | | Reader for the purpose of keeping the display | | | | | | | refreshed. It also tells (on the VGAVidSelect signal) | | | | | | | the video select logic external to the VGA core that | | | | | | | the display should be driven from the VGA core. | | | | | | | 0 No accesses to display memory are to be made | | | | | | | and the video source should not be the VGA | | | | | | | core. The Memory Reader, Attribute Controller | | | | | | | | | | | | | | and Video Timing Generator are held in their | | | | | | | reset state. | | | | | | | 1 Accesses to the display memory are made and | | | | | | | the video to be displayed comes from the VGA | | | | | | | core. | | | | | | | This bit is further qualified by the VGAEnable signal | | | | | | | which acts as a global disable. | | 4 | DacAddr2 | 1 | 1 | | This bit extends the RAMDAC address range. | | 5 | DacAddr3 | ✓ | ✓ | | This bit extends the RAMDAC address range. | | 6 | EnableVTG | ✓ | ✓ | X | 0 Stops the VTG running and producing | | | | | | | sync pulses. | | | | | | | 1 Enables the VTG to run and produce sync | | | | | | | pulses. | | | | | | | This bit only has an effect when the VGA display has | | | | | | | been disabled by EnableVGADisplay. When the | | | | | | | display has been disabled by VGAEnable this bit is | | | | | | | ignored. When the VGA dispaly is active then this bit | | | | | | | is ignored. | | 7 | InvertVBlank | 1 | 1 | 0 | 0 No Invert VBlank. | | ' | 111VCI ( V DIGITA | • | • | 3 | 1 Invert VBlank | | 1 | 1 | 1 | | 1 | I HIVELL A DIGHTY | #### Notes: - On reset EnableHostMemoryAccess, EnableHostDacAccess and EnableVGADisplay are enabled, EnableInterrupts is disabled and DacAddr2 and DacAddr3 bits are set to 0, InvertVBlank is set to 0. - This is a non standard VGA register. - To read/write this register, first write 0x05 to SequencerIndexReg # **VLockShiftReg** Name Type Offset Format VLockShiftReg VGA 0x635C Bitfield index 0x0E Control register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|--------------------------------------------------------------------------------------------------------------------| | 07 | | 1 | 1 | 0 | If genlocking is enabled, this field specifies the number of scanlines by which the vertical blank end is delayed. | Notes: This register is not supported in current releases. # 4.10 Region 0 Texture Data FIFO (0x7000-0x7FFF) No 0x7000 series registers are listed. # 4.11 Region 3 Indirect Addressing #### **IndirectAccess** | Name | Type | Offset | Format | |----------------|------------------|--------|---------| | IndirectAccess | Region 3 | 0x0C | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 031 | Reserved | × | X | 0 | Accessing any part of these 32 bits triggers an indirect access to the location addressed by IndirectAddr. A write here will trigger the write of IndirectData into the location. A read here will trigger the read of the location into IndirectData. The access is further masked by the byte enables specified in Indirect ByteEn. | | rvotes: | |---------| |---------| #### IndirectAddr | Name | Туре | Offset | Format | |--------------|------------------|--------|---------| | IndirectAddr | Region 3 | 0x08 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|----------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 028 | Offset | <b>√</b> | ✓ | 0 | These bits specify the offset of the location to be accessed. | | 2931 | Region | <b>√</b> | ✓ | 0 | These bits specify the region of the location to be accessed. If region is 1, accesses are to region 1. If region is 2, accesses are to region 2. If region is 3, accesses are to region 3. If region is 4, accesses are to region 4. Otherwise accesses are to region 0. | | Notes: | | | |--------|--|--| # IndirectByteEnable | Name | Type | Offset | Format | |--------------------|------------------|--------|---------| | IndirectByteEnable | Region 3 | 0x00 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 03 | Byte Enables | ✓ | <b>√</b> | 0 | These four bits specify the mask to apply to accesses to the location by IndirectAddr. bit 0 set to 1 enables IndirectData byte 0 bit 1 set to 1 enables IndirectData byte 1 bit 2 set to 1 enables IndirectData byte 2 bit 3 set to 1 enables IndirectData byte 3 | | 431 | Reserved | ✓ | X | 0 | | #### IndirectData | Name | Type | Offset | <b>Format</b> | |--------------|------------------|--------|---------------| | IndirectData | Region 3 | 0x04 | Integer | | | Control register | | | | I | Bits | Name | Read | Write | Reset | Description | |----|------|------|----------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 03 | | Data | <b>√</b> | ✓ | 0 | These 32 bits hold the data to be written to, or read from, the location addressed by IndirectAddr. The access is further masked by the byte enables specified in IndirectByteEn. | | Notes: | | | |--------|--|--| 5 5-1 # **Graphics Registers** This chapter lists PERMEDIA 3 graphics core ('software') registers in region 0, offset group 0x8000-0xFFFF. Within this group the registers are listed alphanumerically. All other registers are described in chapter 4. Global cross-reference listings in alphanumeric and offset order are available in chapter 6. Register details have the following format information: **Name** The register's name. **Type** The region in which the register functions. **Offset** The offset of this register from the base address of the region. **Format** Can be bitfield or integer. Bit Bit Name **Read** Indicates whether the register bit can be read from. A $\checkmark$ mark indicates the register can be read from, a $\times$ indicates the register bit is not readable. **Write** Indicates whether the register bit can be written to. A ✓ mark indicates the register can be written to, a $\times$ indicates the register bit is not writable. **Reset** The value of the register following hardware reset. **Description** In the register descriptions: **Reserved** Indicates bits that may be used in future members of the PERMEDIA family. To ensure upwards compatibility, any software should not assume a value for these bits when read, and should always write them as zeros. **Not Used**/ Indicates bits that are adjacent to numeric fields. These may be used in future **Unused** members of the PERMEDIA family, but only to extend the dynamic range of these fields. The data returned from a read of these bits is undefined. When a Not Used field resides in the most significant position, a good convention to follow is to sign extend the numeric value, rather than masking the field to zero before writing the register. This will ensure compatibility if the dynamic range is increased in future members of the PERMEDIA family. For enumeration fields that do not specify the full range of possible values, only the specified values should be used. An example of an enumeration field is the comparison field in the DepthMode register. Future members of the PERMEDIA family may define a meaning for the unused values. # AlphaBlendAlphaModeAnd AlphaBlendAlphaModeAnd AlphaBlendAlphaModeOr Туре Name Offset **Format** AlphaBlendAlphaMode Alpha Blend 0x AFA8 Bitfield AlphaBlendAlphaModeAnd Alpha Blend 0x AD30 Bitfield Logic Mask AlphaBlendAlphaModeOr Alpha Blend Bitfield Logic Mask 0x AD38 Control registers | Bits | Name | Read <sup>1</sup> | Write | Reset | Description | |------|--------------------|-------------------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | √ | X | When set causes the fragment's alpha to be alpha blended under control of the remaining bits in this register. When clear the fragment alpha remains unchanged (but may later to affected by the chroma test). | | 14 | SourceBlend | <b>√</b> | ✓ | X | This field defines the source blend function to use.<br>See the table below for the possible options. | | 57 | DestBlend | 1 | 1 | Х | This field defines the destination blend function to use. See the earlier table for the possible options. | | 8 | Source<br>TimesTwo | <b>√</b> | <b>√</b> | Х | This bit, when set causes the source blend result to be multiplied by two before it is combined with the dest blend result. When this bit is clear no multiply occurs. | | 9 | DestTimes<br>Two | <b>√</b> | <b>√</b> | Х | This bit, when set causes the dest blend result to be multiplied by two before it is combined with the source blend result. When this bit is clear no multiply occurs. | | 10 | Invert Source | 1 | <b>√</b> | х | This bit, when set, causes the incomming source data to be inverted before any blend operation takes place. | | 11 | Invert Dest | 1 | <b>√</b> | Х | This bit, when set, causes the incomming dest data to be inverted before any blend operation takes place. | | 12 | NoAlpha<br>Buffer | 1 | V | х | When this bit is set the source alpha value is always set to 1.0. This is typically used when no retained alpha buffer is present but will also override any retained alpha value if one is present. Color formats with no alpha field defined automatically have their alpha value set to 1.0 regardless of the state of this bit. | | 13 | Alpha Type | <b>√</b> | ✓ | х | This bit selects which set of equations are to be used for the alpha channel. 0 = OpenGL 1 = Apple | 5-2 Proprietary and Confidential 3Dlabs $<sup>^{1}\,\</sup>mathrm{Logic}$ Op register readback is via the main register. | 14 | Alpha | ✓ | ✓ | X | This bit selects how alpha component less than 8 bits | |------|---------------|---|---|---|---------------------------------------------------------| | | Conversion | | | | wide are converted to 8 bit wide values prior to the | | | | | | | alpha blend calculations. The options are | | | | | | | 0 = Scale | | | | | | | 1 = Shift | | 15 | Constant | ✓ | ✓ | X | This bit, when set, forces the Source color to come | | | Source | | | | from the AlphaSourceColor register (in 8888 format) | | | | | | | instead of the framebuffer. | | | | | | | 0 = Use framebuffer alpha | | | | | | | 1 = Use AlphaSourceColor register alpha value. | | 16 | Constant Dest | ✓ | ✓ | X | This bit, when set, forces the destination color to | | | | | | | come from the AlphaDestColor register (in 8888 | | | | | | | format) instead of the fragment's color. | | | | | | | 0 = Use fragment's alpha. | | | | | | | 1 = Use AlphaDestColor register alpha value | | 1719 | Operation | ✓ | ✓ | X | This field selects how the source and destination blend | | | | | | | results are to be combined. The options are: | | | | | | | 0 = Add $1 = Subtract$ (i.e. S - D) | | | | | | | 2 = Subtract reversed (i.e. D - S) | | | | | | | 3 = Minimum $4 = Maximum$ | Notes The Alpha Conversion bit selects the conversion method for alpha values read from the framebuffer. - The Scale method linearly scales the alpha values to fill the full range of an 8 bit value. This method is preferable when, for example, downloading an image with fewer bits per pixel into a deeper (i.e. more bits per pixel) framebuffer. - The Shift method just left shifts by the appropriate amount to make the component 8 bits wide. This method is preferable when blending into a dithered framebuffer as it preserves the framebuffer alpha when fragment alpha does not contribute to it. Alpha is controlled separately from color to allow, for example, the situation in antialiasing where it represents coverage - this must be linearly scaled to preserve the 100% covered state. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. The table below shows the different color modes supported. In the R, G, B and A columns the nomenclature <u>n@m</u> means this component is n bits wide and starts at bit position m in the framebuffer. The least significant bit position is 0 and a dash in a column indicates that this component does not exist for this mode. In the case of the RGB formats where no Alpha is shown then the alpha field is set to 255. In this case the NoAlphaBuffer bit in the AlphaBlendAlphaMode register should be set which causes the alpha component to be set to 255. Two color ordering formats are supported, namely ABGR and ARGB, with the right most letter representing the color in the least significant part of the word. This is controlled by the Color Order bit in the *AlphaBlendColorMode* register, and is easily implemented by just swapping the R and B components after conversion into the internal format. The only exception to this are the 3:3:2 formats where the actual bit fields extracted from the framebuffer data need to be modified as well because the R and B components are differing widths. CI processing is not affected by this and the result is always on internal R channel. The format to use is held in the *AlphaBlendColorMode* register. Note that in OpenGL alpha blending is not defined for CI mode.. #### When converting a Color Index value to the internal format any unused bits are set to zero | | | | | | Intern | al Color Cl | nannels | |----|--------|-------|---------|------|--------|-------------|---------| | | Format | Color | Name | R | G | В | Α | | | | Order | | | | | | | | 0 | BGR | 8:8:8:8 | 8@0 | 8@8 | 8@16 | 8@24 | | | 1 | BGR | 4:4:4:4 | 4@0 | 4@4 | 4@8 | 4@12 | | C | 2 | BGR | 5:5:5:1 | 5@0 | 5@5 | 5@10 | 1@15 | | 0 | 3 | BGR | 5:6:5 | 5@0 | 6@5 | 5@11 | - | | l | 4 | BGR | 3:3:2 | 3@0 | 3@3 | 2@6 | - | | 0 | 0 | RGB | 8:8:8:8 | 8@16 | 8@8 | 8@0 | 8@24 | | u | 1 | RGB | 4:4:4:4 | 4@8 | 4@4 | 4@0 | 4@12 | | r | 2 | RGB | 5:5:5:1 | 5@10 | 5@5 | 5@0 | 1@15 | | | 3 | RGB | 5:6:5 | 5@11 | 6@5 | 5@0 | - | | | 4 | RGB | 3:3:2 | 3@5 | 3@2 | 2@0 | - | | CI | 15 | X | CI8 | 8@0 | 0 | 0 | 0 | # AlphaBlendColorModeAnd AlphaBlendColorModeOr Name Offset **Format Type** Alpha Blend Color ModeAlpha Blend 0x AFA0 Bitfield AlphaBlendColorModeAnd Alpha Blend Bitfield Logic Mask 0x ACB0 Alpha Blend Alpha Blend Color Mode Or0x ACB8 Bitfield Logic Mask Control registers | Bits | Name | Read <sup>2</sup> | Write | Reset | Description | |------|---------------------|-------------------|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | <b>√</b> | Х | When set causes the fragment's color to be alpha blended under control of the remaining bits in this register. When clear the fragment color remains unchanged (but may later to effected by the chroma test). | | 14 | SourceBlend | 1 | 1 | X | This field defines the source blend function to use. See the table in the <i>AlphaBlendColorMode</i> register for the possible options | | 57 | DestBlend | 1 | 1 | Х | This field defines the destination blend function to use. See the table in the <i>AlphaBlendColorMode</i> register for the possible options | | 8 | Source<br>TimesTwo | 1 | ✓ | Х | This bit, when set causes the source blend result to be multiplied by two before it is combined with the dest blend result. When this bit is clear no multiply occurs | | 9 | DestTimes<br>Two | 1 | <b>✓</b> | Х | This bit, when set causes the dest blend result to be multiplied by two before it is combined with the source blend result. When this bit is clear no multiply occurs | | 10 | InvertSource | 1 | 1 | Х | This bit, when set, causes the incomming source data to be inverted before any blend operation takes place | | 11 | InvertDest | 1 | 1 | Х | This bit, when set, causes the incomming dest data to be inverted before any blend operation takes place | | 1215 | Color Format | 1 | 1 | X | This field defines framebuffer color formats. See the table in the <i>AlphaBlendColorMode</i> register for the possible options | | 16 | ColorOrder | 1 | ✓ | Х | This bit selects the color order in the framebuffer:<br>0 = BGR<br>1 = RGB | | 17 | Color<br>Conversion | 1 | 1 | х | This bit selects how color components less than 8 bits wide are converted to 8 bit wide values prior to the alpha blend calculations. The options are 0 = Scale 1 = Shift | 3D labs Proprietary and Confidential 5-5 $<sup>^2\,\</sup>mathrm{Logic}$ Op register readback is via the main register | 18 | Constant | <b>√</b> | ✓ | X | This bit, when set, forces the Source color to come | |------|--------------|----------|----------|---|---------------------------------------------------------| | | Source | | | | from the AlphaSourceColor register (in 8888 format) | | | | | | | instead of the framebuffer. | | | | | | | 0 = Use framebuffer | | | | | | | 1 = Use AlphaSourceColor register | | 19 | ConstantDest | <b>√</b> | <b>√</b> | X | This bit, when set, forces the destination color to | | | | | | | come from the AlphaDestColor register (in 8888 | | | | | | | format) instead of the fragment's color. | | | | | | | 0 = Use fragment's color. | | | | | | | 1 = Use AlphaDestColor register. | | 2023 | Operation | 1 | 1 | X | This field selects how the source and destination blend | | | | | | | results are to be combined. The options are: | | | | | | | 0 Add | | | | | | | 1 Subtract (i.e. S - D) | | | | | | | 2 Subtract reversed (i.e. D - S) | | | | | | | 3 Minimum | | | | | | | 4 Maximum | | 24 | SwapSD | <b>√</b> | <b>√</b> | X | This bit, when set causes the source and destination | | | | | | | pixel values to be swapped. The main use for this is | | | | | | | to allow a downloaded color value to be in a format | | | | | | | other than 8888 and use this unit to do color | | | | | | | conversion. | Notes AlphaBlendColor combines the fragment's Color with the Color stored in the framebuffer using the alpha blend equations, to create lighting or translucncy effects for example. Alpha blending only works for pixels stored in the RGBA format (since Alpha values are not specified in color-index mode). After blending is done the new blended Color replaces the former Color. If alpha blending is disabled then the Color field passes the alpha blend unchanged. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. #### AlphaDestColor | Name | Type | Offset | Format | |----------------|------------------|--------|----------| | AlphaDestColor | Alpha Blend | 0xAF88 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|-------------| | 07 | R | <b>√</b> | 1 | X | Red | | 815 | G | <b>√</b> | <b>√</b> | X | Green | | 1623 | В | ✓ | ✓ | X | Blue | | 2431 | A | ✓ | <b>√</b> | X | Alpha | Notes: This register holds the destination color to use instead of the fragment color when ConstantDest (in AlphaBlendcolorMode or AlphaBlendAlphaMode) is enabled. Each color component has a separate boundary held as an unsigned 8-bit number from Red (least significant bit) to Alpha. #### AlphaSourceColor | Name | Туре | Offset | Format | |------------------|------------------|--------|---------| | AlphaSourceColor | Aľpha Blend | 0xAF80 | Integer | | • | Control register | | · · | | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|-------------| | 07 | R | <b>√</b> | <b>√</b> | X | Red | | 815 | G | ✓ | ✓ | X | Green | | 1623 | В | ✓ | ✓ | X | Blue | | 2431 | A | ✓ | ✓ | X | Alpha | Notes: This register holds the source color to use instead of the framebuffer color when ConstantSource (in AlphaBlendcolorMode or AlphaBlendAlphaMode) is enabled. Each color component has a separate boundary held as an unsigned 8-bit number from Red (least significant bit) to Alpha. # AlphaTestMode AlphaTestModeAnd AlphaTestModeOr Name Offset **Format Type** AlphaTestMode AlphaBlend 0x 8800 Bitfield AlphaTestModeAnd AlphaBlend 0x ABF0 Bitfield Logic Mask AlphaTestModeOr AlphaBlend 0x ABF8 Bitfield Logic Mask Control registers | Bits | Name | Read <sup>3</sup> | Write | Reset | Description | |------|-----------|-------------------|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | x | When set causes the fragment's alpha value to be tested under control of the remaining bits in this register. If the alpha test fails then the fragment is discarded. When this bit is clear the fragment alway passes the alpha test. 0 = Disable | | 13 | Compare | | 7 | X | This field defines the unsigned comparison function to use. The options are: 0 = Never 1 = Less 2 = Equal 3 = Less Equal 4 = Greater 5 = Not Equal 6 = Greater Equal 7 = Always The comparison order is as follows: result = fragment, Alpha Compare Function, reference, Alpha. | | 411 | Reference | 1 | 1 | х | This field holds the 8 bit reference alpha value used in the comparison. | | 1231 | Unused | 0 | 0 | X | • | Notes The Alpha Test, if enabled, compares the alpha value of a fragment, after coverage weighting, against a reference value and if the compare passes the fragment is allowed to continue. If the comparison fails the fragment is culled and will not be drawn. 5-8 Proprietary and Confidential 3Dlabs $<sup>^3</sup>$ Logic Op register readback is via the main register #### AntialiasMode AntialiasModeAnd AntialiasModeOr Name **Type** Offset **Format** AntialiasMode Alpha Test 0x 8808 Bitfield Bitfield Logic Mask AntialiasModeAnd Alpha Test 0x ABF0 AntialiasModeOr Alpha Test 0x ABF8 Bitfield Logic Mask Control registers | Bits | Name | Read <sup>4</sup> | Write | Reset | Description | |------|-------------|-------------------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | х | When set causes the fragment's alpha value to be scaled under control of the remaining bits in this register and the coverage value. When this bit is clear the fragment's alpha value is not changed. 0 = Disable 1 = Enable | | 1 | Color Mode | 7 | 1 | Х | This bit defines the color format the fragment's color is in: $0 = RGBA$ $1 = CI$ | | 2 | Scale Color | 1 | <b>√</b> | Х | This bit, when set allows the coverage value to scale the RGB components as well as the alpha component. When this bit is reset only the alpha component is scaled. This allows antialiasing of pre multiplied images used in compositing. | | 331 | Unused | 0 | 0 | X | | Notes: The register controls the operation of antialiasing. When the unit is enabled: - In Color Index (CI) mode the bottom 4 bits of the color index of a fragment is replaced by the coverage value scaled by 15/256, where the result is rounded to the nearest integer. - In RGBA mode the alpha component of a fragment is multiplied by the coverage value, but the RGB components are not changed unless ScaleColor is also enabled When antialiased primitives are being rendered the fragment's color is weighted by the percentage area of the pixel the fragment covers. An approximation to the area covered is calculated. If antialiasing is disabled then the color is passed onto the alpha test stage unchanged. Note that the CoverageEnable bit in the *Render* command must also be set to enable antialiasing. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. 3Dlabs Proprietary and Confidential 5-9 <sup>&</sup>lt;sup>4</sup> Logic Op register readback is via the main register only 0xABD8 Bitfield Logic Mask # AreaStippleModeAnd AreaStippleModeAnd AreaStippleModeOr NameTypeOffsetFormatAreaStippleModeStipple0x81A0BitfieldAreaStippleModeAndStipple0xABD0Bitfield Logic Mask AreaStippleModeOr Stipple Control registers | Bits | Name | Read <sup>5</sup> | Write | Reset | Description | |------|---------------------------|-------------------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | X | This field, when set, enables area stippling. The AreaStippleEnable bit in <i>Render</i> must also be set for this to have an effect. | | 13 | X address<br>select: | 1 | 1 | Х | 0 = 1 bit $1 = 2 bit$ $2 = 3 bit$ $3 = 4 bit$ $4 = 5 bit$ | | 46 | Y address<br>select: | 1 | 1 | Х | 0 = 1 bit $1 = 2 bit$ $2 = 3 bit$ $3 = 4 bit$ $4 = 5 bit$ | | 711 | X Offset | 1 | 1 | х | This field holds the offset to add to the X value before it is used to index into the stipple bit. This allows a window relative stipple pattern to be selected when the coordinates are given in screen relative format. | | 1216 | Y Offset | 1 | 1 | Х | This field holds the offset to add to the Y value before it is used to index into the area stipple pattern table. This allows a window relative stipple pattern to be selected when the coordinates are given in screen relative format. | | 17 | Invert Stipple<br>Pattern | 1 | 1 | Х | 0 = No Invert 1 = Invert | | 18 | Mirror X | ✓ | ✓ | X | 0 = No Mirror 1 = Mirror | | 19 | Mirror Y | 1 | <b>√</b> | X | 0 = No Mirror $1 = Mirror$ | | 20 | OpaqueSpan | 1 | 1 | X | This bit, when set, allows the area stipple pattern to modify the color mask, otherwise the pixel mask is modified. | | 2125 | XTableOffset | 1 | 1 | Х | This field allows a sub area stipple pattern to be extracted from the area stipple table, i.e. the area stipple table is treated as a cache of smaller stipple patterns. | | 2630 | YTableOffset | 1 | 1 | Х | This field allows a sub area stipple pattern to be extracted from the area stipple table, i.e. the area stipple table is treated as a cache of smaller stipple patterns. | | 31 | Unused | 0 | 0 | X | | $<sup>^{5}</sup>$ Logic Op register readback is via the main register only Notes: - This register controls Area Stippling. This involves applying the correct stipple pattern (mask) which can also be mirrored or inverted. The least significant bits of the fragment's XY coordinates index into a 2D stipple pattern. If the selected bit is set the fragment passes the test, otherwise it fails. An offset is added to the XY coordinate and the result optionally mirrored and/or inverted before the stipple bit is accessed. - **2.** Both the AreaStippleEnable bit in the *Render* command and the enable in the *AreaStippleMode* register must be set, to enable the area stipple test. - 3. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. # AreaStipplePattern [0...15] AreaStipplePattern [16...31] | Name | Туре | Offset | Format | |--------------------|------------------|---------------|---------| | AreaStipplePattern | Stipple | 0x8200 - 82F8 | Bitmask | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-----------------------------------| | 031 | Mask | ✓ | ✓ | X | 32 bit mask for area pattern data | Notes: These 32 registers provide the bitmask which enables and disables corresponding fragments for drawing when rasterizing a primtive with area stippling. They hold the LSBs and MSBs of area pattern data. The Y' value in the StippleMode register selects the row in the stipple RAM (row zero is at AreaStipplePattern[0]) and this is the first value of the AreaStippleMask. #### **AStart** | Name | Type | Offset | Format | |--------|------------------|--------|--------------------| | AStart | Color | 0x87C8 | Fixed point number | | | Control register | | - | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------| | 014 | Fraction | <b>√</b> | <b>√</b> | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: Used to set the initial Alpha value of a vertex when in Gouraud shading mode. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### **BackgroundColor** | Name | Туре | Offset | Format | |-----------------|------------------|--------|---------| | BackgroundColor | Logic Ops | 0xB0C8 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------------------|----------|-------|-------|----------------| | 031 | Background<br>Color | <b>√</b> | 1 | X | 32 bit integer | Notes: With ForegroundColor, holds the foreground and background color values. A background pixel is a pixel whose corresponding bit in the color mask is zero. The color format is in the raw framebuffer format and 8 or 16 bit pixels are automatically replicated to fill the 32 bits of register. #### **BasePageOfWorkingSet** | Name | Type | Offset | Format | |----------------------|------------------|--------|---------| | BasePageOfWorkingSet | Texture Read | 0xB4C8 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-------|-------|--------------------------------------| | 015 | Page number | ✓ | ✓ | X | 16 bit integer value from 0 to 65535 | | 1531 | Unused | 0 | 0 | X | | Notes: Holds the page number of the start of the region of memory to be used as the working set. This is measured in units of 4K bytes from 0 (the first byte address with respect to P3's view of the memory map). This allows the Physical Page Allocation Table to be smaller as it doesn't have to include low memory locations reserved for Z buffer, color buffers, etc. The legal range of values is 0...65535. Before any logical or virtual texture management can be done there are a number of areas which need to be initialised (in addition to the usual mode, etc. register initialisation): - Space for the Logical Texture Page Table must be reserved in the local buffer and the table initialised to zero. The LogicalTexturePageAddr and LogicalTexturePageTableLength must be set up. - Space for the working set must be reserved in the local buffer and/or framebuffer. This need not be physically consecutive pages. The BasePageOfWorkingSet register is set up. #### **BasePageOfWorkingSetHost** | Name | Type | Offset | Format | |----------------------|--------------|--------|---------| | BasePageOfWorkingSet | Texture Read | 0xB4E0 | Integer | | Host | | | Ü | Control register | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-------|-------|-----------------------| | 019 | Page number | ✓ | ✓ | X | 20 bit integer value. | Notes: This 20 bit register holds the page number of the start of the region of host memory to be used as the working set. This is a 256MByte region and can be positioned anywhere in the 4GByte host address range. This is measured in units of 4K bytes from 0 (the first byte address in the physical memory map). #### **BitMaskPattern** | Name | Туре | Offset | Format | |----------------|---------------|--------|---------| | BitMaskPattern | Rasterizer | 0x8068 | Integer | | | Command and C | · · | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Bitmask | 1 | 1 | X | 32 bit value | Notes: Value used to control the bit mask stipple operation (if enabled). Fragments are accepted or rejected based on the current BitMask test modes defined by the RasterizerMode register. Note: the SyncOnBitmask bit in the Render command must also be enabled. The bit mask is written in the BitMaskPattern register and can be modified in a number of ways before being used. These modifications are applied in the order below and are enabled using the corresponding bit in the RasterizerMode register. As each pixel in the primitive is generated one bit of the bit mask is consumed. Internally the bits are always consumed from the least significant end towards the most significant end, however the MirrorBitMask effectively reverses this order. | В | itMaskPa | ttern Application Bits in the RasterizerMode Register | |-----------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Mode | Raster-<br>izer<br>Mode<br>Bit no. | Description (See RasterizerMode register for details) | | ByteSwapBitMask | 7,8 | Byte swaps the bit mask pattern as directed by the <i>BitMaskByteSwapMode</i> . This allows the bitmasks used internally for Windows or WindowsNT to be used directly | | MirrorBitMask | 0 | The bit mask pattern is mirrored so bit 0 become bit 31, bit 1 becomes bit 30, etc. Bit 0 is the least significant bit. This feature allows the left most pixel in a window to be assigned to the most or least significant bit in the bit mask pattern. | | InvertBitMask | 1 | The bit mask pattern is inverted before it is used so that fragments associated with '0' bits are now written instead of fragments associated with '1' bits. The inversion is useful when two passes are needed to draw the primitive, for example to draw the foreground pixels using a different logical operation to the background pixels for a character. | | BitMaskPacking | 9 | Selects whether the bit mask pattern is packed so that adjacent rows butt together to minimise the number of words to transfer for the whole pattern. If not then a new bit mask pattern is required for every scanline. For span fills a new bit mask pattern <i>must</i> be provided at the start of every scanline. | | BitMaskOffset | 1014 | Determines the first bit to use in the bit mask pattern for the first bit mask pattern on a scanline. Subsequent bit masks will always start at bit 0 until the next scanline is encountered. The default is zero and the bit position refers to the position <i>after</i> any byte swapping or mirroring has been done. This allows the source and destination rectangle alignments to be different. | #### BorderColor0 BorderColor1 | Name | Type | Offset | Format | |--------------|------------------|--------|----------| | BorderColor0 | Texture | 0x84A8 | Bitfield | | BorderColor1 | Texture | 0x84F8 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|-------------| | 07 | R | <b>√</b> | <b>√</b> | X | Red | | 815 | G | ✓ | ✓ | X | Green | | 1623 | В | ✓ | ✓ | X | Blue | | 2431 | A | ✓ | ✓ | X | Alpha | Notes: If a border has not been provided in the texture map, but a border texel is needed, they are taken from the BorderColor registers. BorderColor0 holds the border color to be used for Texels T0...T3. Its format is red in byte 0, green in byte 1, blue in byte 2 and alpha in byte 3. BorderColor1 holds the border color to be used for Texels T4...T7. Its format is identical. #### **BStart** | Name | Туре | Offset | Format | |--------|------------------|--------|--------------------| | BStart | Color | 0x87B0 | Fixed point number | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | ✓ | ✓ | Х | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: Used to set the initial Blue value for a vertex when in Gouraud shading mode. The value is 24 bit 2's complement fixed point numbers in 9.15 format. #### ChromaFailColor | Name | Type | Offset | Format | |-----------------|------------------|--------|----------| | ChromaFailColor | Color | 0xAF98 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|-------------| | 07 | R | 1 | <b>√</b> | X | Red | | 815 | G | ✓ | <b>√</b> | X | Green | | 1623 | В | ✓ | ✓ | X | Blue | | 2431 | A | <b>√</b> | <b>√</b> | X | Alpha | Notes: This register holds the chroma color to use when the chroma test is enabled and the chroma operation is substitute fail color. Its format is 8 bit ABGR components packed into a 32 bit word with R in the LS byte. #### ChromaLower | Name | Type | Offset | Format | |-------------|------------------|--------|----------| | ChromaLower | Color | 0x8F10 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|-------------| | 07 | R | <b>√</b> | <b>√</b> | X | Red | | 815 | G | ✓ | ✓ | X | Green | | 1623 | В | ✓ | ✓ | X | Blue | | 2431 | A | ✓ | ✓ | X | Alpha | Notes: This register holds the lower bound color for the chroma test. Each color component has a seperate boundary held as an unsigned 8 bit number with Red in the lower byte, then green, then blue and finaly in the upper byte alpha. The test is inclusive so the fragment is in range if all its components are less than or equal to the upper bound and greater than or equal to the lower bound. The options are to reject the fragment so nothing gets drawn or the color is replaced by the value held in the ChromaPassColor or ChromaFailColor registers. Note this is different to GLINT MX #### ChromaPassColor | Name | Type | Offset | Format | |-----------------|------------------|--------|----------| | ChromaPassColor | Color | 0xAF90 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|-------------| | 07 | R | <b>√</b> | <b>√</b> | X | Red | | 815 | G | <b>√</b> | ✓ | X | Green | | 1623 | В | <b>√</b> | ✓ | X | Blue | | 2431 | A | <b>√</b> | ✓ | X | Alpha | Notes: This register holds the chroma color to use when the chroma test is enabled and the chroma operation is substitute pass color. Its format is 8 bit ABGR components packed into a 32 bit word with R in the LS byte. # ChromaTestMode ChromaTestModeAnd ChromaTestModeOr Name Offset **Format** Type ChromaTestMode Alpha Blend 0x8F18 Bitfield Chroma Test Mode AndAlpha Blend 0xACC0 Bitfield Logic Mask ChromaTestModeOr Alpha Blend 0xACC8 Bitfield Logic Mask Control registers | Bits | Name | Read <sup>6</sup> | Write | Reset | Description | |------|------------|-------------------|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | <b>√</b> | X | When set enables chroma testing under control of the remaining bits in this register. When clear no chroma test is done. | | 12 | Source | 1 | 1 | X | This field selects which color (after any suitable conversion) is to be used for the chroma test. The values are: 0 = FBSourceData 1 = FBData 2 = Input Color (from fragment) 3 = Output Color (after any alpha blending) | | 34 | PassAction | 1 | ✓ | Х | This field defines what action is to be taken if the chroma test passes (and is enabled). The options are: 0 = Pass 1 = Reject 2 = Substitute ChromaPassColor 3 = Substitute ChromaFailColor | | 56 | FailAction | <b>√</b> | <b>√</b> | х | This field defines what action is to be taken if the chroma test fails (and is enabled). The options are: 0 = Pass 1 = Reject 2 = Substitute ChromaPassColor 3 = Substitute ChromaFailColor | | 731 | Unused | 0 | 0 | X | | Notes: Used to test the fragment's color against a range of colors after alphablending. The chroma test is enabled by the enable bit (0) in the register. Note: incompatible with MX programming. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. <sup>&</sup>lt;sup>6</sup> Logic Op register readback is via the main register only #### ChromaUpper | Name | Type | Offset | Format | |-------------|------------------|--------|----------| | ChromaUpper | Color | 0x8F08 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|-------------| | 07 | R | <b>√</b> | <b>√</b> | X | Red | | 815 | G | <b>√</b> | ✓ | X | Green | | 1623 | В | <b>√</b> | ✓ | X | Blue | | 2431 | A | <b>√</b> | ✓ | X | Alpha | Notes: This register holds the upper bound color for the chroma test. Each color compoent has a seperate boundary held as an unsigned 8 bit number with Red in the lower byte, then greeen, then blue and finaly in the upper byte alpha. The test is inclusive so the a fragment is in range if all its components are less than or equal to the upper bound and greater than or equal to the lower bound. The options are to reject the fragment so nothing gets drawn or the color is replaced by the value held in the ChromaPassColor or ChromaFailColor registers. Note this is different to GLINT MX #### Color | Name | Туре | Offset | Format | |-------|------------------|--------|----------| | Color | Host In | 0x87F0 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|----------|----------|-------|-------------| | 07 | Red | <b>√</b> | <b>√</b> | X | | | 815 | Green | ✓ | ✓ | X | | | 1623 | Blue | ✓ | ✓ | X | | | 2431 | Alpha | ✓ | ✓ | X | | Notes: This register is used in conjunction with the *SyncOnHost* bit in the **Render** command to trigger fragment generation under Host control. ### ColorDDAModeAnd ColorDDAModeAnd ColorDDAModeOr | Name | Туре | Offset | Format | |-----------------|-------------------|--------|---------------------| | ColorDDAMode | Color | 0x87E0 | Bitfield | | ColorDDAModeAnd | Color | 0xABE0 | Bitfield Logic Mask | | ColorDDAModeOr | Color | 0xABE8 | Bitfield Logic Mask | | | Control registers | | 9 | | Bits | Name | Read <sup>7</sup> | Write | Reset | Description | |------|---------|-------------------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | Enable | 1 | <b>✓</b> | X | This bit, when set, causes the current color to be generated. | | 2 | Shading | 1 | • | Х | Selects the shading mode. The two options are: 0 = Flat – the color is taken from the Constant Color register. 1 = Gouraud – the color is taken from the DDAs. | | 331 | Unused | 0 | 0 | X | | Notes: The ColorDDAMode register controls the operation of the Color DDA unit using the Enable and Shading bits. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. # CommandInterrupt | Name | <b>Type</b> | Offset | <b>Format</b> | |------------------|------------------|--------|---------------| | CommandInterrupt | Host In | 0xA990 | Bitfield | | 1 | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|-----------------------------------------| | 0 | Output DMA | ✓ | ✓ | X | 1 = trigger on completion of output DMA | | 131 | Reserved | ✓ | ✓ | X | | | Notes: | <br> | | |--------|------|--| 5-20 Proprietary and Confidential 3Dlabs <sup>&</sup>lt;sup>7</sup> Logic Op register readback is via the main register only # Config2D Name Type Offset Format Config2D Global 0xB618 Bitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|-------------------------------|----------|-------|-------|-------------------------------------------------------------------------------------| | 0 | Opaque Span | 1 | 1 | Х | In RasterizerMode, AreaStippleMode, LogicalOpMode,<br>FBWriteMode, TextureReadMode. | | 1 | MultiRXBlit | × | × | X | Reserved | | 2 | UserScissorEna<br>ble | <b>√</b> | 1 | X | ScissorMode | | 3 | FBDestReadEn<br>able | ✓ | 1 | Х | In $FBDestReadMode$ bit $3 = (ReadEnable)$ | | 4 | AlphaBlendEna<br>ble | <b>√</b> | 1 | Х | In AlphaBlendColorMode and AlphaBlendAlphaMode. bit 4 = AlphaBlendEnable (Enable) | | 5 | DitherEnable | <b>√</b> | 1 | X | In DitherMode. bit 5 = DitherEnable (Enable) | | 6 | ForgroundLogi<br>calOpEnable | ✓ | 1 | х | In LogicalOpMode: bit 6 = ForgroundLogicalOpEnable (Enable) | | 710 | ForgroundLogi<br>calOp | <b>√</b> | 1 | Х | In LogicalOpMode: Bits 7-10 = ForgroundLogicalOp (LogicOp) | | 11 | BackgroundLog<br>icalOpEnable | ✓ | 1 | х | In LogicalOpMode: Bit 11 = BackgroundLogicalOpEnable (Background En.) | | 1215 | BackgroundLog icalOp | ✓ | 1 | Х | In LogicalOpMode: Bits 12-15 = BackgroundLogicalOp | | 16 | UseConstantSo<br>urce | <b>√</b> | 1 | X | In LogicalOpMode: bit 16 = UseConstantSource | | 17 | FBWriteEnable | ✓ | 1 | Х | In FBWriteMode. bit 17 = FBWriteEnable (WriteEnable) | | 18 | Blocking | <b>√</b> | 1 | Х | In FBSourceReadMode bit 18 = Blocking | | 19 | ExternalSource<br>Data | <b>√</b> | 1 | Х | In FBSourceReadMode bit 19 = ExternalSourceData | | 20 | LUTMode<br>Enable | ✓ | ✓ | X | In LUTMode. bit 20 = Enable | Notes: This register updates the mode registers in multiple units as shown. The name in brackets is the field name in the corresponding mode register, if different to the field name for the *Config2D* command. Also note that bit 0 affects several mode registers. #### **Constant Color** | Name | Type | Offset | Format | |---------------|------------------|--------|----------| | ConstantColor | Delta | 0x87E8 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|-------------| | 07 | Red | ✓ | 1 | х | | | 815 | Green | 1 | 1 | X | | | 1623 | Blue | 1 | 1 | X | | | 2431 | Alpha | 1 | 1 | X | | Notes: This register holds the constant color in packed format. This is a legacy register maintained for backwards compatibility which has been superceded by the *ConstantColorDDA* register. The *ConstantColorDDA* register, as well as loading up the constant color register, also loads the DDA start register from the corresponding color byte and sets the dx and dyDom gradients to zero. This allows a constant color to be set up irrespective of the shading mode. #### ConstantColorDDA | Name | Type | Offset | Format | |------------------|------------------|--------|----------| | ConstantColorDDA | Color | 0xAFB0 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|-------------| | 07 | R | <b>√</b> | <b>√</b> | X | Red | | 815 | G | ✓ | ✓ | X | Green | | 1623 | В | ✓ | ✓ | X | Blue | | 2431 | A | ✓ | ✓ | X | Alpha | Notes: This register holds the constant color in packed format. As well as loading up the constant color register it also loads up the DDA start register from the corresponding color byte and sets the dx and dyDom gradients to zero. This allows a constant color to be set up irrespective of the shading mode. #### ContextData | Name | Type | Offset | Format | |-------------|------------------|--------|----------| | ContextData | Global | 0x8DD0 | Variable | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-------|-------|------------------------------------------------------------------------| | 115 | Reserved | | | | | | 1631 | ContextData | ✓ | × | X | Undefined, returned by ContextDump command = (number of data words) -1 | Notes: The context data is read from the Host Out FIFO and stored in memory in a context buffer (excluding any tags), while the context mask is typically discarded. This context buffer can be restored by prefixing it with the three words: **RestoreContext** tag, context mask (used to generate the buffer in the first place) and the **ContextData** tag, and loading it all. The **ContextData** tag has the upper 16 bits set to the number of words of context data in the buffer minus one<sup>8</sup>. The layout of the data in the context dump buffer is not important (and is in fact largely undocumented) because no massaging of the data is necessary before it can be restored. 3Dlabs Proprietary and Confidential 5-23 $<sup>^8</sup>$ A tag with a count in the upper 16 bits is a hold mode tag so all the subsequent data is automatically given the same tag. #### ContextDump Name Type Offset Format ContextDump Global 0x8DC0 Bitfield Command | Bits | Name | Read | Write | Reset | Description | Data<br>Words | |------|-----------------|------|----------|-------|--------------------------------------------|---------------| | 0 | GeneralControl | X | ✓ | Х | Vertex list and Delta setup mode registers | 4 | | 1 | Geometry | X | 1 | X | Delta unit state | 67 | | 2 | Matrices | X | ✓ | Х | unused | | | 3 | Material | × | <b>√</b> | X | unused | | | 4 | Lights0_7 | × | <b>√</b> | X | unused | | | 5 | Lights8_15 | X | ✓ | Х | unused | | | 6 | RasterPos | × | <b>√</b> | X | unused | | | 7 | CurrentState | × | <b>√</b> | X | unused | | | 8 | TwoD | X | ✓ | Х | State used for 2D operations and 2D | 7 | | | | | | | setup | | | 9 | DMA | × | <b>√</b> | X | State used for tag-driven DMAs | 52 | | | | | | | (If using Command DMA) | (51) | | 10 | Select | × | <b>√</b> | X | unused | | | 11 | RasterizerState | X | 1 | X | General setup of the rasterization units | 231 | | 12 | DDA | × | <b>√</b> | X | DDA Values | 69 | | 13 | Ownership | × | ✓ | X | Stripe ownership state | 2 | | 14 | FogTable | X | 1 | Х | Contents of the Fog Table | 64 | | 15 | LŬT | X | 1 | Х | Contents of the LUT | 256 | | 16 | TextureManage | X | 1 | Х | State used for logical texturing (virtual | 9 | | | ment | | | | texturing) | | | 1731 | Reserved | 0 | 0 | X | | | Notes: This command forces the P3 to dump the selected context. Context switching can be done on any command boundary but not during internal processing or texture/image downloads. The context is dumped from each unit by the *ContextDump* command and restored by the *ContextRestore* command. The data sent with this command (the context mask) dictates what subset of the full context is to be dumped: - The context for each unit is defined by the ContextMask sent in the data word of the ContextDump and ContextRestore commands. - It appears in the Host Output FIFO tagged as ContextData where the host of the output DMA controller can read it. - The amount of data sent depends on the context mask sent with the command. - The last tag and data sent to the FIFO is the ContextDump tag and mask, but this is not included in the word counts above - For paired context dump and restore operations the same mask is required. - The context data is read from the Host Out FIFO and stored in memory in a context buffer (excluding any tags). - For further information see the ContextRestore, EndofFeedback, FilterMode and ContextData registers #### ContextRestore NameTypeOffsetFormatContextRestoreGlobal0x8DC8BitfieldCommand | Bits | Name | Read | Write | Reset | Description | Data<br>Words | |------|-----------------|------|----------|-------|--------------------------------------------|---------------| | 0 | GeneralControl | × | 1 | X | Vertex list and Delta setup mode registers | 4 | | 1 | Geometry | × | 1 | X | Delta unit state | 67 | | 2 | Matrices | X | 1 | X | unused | | | 3 | Material | X | 1 | X | unused | | | 4 | Lights0_7 | X | 1 | X | unused | | | 5 | Lights8_15 | X | 1 | X | unused | | | 6 | RasterPos | X | 1 | X | unused | | | 7 | CurrentState | X | 1 | X | unused | | | 8 | TwoD | X | <b>√</b> | Х | State used for 2D operations and 2D | 7 | | | | | | | setup | | | 9 | DMA | X | <b>√</b> | X | State used for tag-driven DMAs | 52 | | | | | | | (If using Command DMA) | (51) | | 10 | Select | × | ✓ | X | unused | | | 11 | RasterizerState | X | <b>√</b> | Х | General setup of the rasterization units | 231 | | 12 | DDA | × | <b>√</b> | Х | DDA Values | 69 | | 13 | Ownership | × | <b>√</b> | Х | Stripe ownership state | 2 | | 14 | FogTable | × | <b>√</b> | Х | Contents of the Fog Table | 64 | | 15 | LUT | × | <b>√</b> | Х | Contents of the LUT | 256 | | 16 | TextureManage | × | <b>√</b> | Х | State used for logical texturing (virtual | 9 | | | ment | | | | texturing) | | | 1731 | Reserved | 0 | 0 | Х | _ | | #### Notes: - The context for each unit is defined by the ContextMask sent in the data word of the ContextDump and ContextRestore commands. The various fields in the mask and their effect on units is as shown. - For further information see the ContextDump, EndofFeedback, FilterMode and ContextData registers #### Continue | Name | Туре | Offset | Format | |----------|------------|--------|---------| | Continue | Rasterizer | 0x8058 | Integer | | | Command | | · · | | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|-------|-------|------------------------------------| | 015 | Scanlines | ✓ | ✓ | X | 16 bit unsigned integer | | 1631 | Reserved | 0 | 0 | X | Reserved for future use, mask to 0 | Notes: Continues rasterisation to continue after new delta value(s) have been loaded, but doesn't cause either of the trapezoid's edge DDAs to be reloaded. The data field holds the number of scanlines (or sub scanlines) to fill as a 16 bit unsigned integer. Note: this count does not get loaded into the *Count* register. #### **ContinueNewDom** | Name | Туре | Offset | Format | |----------------|------------|--------|---------| | ContinueNewDom | Rasterizer | 0x8048 | Integer | | | Command | | _ | | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|-------|-------|------------------------------------| | 015 | Scanlines | ✓ | ✓ | X | 16 bit unsigned integer | | 1631 | Reserved | 0 | 0 | X | Reserved for future use, mask to 0 | Notes: This command causes rasterization to continue with a new dominant edge. The dominant edge DDA in the rasterizer is reloaded with the new parameters. The subordinate edge is carried on from the previous trapezoid. This allows any convex 2D polygon to be broken down into a collection of trapezoids and continuity maintained across boundaries. Since this command only affects the rasterizer DDA (and not any of the other units), it is not suitable for 3D operations. The data field holds the number of scanlines (or sub scanlines) to fill. Note this count does not get loaded into the *Count* register. #### **ContinueNewLine** | Name | Туре | Offset | Format | |-----------------|------------|--------|---------| | ContinueNewLine | Rasterizer | 0x8040 | Integer | | | Command | | _ | | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|-------|-------|------------------------------------| | 015 | Scanlines | ✓ | ✓ | X | 16 bit unsigned integer | | 1631 | Reserved | 0 | 0 | X | Reserved for future use, mask to 0 | Notes: Allows the raterization to continue for the next segment in a polyline. The XY position is carried on from the previous line, however the fraction bits in the DDAs can be kept, set to zero or half under control of the *RasterizerMode*. The data field holds the number of scanlines (or sub scanlines) to fill as a 16 bit unsigned integer. Note this count does not get loaded into the *Count* register. The use of *ContinueNewLine* is not recommended for OpenGL because the DDA units will start with a slight error as compared with the value they would have been loaded with for the second and subsequent segments. #### **ContinueNewSub** | Name | Туре | Offset | Format | |----------------|------------|--------|---------| | ContinueNewSub | Rasterizer | 0x8050 | Integer | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|-------|-------|------------------------------------| | 015 | Scanlines | ✓ | ✓ | X | 16 bit unsigned integer | | 1631 | Reserved | 0 | 0 | X | Reserved for future use, mask to 0 | Notes: This command causes rasterization to continue with a new subordinate edge. The subordinate edge DDA in the rasterizer is reloaded with the new parameters. The dominant edge is carried on from the previous trapezoid. This is very useful when scan converting triangles with a "knee" (i.e. two subordinate edges. The data field holds the number of scanlines (or sub scanlines) to fill. Note this count does not get loaded into the *Count* register. #### Count | Name | Туре | Offset | Format | |-------|------------------|--------|---------| | Count | Rasterizer | 0x8030 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------| | 015 | variable | ✓ | ✓ | X | 16 bit unsigned integer | | 1631 | Reserved | 0 | 0 | X | Reserved for future use, mask to 0 | Notes: Mode set in Render command: - Number of pixels in a line. - Number of scanlines in a trapezoid. - Number of sub scanlines in an antialiased trapezoid. - Diameter of a point in sub scanlines. Unsigned 16 bits. #### dAdx | Name | Type | Offset | Format | |------|------------------|--------|-------------| | dAdx | Color | 0x87D0 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------| | 014 | Fraction | <b>√</b> | <b>√</b> | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: Used to set the X derivative for the Alpha value for the interior of a trapezoid when in Gouraud shading mode. The format is 24 bit 2's complement 9.15 fixed point numbers. With dBdx, dGdx and dRdx, holds the X gradient values for the Red, Green, Blue and Alpha Color components. See also dFdx for Fog rendering coefficient. ### dAdyDom | Name | Туре | Offset | Format | |---------|------------------|--------|-------------| | dAdyDom | Color DDA | 0x87D8 | Fixed point | | • | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------| | 014 | Fraction | <b>√</b> | <b>√</b> | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: This register is used to set the Y derivative dominant for the Alpha value along a line, or for the dominant edge of a trapezoid, when in Gouraud shading mode. The value is in 24 bit 2's complement 9.15 fixed point format. #### dBdx | Name | Туре | Offset | Format | |------|------------------|--------|-------------| | dBdx | Color | 0x87B8 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | ✓ | ✓ | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: Used to set the X derivative for the Red value for the interior of a trapezoid when in Gouraud shading mode. The format is 24 bit 2's complement 9.15 fixed point numbers. # dBdyDom | Name | Type | Offset | Format | |---------|--------------|--------|-------------| | dBdyDom | Color | 0x87C0 | Fixed point | | · | Control regi | ster | • | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | ✓ | ✓ | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: This register is used to set the Y derivative dominant for the Blue value along a line, or for the dominant edge of a trapezoid, when in Gouraud shading mode. The value is in 24 bit 2's complement 9.15 fixed point format. # DeltaControlAnd DeltaControlOr NameTypeOffsetFormatDeltaControlDelta0x9350Bitfield DeltaControlAnd Delta 0xAB20 Bitfield Logic Mask DeltaControlOr Delta 0xAB28 Bitfield Logic Mask **Control Register** | Bits | Name | Read <sup>9</sup> | Write | Reset | Description | |-------|---------------|-------------------|----------|-------|------------------------------------------------| | 0 | WrapS | <b>√</b> | <b>√</b> | Х | 1 = enable wrapping in S | | 1 | WrapT | ✓ | ✓ | X | 1 = enable wrapping in T | | 2 | FullScreenAA | ✓ | ✓ | X | 1 = enabled | | 3 | DrawLineEndP | ✓ | ✓ | X | 1 = enabled | | 4 | ForceQ | ✓ | ✓ | X | 0 = leave Q as delivered, $1 = set Q$ to $1.0$ | | 5 | Reserved | 0 | 0 | X | | | 6 | UseProvokingV | ✓ | ✓ | X | 1 = enabled | | 7 | Reserved | 0 | 0 | X | | | 8 | WrapS1 | ✓ | ✓ | X | 1 = enable wrapping in S for texture 1 | | 9 | WrapT1 | ✓ | ✓ | X | 1 = enable wrapping in T for texture 1 | | 10 | ShareQ | ✓ | ✓ | X | 1 = Set Q1 = Q | | 11 | Line2D | ✓ | ✓ | X | 1 = draw 2D lines | | 12 | ShareS | ✓ | ✓ | X | 1 = set S1 = S | | 13 | ShareT | ✓ | ✓ | X | 1 = set T1 = T | | 14 | ShareColor | ✓ | ✓ | X | 1 = set diffuse to color | | 15 | Reserved | 0 | 0 | X | | | 16 | Reserved | 0 | 0 | X | | | 17-31 | Reserved | 0 | 0 | X | | Notes: - The texture coordinates can be modified by enabling wrapping in S or T. This mode adjusts the texture coordinates so that shortest path is taken; if the normalized S coordinates of two points are 0.1 and 0.9, the shortest path goes from 0.1 to 0, wraps around to 1.0 amd goes down to 0.9. - 2. Full screen antialiasing is acheived by drawing at 2x reolution in X and Y, then filtering down to the correct size. This mode requires all X and Y values to be doubled. - 3. The end point of a line is not normally drawn, but will be if enabled in this register. - If UseProvokingVertex is enabled, certain parameters (defined by the ProvokingVertexMask) are flat shaded using the vertex specified by the provoking vertex register. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. 3Dlabs Proprietary and Confidential 5-31 <sup>&</sup>lt;sup>9</sup> Logic Op register readback is via the main register only # DeltaMode DeltaModeAnd DeltaModeOr NameTypeOffsetFormatDeltaModeDelta0x9300BitfieldDeltaModeAndDelta0xAAD0Bitfield DeltaModeAnd Delta 0xAAD0 Bitfield Logic Mask DeltaModeOr Delta 0xAAD8 Bitfield Logic Mask Control registers | Bits | Name | Read<br>10 | Write | Reset | Description | |--------|------------------------------|------------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0, 1 | TargetChip | 1 | ✓ | X | Read only field, fixed at $1 = TX$ . | | 2, 3 | DepthFormat | <b>√</b> | 1 | Х | This field defines the depth format and hence the final format of the depth parameters to be written into the P3. The options are: $0 = 15 \text{ bits} \qquad 1 = 16 \text{ bits}$ $2 = 24 \text{ bits} \qquad 3 = 32 \text{ bits}$ | | 4 | FogEnable | ✓ | 1 | Х | When set enables the fog calculations. This is qualified by the FogEnable bit in the Draw command. | | 5 | Texture Enable | ✓ | <b>√</b> | Х | When set enables the texture calculations. This is qualified by the TextureEnable bit in the Draw command. | | 6 | Smooth Shad-<br>ing Enable | <b>√</b> | <b>√</b> | х | When set enables the color calculations. | | 7 | Depth Enable | ✓ | ✓ | X | When set enables the depth calculations. | | 8 | Specular<br>Texture Enable | ✓ | <b>√</b> | Х | When set enables the specular texture calculations. | | 9 | Diffuse Texture<br>Enable | ✓ | <b>√</b> | х | When set enables the diffuse texture calculations | | 10 | SubPixelCorrec<br>tionEnable | ✓ | 1 | Х | When set provides the subpixel correction in Y. This is qualified by the SubPixelCorrectionEnable in the Draw command. | | 11 | DiamondExit | 1 | 1 | х | When set enables the application of the OpenGL 'Diamond-exit' rule to modify the start and end coordinates of lines. | | 12 | NoDraw | ✓ | <b>√</b> | Х | When set prevents any rendering from starting after the set up calculations are done and parameters sent to P3. This only effect the Draw* commands. | | 13 | ClampEnable | ✓ | <b>√</b> | Х | When set causes the input values to be clamped into a parameter specific range. Note that the texture parameters are not included. | | 14, 15 | Texture<br>Parameter<br>Mode | <b>√</b> | <b>√</b> | Х | These field causes the texture parameters to be: 0: Used as given 1: Clamped to lie in the range -1.0 to 1.0 2: Normalise to lie in the range -1.0 to 1.0 | | 16 | Reserved | 0 | 0 | X | | $<sup>^{10}\,\</sup>mathrm{Logic}$ Op register readback is via the main register only | 17 | BackfaceCull | ✓ | ✓ | X | When set enables backface culling. Rejection is based | |-------|--------------|----------|---|---|---------------------------------------------------------| | | | | | | on the sign of the area of the triangle, whether +ve or | | | | | | | -ve is controlled by the draw command. | | 18 | ColorOrder | ✓ | ✓ | X | Specifies order of colors when packed as RGBA in a | | | | | | | 32 bit word, reading from MSB to LSB: | | | | | | | 0 = Alpha, Blue, Green, Red | | | | | | | 1 = Alpha, Red, Green, Blue | | | | | | | Each color component is 8 bits. | | 19 | Bias | <b>√</b> | ✓ | X | 0 = off, 1 = on | | | Coordinates | | | | | | 20 | Reserved | 0 | 0 | X | | | 21-25 | Reserved | 0 | 0 | X | | | 26 | Texture | <b>√</b> | ✓ | X | 0 = off, 1 = on | | | Enable1 | | | | | | 27 | Reserved | ✓ | ✓ | X | Reserved | | 28 | Reserved | 0 | 0 | X | | | 29 | Texture3D | ✓ | ✓ | X | 0 = off, 1 = on | | 30,31 | Reserved | 0 | 0 | X | | Notes: The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. ### **Depth** | Name | Туре | Offset | Format | |-------|------------------|--------|---------| | Depth | Depth | 0x89A8 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-------|-------|-------------------------------------------------------------------------| | 030 | Depth value | 1 | 1 | Х | Integer value right-justified to LSB end and padded with 0s to 31 bits. | | 31 | Reserved | 0 | 0 | X | | Notes: Holds an externally sourced 31 bit depth value. If the depth buffer holds less than 31bits then the user supplied depth value is right justified to the least significant end. The unused most significant bits should be set to zero. This is used in the draw pixels function where the host supplies the depth values through the Depth register. Alternatively this is used when a constant depth value is needed, for example, when clearing the depth buffer, or for 2D rendering where the depth is held constant. # DepthMode DepthModeAnd DepthModeOr NameTypeOffsetFormatDepthModeDepth0x89A0BitfieldDepthMode ΔndDepth0yΔC70Bitfield Log DepthModeAndDepth0xAC70Bitfield Logic MaskDepthModeOrDepth0xAC78Bitfield Logic Mask Control registers | Bits | Name | Read<br>11 | Write | Reset | Description | |------|---------------------|------------|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | X | This bit, when set, enables the depth test and the replacement depth value to depend on the outcome of the test. Otherwise the test always passes and the depth data in the local buffer is not changed. | | 1 | WriteMask | 1 | • | X | This bit, when set enables the depth value in the local buffer to be updated when doing a read-modify-write operation. The byte enables (LB Write) can also be used when the Z value is 16 or 24 bits in size. | | 23 | NewDepth<br>Source | • | • | X | The depth value to write to the local buffer can come from several places. The options are: 0 = DDA. 1 = Source depth (i.e. read from Local Buffer) 2 = Depth register 3 = LBSourceData register. Only generated when source and destination reads are enabled. | | 46 | Compare<br>Function | <b>J</b> | 1 | Х | This field selects the compare function to use. The options are: 0 = Never | | 78 | Width | 1 | 1 | х | This field holds the width in bits of the depth field in local buffer. The options are: $0 = 16$ bits wide $1 = 24$ bits wide $2 = 31$ bits wide $3 = 15$ bits wide | | 9 | Normalise | <b>J</b> | 1 | Х | This bit, when set, will use all 50 bits of the DDA for Z interpolation, even for 24 or less bits of depth. The Width field must be set up to restrict the number of bits used in the comparison operation. When this bit is clear the depth test is compatible with GLINT MX. This bit should be 0 if NonLinearZ is set. | | 10 | NonLinearZ | 1 | 1 | Х | This bit, when set, enables the 32 bit DDA Z value to be encoded in 15, 16 or 24 bits using a non linear pseudo floating point representation. The non linear format is controlled by the following two fields. | $<sup>^{11}</sup>$ Logic Op register readback is via the main register only | 1112 | Exponent Scale | 1 | 1 | Х | This field defines how much the exponent should be scaled by. The options are: | | | |------|----------------|----------|----------|---|--------------------------------------------------------------------------------|--|--| | | | | | | 0 = scale by 1 $1 = scale by 2$ | | | | | | | | | 2 = scale by 4 $3 = scale by 8$ | | | | 1314 | Exponent | <b>√</b> | <b>√</b> | X | This field defines the number of bits in the depth | | | | | Width | | | | word to use as exponent bits. The options are: | | | | | | | | | 0 = 1 bit wide exponent field | | | | | | | | | 1 = 2 bits wide $2 = 3$ bits wide | | | | | | | | | 3 = 4 bits wide | | | | 1531 | Unused | 0 | 0 | X | | | | Notes: The register defines Depth operation. It controls the comparison of a fragment's depth value and updating of the depth buffer. (If the compare function is LESS and result = TRUE then the fragment value is less than the source value.) The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. #### dFdx | Name | Туре | Offset | Format | |------|------------------|--------|-------------| | dFdx | Fog | 0x86A8 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 021 | Fraction | ✓ | ✓ | X | | | 2231 | Integer | ✓ | ✓ | X | | Notes: Used to set the X derivative for the Fog value for trapezoid rendering. The format is 32 bit 2's complement 10.22 fixed point numbers. # dFdyDom | Name | Type | Offset | Format | |---------|------------------|--------|-------------| | dFdyDom | Fog | 0x86B0 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 021 | Fraction | ✓ | ✓ | X | | | 2231 | Integer | ✓ | ✓ | X | | Notes: This register holds the Y gradient values along the dominant edge for the Fog. The format is 32 bit 2's complement fixed point numbers in 10.22 format #### dGdx | Name | Туре | Offset | Format | |------|------------------|--------|-------------| | dGdx | Color | 0x87A0 | Fixed point | | | Control register | | • | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------| | 014 | Fraction | <b>√</b> | <b>√</b> | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: Used to set the X derivative for the Green value for the interior of a trapezoid when in Gouraud shading mode. The format is 24 bit 2's complement 9.15 fixed point numbers. # dGdyDom | Name | Туре | Offset | Format | |---------|------------------|--------|-------------| | dGdyDom | Color | 0x87A8 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|----------|-------|-------------| | 014 | Fraction | 1 | <b>√</b> | х | | | 1523 | Integer | ✓ | ✓ | X | | | 2331 | Reserved | 0 | 0 | X | Unused | Notes: This register is used to set the Y derivative dominant for the Green value along a line, or for the dominant edge of a trapezoid, when in Gouraud shading mode. The value is in 2's complement 24 bit 9.15 fixed point format. # DitherMode DitherModeAnd DitherModeOr NameTypeOffsetFormatDitherModeGlobal0x8818Bitfield DitherModeAnd Global 0xACD0 Bitfield Logic Mask DitherModeOr Global 0xACD8 Bitfield Logic Mask Control Register | Bits | Name | Read<br>12 | Write | Reset | Description | | | |------|------------------|------------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 0 | Enable | 1 | 7 | х | When set causes the fragment's color values to be dithered or rounded under control of the remaining bits in this register. If this bit is clear then the fragment's color is passed unchanged. | | | | 1 | Dither Enable | 1 | 1 | Х | When this bit is set any RGB format color is dithered otherwise it is rounded to the destination size under control of the RoundingMode field. See the table below for the dither matrix and how it is combined with the color components. Color Index formats at always rounded. | | | | 25 | Color Format | 1 | 1 | Х | The color format which in turn is coded from the size and position of the red, green, blue and (if present) the alpha components. | | | | 67 | Xoffset | 1 | 1 | Х | This offset is added to the fragment's x coordinate to derive the x address in the dither table. This allows window-relative dithering using screen coordinates. | | | | 89 | Yoffset | 1 | 1 | Х | This offset is added to the fragment's y coordinate to derive the y address in the dither table. This allows window-relative dithering using screen coordinates. | | | | 10 | Color Order | 1 | 1 | Х | Holds the color order. The options are: 0 = BGR 1 = RGB | | | | 1113 | Reserved | 0 | 0 | X | | | | | 14 | Alpha Dither | 1 | 1 | х | This bit allows the alpha channel to be rounded even when the color channels are dithered. This helps when antialiasing. 0 = Alpha value is dithered (if DitherEnable is set) 1 = Alpha value is always rounded. | | | | 1516 | Rounding<br>Mode | 1 | 1 | Х | 0 = Truncate<br>1 = Round Up<br>2 = Round Down | | | | 1731 | Unused | 0 | 0 | X | | | | $<sup>^{\</sup>rm 12}\,{\rm Logic}$ Op register readback is via the main register only Notes: Dithering controls color formatting. The dither function converts the internal color format into the framebuffer color information format. The following table shows the different color formats supported by the dither unit: - In the R, G, B and A columns the nomenclature n@m means this component is n bits wide and starts at bit position m in the framebuffer. The least significant bit position is 0 and a dash in a column indicates that this component does not exist for this mode. When two entries are shown the colour value is replicated into both fields. - Two color ordering formats are supported, namely ABGR and ARGB, with the right most letter representing the color in the least significant part of the word. This is controlled by the Color Order bit in the DitherMode register, and is easily implemented by just swapping the R and B components before conversion into the framebuffer format. - The only exception to this are the 3:3:2 formats where the actual bit fields sent to the framebuffer data need to be modified as well because the R and B components are differing widths. - CI processing is not affected by this swap. | | Internal Colour Channels | | | | | | | | | |----|--------------------------|--------|---------|-------------|------------|-------------|-------------|--|--| | | Format | Colour | Name | R | G | В | A | | | | | | Order | | | | | | | | | | 0 | BGR | 8:8:8:8 | <u>8@0</u> | 8@8 | <u>8@16</u> | <u>8@24</u> | | | | | 1 | BGR | 4:4:4:4 | <u>4@0</u> | 4@4 | <u>4@8</u> | <u>4@12</u> | | | | С | 2 | BGR | 5:5:5:1 | <u>5@0</u> | <u>5@5</u> | <u>5@10</u> | <u>1@15</u> | | | | 0 | 3 | BGR | 5:6:5 | <u>5@0</u> | <u>6@5</u> | <u>5@11</u> | - | | | | l | 4 | BGR | 3:3:2 | <u>3@0</u> | 3@3 | <u>2@6</u> | - | | | | 0 | 0 | RGB | 8:8:8:8 | <u>8@16</u> | <u>8@8</u> | <u>8@0</u> | <u>8@24</u> | | | | u | 1 | RGB | 4:4:4:4 | <u>4@8</u> | 4@4 | <u>4@0</u> | <u>4@12</u> | | | | r | 2 | RGB | 5:5:5:1 | <u>5@10</u> | <u>5@5</u> | <u>5@0</u> | <u>1@15</u> | | | | | 3 | RGB | 5:6:5 | <u>5@11</u> | <u>6@5</u> | <u>5@0</u> | - | | | | | 4 | RGB | 3:3:2 | <u>3@5</u> | <u>3@2</u> | <u>2@0</u> | - | | | | CI | 15 | X | CI8 | <u>8@0</u> | 8@8 | <u>8@16</u> | <u>8@24</u> | | | The format to use is held in the DitherMode register. In CI mode the lower byte (CI8) replicated up to the full 32 bit width as an aid to double buffering when the alternative buffers are stored in different bit planes in the same 32 bit word. The replication is done after dithering. ### dKdBdx | Туре | Offset | Format | |--------------------------------|--------|----------------------| | Texture Color Control register | 0x8D38 | Fixed point | | | JI | Texture Color 0x8D38 | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | ✓ | ✓ | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | reserved | 0 | 0 | X | | Notes: *dKdBdx* holds the X gradient value for the Blue Kd color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. # dKdBdyDom | Name | Type | Offset | Format | |-----------|------------------|--------|-------------| | dKdBdyDom | Texture | 0x8D40 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------| | 014 | Fraction | <b>√</b> | <b>√</b> | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Reserved | 0 | 0 | X | | Notes: dKdBdyDom holds the Y gradient value along the dominant edge for the Blue Kd (diffuse) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### dKdGdx | Name | Туре | Offset | Format | |--------|------------------|--------|-------------| | dKdGdx | Texture Color | 0x8D20 | Fixed point | | | Control register | | - | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------| | 014 | Fraction | <b>√</b> | <b>√</b> | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: *dKdGdx* holds the X gradient value for the Green Kd (diffuse) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. # dKdGdyDom | Name | Туре | Offset | Format | |-----------|------------------|--------|-------------| | dKdGdyDom | Texture | 0x8D28 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | ✓ | ✓ | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: The Ks and Kd DDA units are responsible for generating the specular and diffuse RGB values. dKdGdyDom holds the Y gradient value along the dominant edge for the Green Kd (diffuse) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### dKdRdx | Name | Туре | Offset | Format | |--------|------------------|--------|--------------| | dKdRdx | Texture | 0x8D08 | Fixed point | | | Control register | | <del>-</del> | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | ✓ | ✓ | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: *dKdRdx* holds the X gradient value for the Red Kd (diffuse) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. # dKdRdyDom | Name | Type | Offset | Format | |-----------|------------------|--------|-------------| | dKdRdyDom | Texture | 0x8D10 | Fixed point | | - | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | ✓ | ✓ | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: dKdRdyDom holds the Y gradient value along the dominant edge for the Red Kd (diffuse) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### dKsBdx | Name | Туре | Offset | Format | |--------|------------------|--------|-------------| | dKsBdx | Texture | 0x8CB8 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | ✓ | ✓ | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: *dKsBdx* holds the X gradient value for the Blue Ks (specular) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. (Note: numeric format differs from the MX.) # dKsBdyDom | Name | Туре | Offset | Format | |-----------|------------------|--------|-------------| | dKsBdyDom | Texture | 0x8CC0 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | ✓ | ✓ | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | unused | 0 | 0 | X | | Notes: *dKsBdyDom* holds the Y gradient value along the dominant edge for the Blue Ks (Specular) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. ### dKsdx | Name | Туре | Offset | Format | |-------|------------------|--------|-------------| | dKsdx | Texture | 0x86D0 | Fixed point | | | Control register | | = | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|------------------------------------------| | 021 | Fraction | <b>√</b> | <b>√</b> | X | 2's complement 2.22 fixed point fraction | | 2223 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: Ks (specular) derivative for unit X. The value is 2.22 2's complement format.. ### dKsdyDom $\begin{array}{cccc} \textbf{Name} & \textbf{Type} & \textbf{Offset} & \textbf{Format} \\ \text{dKsdyDom} & \text{Texture} & 0x86D8 & \text{Fixed point} \\ & & & & & & & & & \\ \hline \textit{Control register} & & & & & & & \\ \hline \end{array}$ | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------| | 021 | Fraction | <b>√</b> | <b>√</b> | X | | | 2223 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: Ks (specular) derivative per unit Y along the dominant edge. The value is 2.22 2's complement format #### dKsGdx $\begin{array}{ccccc} \textbf{Name} & \textbf{Type} & \textbf{Offset} & \textbf{Format} \\ \text{dKsGdx} & \text{Texture} & 0x8\text{CA0} & \text{Fixed point} \\ & & & & & & & & \\ \hline \textit{Control register} & & & & & & \\ \end{array}$ | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------| | 014 | Fraction | <b>√</b> | <b>√</b> | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: dKsGdx holds the X gradient value for the Green Ks (specular) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. (Note: numeric format differs from MX.) # dKsGdyDom | Name | Туре | Offset | Format | |-----------|------------------|--------|-------------| | dKsGdyDom | Texture | 0x8CA8 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------| | 014 | Fraction | <b>√</b> | <b>√</b> | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: *dKsGdyDom* holds the Y gradient value along the dominant edge for the Green Ks (Specular) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### dKsRdx | Name | Туре | Offset | Format | |--------|------------------|--------|-------------| | dKsRdx | Texture | 0x8C88 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------| | 014 | Fraction | <b>√</b> | <b>√</b> | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: dKsRdx holds the X gradient value for the Re Ks (specular) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. (Note: numeric format has changed from the MX.) ### dKsRdyDom | Name | Type | Offset | Format | |-----------|------------------|--------|-------------| | dKsRdyDom | Texture | 0x8CC0 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|----------|-------|-------------| | 014 | Fraction | ✓ | <b>√</b> | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: dKsRdyDom holds the Y gradient value along the dominant edge for the Red Ks (Specular) color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### **DMAAddr** | Name | Туре | Offset | Format | |---------|---------------|--------|---------| | DMAAddr | Input | 0xA980 | Integer | | | Control Regis | ter | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|-------|-------|-------------| | 01 | Reserved | 0 | 0 | X | | | 231 | Address | <b>√</b> | ✓ | X | Address | Notes: This register holds the byte address of the next DMA buffer to read from (reading doesn't start until the *DMACount* command). The bottom two bits of the address are ignored, hence the byte address is forced to be 32 bit aligned. This register should not be confused with the PCI register of the same name. *DMAAddr* must be loaded by itself and not as part of any increment, hold or indexed group. See also: *DMACount*. #### **DMAContinue** | Name | Туре | Offset | Format | |-------------|---------|--------|---------| | DMAContinue | Input | 0xA9F8 | Integer | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|---------------------------------| | 029 | Count | ✓ | ✓ | X | Number of DMA words to transfer | | 3031 | Reserved | 0 | 0 | X | | Notes: #### **DMACount** | Name | Туре | Offset | Format | |----------|------------------|--------|---------| | DMACount | Input | 0xA988 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|---------------------------------| | 029 | Count | ✓ | ✓ | X | Number of DMA words to transfer | | 3031 | Reserved | 0 | 0 | X | | Notes: At chip reset the MasterEnable bit in the *CFGCommand* register must be set to allow DMA to operate. Then, for the simplest form of DMA, the host software prepares a host buffer containing register address tag descriptions and data values. The host writes the base address of this buffer to the *DMAAddr* register and the count of the number of words to transfer to the *DMACount* register. Writing to the *DMACount* register starts the DMA transfer and the host is then free to perform other work. #### **DMAFeedback** | Name | Туре | Offset | Format | |-------------|---------|--------|---------| | DMAFeedback | Input | 0xAA10 | Integer | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|---------------------------------| | 029 | Count | ✓ | ✓ | X | Number of DMA words to transfer | | 3031 | Reserved | 0 | 0 | X | Reserved | Notes: The Feedback DMA mechanism allows the collection and transfer of an unspecified amount of data from the Host Out FIFO. This can be used for OpenGL feedback and select modes. - The feedback DMA transfer is set up by using the *DMAOutputAddress* register and the *DMAFeedback* command. - The *DMAOutputAddress* holds the address where the data is to be written The start address is given as a byte address but the lower two bits are ignored. - The *DMA Feedback* command with the length of the memory buffer (in words) is sent to start the Output DMA controller. Data is never written beyond the end of the given buffer length. - Once all the data to write to memory has been generated the EndOfFeedback command is sent to terminate the DMA operation. A count of the number of words transferred is recorded in the PCIFeedbackCount register. # **DMAMemoryControl** NameTypeOffsetFormatDMAMemoryControlInput0xB780BitfieldCommand | Bits | Name | Read | Write | Reset | Description | |-------|------------------------|----------|----------|-------|------------------| | 0 | InputDMA<br>Memory | 1 | 1 | Х | 0 = PCI, 1 = AGP | | 1 | Reserved | 0 | 0 | | | | 2 | Input DMA<br>Alignment | <b>√</b> | 1 | X | 0 = off, 1 = on | | 3 | Index Memory | <b>√</b> | <b>√</b> | X | 0 = PCI, 1 = AGP | | 4 | Reserved | 0 | 0 | X | | | 5 | Index<br>Alignment | <b>√</b> | 1 | X | 0 = off, 1 = on | | 6 | Vertex Memory | ✓ | <b>√</b> | X | 0 = PCI, 1 = AGP | | 7 | Reserved | 0 | 0 | X | | | 8 | Vertex<br>Alignment | 1 | 1 | X | 0 = off, 1 = on | | 9 | ReadDMA<br>Memory | <b>√</b> | 1 | Х | 0 = PCI, 1 = AGP | | 10 | Reserved | 0 | 0 | Х | | | 11 | ReadDMA<br>Alignment | 1 | 1 | X | 0 = off, 1 = on | | 12-23 | Reserved | 0 | 0 | Х | | | 24-28 | Burst Size | ✓ | ✓ | Х | | | 29-30 | Reserved | 0 | 0 | X | | | 31 | WriteDMA<br>Alignment | 1 | 1 | X | 0 = off, 1 = on | | Notes: | | |--------|--| ### **DMAOutputAddress** | Name | Туре | Offset | Format | | |------------------|---------|--------|---------|--| | DMAOutputAddress | Input | 0xA9E0 | Integer | | | | Command | | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|------------------------| | 01 | Reserved | 0 | 0 | X | Reserved | | 231 | Address | <b>√</b> | <b>√</b> | X | 32 bit aligned address | Notes: This register holds the byte address where the output DMA controller will write to. The lower two bits of the address are ignored. This register must be loaded by itself and not as part of any increment, hold or indexed group. # **DMAOutputCount** | Name | Type | Offset | Format | |----------------|---------|--------|---------| | DMAOutputCount | Input | 0xA9E8 | Integer | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|---------------------------------| | 029 | Count | ✓ | ✓ | X | Number of DMA words to transfer | | 3031 | Reserved | 0 | 0 | X | | Notes: This command starts a new output DMA if the output DMA controller is idle, otherwise it will block until the output DMA controller becomes available and all subsequent commands and register loads are suspended. - The number of words to read from the P3 Host Out FIFO is given in the bottom 24 bits of the command, and the memory buffer address will have previously been set up in the DMAOutputAddress register. - The P3 FilterMode register must have been set up to allow the required tags and/or data to be written in to the FIFO.. - This register must be loaded by itself and not as part of any increment, hold or indexed group. - See also: DMAOutputAddress # **DMARectangleRead** NameTypeOffsetFormatDMARectangleReadInput0xA9A8BitfieldControl Register | Bits | Name | Read | Write | Reset | Description | |-------|-----------|----------|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0-11 | Width | 1 | 1 | X | Width of the rectangle in pixels. Range 04095 | | 12-23 | Height | <b>√</b> | <b>√</b> | X | Height of the rectangle in pixels. Range 04095 | | 24-25 | PixelSize | 1 | 1 | х | The size of the pixels in the source image to read. The pixel size is used during alignment and packing. The values are: $0 = 8$ bits, $1 = 16$ bits, $2 = 24$ bits, $3 = 32$ bits | | 26 | Pack | 1 | 1 | Х | This field, when set, causes the data to be packed into 32 bit words when used, otherwise the data is right justified and any unused bits (in the most significant end of the word) are set to zero. | | 27-28 | ByteSwap | 7 | 1 | X | These bits control the byte swapping of the data read from the PCI bus before it is aligned and packed/unpacked. If the input bytes are labeled ABCD on input then they are swapped as follows: 0 = ABCD (i.e. no swap) 1 = BADC 2 = CDAB 3 = DCBA | | 29 | Reserved | 0 | 0 | Х | | | 30-31 | Alignment | 1 | 1 | х | When set, causes P3 to start and stop PCI or AGP transfers on 64 byte boundaries where possible. | Notes: 1. The Rectangle DMA mechanism allows image data to be transferred from host memory to the P3. The image data may be a sub image of a larger image and have any natural alignment or pixel size. Information regarding the rectangle transfer is held in registers loaded from the input FIFO or a DMA buffer. - 2. The pixel data read from host memory is always packed, however when passed to P3 it can be in packed or unpacked format. It can also, optionally, be aligned on 64 byte boundaries. - 3. The minimum number of PCI reads are used to align and pack the image data. - 4. P3 is set up to rasterize the destination area for the pixel data (depth, stencil, color, etc.) with SyncOnHostData or SyncOnBitMask enabled in the Render command. This is done before the Rectangular DMA is started. - 5. This register must be loaded by itself and not as part of any increment, hold or indexed group. - 6. See also DMARectangleReadAddress; DMARectangleReadLinePitch; DMARectangleReadTarget. ### **DMARectangleReadAddress** | Name | Туре | Offset | Format | |-------------------------|------------------|--------|---------| | DMARectangleReadAddress | Input | 0xA9B0 | Integer | | | Control Register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------|----------|-------|-------|------------------------------| | 031 | Address | <b>✓</b> | ✓ | X | 32 bit pixel aligned address | Notes: This register provides the byte address of the first pixel in the image or sub image to read during a rectangular DMA transfer from host memory to P3. The address should be aligned to the natural size of the pixel, except for 24 bit pixels which may be aligned to any byte boundary. This register must be loaded by itself and not as part of any increment, hold or indexed group. See also: DMARectangleRead; DMARectangleReadLinePitch; DMARectangleReadTarget ### **DMARectangleReadLinePitch** | Name | Type | Offset | Format | |----------------------|-------|--------|---------| | DMARectangleReadLine | Input | 0xA9B8 | Integer | | Pitch | - | | - | Control Register | Bits | Name | Read | Write | Reset | Description | |------|------------|----------|----------|-------|-------------| | 031 | Line Pitch | <b>√</b> | <b>√</b> | X | LinePitch | Notes: This register defines the amount, in bytes, to move from one scanline in the image to the next scanline during a rectangular DMA transfer from host memory to P3. For a sub image this is based on the width of the whole image. The pitch is held as a 32 bit 2's complement number. This is normally an integer multiple of the number of bytes in a pixel. The register must be loaded by itself and not as part of any increment, hold or indexed group. See also: DMARectangleReadAddress; DMARectangleRead; DMARectangleReadTarget. ### **DMARectangleReadTarget** NameTypeOffsetFormatDMARectangleReadTargetInput0xA9C0BitfieldCommand | Bits | Name | Read | Write | Reset | Description | |----------|----------|------|-------|-------|---------------------------| | 0-10 Tag | Tag | ✓ | ✓ | X | Tag to use with DMA data. | | 11-31 | Reserved | 0 | 0 | X | Reserved | #### Notes: - This register holds the 16 bit tag sent to the Rasterizer just before the image data is sent during a rectangular DMA transfer from host memory to the P3. Normally it would be one of the tags allowed by the rasterizer during a SyncOnHostData or SyncOnBitMask operation with the tag mode set to Hold. The secondary PCI bus traffic is minimized by sending multiple image words with a single tag (with a count). - 2. This register must be loaded by itself and not as part of any increment, hold or indexed group. - 3. See also: DMARectangleReadAddress; DMARectangleReadLinePitch; DMARectangleRead # **DMARectangleWrite** NameTypeOffsetFormatDMARectangleWriteInput0xA9C8BitfieldControl register | Bits | Name | Read | Write | Reset | Description | |-------|-----------|------|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0-11 | Width | 1 | 1 | Х | Width of the rectangle in pixels. Range 04095 | | 12-23 | Height | ✓ | ✓ | X | Height of the rectangle in pixels. Range 04095 | | 24-25 | PixelSize | 1 | 1 | Х | The size of the pixels in the source image to read. The pixel size is used during alignment and packing. The values are: $0 = 8$ bits, $1 = 16$ bits, $2 = 24$ bits, $3 = 32$ bits | | 26 | Pack | 1 | 7 | X | This field, when set, specifies the data is right justified and any unused bits (in the most significant end of the word) are set to zero. Otherwise the data read from the Host Out FIFO is packed. N.B. this is the inverse of the bit setting in GLINT Gamma. | | 27-28 | ByteSwap | 1 | 7 | X | These bits control the byte swapping of the data written to the PCI bus. If the input bytes are labeled ABCD on input then they are swapped as follows: 0 = ABCD (i.e. no swap) 1 = BADC 2 = CDAB 3 = DCBA | | 29 | Reserved | 0 | 0 | X | | | 30-31 | Alignment | 1 | 1 | х | When set, causes P3 to start and stop PCI or AGP transfers on 64 byte boundaries where possible. | Notes: - The Rectangle DMA mechanism allows image data to be transferred from P3 to host memory. The image data may be a sub image of a larger image and have any natural alignment or pixel size. Information regarding the rectangle transfer is held in registers loaded from the input FIFO or a DMA buffer. Note that failure to supply an EOF may have unpredictable results. - 2. The pixel data written to host memory is always packed, however when read from the Host Out FIFO it can be in packed or unpacked format. Note that it is packed when Reset. It can also, optionally, be aligned on 64 byte boundaries. - 3. The minimum number of PCI writes are used to align and pack the image data. - 4. P3 is set up to rasterize the source area for the pixel data (depth, stencil, color, etc.) enabled in the Render command. This is done before the Rectangular DMA is started. - 5. This register must be loaded by itself and not as part of any increment, hold or indexed group. - 6. See also: DMARectangleReadAddress; DMARectangleReadLinePitch; DMARectangleReadTarget # **DMARectangleWriteAddress** NameTypeOffsetFormatDMARectangleWriteInput0xA9D0IntegerAddress Control register | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|------------------------------| | 031 | Address | ✓ | ✓ | X | 32 bit pixel aligned address | Notes: - This register provides the byte address of the first pixel in the image or sub image to write during a rectangular DMA transfer from P3 to host memory. The address should be aligned to the natural size of the pixel, except for 24 bit pixels which may be aligned to any byte boundary. - This register must be loaded by itself and not as part of any increment, hold or indexed group. - See also: DMARectangleWrite; DMARectangleWriteLinePitch; DMAReadGLINTSource ### **DMARectangleWriteLinePitch** NameTypeOffsetFormatDMARectangleWriteLineInput0xA9D8IntegerPitch Control Register | Bits | Name | Read | Write | Reset | Description | |------|------------|----------|----------|-------|-------------| | 031 | Line Pitch | <b>√</b> | <b>√</b> | X | LinePitch | Notes: This register defines the amount, in bytes, to move from one scanline in the image to the next scanline during a rectangular DMA transfer from P3 to host memory. For a sub image this is based on width of the whole image. - The pitch is held as a 32 bit 2's complement number. This is normally an integer multiple of the number of bytes in a group. - See also: DMARectangleWriteAddress; DMARectangleWrite; DMAReadGLINTSource #### **DownloadAddress** | Name | Туре | Offset | <b>Format</b> | |-----------------|------------------|--------|---------------| | DownloadAddress | Framebuffer | 0xB0D0 | Integer | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|----------|-------|--------------------------------------| | 031 | Page Address | ✓ | <b>√</b> | X | 32 bit integer value from 0 to 65535 | Notes: This register holds the address to which to download 32 bits of data. The address is incremented after every write. The simplest way to download data to the framebuffer (or indeed any memory) is to use the **DownloadAddress** message to set up the word address. Each subsequent **DownloadData** command sends 32 bits of message data to the download address, after which the download address is auto incremented to address the next word. The bottom two bits of the **DownloadAddress** are forced to zero for the memory update, and readback will return the incremented address value #### **DownloadData** | Name | Туре | Offset | Format | |--------------|------------------|--------|---------| | DownloadData | Framebuffer | 0xB0D8 | Integer | | | Control register | r | Ü | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 031 | Data | × | ✓ | X | 32 bit data | Notes: This register holds the data to write to memory. The address will have previously been set up using the DownloadAddress message. Each **DownloadData** command sends 32 bits of message data to the download address, after which the download address is auto incremented to address the next word. The bottom two bits of the **DownloadAddress** are forced to zero for the memory update, and readback returns the incremented address value ### DownloadGlyphWidth | Name | Туре | Offset | Format | |--------------------|------------------|--------|---------| | DownloadGlyphWidth | Setup | 0xB658 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-------|-------|--------------------------------------| | 015 | Glyph width | ✓ | ✓ | X | 16 bit integer value from 0 to 65535 | Notes: This register holds the width of the glyph in bytes (range 0...31) which is just about to be downloaded via the *GlyphData* register. This must be sent for every download as it sets up some state used to manage the download. ### **DownloadTarget** | Name | Туре | Offset | Format | |----------------|------------------|--------|----------| | DownloadTarget | 2DSetup | 0xB650 | Tag name | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 012 | Tag name | ✓ | ✓ | X | | Notes: This tag holds the register the various download operations will write the expanded or generated data to. It can hold any legal tag, but typically will be set to FBData or FBSourceData. #### dQ1dx | Name | Туре | Offset | Format | |-------|------------------|--------|-------------| | dQ1dx | Texture | 0x8438 | Fixed point | | | Control register | | - | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | ✓ | ✓ | X | | | n31 | Integer | ✓ | ✓ | X | | Notes: dQ1dx holds the X gradient values for the Q1 texture coordinate. The format is 32 bit 2's complement fixed point numbers. The binary point is arbitrary but must be consistent for all S1, T1 and Q1 values. # dQ1dyDom | Name | Туре | Offset | Format | |----------|------------------|--------|-------------| | dQ1dyDom | Texture | 0x8440 | Fixed point | | | Control register | | • | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | ✓ | ✓ | X | | | n31 | Integer | ✓ | ✓ | X | | Notes: dQ1dyDom holds the Y gradient values along the dominant edge for the Q1 texture coordinate. The format is 32 bit 2's complement fixed point. The binary point is at an arbitrary location, but must be consistent for all S1, T1 and Q1 values. #### dQdx | Name | Type | Offset | Format | |------|------------------|--------|-------------| | dQdx | Texture | 0x83C0 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------| | 0n | Fraction | <b>√</b> | <b>√</b> | X | | | n31 | Integer | ✓ | ✓ | X | | Notes: Sets the X derivative for the Q parameter for texture map interpolation. The value is in 32 bit 2's complement fixed point format. The binary point is at an arbitrary location, but must be consistent for all S, T and Q values. ### dQdy | Name | Туре | Offset | Format | |------|------------------|--------|-------------| | dQdy | Texture | 0x83E8 | Fixed point | | - | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|----------|-------|-------------| | 0n | Fraction | ✓ | <b>√</b> | Х | | | n31 | Integer | ✓ | ✓ | X | | Notes: The register holds the Y gradient value for the Q texture coordinate. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location, but must be consistent for all S, T and Q values. ### dQdyDom | Name | Туре | Offset | Format | |---------|------------------|--------|-------------| | dQdyDom | Texture | 0x83C8 | Fixed point | | - | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | ✓ | ✓ | X | | | n31 | Integer | ✓ | ✓ | X | | Notes: Sets the Y derivative dominant for the Q parameter for texture map interpolation. Expressed in 32 bit 2's complement fixed point, binary point arbitrary but must be consistent for all S, T and Q values. #### DrawLine0 | Name | Туре | Offset | Format | |-----------|---------|--------|----------| | DrawLine0 | Delta | 0x9318 | Bitfield | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|----------|-------|----------------| | 015 | X | × | ✓ | X | 2's complement | | 1631 | Y | X | <b>✓</b> | X | 2's complement | Notes: - Initiates a line (between V0 and V1) set up and render. *DrawLine2D01* and *DrawLine2D10* commands have identical behaviour to *Drawline0* and *DrawLine1* and are only duplicated for efficient grouping in DMA. - LineCoord0 loads vertex store 0, LineCoord1 loads vertex store 1. DrawLine0 draws a line from vertex 0 to vertex1, DrawLine1 draws a line from vertex 1 to vertex 0. #### DrawLine1 | Name | Type | Offset | Format | |------------|---------|--------|----------| | DrawLine01 | Delta | 0x9320 | Bitfield | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|----------|-------|----------------| | 015 | X | × | <b>√</b> | X | 2's complement | | 1631 | Y | × | ✓ | X | 2's complement | Notes: - Initiates a line (between V1 and V0) set up and render. DrawLine2D01 and DrawLine2D10 commands have identical behaviour to Drawline01 and DrawLine10 and are only duplicated for efficient grouping in DMA. - LineCoord0 loads vertex store 0, LineCoord1 loads vertex store 1. DrawLine01 draws a line from vertex 0 to vertex1, DrawLine10 draws a line from vertex 1 to vertex 0. #### DrawLine2D01 | Name | Туре | Offset | Format | |--------------|---------|--------|----------| | DrawLine2D01 | Delta | 0x9778 | Bitfield | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|----------------| | 015 | X | × | ✓ | Х | 2's complement | | 1631 | Y | × | ✓ | X | 2's complement | Notes: - Initiates a line (between V0 and V1) set up and render. *DrawLine2D01* and *DrawLine2D10* commands have identical behaviour to *Drawline1* and *DrawLine1* and are only duplicated for efficient grouping in DMA. - LineCoord0 loads vertex store 0, LineCoord1 loads vertex store 1. DrawLine0 draws a line from vertex 0 to vertex1, DrawLine1 draws a line from vertex 1 to vertex 0. #### DrawLine2D10 | Name | Type | Offset | Format | | |--------------|---------|--------|----------|--| | DrawLine2D01 | Delta | 0x9768 | Bitfield | | | | Command | | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|----------------| | 015 | X | X | ✓ | X | 2's complement | | 1631 | Y | × | ✓ | X | 2's complement | Notes: - Initiates a line (between V1 and V0) set up and render. *DrawLine2D01* and *DrawLine2D10* commands have identical behaviour to *Drawline0* and *DrawLine1* and are only duplicated for efficient grouping in DMA. - LineCoord0 loads vertex store 0, *LineCoord1* loads vertex store 1. *DrawLine0* draws a line from vertex 0 to vertex 1, *DrawLine1* draws a line from vertex 1 to vertex 0. #### **DrawPoint** | Name | Туре | Offset | Format | | |-----------|---------|--------|----------|--| | DrawPoint | Delta | 0x9330 | Bitfield | | | | Command | | | | | Bits | Name | Read | Write | Reset | Description | |------|-------------------------|------|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | AreaStipple<br>Enable | × | 1 | Х | Area stippling enable | | 1 | LineStipple<br>Enable | × | 1 | х | Line stippling enable. | | 2 | ResetLine<br>Stipple | × | 1 | Х | Reset line stipple counters | | 3 | FastFillEnable | × | ✓ | X | Enable span fills | | 4, 5 | Unused | 0 | 0 | X | | | 6, 7 | Primitive Type | × | 1 | | Select primitive type:<br>0 = Line 1 = Trapezoid 2 = Point | | 8 | Antialiase<br>Enable | × | 1 | | Enables antialiasing | | 9 | Antialiasing<br>Quality | × | 1 | | Set (=1) sub pixel resolution to 8x8<br>Reset (=0) sub pixel resolution to 4x4. | | 10 | UsePoint Table | X | 1 | | When this bit and the AntialiasingEnable are set, the dx values used to move from one scanline to the next are derived from the Point Table. | | 11 | SyncOnBit<br>Mask | × | 1 | | See Render command for details | | 12 | SyncOnHost<br>Data | × | 1 | | When this bit is set a fragment is produced only when<br>one of the following registers have been received from<br>the host: Depth, Stencil, Color or FBData, FBSourceData | | 13 | TextureEnable | × | 1 | х | Enables texturing of the fragments produced during rasterisation. | Register Descriptions Permedia Reference Guide | 14 | FogEnable | × | 1 | X | Enables fogging of the fragments produced during rasterisation. Note that the Fog Unit must be suitably enabled as well for any fogging to occur. | |------|----------------------------------|---|----------|---|---------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | Coverage<br>Enable | × | 1 | Х | Enables the coverage value produced as part of the antialiasing to weight the alpha value in the alpha test unit. | | 16 | SubPixel<br>Correction<br>Enable | × | 1 | X | Enables the sub pixel correction of the color, depth, fog and texture values at the start of a scanline. | | 17 | Reserved | 0 | 0 | X | Reserved | | 18 | SpanOperation | × | 1 | Х | Indicates the writes are to use the constant color found in the previous FBBlockColor register. | | 1926 | Reserved | X | X | X | Reserved | | 27 | FBSourceRead<br>Enable | × | <b>√</b> | Х | Enables source buffer reads to be done in the Framebuffer Read Unit. | Notes: Initiates point set up and render. *Command* - data field duplicates the Render command – for details see the *Render* command description. ## DrawTriangle | Name | Туре | Offset | Format | |--------------|---------|--------|----------| | DrawTriangle | Delta | 0x9308 | Bitfield | | · · | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|-------------------------|------|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | AreaStipple<br>Enable | X | 1 | Х | Area stippling enable | | 1 | LineStipple<br>Enable | × | 1 | X | Line stippling enable. | | 2 | ResetLine<br>Stipple | × | 1 | X | Reset line stipple counters | | 3 | FastFillEnable | × | ✓ | X | Enable span fills | | 4, 5 | Unused | 0 | 0 | X | | | 6, 7 | Primitive Type | × | 1 | | Select primitive type:<br>0 = Line 1 = Trapezoid 2 = Point | | 8 | Antialiase<br>Enable | × | 1 | | Enables antialiasing | | 9 | Antialiasing<br>Quality | × | 1 | | Set (=1) sub pixel resolution to 8x8<br>Reset (=0) sub pixel resolution to 4x4. | | 10 | UsePoint Table | X | 1 | | When this bit and the AntialiasingEnable are set, the dx values used to move from one scanline to the next are derived from the Point Table. | | 11 | SyncOnBit<br>Mask | × | 1 | | See Render command for details | | 12 | SyncOnHost<br>Data | X | 1 | | When this bit is set a fragment is produced only when one of the following registers have been received from the host: <i>Depth, Stencil, Color</i> or <i>FBData, FBSourceData</i> | | 13 | TextureEnable | × | <b>√</b> | X | Enables texturing of the fragments produced during | |------|----------------------------------|---|----------|---|---------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | | rasterisation. | | 14 | FogEnable | × | 1 | X | Enables fogging of the fragments produced during rasterisation. Note that the Fog Unit must be suitably enabled as well for any fogging to occur. | | 15 | Coverage<br>Enable | × | 1 | X | Enables the coverage value produced as part of the antialiasing to weight the alpha value in the alpha test unit. | | 16 | SubPixel<br>Correction<br>Enable | × | 1 | Х | Enables the sub pixel correction of the color, depth, fog and texture values at the start of a scanline. | | 17 | Reserved | 0 | 0 | X | Reserved | | 18 | SpanOperation | × | 1 | Х | Indicates the writes are to use the constant color found in the previous FBBlockColor register. | | 1926 | Reserved | X | × | X | Reserved | | 27 | FBSourceRead<br>Enable | × | 1 | Х | Enables source buffer reads to be done in the Framebuffer Read Unit. | Notes: Initiates a triangle set up and render. P3 Delta unit only.. *Command* - data field duplicates the Render command – for details see the *Render* command description. ## dRdx | Name | Туре | Offset | Format | |------|------------------|--------|-------------| | dRdx | Color DDA | 0x8788 | Fixed point | | | Control register | | • | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | ✓ | ✓ | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: Used to set the X derivative for the Red value for the interior of a trapezoid when in Gouraud shading mode. The format is 24 bit 2's complement 9.15 fixed point numbers. ## dRdyDom | Name | Type | Offset | Format | |---------|------------------|--------|-------------| | dRdyDom | Color | 0x8790 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | ✓ | ✓ | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: This register is used to set the Y derivative dominant for the Red value along a line, or for the dominant edge of a trapezoid, when in Gouraud shading mode. The value is in 2's complement 9.15 fixed point format. #### dS1dx | Name | Type | Offset | Format | |-------|------------------|--------|-------------| | dS1dx | Texture | 0x8408 | Fixed point | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | ✓ | ✓ | X | | | n31 | Integer | ✓ | ✓ | X | | Notes: dS1dx holds the X gradient value for the S1 texture coordinate. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location, but must be consistent for all S1, T1 and Q1 values. ## dS1dyDom | Name | Туре | Offset | Format | |----------|------------------|--------|-------------| | dS1dyDom | Texture | 0x8410 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | ✓ | ✓ | X | | | n31 | Integer | ✓ | ✓ | X | | Notes: The dominant edge gradient of the texture S1 parameter. The format is 32 bit 2's complement fixed point numbers. The value is in 2's complement fixed point format. The binary point is at an arbitrary location, but must be consistent for all S1, T1 and Q1 values. #### dSdx | Name | Туре | Offset | Format | |------|------------------|--------|-------------| | DSdx | Texture | 0x8390 | Fixed point | | | Control register | | - | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | ✓ | ✓ | X | | | n31 | Integer | ✓ | ✓ | X | | Notes: Sets the X derivative for the S parameter for texture map interpolation. The value is in 2's complement fixed point format. The binary point is at an arbitrary location, but must be consistent for all S, T and Q values. ## dSdy | Name | Type | Offset | Format | |------|------------------|--------|-------------| | DSdy | Texture | 0x83D8 | Fixed point | | - | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | ✓ | ✓ | X | | | n31 | Integer | ✓ | ✓ | X | | Notes: The register holds the Y gradient value for the S texture coordinate. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location, but must be consistent for all S, T and Q values. ## dSdyDom | Name | Туре | Offset | Format | |---------|------------------|--------|--------------| | DSdyDom | Texture | 0x8398 | Fixed point | | • | Control register | | <del>-</del> | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | ✓ | ✓ | X | | | n31 | Integer | ✓ | ✓ | X | | Notes: Sets the Y derivative dominant for the S parameter for texture map interpolation. Expressed in 2's complement fixed point, binary point arbitrary but must be consistent for all S, T and Q values. #### dT1dx | Name | Туре | Offset | Format | |-------|------------------|--------|-------------| | DT1dx | Texture | 0x8420 | Fixed point | | | Control register | | • | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | ✓ | ✓ | X | | | n31 | Integer | ✓ | ✓ | X | | Notes: dT1dx holds the X gradient value for the T1 texture coordinate. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location but must be consistent for all S1, T1 and Q1 values. ## dT1dyDom | Name | Type | Offset | Format | | |----------|------------------|--------|-------------|--| | DT1dyDom | Texture | 0x8428 | Fixed point | | | v | Control register | | • | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | ✓ | ✓ | X | | | n31 | Integer | ✓ | ✓ | X | | Notes: The dominant edge gradient of the texture T1 parameter. The format is 32 bit 2's complement fixed point numbers. The value is in 2's complement fixed point format. The binary point is at an arbitrary location, but must be consistent for all S1, T1 and Q1 values. #### dTdx | Name | Туре | Offset | Format | |------|------------------|--------|-------------| | dTdx | Texture | 0x83A8 | Fixed point | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | ✓ | ✓ | X | | | n31 | Integer | ✓ | ✓ | X | | Notes: Sets the X derivative for the T parameter for texture map interpolation. The value is in 32 bit 2's complement fixed point format. The binary point is at an arbitrary location, but must be consistent for all S, T and Q values. ## dTdy | Name | Туре | Offset | Format | |------|------------------|--------|-------------| | dTdy | Texture | 0x83E0 | Fixed point | | · | Control register | | - | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | ✓ | ✓ | X | | | n31 | Integer | ✓ | ✓ | X | | Notes: The register holds the Y gradient value for the T texture coordinate. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location, but must be consistent for all S, T and Q values. ## dTdyDom | Name | Туре | Offset | Format | |---------|------------------|--------|--------------| | dTdyDom | Texture | 0x83B0 | Fixed point | | - | Control register | | <del>-</del> | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | ✓ | ✓ | X | | | n31 | Integer | ✓ | ✓ | X | | Notes: Sets the Y derivative dominant for the T parameter for texture map interpolation. Expressed in 2's complement fixed point, binary point arbitrary but must be consistent for all S, T and Q values. #### dXDom | Name | Туре | Offset | Format | |------------------|------------------|--------|-------------| | Delta X Dominant | Rasterizer | 0x8008 | Fixed point | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 015 | Fraction | ✓ | × | X | | | 1631 | Integer | ✓ | × | X | | Notes: The gradient for the dominant edge held as a 16.16 fixed point 2s complement value. Value added when moving from one scanline (or sub scanline) to the next for the dominant edge in trapezoid filling. The register also holds the change in X when plotting lines. For Y major lines this will be some fraction (dx/dy), otherwise it is normally $\pm$ 1.0, depending on the required scanning direction. ## dXSub | Name | Type | Offset | Format | |---------------------|------------------|--------|-------------| | Delta X Subordinate | Rasterizer | 0x8018 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 015 | Fraction | ✓ | X | X | | | 1631 | Integer | ✓ | × | X | | Notes: The gradient for the subordinate edge: the value added when moving from one scanline or sub scanline to the next for the subordinate edge in trapezoid filling. Two's complement fixed point 16.16 format. #### dY | Name | Туре | Offset | Format | |---------|------------------|--------|-------------| | Delta Y | Rasterizer | 0x8028 | Fixed point | | | Control register | | • | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 015 | Fraction | ✓ | × | X | | | 1631 | Integer | ✓ | X | X | | Notes: The change in Y between scanlines or sub-scanlines: the value added to Y to move from one scanline to the next. For X major lines this will be some fraction (dy/dx), otherwise it is normally $\pm$ 1.0, depending on the required scanning direction. Two's complement fixed point 16.16 format. #### dZdxL | Name | Туре | Offset | Format | |-------|------------------|--------|------------------| | dZdxL | Fog | 0x89C8 | Fixed point pair | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------------------------| | 015 | Reserved | 0 | 0 | X | LSBs all 0 | | 1631 | Integer | ✓ | ✓ | X | 16bit LSB part of 32.16 fixed point value | Notes: dZdxL and dZdxU set the depth derivative per unit in X used in rendering trapezoids and/or for Fog when Fog mode is UseZ. dZdxU holds the 32 most significant bits, and dZdxL the least significant 16 bits. The value is in 2's complement 32.16 fixed point format. #### dZdxU | Name | Туре | Offset | Format | |-------|------------------|--------|------------------| | dZdxU | Fog | 0x89C0 | Fixed point pair | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|----------------| | 3263 | dZdxU | ✓ | ✓ | X | 32 bit integer | Notes: dZdxL and dZdxU set the depth derivative per unit in X used in rendering trapezoids and/or for Fog when Fog mode is UseZ. dZdxU holds the 32 most significant bits, and dZdxL the least significant 16 bits. The value is in 2's complement 32.16 fixed point format. Register Descriptions Permedia3 Reference Guide ## dZdyDomL | Name | Type | Offset | Format | |----------|------------------|--------|------------------| | dZdyDomL | Fog | 0x89D8 | Fixed point pair | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------------| | 015 | Reserved | X | × | X | LSBs all 0 | | 1631 | Integer | ✓ | ✓ | X | 16bit LSB part or 32.16 value | Notes: dZdyDomL and dZdyDomU set the depth derivative per unit in Y along the dominant edge or along a line during trapezoid rendering when Fog mode is "UseZ". dZdyDomU holds the most significant bits, and the least significant bits.. The value is in 2's complement 32.16 fixed point format. ## dZdyDomU | Name | Туре | Offset | Format | |----------|------------------|--------|------------------| | dZdyDomU | Fog | 0x89D0 | Fixed point pair | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------|----------|----------|-------|---------------------| | 3263 | integer | <b>√</b> | <b>√</b> | X | 32 bit integer part | Notes: \( \delta Z \dy D \text{om} U \) and \( \dz \dy D \text{om} L \) set the depth derivative per unit in Y for the dominant edge, or along a line. \( \dz \dy D \text{om} U \) holds the most significant bits, and \( \dz \dy D \text{om} L \) the least significant bits. The value is in 2's complement 32.16 fixed point format. #### **EndOfFeedback** | Name | Туре | Offset | Format | |---------------|-------------------|--------|--------| | EndOfFeedback | Output<br>Command | 0x8FF8 | unused | | Bits | Name | Read | Write | Reset | Description | |------|---------------|------|-------|-------|-------------| | 0 | EndofFeedback | X | ✓ | X | Command tag | Notes: DMA transfers to or from the P3 Host Out FIFO can use either a fixed count (where the precise amount of data is known) or a variable count (where the amount of data is unknown or undefined). EndofFeedback is used to terminate DMA variable-length mode transfers. #### Variable Count: Typically, variable count mode is used for Context Dump or Run Length Encoded data. In this mode the Output DMA controller is placed in Feedback mode and continues to transfer data from the Host Out FIFO until it finds an EndOfFeedback tag. The FilterMode register should be set up by setting bits 18 and 19 to allow both context data and tags through so tags and data inappropriate to this mode can be discarded and the EndOfFeedback tag can be identified. Bit 20 of the FilterMode register enables RLE data into the output FIFO. The Host Out FIFO does not need to be empty but this would be preferable. The PCI FeedbackSelectCount register will hold the number of words written to memory when the Output DMA has finished. This method relieves the programmer from knowing beforehand how much context data will be saved. #### **FBBlockColor** | Name | Туре | Offset | Format | |--------------|------------------|--------|---------| | FBBlockColor | Framebuffer | 0x8AC8 | integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|-------------------------------| | 031 | Color | ✓ | ✓ | X | 32 bit raw framebuffer format | s: Holds the color and optionally alpha value to write during span writes. The data is in raw framebuffer format and is automatically replicated up to 128 bits and loaded into FBBlockColor[0...3]. The local registers as well as the registers in the memory devices are updated. This color information is used for constant color transparent span fills or constant color opaque span fill for foreground pixels. Readback returns the data in FBBlockcolor0. FBBlockColor [0] FBBlockColor [1] FBBlockColor [2] FBBlockColor [3] NameTypeOffsetFormatFBBlockColor [0...3]Framebuffer0xB060, 0xB068, 0xB068, 0xB070, 0xB078 Control registers | Bits | Name | Read | Write | Reset | Description | |------|--------------|----------|-------|-------|------------------------------| | 031 | Color word 1 | <b>√</b> | ✓ | X | 32 bit raw framebuffer value | Notes: These registers update the corresponding 32 bits of block color (in raw framebuffer format) in the local register and memory devices. This color information is used for constant color transparent span fills or constant color opaque span fill for foreground pixels. Use of the individual registers allows different colors for pattern fills, for example. #### **FBBlockColorBack** | Name | Туре | Offset | Format | |------------------|------------------|--------|---------| | FBBlockColorBack | Framebuffer | 0xB0A0 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|-------------------------------| | 031 | Color word | ✓ | ✓ | X | 32 bit raw framebuffer format | Notes: Holds the color and optionally alpha value to write during span writes. The data is in raw framebuffer format and is automatically replicated up to 128 bits. The local registers, FBBlockColorBack[0...3] are updated. This color information is used for constant color transparent span fills or constant color opaque span fill for background pixels. Readback returns the data in FBBlockcolorBack0. FBBlockColorBack [0] FBBlockColorBack [1] FBBlockColorBack [2] FBBlockColorBack [3] NameTypeOffsetFormatFBBlockColorBack [0...3]Framebuffer0xB080, 0xB088, 0xB088, 0xB090, 0xB098integer Control registers | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|------------------------------| | 031 | Color word 1 | ✓ | ✓ | X | 32 bit raw framebuffer value | Notes: These registers update the corresponding 32 bits of block color (in raw framebuffer format) in the local register. This color information is used for constant color transparent span fills or constant color opaque span fill for background pixels. #### **FBColor** | Name | Type | Offset | Format | |---------|------------------|--------|--------| | FBColor | Framebuffer | 0x8A98 | | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 031 | Reserved | 0 | × | X | Reserved | Notes: Internal register used in image upload and processed as configured in FilterMode settings. This register should not be written to. It is documented solely to provide the tag name of the data returned through the Host Out FIFO. Format depends on the raw framebuffer organization and any reformatting which takes place in Color processing ## FBDestReadBufferAddr[0...3] | Name | Type | Offset | Format | |----------------------|-------------------|-----------------|---------| | FBDestReadBufferAddr | Framebuffer | 0xAE80, 0xAE88, | Integer | | [03] | | 0xAE90, 0xAE98 | O | | | Control registers | | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | ✓ | ✓ | X | 32 bit value | Notes: Holds the 32 bit base address of the four destination buffers in memory. The address is a byte address and should be aligned to the natural boundary for the selected pixel size. ## FBDestReadBufferOffset[0...3] | Name | Туре | Offset | Format | |------------------------|------------------|-----------------|---------| | FBDestReadBufferOffset | Framebuffer | 0xAEA0, 0xAEA8, | Integer | | [03] | | 0xAEB0, 0xAEB8 | Ü | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------| | 015 | X offset | ✓ | ✓ | X | 2's complement X offset | | 1631 | Y offset | ✓ | ✓ | X | 2's complement Y offset | Notes: These registers hold the offset added to the fragment's coordinate for each destination buffer. The new coordinate is used for address calculations. This offset allows, for example, window relative coordinates to be converted into screen relative ones prior to patching (patching only works screen relative). #### **FBData** | Name | Type | Offset | Format | |--------------|------------------|--------|---------| | FBSourceData | Framebuffer | 0x8AA0 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|-------------|-------|-------|------------------------------------------------------| | 063 | Mask | <b>&gt;</b> | × | X | This message holds 64 bits of destination span data. | Notes: ## FBDestReadBufferWidth[0...3] | Name | Type | Offset | Format | |-----------------------|-------------|-----------------|---------| | FBDestReadBufferWidth | Framebuffer | 0xAEC0, 0xAEC8, | Integer | | [03] | | 0xAED0, 0xAED8 | O | Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|------------------------| | 011 | Width | ✓ | ✓ | X | 12 bit width of buffer | Notes: Holds the width of each destination buffer. The width is held as a 12 bit unsigned integer so has the range 0...4095. # FBDestReadEnablesAnd FBDestReadEnablesOr Name Offset Format Type FBDestReadEnables Framebuffer 0xAEE8 Bitfield FBDestReadEnablesAnd Framebuffer 0xAD20 Bitfield Logic Mask FBDestReadEnablesOr Framebuffer Bitfield Logic Mask 0xAD28 Control registers | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | 13 | | | | | 03 | E1 to E3 | 1 | 1 | х | These bits are the Enable bits. Software assigns these to major modes which can be enabled or disabled (such as Alpha Blending) it wants the FB Read Unit to track so destination reads are automatically done when necessary. When a bit is 1 it is enabled. E0E3 are used for fragments. | | 47 | E4 to E7 | 1 | 1 | X | Used for spans | | 811 | R0 to R3 | 1 | 1 | | These are Read bits. Software assigns these to operations within a major mode which require reads. For example the major mode would be Alpha Blending, but not all alpha blending option require the destination buffer to be read. When a bit is 1 a read is required. R0R3 are used for fragments. | | 1215 | R4 to R7 | 1 | 1 | x | Used for spans | | 2431 | Reference | ✓ | 1 | X | This is the alpha value used to disable reads when | | | Alpha | | | | AlphaFiltering is enabled. | Notes: Monitors potential FB Read activity on up to 4 parameters assignable in software. E.g.: E0 = Alpha Blend Enable R0 = Set whenever an alpha blend mode requires a read E1 = logically Enable R1 = Set whenever a logical operation requires a read The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. $<sup>^{13}</sup>$ Logic Op register readback is via the main register only ## FBDestReadModeAnd FBDestReadModeAnd FBDestReadModeOr **Type** Alpha Blend Name Offset **Format** FBDestReadMode 0xAEE0 Bitfield FBDestReadModeAnd Alpha Blend 0xAC90 Bitfield Logic Mask Alpha Blend Bitfield Logic Mask FBDestReadModeOr 0xAC98 Control registers | Bits | Name | Read<br>14 | Write | Reset | Description | |------|--------------|------------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | ReadEnable | 1 | 1 | X | This bit, when set, causes fragments or spans to read from the those buffers which are enabled (Enable[03] fields). If this bit is clear then no reads from any of the destination buffers are made. | | 1 | Reserved | × | × | X | | | 57 | Stripe Pitch | 1 | 1 | X | This field specifies the number of scanlines between the first scanline in a stripe and the first scanline in the next stripe. It would normally be set to number of RXs * StripeHeight. The options are: 0 = 1 | | 51 | StripeHeight | <b>1</b> | 1 | X | This field specifies the number of scanlines in a stripe. The options are: $0 = 1 \qquad 3 = 8$ $1 = 2 \qquad 4 = 16$ $2 = 4$ This field will normally be set to zero for P3. | | 8 | Enable0 | 1 | 1 | Х | Enable reading from buffers 0. The ReadEnable bit must also be set. | | 9 | Enable1 | 1 | 1 | х | Enable reading from buffers 1. | | 10 | Enable2 | 1 | 1 | x | Enable reading from buffers 2. | | 11 | Enable3 | 1 | 1 | X | Enable reading from buffers 3. | | 1213 | Layout0 | 1 | 1 | x | Selects the layout of the pixel data in memory for buffer 0. The options are: 0 = Linear 1 = Patch64 Color buffer 2 = Patch32_2 Large texture maps 3 = Patch2 Small texture maps Note: 32_2 and Patch2 are not supported for span reads. | $<sup>^{14}\,\</sup>mathrm{Logic}$ Op register readback is via the main register only 3Dlabs Proprietary and Confidential 5-77 Register Descriptions Permedia3 Reference Guide | 1415 | Layout1 | 1 | 1 | Х | Selects the layout of the pixel data in memory for buffer 1. | |----------------------|------------------------------------------|----------|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1617 | Layout2 | 1 | 1 | x | Selects the layout of the pixel data in memory for buffer 2. | | 1819 | Layout3 | 1 | 1 | х | Selects the layout of the pixel data in memory for buffer 3. | | 20<br>21<br>22<br>23 | Origin0<br>Origin1<br>Origin2<br>Origin3 | 1 | 1 | х | These fields selects where the window origin is for buffer 03 respectively. The options are: 0 = Top Left. 1 = Bottom Left | | 24 | Blocking | 1 | 1 | X | This bit, when set, causes destination span reads to block to prevent reads and writes from overlapping (in time). Each span is read in full and then written. This is less efficient than streaming (bit is clear), but allows overlapping blits (spans overlap) without corruption. Note this does not need to be set if the destination read and write buffers are the same. | | 25 | Reserved | 0 | 0 | X | | | 26 | UseRead<br>Enables | 1 | ✓ | х | When this bits is set the enables in the FBDestReadEnables register are used to determine if a destination read is required. The ReadEnable bit must also be set and the corresponding buffer bits as well for a read to occur. | | 27 | Alpha Filtering | <b>√</b> | 1 | Х | This bit, when set, compares the fragment's alpha value and if it is equal to the AlphaReference value (held in the FBReadEnables register) then no read is done. This is done to save memory bandwidth when the alpha blend mode is such that with the given alpha value the destination color doesn't contribute to the fragment's color. | Notes: The destination address calculation(s) are controlled by the FBDestReadMode register and the address is a function of X, Y, FBDestReadBufferAddr, FBDestReadBufferOffset, FBDestReadBufferWidth and PixelSize parameters. The Addr, Offset and Width are specified independently for each of the four possible write buffers. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. #### **FBHardwareWriteMask** | Name | Туре | Offset | Format | |---------------------|-------------------|--------|--------| | FBHardwareWriteMask | Framebuffer | 0x8AC0 | | | | Control registerr | | | | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|-------------| | 031 | Write mask | 1 | ✓ | X | 32 bit mask | Notes: This register holds the write mask used for all writes. When a bit is set the corresponding bit in each framebuffer word is set (enabled for writing). The masking is actually done in the memory devices so has zero impact on performance and doesn't require any reads. - The hardware write mask applies only where the memory devices (i.e. SGRAM) are used. Where it is not supported, this register should not be written to. - Where hardware writemask is supported and used, the software writemask must be disabled by setting all bits to 1. - If the framebuffer is used in 8bit packed mode the hardware writemask must be 8 bits wide and replicated to all four bytes of this register. #### **FBSoftwareWriteMask** | Name | Type | Offset | Format | |---------------------|-------------------|--------|--------| | FBSoftwareWriteMask | Framebuffer | 0x8820 | int | | | Control registerr | | | | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|-------------| | 031 | Write mask | ✓ | ✓ | X | 32 bit mask | Notes: Contains the software writemask for the framebuffer: - If a bit is set (=1) then the corresponding bit in the framebuffer is enabled for writing. - If hardware writemasking is implemented then the software writemask must be disabled by setting all bits to 1. - Framebuffer destination reads should be enabled if the write mask is **not** set to all ones. #### **FBSourceData** | Name | Туре | Offset | Format | |--------------|------------------|--------|---------| | FBSourceData | Framebuffer | 0x8AA8 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|----------|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------| | 063 | Mask | <b>√</b> | × | X | This message hold the 32 bits of source pixel data when generated by an active step. When generated for span masking it holds 64 bits of source span data. | Notes: #### **FBSourceReadBufferAddr** | Name | Туре | Offset | Format | |------------------------|------------------|--------|---------| | FBSourceReadBufferAddr | Framebuffer | 0xAF08 | Integer | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | ✓ | ✓ | X | 32 bit value | Notes: This register holds the 32 bit base address of the source buffer in memory. The address is a byte address and should be aligned to the natural boundary for the selected pixel size. ## **FBSourceReadBufferOffset** | <b>Name</b> | <b>Type</b> | Offset | <b>Format</b> | |------------------------|------------------|--------|---------------| | FBDestReadBufferOffset | Framebuffer | 0xAF10 | Integer | | | Control register | | S | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------| | 015 | X offset | ✓ | ✓ | X | 2's complement X offset | | 1631 | Y offset | ✓ | ✓ | X | 2's complement Y offset | Notes: These registers hold the offsets added to the fragment's coordinate for each destination buffer. The new coordinate is used for address calculations. This offset allows, for example, window relative coordinates to be converted into screen relative ones prior to patching (patching only works screen relative). #### **FBSourceReadBufferWidth** | Name Type | Offset | Format | |-----------|--------|--------| |-----------|--------|--------| FBSourceReadBufferWidth Framebuffer 0xAF18 Integer $Control\ register$ | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|---------------------| | 011 | Width | ✓ | ✓ | X | 12 bit buffer width | Notes: This register holds the width of the source buffer. The width is held as a 12 bit unsigned integer so has the range 0...4095. # FBSourceReadModeAnd FBSourceReadModeOr | Name | Type | Offset | Format | |---------------------|------------------|--------|----------| | FBSourceReadMode | Framebuffer | 0xAF00 | Bitfield | | FBSourceReadModeAnd | Framebuffer | 0xACA0 | Bitfield | | FBSourceReadModeOr | Framebuffer | 0xACA8 | Bitfield | | | Control register | | | | Bits | Name | Read<br>15 | Write | Reset | Description | |------|---------------|------------|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | ReadEnable | 1 | 1 | X | This bit, when set, causes fragments or spans to read from the source buffer providing they are enabled in the <i>Render command</i> (using the FBSourceReadEnable bit, bit 27). If this bit is clear then no source reads are made. | | 1 | Reserved | × | × | Х | | | 24 | StripePitch | 1 | 1 | х | This field specifies the number of scanlines between the first scanline in a stripe and the first scanline in the next stripe. It would normally be set to number of RXs * StripeHeight. The options are: $0 = 1 \qquad 4 = 16$ $1 = 2 \qquad 5 = 32$ $2 = 4 \qquad 6 = 64$ $3 = 8 \qquad 7 = 128$ This field will normally be set to zero for P3. | | 57 | Stripe Height | 1 | 1 | х | This field specifies the number of scanlines in a stripe. The options are: $0 = 1 \qquad 3 = 8$ $1 = 2 \qquad 4 = 16$ $2 = 4$ This field will normally be set to zero for P3. | | 89 | Layout | 1 | 1 | x | This field selects the layout of the pixel data in memory for buffer 03 respectively. The options are: 0 = Linear 1 = Patch64 | | 10 | Origin | ✓ | 1 | х | This field selects where the window origin is. The options are: 0 = Top Left. 1 = Bottom Left | $<sup>^{\</sup>rm 15}\,{\rm Logic}$ Op register readback is via the main register only | 11 | Blocking | 1 | 1 | х | This bit, when set, causes source span reads to block to prevent reads and writes from overlapping (in time). Each span is read in full and then written. This is less efficient than streaming (bit is clear), but allows overlapping blits (spans overlap) without corruption. | |------|-------------------------|----------|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 12 | Reserved | × | × | х | | | 13 | UseTexel<br>Coord | ✓ | ✓ | x | This bit, when set, allows the texel coordinate generated in the Texture Read Unit to be used instead of the fragments X, Y coordinate as part of the source address calculation. The Texture Read Unit must also be set up as appropriate, although failure to do so will not cause a chip hang. This bit should not be set when span reads are done. This is useful for stretch blits when the source is the framebuffer. | | 14 | WrapX Enable | 1 | 1 | х | This bit, when set, causes the X coordinate to be wrapped. The wrapping is done on power of two pixel boundaries as defined in the WrapX field. When span reads are used the wrapping point must be a multiple of 16 bytes so smaller patterns must be replicated in X to be this width. Normal pixel reads do not suffer from this restriction. | | 15 | WrapY Enable | 1 | 1 | х | This bit, when set, causes the Y coordinate to be wrapped. The wrapping is done on power of two pixel boundaries as defined in the WrapY field. | | 1619 | WrapX | <b>√</b> | 1 | х | This field defines the mask to use for $X$ wrapping. The options are: $09 \qquad mask = 2^{(WrapX + 1)} - 1$ $1015 \qquad mask = 0xffff$ | | 2023 | WrapY | | | | This field defines the mask to use for Y wrapping. The options are: $09 \qquad mask = 2^{(WrapY \ + \ 1)} - 1 \\ 1015 \qquad mask = 0xffff$ | | 24 | External Source<br>Data | | | | This bit, when set, indicates that even though source reads are disabled source data is being provided from an external source. This will be data downloaded by the host (using the Color command) or from the LUT. This data is interleaved with the destination data as if the source data had really been read from memory. This is important for span logical op processing when the source data is <i>not</i> from memory. | | 2531 | Unused | 0 | 0 | x | | Notes: Distinct source reads are still needed when a source image is to be blended or logically combined into the destination buffer or buffers. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. Register Descriptions Permedia3 Reference Guide ## FBWriteBufferAddr[0...3] NameTypeOffsetFormatFBWriteBufferAddr[0...3]Framebuffer0xB000, 0xB008, 0xB008, 0xB010, 0xB018Integer Control registers | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | ✓ | ✓ | X | 32 bit value | Notes: These registers holds the 32 bit base addresses of the four buffers in memory. The address is a byte address and should be aligned to the natural boundary for the selected pixel size ## FBWriteBufferOffset[0...3] NameTypeOffsetFormatFBWriteBufferOffset[0...3]Framebuffer0xB020, 0xB028, 0xB028, 0xB030, 0xB038Integer Control registers | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------| | 015 | X offset | ✓ | ✓ | X | 2's complement X offset | | 1631 | Y offset | ✓ | ✓ | X | 2's complement Y offset | Notes: These registers hold the offset added to the fragment's coordinate for each buffer. The new coordinate is used for address calculations. This offset allows, for example, window relative coordinates to be converted into screen relative ones prior to patching (patching only works screen relative). ## FBWriteBufferWidth[0...3] NameTypeOffsetFormatFBWriteBufferWidth[0...3]Framebuffer0xB040, 0xB048, 0xB048, 0xB050, 0xB058Integer Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|------------------------| | 011 | Width | ✓ | ✓ | X | 12 bit width of buffer | Notes: These registers hold the width of each buffer. The width is held as a 12 bit unsigned integer so has the range 0...4095 ## FBWriteModeAnd FBWriteModeOr | Name | Туре | Offset | Format | |-----------------|-------------------|--------|---------------------| | FBWriteMode | Alpha Blend | 0x8AB8 | Bitfield | | FBWriteMode And | Alpha Blend | 0xACF0 | Bitfield Logic Mask | | FBWriteMode Or | Alpha Blend | 0xACF8 | Bitfield Logic Mask | | | Control registers | | | | Bits | Name | Read<br>16 | Write | Reset | Description | |------|-------------|------------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | WriteEnable | 1 | 1 | х | This bit, when set, causes fragment or spans to write to the buffer 0, or if mulit-reads in FB Read then write are done to the corresponding buffers which were read. If this bit is clear then no writes to any buffer are made. Note that the Enable[03] bits are ignored unless Replicate is also set. | | 13 | reserved | 1 | 1 | X | | | 4 | Replicate | 1 | ✓ | X | This bit, when set, causes each fragment or span to be written into all the enabled buffers. It should not be set if multi-buffer reads are enabled in FB Read Mode. | 3Dlabs Proprietary and Confidential 5-85 $<sup>^{16}\,\</sup>mathrm{Logic}$ Op register readback is via the main register only Register Descriptions PERMEDIA3 Reference Guide | 5 | OpaqueSpan | 1 | 1 | х | This field determines how constant color spans are written (recall the Render command selects between constant color or variable color spans). The options are: 0 = Transparent 1 = Opaque Transparent spans just use one color for the foreground pixels and the background pixels are not written. Opaque spans write to foreground and background pixels using FBBlockColor for the foreground pixels and FBBlockColorBack for the background pixels. | |------------------------------|------------------------------------------|---|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 68 | StripePitch | 1 | 1 | Х | This field specifies the number of scanlines between the first scanline in a stripe and the first scanline in the next stripe. It would normally be set to number of RXs * StripeHeight. The options are: $0=1 \qquad 4=16 \\ 1=2 \qquad 5=32 \\ 2=4 \qquad 6=64 \\ 3=8 \qquad 7=128$ This field will normally be set to 0 for P3. | | 911 | StripeHeight | ✓ | 1 | х | This field specifies the number of scanlines in a stripe. The options are: $ 0 = 1 \qquad 3 = 8 \\ 1 = 2 \qquad 4 = 16 \\ 2 = 4 $ This field will normally be set to 0 for P3. | | 12<br>13<br>14<br>15 | Enable0<br>Enable1<br>Enable2<br>Enable3 | 1 | 1 | х | These bits, when set, enable writes to buffer 03 respectively during replication. The WriteEnable bit must also be set. | | 1617<br>1819<br>2021<br>2223 | Layout0<br>Layout1<br>Layout2<br>Layout3 | 1 | ✓ | х | These fields select the layout of the pixel data in memory for buffer 03 respectively. The options are: 0 = Linear 1 = Patch64 Color buffer 2 = Patch32_2 Large texture maps 3 = Patch2 Small texture maps | | 24<br>25<br>26<br>27 | Origin0<br>Origin1<br>Origin2<br>Origin3 | 1 | ✓ | х | These fields select where the window origin is for buffer 03 respectively. The options are: 0 = Top Left. 1 = Bottom Left | | 2831 | Unused | 0 | 0 | X | | The Framebuffer is responsible for: Notes: - Managing the updates to up to 4 memory buffers, - Calculating the write address(es) of the fragment in the memory, Combining multiple fragments in the same memory word, - Calculating the write addresses of the spans in the memory, - Aligning span data and issuing multiple normal writes, - Implementing transparent or opaque fills, Dispatch the addresses and data/mask to the Memory Controller . The FBWriteMode command controls write operations. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. #### **FeedbackX** | Name | Туре | Offset | Format | |-----------|------------------|--------|---------| | FeedbackX | Output | 0x8F88 | Integer | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|-------|-------|----------------------| | 031 | Runlength | × | ✓ | X | 32 bit integer value | Notes: This tag is used to hold the run length when run length encoding of image data is enabled. #### **FeedbackY** | Name | Туре | Offset | Format | |-----------|------------------|--------|---------| | FeedbackY | Output | 0x8F90 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|-------|-------|----------------------| | 031 | Runlength | ✓ | ✓ | X | 32 bit integer value | Notes: This tag is used to hold the run length when run length encoding of image data is enabled. ## FillBackgroundColor | Name | Туре | Offset | Format | |---------------------|------------------|--------|---------| | FillBackgroundColor | 2ĎSetup | 0x8330 | Integer | | <u> </u> | Control register | | o o | | Bits | Name | Read | Write | Reset | Description | |------|---------------------|------|-------|-------|----------------| | 031 | Background<br>Color | × | 1 | Х | 32 bit integer | Notes: FillBackgroundColor is an alias for the BackGroundColor register. With ForegroundColor, holds the foreground and background color values. A background pixel is a pixel whose corresponding bit in the color mask is zero. The color format is in the raw framebuffer format and 8 or 16 bit pixels are automatically replicated to fill the 32 bits of register. # FillConfig2D0 FillConfig2D1 NameTypeOffsetFormatFillConfig2D02DSetup0x8338BitfieldFillConfig2D12DSetup0x8360BitfieldControl register | Bits | Name | Read | Write | Reset | Description | |------|-------------------------------|------|----------|-------|-----------------------------------------------------------------------------------| | 0 | Opaque Span | × | <b>√</b> | Х | In RasterizerMode, AreaStippleMode, LogicalOpMode, FBWriteMode, TextureReadMode. | | 1 | MultiRXBlit | × | ✓ | X | RasterizerMode, ScissorMode | | 2 | UserScissorEna<br>ble | X | 1 | х | ScissorMode | | 3 | FBDestReadEn<br>able | X | 1 | х | In FBDestReadMode bit 3 = (ReadEnable) | | 4 | AlphaBlendEna<br>ble | × | 1 | Х | In AlphaBlendColorMode and AlphaBlendAlphaMode. bit 4 = AlphaBlendEnable (Enable) | | 5 | DitherEnable | X | 1 | X | In DitherMode: bit 5 = DitherEnable (Enable) | | 6 | ForgroundLogi<br>calOpEnable | X | 1 | X | In LogicalOpMode. bit 6 = ForgroundLogicalOpEnable (Enable) | | 710 | ForgroundLogi<br>calOp | × | <b>√</b> | X | In LogicalOpMode: Bits 7-10 = ForgroundLogicalOp (LogicOp) | | 11 | BackgroundLog<br>icalOpEnable | × | 1 | X | In <i>LogicalOpMode</i> . Bit 11 = BackgroundLogicalOpEnable (Background En.) | | 1215 | BackgroundLog<br>icalOp | × | 1 | Х | In LogicalOpMode. Bits 12-15 = BackgroundLogicalOp | | 16 | UseConstantSo<br>urce | X | 1 | X | In LogicalOpMode. bit 16 = UseConstantSource | | 17 | FBWriteEnable | X | 1 | X | In FBWriteMode: bit 17 = FBWriteEnable (WriteEnable) | | 18 | Blocking | X | 1 | X | In FBSourceReadMode bit 18 = Blocking | | 19 | ExternalSource<br>Data | X | 1 | X | In FBSourceReadMode bit 19 = ExternalSourceData | | 20 | LUTMode<br>Enable | × | 1 | Х | In <i>LUTMode</i> : bit 20 = Enable | | 2131 | Unused | 0 | 0 | Х | | Notes: FillConfig2D0 and FillConfig2D1 are aliases for the Config2D register. This register updates the mode registers in multiple units as shown. The name in brackets is the field name in the corresponding mode register, if different to the field name for the Config2D command. Also note that bit 0 affects several mode registers. #### FillFBDestReadBufferAddr0 | Name | Туре | Offset | Format | |---------------------------|------------------|--------|---------| | FillFBDestReadBufferAddr0 | Framebuffer | 0x8310 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | × | ✓ | X | 32 bit value | Notes: An alias for FBDestReadBufferAddr0, this register holds the 32 bit base address of the destination buffer in memory. The address is a byte address and should be aligned to the natural boundary for the selected pixel size. #### FillFBSourceReadBufferAddr | Name | Type | Offset | Format | |------------------------|---------|--------|---------| | FillFBSourceReadBuffer | 2ĎSetup | 0x8308 | Integer | | Addr | | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | X | ✓ | X | 32 bit value | Notes: This register is an alias for *FBSourceReadBufferAddr* and holds the 32 bit base address of the source buffer in memory. The address is a byte address and should be aligned to the natural boundary for the selected pixel size. ## FillFBSourceReadBufferOffset0 | Name | Type | Offset | Format | |----------------------|---------|--------|---------| | FillFBDestReadBuffer | 2ĎSetup | 0x8340 | Integer | | Offset() | • | | J | Control register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------| | 015 | X offset | ✓ | ✓ | X | 2's complement X offset | | 1631 | Y offset | ✓ | ✓ | X | 2's complement Y offset | Notes: Aliasing the FillFBDestReadBufferOffset0 register, this register holds the offset added to the fragment's coordinate for each destination buffer. The new coordinate is used for address calculations. This offset allows, for example, window relative coordinates to be converted into screen relative ones prior to patching (patching only works screen relative). #### FillFBWriteBufferAddr0 NameTypeOffsetFormatFillFBWriteBuffer Addr02DSetup0x8300IntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 03 | Address | × | ✓ | X | 32 bit value | Notes: Aliasing for the FBWriteBufferAddr0 registers, this register holds the 32 bit base addresses of the buffer in memory. The address is a byte address and should be aligned to the natural boundary for the selected pixel size ## FillForegroundColor0 NameTypeOffsetFormatFillForegroundColor02DSetup0x8328IntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|---------------------|------|-------|-------|----------------| | 031 | Foreground<br>Color | × | 1 | Х | 32 bit integer | Notes: This registers is an alias for the *ForegroundColor* register. With *BackgroundColor*, holds the foreground and background color values. The color format is in the raw framebuffer format and 8 or 16 bit pixels are automatically replicated to fill the 32 bits of register. ## FillForegroundColor1 NameTypeOffsetFormatFillForegroundColor12DSetup0x8358IntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|---------------------|------|-------|-------|----------------| | 031 | Foreground<br>Color | × | ✓ | X | 32 bit integer | Notes: This register is an alias for the *ForegroundColor* register. With *BackgroundColor*, holds the foreground and background color values. The color format is in the raw framebuffer format and 8 or 16 bit pixels are automatically replicated to fill the 32 bits of register. ## **FillGlyphPosition** | Name | Туре | Offset | Format | |-------------------|------------------|--------|---------| | FillGlyphPosition | 2ĎSetup | 0x8368 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------| | 015 | X offset | X | ✓ | X | 2's complement X coordinate | | 1631 | Y offset | × | ✓ | X | 2's complement Y coordinate | Notes: This register is an alias for the *GlyphPosition* register. It defines the glyph origin for use by the *Render2Dglyph* command. ## **FillRectanglePosition** | Name | Туре | Offset | Format | |-----------------------|------------------|--------|---------| | FillRectanglePosition | 2ĎSetup | 0x8348 | Integer | | G | Control register | | · · | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------| | 015 | X offset | X | ✓ | X | 2's complement X coordinate | | 1631 | Y offset | × | ✓ | X | 2's complement Y coordinate | Notes: This is an alias for the *RectanglePosition* register. It defines the rectangle origin for use by the Render2D command. Register Descriptions Permedia Reference Guide ## FillRender2D NameTypeOffsetFormatFillRender2D2DSetup0x8350BitfieldControl register | Bits | Name | Read | Write | Reset | Description | |------|---------------|------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 011 | Width | × | 1 | Х | Specifies the width of the rectangle in pixels. Its range is $04095$ . | | 1213 | Operation | × | 1 | x | This two bits field is encoded as follows: 0 = Normal 1 = SyncOnHostData 2 = SyncOnBitMask 3 = PatchOrderRendering The SyncOnHostData and SyncOnBitMask settings just set the corresponding bit in the Render command. PatchOrderRendering decomposes the input rectangle in to a number of smaller rectangels to make better use of the page structure of patched memory (see later). | | 14 | FBReadSource | × | 1 | Х | This bit sets the FBReadSourceEnable bit in the Render command. | | 15 | SpanOperation | × | 1 | х | This bit sets the SpanOperation bit in the Render command. | | 1627 | Height | × | 1 | х | Specifies the height of the rectangle in pixels. Its range is 04095. | | 28 | IncreasingX | × | 1 | Х | This bit, when set, specifies the rasterisation is to be done in increasing X direction. | | 29 | IncreasingY | × | 1 | X | This bit, when set, specifies the rasterisation is to be done in increasing Y direction. | | 30 | AreaStipple | × | 1 | х | This bit sets the AreaStippleEnable bit in the Render command. | | 31 | Texture | × | 1 | Х | This bit sets the TextureEnable bit in the Render command. | Notes: This command starts a rectangle being rendered from the origin given by the RectanglePosition register. #### **FillScissorMaxXY** | Name | Туре | Offset | Format | |------------------|------------------|--------|-------------| | FillScissorMaxXY | 2DSetup | 0x8320 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|-----------------------------------------| | | | | | | | | 015 | X coordinate | × | ✓ | X | 2's complement fixed point X coordinate | | 1631 | Y coordinate | X | ✓ | X | 2's complement fixed point Y coordinate | Notes: This register is an alias for ScissorMaxXY. It holds the maximum XY scissor coordinate - i.e. the rectangle corner farthest from the screen origin. ## **FillScissorMinXY** | Name | Туре | Offset | Format | |------------------|------------------|--------|-------------| | FillScissorMinXY | 2DSetup | 0x8318 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|---------------------------------------------|-------|-----------------------------------------| | 015 | X coordinate | × | ✓ x 2's complement fixed point X coordinate | | 2's complement fixed point X coordinate | | 1631 | Y coordinate | × | ✓ | X | 2's complement fixed point Y coordinate | Notes: This register is an alias for the *ScissorMinXY* register. It holds the minimum XY scissor coordinate - i.e. the rectangle corner closest to the screen origin. Register Descriptions Permedia Reference Guide ## FilterMode FilterModeAnd FilterModeOr Name Type Offset **Format** Output Bitfield FilterMode 0x8C00 Bitfield Logic Mask FilterModeAnd Output 0xAD00 FilterModeOr Output 0xAD08 Bitfield Logic Mask Control registers | Bits | Name | Read<br>17 | Write | Reset | Description | | |------|----------------|------------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 03 | Reserved | 1 | 1 | х | Reserved for diagnostic use – set to 0 | | | 4 | LBDepthTag | 1 | 1 | x | When set allows the <i>LBDepth</i> tag to be written into the output FIFO. | | | 5 | LBDepthData | 1 | 1 | х | When set allows the data upload from the Depth buffer to be written into the output FIFO. | | | 6 | StencilTag | 1 | 1 | х | When set allows the LBStencil tag to be written into the output FIFO. | | | 7 | StencilData | 1 | 1 | x | When set allows the data upload from the Stencil buffer to be written into the output FIFO. | | | 8 | FBColorTag | 1 | 1 | х | When set allows the <i>FBColor</i> tag to be written into the output FIFO. | | | 9 | FBColorData | 1 | 1 | х | When set allows the data upload from the framebuffer to be written into the output FIFO. | | | 10 | SyncTag | 1 | 1 | х | When set allows Sync tag to be written into the output FIFO. | | | 11 | SyncData | 1 | 1 | х | When set allows the Sync data to be written into the output FIFO. | | | 12 | StatisticsTag | 1 | 1 | х | When set allows the <i>PickResult, MaxHitRegion</i> and <i>MinHitRegion</i> tags to be written into the output FIFO. | | | 13 | StatisticsData | 1 | 1 | х | When set allows the <i>PickResult, MaxHitRegion</i> and <i>MinHitRegion</i> data to be written into the output FIFO. | | | 14 | RemainderTag | 1 | 1 | х | When set allows any tags not covered by the categories in this table to be written into the output FIFO. | | | 15 | RemainderData | 1 | 1 | х | When set allows any data not covered by the categories in this table to be written into the output FIFO. | | | 1617 | ByteSwap | 1 | 1 | | This field controls the byte swapping of the data field when it is written into the output FIFO. The options are: $0 = ABCD \qquad \text{(i.e. no swap)} \\ 1 = BADC \\ 2 = CDAB$ | | | | | | | | z = CDAB<br>3 = DCBA | | $<sup>^{\</sup>rm 17}\,{\rm Logic}$ Op register readback is via the main register only | 18 | ContextTag | 1 | 1 | х | When set allows the <i>ContextData</i> and <i>EndOfFeedback</i> tags to be written into the output FIFO. | |------|--------------------------|---|---|---|----------------------------------------------------------------------------------------------------------| | 19 | ContextData | 1 | 1 | х | When set allows the ContextData and EndOfFeedback data to be written into the output FIFO. | | 20 | RunLength<br>Encode Data | 1 | 1 | х | This bit, when set, will write run length encoded data into the host out FIFO. | | 2131 | Unused | 0 | 0 | X | | Notes: This register can only be updated if the *Security* register is set to 0. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. ## **FlushSpan** | Name | Туре | Offset | Format | |-----------|------------|--------|--------| | FlushSpan | Rasterizer | 0x8060 | Tag | | • | Command | | · · | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------| | 031 | Reserved | × | 0 | X | Reserved for future use | Notes: Causes any partial sub scanlines to be written out - command used when antialiasing to force rasterization of any remaining subscanlines in a primitive. ## **FlushWriteCombining** | Name | Туре | Offset | Format | |---------------------|------------------|--------|---------| | FlushWriteCombining | Input | 0x8910 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|--------------| | 031 | Reserved | × | ✓ | X | 32 bit value | Notes: ## **FogColor** | Name | Туре | Offset | Format | |----------|------------------|--------|----------| | FogColor | Fog | 0x8698 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 07 | Red | 1 | 1 | Х | Red | | 815 | Green | 1 | 1 | X | Green | | 1623 | Blue | 1 | 1 | X | Blue | | 2431 | Reserved | 0 | 0 | X | Reserved | Notes: This register holds the fog color to interpolate with. # FogMode FogModeAnd FogModeOr | Name | Type | Offset | Format | |------------|-------------------|--------|---------------------| | FogMode | Fog | 0x8690 | Bitfield | | FogModeAnd | Fog | 0xAC10 | Bitfield Logic Mask | | FogModeOr | Fog | 0xAC18 | Bitfield Logic Mask | | J | Control registers | | · · | | Bits | Name | Read<br>18 | Write | Reset | Description | |------|-----------|------------|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | Х | This bit, when set, and qualified by the FogEnable bit in the <i>Render</i> command causes the current fragment color to be modified by the fog coefficient and background color. | | 1 | ColorMode | <b>√</b> | ✓ | x | This bit selects the color mode. The two options are: 0 = RGB. The RGB fog equation is used. 1 = CI. The Color Index fog equation is used. | | 2 | Table | 1 | 1 | Х | This bit, when set, causes the Fog Index to be mapped via the FogTable before it controls the blending between the fragment's color and the fog color, otherwise the DDA value is used directly. | | 3 | UseZ | 1 | ✓ | х | This bit, when set, causes the DDA to be loaded with the Z DDA values instead of the Fog DDA values. It also adjusts the clamping of the DDA output. | | 48 | ZShift | 1 | 1 | х | This field specifies the amount the (z from DDA + zBias) is right shifted by before it is clamped against 255 and the bottom 8 bits used as the fog index. This should also take into account the number of depth bits there are. | | 9 | InvertFI | <b>1</b> | <b>√</b> | X | This bit, when set, inverts the fog index before it is used to interpolates between the fragment's color and the fog color. This is usually 0 when fog values are used and 1 for Z values. Fog values are set up so they decrease with increasing depth and obviously Z values increase with increasing depth. | | 1031 | Unused | 0 | 0 | х | | Notes: The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. 3Dlabs Proprietary and Confidential 5-97 $<sup>^{18}</sup>$ Logic Op register readback is via the main register only FogTable[0...15] FogTable[16...31] FogTable[32...47] FogTable[48...63] | Name | Type | Offset | Format | |----------------|-------------------|------------|----------| | FogTable[015] | Fog | 0xB100B178 | Bitfield | | FogTable[1631] | Fog | 0xB180B1F8 | Bitfield | | FogTable[3247] | Fog | 0xB200B278 | Bitfield | | FogTable[4863] | Fog | 0xB280B2F8 | Bitfield | | 5 | Control registers | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|---------------------| | 07 | | 1 | 1 | X | Fog index at tag +0 | | 815 | | 1 | 1 | Х | Fog index at tag +1 | | 1623 | | ✓ | 1 | x | Fog index at tag +2 | | 2431 | | 1 | 1 | X | Fog index at tag +3 | Notes: The fog index extracted from the DDA (either as a fog or z value as outlined above) can be used directly to control the blend, or it can be mapped via a table so some non-linear transfer function can be used. The fog table is organised as 256 x 8 so the 8 bit input fog index is mapped to an 8 bit output fog index. The fog table is loaded by the FogTable0...FogTable63 registers and each holds 4 fog values at a time. FogTable0, byte 0 loads the mapping for fog index 0, byte 1 for fog index 1, etc.. The fog table is enabled by the Table bit in FogMode and is independent of how the initial fog index is generated ## **ForegroundColor** | Name | Туре | Offset | Format | |-----------------|------------------|--------|---------| | ForegroundColor | LogicOps | 0xB0C0 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------------------|------|-------|-------|----------------| | 031 | Foreground<br>Color | ✓ | ✓ | Х | 32 bit integer | Notes: With BackgroundColor, holds the foreground and background color values. The color format is in the raw framebuffer format and 8 or 16 bit pixels are automatically replicated to fill the 32 bits of register. #### **FStart** | Name | Туре | Offset | Format | |--------|------------------|--------|-------------| | FStart | Fog | 0x86A0 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 021 | Fraction | 1 | ✓ | х | | | 2231 | Integer | ✓ | ✓ | X | | Notes: Fog Coefficient start value. The value is in 2's complement 10.22 fixed point format. # GIDMode GIDModeAnd GIDModeOr NameTypeOffsetFormatGIDModeLocalbuffer0xB538Bitfield GIDMode And Localbuffer 0x B5B0 Bitfield Logic Mask GIDMode Or Localbuffer 0x B5B8 Bitfield Logic Mask Control registers | Bits | Name | Read<br>19 | Write | Reset | Description | |------|--------------------|------------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Fragment<br>Enable | ✓ | 1 | х | This bit, when set, causes GID testing to occur on fragments. If the test fails then the fragment is discarded | | 1 | Span Enable | ✓ | ✓ | х | This bit, when set, allows the span pixel mask to be modified by GID testing each pixel. The mask is modified to disable those pixels which fail the test. | | 25 | Compare Value | ✓ | 1 | X | This field holds the 4 bit GID value to compare against. Unused bits (where the GID width in the local buffer format is less than 4 bits) should be set to zero. | | 67 | Compare Mode | 1 | 1 | x | This field holds the comparison modes available for use during GID testing. The options are: 0 = Always pass 1 = Never pass (i.e. always fail) 2 = Pass when local buffer gid == CompareValue 3 = Pass when local buffer gid!= CompareValue | | 89 | Replace Mode | 1 | 1 | х | This field specifies the replacement mode. This is independent of the FragmentEnable bit (except when the replacement depends on the outcome of the GID test). The options are: 0 = Always replace 1 = Never replace 2 = Replace on GID test pass. 3 = Replace on GID test fails | | 1013 | Replace Value | ✓ | 1 | X | This field holds the 4 bit GID value to replace the value read from the local buffer, if the replace mode is satisfied. | | 1331 | Reserved | 0 | 0 | X | Reserved | Notes: This register defines the Localbuffer GID operation. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. 5-100 Proprietary and Confidential 3Dlabs $<sup>^{19}\,\</sup>mathrm{Logic}$ Op register readback is via the main register only ## **GlyphData** | Name | Type | Offset | Format | |-----------|------------------|--------|---------| | GlyphData | 2ĎSetup | 0xB660 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-------|-------|------------------------| | 031 | Packed data | ✓ | ✓ | X | Glyph data byte stream | Notes: A byte stream of glyph data (packed four to a word) can be downloaded and automatically chopped up and padded to the necessary width for the texture units to use as a bitmap. For example a gyph with a width between 17 and 24 pixels will be sent down as a stream of bytes and each triplet of bytes will be padded with zero and sent to be written into memory. If the input words have their bytes labelled: First word: DCBA (A is the least significant byte) Second word: HGFE Then the output words send on to the rasterizer are: First word: 0CBA Second word: 0FED ## **GlyphPosition** | <b>Name</b> | <b>Type</b> 2DSetup | Offset | <b>Format</b> | |---------------|---------------------|--------|---------------| | GlyphPosition | | 0xB608 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------| | 015 | X offset | ✓ | ✓ | X | 2's complement X coordinate | | 1631 | Y offset | ✓ | ✓ | X | 2's complement Y coordinate | Notes: This register defines the glyph origin for use by the Render2DGlyph command. This register is updated by the Render2DGlyph command and the updated values will be read back or context dumped. #### **GStart** | Name | Туре | Offset | Format | |--------|------------------|--------|--------------------| | GStart | Color | 0x8798 | Fixed point number | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|-------|-------|-------------| | 014 | Fraction | <b>√</b> | ✓ | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: Used to set the initial Green value for a vertex when in Gouraud shading mode. The value is 24 bit 2's complement fixed point numbers in 9.15 format. # HeadPhysicalPageAllocation[0...3] | Name | Type | Offset | Format | |----------------------------|-------------|--------|---------| | HeadPhysicalPageAllocation | Framebuffer | 0xB480 | Integer | | [03] | | | J | Control register | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------------------------------| | 015 | Address | ✓ | ✓ | X | 16 bit integer value from 0 to 65535 | Notes: These registers hold the head page for memory pools 0...3. This is usually the most recently referenced physical page in the pool of the working set. The range of physical pages is 0...65535 #### **HostinDMAAddr** Name Type Offset Format DMAAddr Input 0x8938 Bitfield Control Register | Bits | Name | Read | Write | Reset | Description | |------|----------|------|----------|-------|-------------| | 01 | Reserved | 0 | 0 | X | | | 231 | Address | ✓ | <b>√</b> | X | Address | Notes: This register holds the byte address of the next DMA buffer to read from (reading doesn't start until the *DMACount* command). The bottom two bits of the address are ignored. This register should not be confused with the PCI register of the same name. *DMAAddr* must be loaded by itself and not as part of any increment, hold or indexed group. See also: *DMACount*. #### **HostinID** | Name | Type | Offset | Format | |----------|------------------|--------|---------| | HostinID | Delta | 0x8900 | Integer | | | Control register | | · · | | Bits | Name | Read | Write | Reset | Description | |------|------|----------|-------|-------|--------------------| | 031 | Data | <b>√</b> | ✓ | X | User-defined field | Notes: The HostInID register can be used to mark any point in the command stream so that the use of index and vertex buffers can be monitored. This register is loaded with an ID field; like the DMA address register, which can be read at any time. #### **HostInState** NameTypeOffsetFormatHostInStateDelta0x8918IntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|--------------| | 031 | State data | ✓ | ✓ | X | 32 bit value | Notes: This register is used to store a retained state that must be restored if a context switch occurs part way through a primitive. #### HostInState2 NameTypeOffsetFormatHostInState2Delta0x8940IntegerControl register | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|--------------| | 031 | State data | ✓ | ✓ | X | 32 bit value | Notes: This register is used to store a retained state that must be restored if a context switch occurs part way through a primitive. ## IndexBaseAddress | Name | Туре | Offset | Format | |------------------|------------------|--------|---------| | IndexBaseAddress | Input | 0xB700 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|----------------------------------| | 0 | Reserved | ✓ | ✓ | X | Reserved | | 116 | Address | ✓ | ✓ | X | 16 bit address of base of buffer | Notes: ## IndexedDoubleVertex | Name | Туре | Offset | Format | |---------------------|------------------|--------|---------| | IndexedDoubleVertex | Input | 0xB7B0 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|------|-------|-------|---------------------------| | 015 | Index0 | X | ✓ | X | Offset into vertex buffer | | 1631 | Index1 | × | ✓ | X | Offset into vertex buffer | | Notes: | | | | |--------|--|--|--| ## IndexedLineList | Name | Type | Offset | Format | |-----------------|------------------|--------|---------| | IndexedLineList | Input | 0xB728 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|--------------------------------| | 031 | Count | × | ✓ | X | Number of indices in primitive | Notes: # IndexedLineStrip | Name | Туре | Offset | Format | |------------------|---------------------------|--------|---------| | IndexedLineStrip | Input<br>Control register | 0xB730 | Integer | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|--------------------------------| | 031 | Count | × | ✓ | X | Number of indices in primitive | Notes: # IndexedPointList | Name | Туре | Offset | Format | |------------------|------------------|--------|---------| | IndexedPointList | Input | 0xB738 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|----------|-------|--------------------------------| | 031 | Count | X | <b>✓</b> | X | Number of indices in primitive | Notes: # IndexedPolygon | Name | Туре | Offset | Format | |----------------|------------------|--------|---------| | IndexedPolygon | Input | 0xB740 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|--------------------------------| | 031 | Count | × | ✓ | X | Number of indices in primitive | Notes: # Indexed Triangle Fan | Name | Туре | Offset | Format | |--------------------|---------------------------|--------|---------| | IndexedTriangleFan | Input<br>Control register | 0xB718 | Integer | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|----------|-------|--------------------------------| | 031 | Count | × | <b>√</b> | X | Number of indices in primitive | Notes: # IndexedTriangleList | Name | Туре | Offset | Format | |---------------------|------------------|--------|---------| | IndexedTriangleList | Input | 0xB710 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|--------------------------------| | 031 | Count | X | ✓ | X | Number of indices in primitive | Notes: # IndexedTriangleStrip | Name | Type | Offset | Format | |----------------------|------------------|--------|---------| | IndexedTriangleStrip | Input | 0xB720 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|--------------------------------| | 031 | Count | × | ✓ | X | Number of indices in primitive | Notes: ## IndexedVertex | Name | Туре | Offset | Format | |---------------|---------------------------|--------|---------| | IndexedVertex | Input<br>Control register | 0xB7A8 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|--------------------------| | 031 | Index | × | ✓ | X | Offset into index buffer | Notes: ## InvalidateCache | Name | Туре | Offset | Format | |-----------------|---------|--------|----------| | InvalidateCache | Texture | 0xB358 | Bitfield | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|------|-------|-------|------------------------------------| | 0 | Bank 0 | × | 1 | X | Invalidate bank 0 of Primary Cache | | 1 | Bank 1 | × | 1 | х | Invalidate bank 1 of Primary Cache | | 2 | TLB | × | 1 | X | Invalidate TLB | | 331 | Unused | 0 | 0 | X | Reserved | Notes: This command invalidates the cache. The bottom three bits control what it to be invalidated. #### **KdBStart** | Name | Type | Offset | Format | |----------|------------------|--------|-------------| | KdBStart | Texture | 0x8D30 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|-------|-------|-------------| | 014 | Fraction | <b>√</b> | ✓ | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | reserved | 0 | 0 | X | | Notes: KdBStart holds the start value for the Blue Kd color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### **KdGStart** | Name | Туре | Offset | Format | |----------|------------------|--------|-------------| | KdGStart | Texture | 0x8D18 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | ✓ | ✓ | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: *KdGStart* holds the start value for the Green Kd color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. ## **KdRStart** | Name | Туре | Offset | Format | |----------|------------------|--------|-------------| | KdRStart | Texture | 0x8D00 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------| | 014 | Fraction | <b>√</b> | <b>√</b> | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: KdRStart holds the start value for the Red Kd color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### **KdStart** | Name | Туре | Offset | Format | |---------|------------------|--------|-------------| | KdStart | Texture | 0x86E0 | Fixed point | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------| | 021 | Fraction | <b>√</b> | <b>√</b> | Х | | | 2223 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: Initial values for Kd (diffuse). The value is 2.22 2's complement fixed point format. #### **KsBStart** | Name | Туре | Offset | Format | |----------|------------------|--------|-------------| | KsBStart | Texture | 0x8CB0 | Fixed point | | | Control register | | • | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | ✓ | ✓ | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: KsBStart holds the start value for the Blue Ks color components. The format is 24 bit 2's complement fixed point numbers in 9.15 format. ### **KsGStart** | Name | Type | Offset | Format | |----------|------------------|--------|-------------| | KsGStart | Texture | 0x8C98 | Fixed point | | | Control register | | | | Ī | Bits | Name | Read | Write | Reset | Description | |---|------|----------|------|-------|-------|-------------| | | | | | | | | | Ī | 014 | Fraction | ✓ | ✓ | X | | | Ī | 1523 | Integer | ✓ | ✓ | X | | | Ī | 2431 | reserved | 0 | 0 | X | | Notes: KsGStart holds the start value for the Green Ks color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### **KsRStart** | Name | Туре | Offset | Format | |----------|------------------|--------|-------------| | KsRStart | Texture | 0x8C80 | Fixed point | | | Control register | | • | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | ✓ | ✓ | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: KsRStart holds the start values for the Red Ks color component. The format is 24 bit 2's complement fixed point numbers in 9.15 format. #### **LBClearDataL** | Name | Туре | Offset | Format | |--------------|------------------|--------|---------| | LBClearDataL | Localbuffer | 0xB550 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|----------------------| | 031 | Address | ✓ | ✓ | X | 32 bit integer value | Notes: This register holds the lower 32 bits of data to write into the local buffer (if so enabled) during a span operation. The data should be in the correct format to match up with the size and position of the depth, stencil and grapics ID fields. # **LBClearDataU** Name Type Offset Format LBClearDataU fer Control register | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------------------------------| | 031 | Address | ✓ | ✓ | X | 32 bit integer value from 0 to 65535 | Notes: This register holds the upper 8 bits of data to write into the local buffer (if so enabled) during a span operation. The data should be in the correct format to match up with the size and position of the depth, stencil, grapics ID and fast clear planes fields. ## **LBDepth** | Name | Туре | Offset | Format | |---------|------------------|--------|---------| | LBDepth | Depth | 0x88B0 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|----------------------| | 031 | LBDepth | × | ✓ | X | 32 bit integer value | Notes: Internal register used in image upload of the depth buffer. This register should not be written to. It is documented here to give the tag value and format of the data which is read from the Host Out FIFO. Where the depth(Z) buffer width is less than 32bits, the depth value is right justified and zero extended. ## LBDestReadBufferAddr | Name | Туре | Offset | Format | |----------------------|------------------|--------|---------| | LBDestReadBufferAddr | Local buffer | 0xB510 | Integer | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | ✓ | ✓ | X | 32 bit value | Notes: This register holds the 32 bit base address of the source buffer in memory. The address is a byte address and should be aligned to the natural boundary for the selected local buffer pixel size. ## **LBDestReadBufferOffset** | Name | Type | Offset | Format | |------------------------|------------------|--------|---------| | LBDestReadBufferOffset | Localbuffer | 0xB518 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------| | 015 | X offset | ✓ | ✓ | X | 2's complement X offset | | 1631 | Y offset | ✓ | ✓ | X | 2's complement Y offset | Notes: These registers hold the offset added to the fragment's coordinate for each destination buffer. The new coordinate is used for address calculations. This offset allows, for example, window relative coordinates to be converted into screen relative ones prior to patching (patching only works screen relative). ## LBDestReadEnables LBDestReadEnablesAnd LBDestReadEnablesOr | Name | Туре | Offset | Format | |----------------------|-------------------|--------|---------------------| | LBDestReadEnables | Localbuffer | 0xB508 | Bitfield | | LBDestReadEnablesAnd | Localbuffer | 0xB590 | Bitfield Logic Mask | | LBDestReadEnablesOr | Localbuffer | 0xB598 | Bitfield Logic Mask | | | Control registers | | | | Bits | Name | Read<br>20 | Write | Reset | Description | |------|----------|------------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 03 | E1 to E3 | <i>✓</i> | ✓ | х | These bits are the Enable bits. Software assigns these to major modes which can be enabled or disabled (such as Depth Testing) it wants the LB Read Unit to track so destination reads are automatically done when necessary. When a bit is 1 it is enabled. E0E3 are used for fragments. | | 47 | E4 to E7 | 1 | 1 | X | Used for spans | | 811 | R0 to R3 | • | 1 | х | These are Read bits. Software assigns these to operations within a major mode which require reads. For example the major mode would be Depth Testing, but not all depth test option require the destination buffer to be read. When a bit is 1 a read is required. R0R3 are used for fragments. | | 1215 | R4 to R7 | 1 | 1 | X | Used for spans | | 2431 | Reserved | 0 | 0 | х | Reserved | Notes: This new register contains 8 pairs of bits which the software can assign to activities which could require local buffer reads. The pairs of bits comprise an E bit and a R bit. The E bit reflects a major mode enable (e.g. stencil) and is set whenever that mode is enabled. The R bit is set when the operation within the major mode requires a read. For example: E0 = Depth Enable E1 = Stencil Enable E2 = GID enable R0 = Set whenever a depth mode requires a read R1 = Set whenever a stencil operation requires a read R2 = Set whenever the GID testing is required. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. 5-114 Proprietary and Confidential 3Dlabs $<sup>^{20}\,\</sup>mathrm{Logic}$ Op register readback is via the main register only # LBDestReadModeAnd LBDestReadModeOr Name Type Offset **Format** Localbuffer LBDestReadMode 0xB500 Bitfield LBDestReadModeAndLocalbuffer Bitfield Logic Mask 0xB580 LBDestReadModeOr Localbuffer 0xB588 Bitfield Logic Mask Control registers | Bits | Name | Read<br>21 | Write | Reset | Description | |------|--------------------|------------|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | x | This bit, when set, causes fragments or spans to read from the destination buffer | | 1 | Reserved | × | × | X | | | 24 | StripePitch | 1 | 1 | X | This field specifies the number of scanlines between the first scanline in a stripe and the first scanline in the next stripe. (It would normally be set to a number of RXs * StripeHeight). The options are: $0 = 1$ $1 = 2$ $2 = 4$ $3 = 8$ $4 = 16$ $5 = 32$ $6 = 64$ $7 = 128$ This field will normally be set to zero for P3. | | 57 | StripeHeight | 1 | 1 | Х | This field specifies the number of scanlines in a stripe. The options are: $0 = 1$ $1 = 2$ $2 = 4$ $3 = 8$ $4 = 16$ This field will normally be set to zero for P3. | | 8 | Layout | 1 | 1 | х | This field selects the layout of the pixel data in memory for the destination buffer. The options are: $0 = \text{Linear}$ $1 = \text{Patch64}$ | | 9 | Origin | 1 | 1 | х | This field selects where the window origin is for the destination buffer. The options are: 0 = Top Left. 1 = Bottom Left | | 10 | UseRead<br>Enables | 1 | 1 | Х | When this bits is set the enables in the LBDestReadEnables register are used to determine if a destination read is required. The Enable bit must also be set as well for a read to occur. | | 11 | Packed16 | 1 | 1 | х | When this bit is set the pixel size is 16 bits so a single memory word can hold 8 depht values. | | 1223 | Width | 1 | 1 | х | This field holds the width of the destination buffer. Its range is 04095. | Notes: Defines the localbuffer destination read operation. The destination address calculations are controlled by the LBDestReadMode register and the address is a function of X, Y, LBDestReadBufferAddr, LBDestReadBufferOffset, width and Packed16 parameters. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. 3Dlabs Proprietary and Confidential 5-115 <sup>&</sup>lt;sup>21</sup> Logic Op register readback is via the main register only #### **LBReadFormat** NameTypeOffsetFormatLBReadFormatLocalbuffer0x8888BitfieldControl register | Bits | Name | Read | Write | Reset | Description | |------|-----------------|------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 01 | DepthWidth | 1 | 1 | Х | This field specifies the width of the depth field. The depth field always starts at bit position 0. The width options are: | | | | | | | 0 = 16 bits $1 = 24$ bits $2 = 31$ bits $3 = 15$ bits When the depth width is 15 the GID and Stencil fields | | | | | | | are ignored and a one bit GID and Stencil are taken from bit 15. Only one of the GID or Stencil operation are enabled to select the desired field type. | | 25 | StencilWidth | ✓ | ✓ | х | This field specifies the width of the stencil field. The legal range of values are 08. The stencil field always starts at bit position given in the next field. | | 610 | StencilPosition | 1 | 1 | х | This field holds position of the least significant bit of the stencil field. The legal range of values are 023, representing bit positions 1639 respectively. | | 1114 | FCPWidth | 0 | 0 | х | Reserved | | 1519 | FCPPosition | 0 | 0 | Х | Reserved | | 2022 | GIDWidth | 1 | 1 | х | This field specifies the width of the Graphics ID field. The legal range of values are 04. The GID field always starts at bit position given in the next field. | | 2327 | GIDPosition | 1 | 1 | Х | This field holds position of the least significant bit of the Graphics ID field. The legal range of values are 023, representing bit positions 1639 respectively. | | 2831 | Unused | 0 | 0 | X | | Notes: This register defines the position and width of the depth, stencil and GID (Graphics ID) in the data read back from the local buffer. Notes: LB ReadFormat register definition has changed to allow more flexible sizing and positioning of the GID and stencil fields. FCP is not supported on Permedia3 - the fields are reserved for future use. #### **LBSourceReadBufferAddr** NameTypeOffsetFormatLBSourceReadBufferAddrLocalbuffer<br/>Control register0xB528Integer | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | ✓ | ✓ | X | 32 bit value | Notes: This register holds the 32 bit base address of the source buffer in memory. The address is a byte address and should be aligned to the natural boundary for the selected pixel size. #### **LBSourceReadBufferOffset** | Name | Type | Offset | Format | |--------------------------|------------------|--------|---------| | LBSourceReadBufferOffset | Localbuffer | 0xB530 | Integer | | | Control register | | · · | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------| | 015 | X offset | ✓ | ✓ | X | 2's complement X offset | | 1631 | Y offset | ✓ | ✓ | X | 2's complement Y offset | Notes: This register hold the offset added to the fragment's coordinate for the source buffer. The new coordinate is used for address calculations. This offset allows, for example, window relative coordinates to be converted into screen relative ones prior to patching (patching only works screen relative). # LBSourceReadModeAnd LBSourceReadModeOr Name **Type** Alpha Blend Offset **Format** LBSourceReadMode 0xB520 Bitfield LBSourceReadModeAnd Alpha Blend 0xB5A0 Bitfield Logic Mask LBSourceReadModeOr Alpha Blend 0xB5A8 Bitfield Logic Mask Control registers | Bits | Name | Read<br>22 | Write | Reset | Description | |------|--------------|------------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | Х | This bit, when set, causes fragments to be read from<br>the source buffer. If this bit is clear then no source<br>reads are made. | | 1 | Reserved | 0 | 0 | X | | | 24 | StripePitch | 1 | 1 | х | This field specifies the number of scanlines between the first scanline in a stripe and the first scanline in the next stripe. It would normally be set to number of RXs * StripeHeight. The options are: | | 57 | StripeHeight | 1 | 1 | х | This field specifies the number of scanlines in a stripe. The options are: $ 0 = 1 \qquad 3 = 8 $ $ 1 = 2 \qquad 4 = 16 $ $ 2 = 4 $ This field will normally be set to zero for P3. | | 8 | Layout | 1 | 1 | х | This field selects the layout of the pixel data in memory for the source buffer. The options are: 0 = Linear 1 = Patch64 | | 9 | Origin | ✓ | 1 | х | This field selects where the window origin is. The options are: 0 = Top Left. 1 = Bottom Left | | 10 | Packed16 | 1 | 1 | х | When this bit is set the pixel size is 16 bits so a single memory word can hold 8 depth values. | | 1122 | Width | 1 | 1 | х | This field holds the width of the destination buffer. Its range is 04095. | | 2331 | Reserved | 0 | 0 | Х | | Notes: This register defines the Localbuffer source read operation. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. <sup>&</sup>lt;sup>22</sup> Logic Op register readback is via the main register only #### **LBStencil** | Name | Туре | Offset | Format | |-----------|-------------|--------|----------| | LBStencil | Localbuffer | 0x88A8 | Bitfield | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 07 | Stencil | × | × | х | | | 815 | Reserved | × | × | X | | | 1619 | GID | × | × | Х | | | 2031 | Reserved | 0 | 0 | X | | Notes: Internal register used in upload of the stencil buffer. It should not be written to and is documented here only to give the tag value and format of the data when read from the host out FIFO. #### **LBWriteBufferAddr** | Name | Туре | Offset | Format | |-------------------|------------------|--------|---------| | LBWriteBufferAddr | Localbuffer | 0xB540 | Integer | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | ✓ | ✓ | X | 32 bit value | Notes: This register holds the 32 bit base address of the source buffer in memory. The address is a byte address and should be aligned to the natural boundary for the selected pixel size. ## **LBWriteBufferOffset** | Name | Type | Offset | Format | |---------------------|------------------|--------|---------| | LBWriteBufferOffset | Localbuffer | 0xB548 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------| | 015 | X offset | ✓ | ✓ | X | 2's complement X offset | | 1631 | Y offset | ✓ | ✓ | X | 2's complement Y offset | Notes: This register holds the offset added to the fragment's coordinate for the destination buffer. The new coordinate is used for address calculations. This offset allows, for example, window relative coordinates to be converted into screen relative ones prior to patching (patching only works screen relative). ## **LBWriteFormat** NameTypeOffsetFormatLBWriteFormatLocalbuffer0x88C8BitfieldControl register | Bits | Name | Read | Write | Reset | Description | |------|-----------------|------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 01 | DepthWidth | 1 | 1 | x | This field specifies the width of the depth field. The depth field always starts at bit position 0. The width options are: 0 = 16 bits 1 = 24 bits 2 = 31 bits 3 = 15 bits When the depth width is 15 the GID and Stencil fields are ignored and a one bit GID and Stencil are taken from bit 15. Only one of the GID or Stencil operation are enabled to select the desired field type. | | 25 | StencilWidth | 1 | 1 | X | This field specifies the width of the stencil field. The legal range of values are 08. The stencil field always starts at bit position given in the next field. | | 610 | StencilPosition | 1 | 1 | Х | This field holds position of the least significant bit of the stencil field. The legal range of values are 023, representing bit positions 1639 respectively. | | 1119 | Reserved | 0 | 0 | Х | | | 2022 | GIDWidth | 1 | 1 | Х | This field specifies the width of the Graphics ID field. The legal range of values are 04. The GID field always starts at bit position given in the next field. | | 2327 | GIDPosition | 1 | 1 | Х | This field holds position of the least significant bit of the Graphics ID field. The legal range of values are 023, representing bit positions 1639 respectively. | | 2831 | Reserved | 0 | 0 | X | | Notes: This register defines the position and width of the depth, stencil, GID (Graphics ID) in the data read back from the local buffer. # LBWriteMode LBWriteModeAnd LBWriteModeOr | Name | Туре | Offset | Format | |----------------|------------------|--------|----------| | LBWriteMode | Localbuffer | 0x88C0 | Bitfield | | LBWriteModeAnd | Localbuffer | 0xAC80 | Bitfield | | LBWriteModeOr | Localbuffer | 0xAC88 | Bitfield | | | Control register | | | | Bits | Name | Read<br>23 | Write | Reset | Description | |------|--------------|------------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | WriteEnable | 1 | 1 | х | This bit, when set, causes fragments or spans to written to the destination buffer. Note each byte must also be enabled in the ByteEnables field. | | 12 | Reserved | 0 | 0 | X | | | 35 | StripePitch | 1 | 1 | X | This field specifies the number of scanlines between the first scanline in a stripe and the first scanline in the next stripe. It would normally be set to number of RXs * StripeHeight. The options are: | | 68 | StripeHeight | 1 | 1 | х | This field specifies the number of scanlines in a stripe. The options are: $ 0 = 1 \qquad 3 = 8 $ $ 1 = 2 \qquad 4 = 16 $ $ 2 = 4 $ This field will normally be set to zero for P3. | | 9 | Layout | 1 | 1 | х | This field selects the layout of the pixel data in memory for the destination buffer. The options are: 0 = Linear 1 = Patch64 | | 10 | Origin | 1 | 1 | х | This field selects where the window origin is for the destination buffer. The options are: 0 = Top Left. 1 = Bottom Left | | 11 | Packed16 | 1 | 1 | х | When this bit is set the pixel size is 16 bits so a single memory word can hold 8 depth values. | | 1223 | Width | 1 | 1 | X | This field holds the width of the destination buffer. Its range is 04095. | 3Dlabs Proprietary and Confidential 5-121 $<sup>^{\</sup>rm 23}\,{\rm Logic}$ Op register readback is via the main register only | 2428 | ByteEnables | 1 | 1 | Х | This field holds the byte enables for each byte in the pixel. A byte enable bit must be set for the corresponding byte to be written. Ideally the depth, stencil, etc. fields are byte aligned and integral bytes in length so these can be used to disable modifying a field, otherwise read-modify-write operations will need to be done. | |------|-------------|---|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2931 | Operation | 1 | 1 | х | This field defines where the data is to be taken from to do the write and what is to happen to it afterwards. This is only of interest during an upload or download operation. The options are: 0 = No operation 1 = Download depth 2 = Download stencil 3 = Upload depth 4 = Upload stencil | Notes: The write requests have two forms: - Single pixel. This is the normal mode for 3D operation but is only used for exotic 2D operations. The calculated address is always a pixel address and this is shifted to take into account the width of a pixel (16 or 32 bits) in calculating the memory address and byte enables. The pixel data (Z, stencil and GID) are formatted and shifted into the correct byte lanes for the memory. - Pixel spans. Spans are useful for clearing down the local buffer but do not use any block fill capabilities of the memory (these are only available through the FB Write Unit), although 4 or 8 pixels will be cleared down per cycle. - N.B Write operation is not compatible with GLINT MX for programming purposes. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. #### LineCoord0 | Name | Туре | Offset | Format | | |------------|---------|--------|----------|--| | LineCoord0 | Delta | 0x9760 | Bitfield | | | | Command | | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|----------|-------|------------------| | 015 | X | × | <b>√</b> | X | 2's complement X | | 1631 | Y | × | ✓ | X | 2's complement Y | Notes: - LineCoordO loads vertex store 0 - LineCoord1 loads vertex store 1. - DrawLine0 draws a line from vertex 0 to vertex1 - DrawLine1 draws a line from vertex 1 to vertex 0. Note: to confirm LineCoord tages have written values correctly, readback using V0FloatX, V0FloatY and similar registers.. ### LineCoord1 | Name | Туре | Offset | Format | | |------------|---------|--------|----------|--| | LineCoord1 | Delta | 0x9770 | Bitfield | | | | Command | | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|------------------| | 015 | X | × | ✓ | X | 2's complement X | | 1631 | Y | X | ✓ | X | 2's complement Y | Notes: - LineCoordO loads vertex store 0 - LineCoord1 loads vertex store 1. - DrawLine0 draws a line from vertex 0 to vertex1 - DrawLine1 draws a line from vertex 1 to vertex 0. Note: to confirm LineCoord tages have written values correctly, readback using V0FloatX, V0FloatY and similar registers. # LineStippleMode LineStippleModeAnd LineStippleModeOr | Name | Туре | Offset | Format | |--------------------|------------------|--------|---------------------| | LineStippleMode | Stipple | 0x81A8 | Bitfield | | LineStippleModeAnd | Stipple | 0xABC0 | Bitfield Logic Mask | | LineStippleModeOr | Stipple | 0xABC8 | Bitfield Logic Mask | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------------|------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------| | 0 | StippleEnable | 1 | 1 | X | This field, when set, enables the stippling of lines. The LineStippleEnable bit in the <i>Render</i> command must also be set. | | 19 | RepeatFactor | 1 | 1 | х | This field holds the positive repeat factor for stippled lines. The repeat factor stored here is one less than the desired repeat factor. | | 1025 | StippleMask | 1 | ✓ | X | This field holds the stipple pattern. | | 26 | Mirror | 1 | 1 | х | This field, when set, will mirror the StippleMask before it is used. | | 2731 | Unused | 0 | 0 | X | | Notes: Controls line stippling: - The repeat factor is set to one less than the required value. - The least significant bit of the *UpdateLineStippleCounters* register, controls loading the line stipple counters if set the line stipple counters are loaded with the previously saved values. If reset, the counters are cleared to zero. - The counters can also be reset by means of the ResetLineStipple bit in the Render command. - The Enable bit in the *LineStippleMode* register is qualified by the LineStippleEnable bit in the *Render* Command. ## LoadLineStippleCounters | Name | Type | Offset | Format | |-------------------------|---------|--------|----------| | LoadLineStippleCounters | Gľobal | 0x81B0 | Bitfield | | • • | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|--------------------------|------|-------|-------|-------------| | 03 | LiveBit<br>Counter | × | 1 | х | | | 412 | LiveRepeat<br>Counter | × | 1 | Х | | | 1316 | SegmentBit<br>Counter | × | 1 | Х | | | 1725 | SegmentRepeat<br>Counter | × | 1 | Х | | | 2631 | Unused | 0 | 0 | Х | | Notes: Command used to restore the line stipple counters and segment register after a task switch. The counters are incremented during a line stipple so the value read from them, via the readback path may not match the value loaded in to them using this register. #### LOD | Name | Type | Offset | Format | |------|------------------|--------|-------------| | LOD | Texture | 0x83D0 | Fixed point | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------------------| | 07 | Fraction | 1 | ✓ | Х | | | 811 | Integer | ✓ | ✓ | X | | | 1231 | Reserved | 0 | 0 | X | Reserved for future use. Mask to 0. | Notes: Holds the computed level of detail value for texture 0. The format is 4.8 unsigned fixed point. The Level Of Detail (LOD) calculates the approximate area a fragment projects onto the texture map. The LOD calculation is enabled by the EnableLOD bit in the TextureCoordMode register. When this bit is clear no LOD is calculated and a constant LOD from the LOD register is used (when it is required by the *TextureReadMode* register setting). The format is unsigned 4.8 fixed point and can be interpreted as follows: - the integer part selects the higher resolution map of the pair to use with 0 using the map at the address given by TextureBaseAddress[0] register - the fraction gives the between map interpolation coefficient measured from the higher resolution map selected. #### LOD1 | Name | Туре | Offset | Format | |------|------------------|--------|-------------| | LOD1 | Texture | 0x8448 | Fixed point | | | Control register | | • | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 07 | Fraction | ✓ | ✓ | X | | | 811 | Integer | ✓ | ✓ | x | | | 1231 | Reserved | 0 | 0 | Х | | Notes: Holds the constant level of detail to use for mip mapping from texture 1. The format is 4.8 unsigned fixed point. The Level Of Detail (LOD) calculates the approximate area a fragment projects onto the texture map. The LOD calculation is enabled by the EnableLOD bit in the TextureCoordMode register. When this bit is clear no LOD is calculated and a constant LOD from the LOD register is used (when it is required by the *TextureReadMode* register). The format is unsigned 4.8 fixed point and can be interpreted as follows: - the integer part selects the higher resolution map of the pair to use with 0 using the map at the address given by TextureBaseAddress[0] register - the fraction gives the between map interpolation coefficient measured from the higher resolution map selected. ## LODRange0 | Name | Type | Offset | Format | |-----------|------------------|--------|-------------| | LODRange0 | Texture | 0xB348 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------------------| | 011 | Min | ✓ | ✓ | х | 2's complement 4.8 fixed point fraction | | 1223 | Max | ✓ | ✓ | X | 2's complement 4.8 fixed point integer | | 2431 | Reserved | 0 | 0 | X | | Notes: This register holds the clamping range for lod0 calculations. Bits 0-11 define the minimum value, bits 12-23 hold the maximum value. # LODRange1 | Name | Туре | Offset | Format | |-----------|------------------|--------|-------------| | LODRange1 | Texture | 0xB350 | Fixed point | | 3 | Control register | | • | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------------------| | 011 | Min | 1 | 1 | х | 2's complement 4.8 fixed point fraction | | 1223 | Max | ✓ | ✓ | X | 2's complement 4.8 fixed point integer | | 2431 | Reserved | 0 | 0 | X | | Notes: This register holds the clamping range for lod1 calculations. Bits 0-11 define the minimum value, bits 12-23 hold the maximum value. # LogicalOpModeAnd LogicalOpModeOr Name Type Offset Format LogicalOpMode Logic Ops 0x8828 Bitfield LogicalOpModeAnd Logic Ops 0xAEC0 Bitfield Logic Mask LogicalOpModeOr Logic Ops 0xAEC8 Bitfield Logic Mask #### Control registers | Bits | Name | Read<br>24 | Write | Reset | Description | |------|----------------------------|-------------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | ✓ | 1 | х | When set causes the fragment's color to be logial op'ed under control of the remaining bits in this register. When clear the fragment color remains unchanged (but may later to effected by write masking). | | 14 | LogicOp | <b>&gt;</b> | <b>✓</b> | x | This field defines the logical op function to use. The options are: 0 = Clear (0) | | 5 | UseConstantFB<br>WriteData | <b>√</b> | ✓ | Х | There is no longer any performance advantage to using this bit but it is retained for backwards compatability. | | 6 | BackgroundEn<br>able | <b>√</b> | 1 | x | This bit, when set, enables a different logical operation to be done for background pixels. If this bit is clear then the same logical operation is applied to foreground and background pixels. Setting this bit when the Enable field is zero has no effect. A background pixel is a pixel whose corresponding bit in the color mask is zero. | | 710 | BackgroundLog<br>icalOp | <b>√</b> | 1 | X | This field specifies the logical operation to apply to background pixels, if this has been enabled by the BackgroundEnable field. The options and field values are the same as the LogicalOp field. | $<sup>^{\</sup>rm 24}\,\rm Logic$ Op register readback is via the main register only | 11 | UseConstantSo<br>urce | ✓ | ✓ | х | This field, when set, causes the source data to be taken from the ForegroundColor register, otherwise it is taken from the fragment, if needed. The color format is in the raw framebuffer format and 8 or 16 bit pixels should have their color replicated to fill the full 32 bits. | |------|-----------------------|----------|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 12 | OpaqueSpan | <b>√</b> | 1 | х | This bit determines how constant colour spans are to be processed. The two options are: 0 = Transparent 1 = Opaque Transparent spans take the source pixel colour from the message stream or the ForegroundColour register as appropriate. Opaque spans take the source pixel colour from the message stream or register. The ForegroundColour register is used when the corresponding bit in the SpanColourMask is 1, otherwise the BackgroundColour register is used. | | 1231 | Unused | 0 | 0 | X | <u> </u> | Notes: The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. # LogicalTexturePageTableAddr | Name | Туре | Offset | Format | |-------------------------|---------|--------|---------| | LogicalTexturePageTable | Texture | 0xB4D0 | Integer | | Addr | | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|---------|----------|-------|-------|--------------| | 031 | Address | <b>√</b> | ✓ | Х | 32 bit value | Notes: This register holds the base address of the Logical Texture Page Table. The address should be aligned to a 64 bit boundary. # LogicalTexturePageTableLength | Name | Type | Offset | Format | |-------------------------|---------|--------|---------| | LogicalTexturePageTable | Texture | 0xB4D8 | Integer | | Length | | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|--------------------|----------|----------|-------|--------------------------------------| | 016 | Logical page count | <b>√</b> | <b>√</b> | Х | 17 bit integer value from 0 to 65536 | Notes: This register holds the number of logical pages to be managed. Any logical pages past this value are folded to logical page 0. Setting this register to zero effectively disables logical to physical mapping. The legal range of values is 0...65536. ## LUT[0...15] | Name | Type | Offset | Format | |----------|-------------------|--------|----------| | LUT[015] | LUT | 0x8E80 | Bitfield | | | Control registers | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|-------------| | 07 | Red | 1 | 1 | х | | | 815 | Green | 1 | 1 | X | | | 1623 | Blue | 1 | 1 | X | | | 2431 | Alpha | 1 | 1 | Х | | Notes: These registers allow the lower 16 entries of the LUT to be loaded and read back directly. #### **LUTAddress** | Name | Туре | Offset | Format | | |------------|------------------|--------|---------|--| | LUTAddress | Texture | 0x84D0 | Integer | | | | Control register | | · · | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | ✓ | ✓ | X | 32 bit value | Notes: This register holds the physical address of a block of data to load into the LUT from memory. This is given as a byte address, but the bottom 4 bits are ignored so the address is effectively aligned to a 128 bit memory word. #### **LUTData** | Name | Type | Offset | Format | |---------|------------------|--------|---------| | LUTData | Texture | 0x84C8 | Integer | | | Control register | | · · | | Bits | Name | Read | Write | Reset | Description | |------|---------------|------|-------|-------|--------------| | 031 | LUT data word | ✓ | ✓ | X | 32 bit value | Notes: This register holds the 32 bits of data to load into the LUT. The data can be loaded in 'as is', have its red and green components swapped over or converted into a replicated 16 bit format. LUT readback is done by first reading the LUTIndex register. As well as returning the current LUT index it has the additional effect of setting the ReadIndex counter to zero. The ReadIndex counter is only used during readback and is not the same as the LUTIndex used for loading the LUT via the message stream. Each subsequent read from the LUTData register returns the LUT data at the ReadIndex and the ReadIndex counter is incremented. The ReadIndex counter wraps from 255 to 0. #### **LUTIndex** | Name | Туре | Offset | Format | |----------|------------------|--------|---------| | LUTIndex | Texture | 0x84C0 | Integer | | | Control register | | · · | | Bits | Name | Read | Write | Reset | Description | |------|--------|------|-------|-------|-----------------------------------| | 07 | Index | ✓ | ✓ | X | 8 bit integer value from 0 to 255 | | 831 | Unused | 0 | 0 | X | | Notes: This register holds the start index to update the LUT at when LUT data message is written. The index is automatically incremented after each load and wraps from 255 to 0. Readback from LUTIndex has side effect of clearing the *ReadIndex* register. # LUTMode LUTModeAnd LUTModeOr | Name | Type | Offset | Format | |------------|-------------------|--------|---------------------| | LUTMode | LUT | 0xB378 | Bitfield | | LUTModeAnd | LUT | 0xAD70 | Bitfield Logic Mask | | LUTModeOr | LUT | 0xAD78 | Bitfield Logic Mask | | | Control registers | | 3 | | Bits | Name | Read<br>25 | Write | Reset | Description | |------|--------------------|------------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | ✓ | 1 | Х | When set causes the fragment or span data to be modified under control of the remaining bits in this register. | | 1 | InColorOrder | ✓ | 1 | х | This bit, when set, swaps the red and green bytes (i.e. bytes 0 and 2) of the 32 bit load data. This can be used to convert ARGB input data into ABGR data to match the internal processing format. | | 23 | LoadFormat | 1 | 1 | x | This field controls how the 32 bit data is to be loaded into the LUT. The options are: 0 = Copy (i.e. no formatting). 1 = 565 Replicated 2 = 5551 Replicated The conversion from 8 bits to 1, 5 or 6 bits is done by subtracting half and truncating. The 16 bit value is replicated into both halves of the LUT. | | 4 | LoadColorOrde<br>r | 1 | 1 | х | This bit controls the order the 16 bit color components are assembled in after the conversion while loading. The options are: 0 = BGR or ABGR 1 = RGB or ARGB | 3Dlabs Proprietary and Confidential 5-133 $<sup>^{\</sup>rm 25}\,{\rm Logic}$ Op register readback is via the main register only | 810 | FragmentOperation | <b>√</b> | <b>√</b> | x | This field specifies the operation to be done on each fragment when not using spans to do the rendering. The options are: 0 = None 1 = IndexedTexture. The 8 bit indexed texels are converted into 32 bit true color values. 2 = Translate8To32. The fragment's red channel is converted into a 32 bit ABGR value using the LUT. 3 = Translate32To32. Each of the four color components are translated using its own LUT. 4 = MotionComp. The LUT holds motion compensation data held in Planar 411 format as 8 bit or 9 bit YUV values. This is indexed based on the fragments coordinates and expanded to 9 bits, if necessary, and assigned to the fragment's color. 5 = Pattern. The LUT holds an 8x8 pattern for the chosen pixel size and this is used to set the fragment's color. Note the SwapSD bit in the AlphaBlendColorMode register may need to be set if the pixel size is 8 or 16 bits. This field specifies the operation to be done on each pixel in a span. The options are: 0 = None 1 = SpanPattern. The LUT holds an 8x8 pattern for the chosen pixel size and this is used to set the block color or the span pixel data depending on the span operation bit in the Render command (constant color uses block color, variable color uses span pixel data). 2 = Translate8To8. Each byte is translated using its corresponding LUT channel (so 8 bytes can be translated in parallel). Normally the LUT is set up so all four byte channels hold the same data. 3 = Translate8To16. Each byte is translated using a pair of LUT channels to generate a 16 bit pixel. The LUT is set up so that pairs of channels hold the same data. This can be arranged | |-----|---------------------|----------|----------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | | | | 11 | MotionComp8<br>Bits | ✓ | ✓ | х | This bit, if set, specifies that the YUV data is held as 8 bit values, packed 4 per 32 bit LUT entry. If this bit is not set the YUV data is held as 9 bit values packed 2 per 32 bit LUT entry (on 16 bit boundaries within the 32 bit word). | | 1214 | XOffset | ✓ | 1 | х | This field holds the X offset into the selected 8x8 pattern. This is used (together with the pixels X coordinate) to rotate the selects row of the pattern to give some control on its registration to the underlying rectangle. | |------|----------------------|----------|----------|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1517 | YOffset | <b>J</b> | <b>✓</b> | х | This field holds the Y offset into the selected 8x8 pattern. This is used (together with the pixels Y coordinate) to select which row of the pattern to use. This gives some control of the patterns registration to the underlying rectangle. | | 1825 | PatternBase | 1 | 1 | х | This field holds the base address of the pattern to use. There are no restrictions on where a pattern starts, other than it must start on a 32 bit boundary (i.e. the start cannot be part way through a LUT entry). | | 26 | SpanCCXAlign<br>ment | <b>√</b> | <b>√</b> | x | This bit controls how the pattern is aligned along the X axis when Constant Color spans are used. The two options are: 0 = The first pixel in the span is taken from the pixel indexed for this row by XOffset. This is the normal method and fixes the pattern with respect to the screen (recall the block color registers are memory aligned). This preserves a vertical line in the pattern when applying to a trapezoid. 1 = The first pixel in the span is taken from (X + XOffset) % 8 | | 27 | SpanVCXAlign<br>ment | 1 | 1 | х | This bit controls how the pattern is aligned along the X axis when Constant Color spans are used. The two options are: 0 = The first pixel in the span is taken from the pixel indexed for this row by XOffset. 1 = The first pixel in the span is taken from (X + XOffset) % 8. This is the normal method and fixes the pattern with respect to the screen (recall these are done via normal writes so are not memory aligned). This preserves a vertical line in the pattern when applying to a trapezoid. | Notes: The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. ## **LUTTransfer** | Name | Туре | Offset | Format | |-------------|---------|--------|----------| | LUTTransfer | Texture | 0x84D8 | Bitfield | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-------|-------|-------------------------| | 07 | Start index | ✓ | ✓ | х | Index | | 814 | Count | 1 | 1 | X | Count in 128 bit words. | | 1531 | Reserved | 0 | 0 | X | | Notes: This register initiates the transfer of data from memory into the LUT. ## MaxHitRegion | Name | Туре | Offset | Format | |--------------|---------|--------|----------| | MaxHitRegion | Output | 0x8C30 | Bitfield | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|-------|-------|-------------------------------------| | 015 | Maximum X | × | 1 | X | maximum X in 2's complement format. | | 1631 | Maximum Y | × | 1 | X | maximum Y in 2's complement format. | Notes: This register causes the current value of the *maxRegion* register to be written to the output FIFO under control of the *FilterMode* register (which may cull the data depending on the setting of the Statistics bits). The data field (on input) is not used. ## **MaxRegion** | Name | Type | Offset | Format | |-----------|------------------|--------|----------| | MaxRegion | Output | 0x8C18 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|-------|-------|-------------------------------------| | 015 | Maximum X | × | 1 | X | maximum X in 2's complement format. | | 1631 | Maximum Y | × | 1 | X | maximum Y in 2's complement format. | Notes: This register initialises the maximum region register. The register is updated during extent testing: - During Picking it contains the max X,Y value for the Pick region. - During Extent collection it is set to the initial minimum extent and is updated whenever a fragment with a higher X or Y value is generated, to reflect the new X or Y. The StatisticMode register allows either fragments or those that were culled after being rasterised to be set as Eligible to update this register. Since register contents are updated during rendering it may not return the value previously written to it. ## MinHitRegion | Name | Type | Offset | Format | |--------------|------------------|--------|----------| | MinHitRegion | Output | 0x8C28 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|-------|-------|-------------------------------------| | 015 | Minimum X | × | 1 | X | minimum X in 2's complement format. | | 1631 | Minimum Y | × | 1 | X | minimum Y in 2's complement format. | Notes: This register causes the current value of the *minRegion* register to be written to the output FIFO under control of the *FilterMode* register (which may cull the data depending on the setting of the Statistics bits). The data field (on input) is not used. # MinRegion | Name | Туре | Offset | Format | |-----------|------------------|--------|----------| | MinRegion | Output | 0x8C10 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|-------|-------|-------------------------------------| | 015 | Minimum X | × | 1 | X | minimum X in 2's complement format. | | 1631 | Minimum Y | × | ✓ | X | minimum Y in 2's complement format. | Notes: This register initialises the minimum region register. The register is updated during extent testing: - During Picking it contains the max X,Y value for the Pick region. - During Extent collection it is set to the initial minimum extent and is updated whenever a fragment with a higher X or Y value is generated, to reflect the new X or Y. The *StatisticMode* register allows either active fragments or those that were culled after being rasterised to be set as Eligible to update this register. Since register contents are updated during rendering it may not return the value previously written to it. #### Packed16Pixels NameTypeOffsetFormatPacked16Pixels2DSetup0xB638IntegerCommand | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|-------|-------|-------------| | 031 | Data word | × | 1 | X | | Notes: Packed Downloads: The target register for the expanded pixel data is set up with the *DownloadTarget* command. Four bit packed pixel downloads are converted into eight bit packed pixels. The 8 and 16 packed pixels are particularly useful when downloading textures because spans (which take packed data) cannot be used when the target buffer layout is Patch2 or Patch32 2. Each *Packed16Pixels* command will be expanded into 2 writes to the target register. If the input bytes are labelled DCBA (with byte A in bit positions 0...7) then this is converted to: First word: 00BA (0 is the byte set to zero) Second word: 000DC #### Packed4Pixels NameTypeOffsetFormatPacked16Pixels2DSetup0xB668IntegerCommand | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|-------|-------|-------------| | 031 | Data word | × | 1 | X | | Notes: Packed Downloads: The target register for the expanded pixel data is set up with the *DownloadTarget* command. Four bit packed pixel downloads are converted into eight bit packed pixels. This register holds the packed nibble pixel data to expand out into packed byte pixel data. Each Packed4Pixels command will be expanded into two writes to the target register. If the input nibbles are labelled HGFEDCBA (with nibble A in bit positions 0...3) then this is converted to: First word: 0C0D0A0B (0 is the nibble set to zero) Second word: 0G0H0E0F #### Packed8Pixels | Name | Type | Offset | Format | |---------------|---------|--------|---------| | Packed8Pixels | 2ĎSetup | 0xB630 | Integer | | | Command | | _ | | Bits | Name | Read | Write | Reset | Description | |------|-----------|------|-------|-------|-------------| | 031 | Data word | × | ✓ | X | | Notes: Packed Downloads: The target register for the expanded pixel data is set up with the *DownloadTarget* command. This register holds the packed 8 bit pixel data to expand out into 4 seperate 8 bit pixels during the download. The data is sent to the register defined in DownloadTarget. Each Packed8Pixels command will be expanded into four writes to the target register. If the input bytes are labelled DCBA (with byte A in bit positions 0...7) then this is converted to: First word: 000A (0 is the byte set to zero) Second word: 000B Third word: 000D Fourth word: 000D # **PhysicalPageAllocationTableAddr** | Name | Type | Offset | Format | |------------------------|---------|--------|---------| | PhysicalPageAllocation | Texture | 0xB4C0 | Integer | TableAddr Control register | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | ✓ | ✓ | X | 32 bit value | Notes: This register holds the base address of the Physical Page Allocation Table. The address should be aligned to a 64 bit boundary. ## **PickResult** | Name | Туре | Offset | Format | |------------|---------|--------|----------| | PickResult | Output | 0x8C38 | Bitfield | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-------|-------|-------------| | 0 | Pick result | X | ✓ | X | Flag | | 131 | Reserved | × | 0 | X | | Notes: This command causes the current value of the pick result flag to be written to the output FIFO under control of the FilterMode settings. The data field (on input) is not used. Output = 0 for false or 1 for true. #### **PixelSize** | Name | Туре | Offset | Format | |-----------|------------|--------|----------| | PixelSize | Rasterizer | 0x80C0 | Bitfield | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|------------------------|------|-------|-------|-----------------------------------------------| | 01 | Global | 1 | 1 | X | All units, if bit 31 is zero, otherwise | | 23 | Rasterizer | 1 | 1 | X | Rastrerizer | | 45 | Scissor and<br>Stipple | 1 | 1 | Х | Scissor and Stipple functions | | 67 | Texture | 1 | 1 | X | | | 89 | LUT | 1 | 1 | X | | | 1011 | Framebuffer | ✓ | 1 | X | | | 1213 | LogicalOps | ✓ | 1 | X | | | 1415 | Framebuffer | 1 | 1 | X | | | 1617 | Setup | 1 | 1 | X | | | 1830 | Reserved | 0 | 0 | X | Reserved | | 31 | Global/local<br>toggle | 1 | 1 | Х | selects global (0) or individual settings (1) | Notes: Two bit pixel size encoding: This field sets the pixel size to be used for merging the pixel data into the memory. It is normally set to the same value for all functions, but for generating texture maps it may be advantageous to use a different write pixel size. - The pixel size is taken from bits 0...1 when bit 31 is 0 or taken from subsequent bites for local functionality when bit 31 is 1. - The two bit pixel size is encoded as follows: 0 = 32 bpp 1 = 16 bpp 2 = 8 bpp During readback bits 0...17 and 31 return values as loaded and bits 18...30 return zero. ## PointTable[0...3] Name Type Offset Format PointTable[0...3] Rasterizer 0x8080, 0x8088, 0x8088, 0x8098, 0x8098 bitfield Control registers | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|---------------------------------------------| | 031 | PointTable | 1 | ✓ | X | 8 delta values 07 in fixed point 1.3 format | Notes: Antialiased point data table. There are 4 words in the table of packed dx point data. The format is unsigned 1.3 fixed point numbers. From the host's view the table is organised as 4 \* 32 bit words to minimize download overhead when points size changes. Only the parts of the table needed for a particular point size need to be loaded. ## **ProvokingVertex** | Name | Туре | Offset | Format | |-----------------|-----------------|--------|----------| | ProvokingVertex | Delta | 0x9338 | Bitfield | | - | Control registe | er | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|---------------------------------------------------------------| | 01 | Vertex | 1 | 1 | х | Data field 0, 1 or 2 for vertex to use for certain parameters | | 231 | Reserved | 0 | 0 | X | | Notes: If UseProvoking vertex is enabled, certain parameters (defined by the ProvokingVertexMask) are flat shaded using the vertex specified by the provoking vertex register. Flat shaded primitives take the values to be used across the whole primitive from one of the vertices, known as the provoking vertex. Which vertex this is depends on the type of primitive being drawn. The Input unit breaks complex primitives (strips, fans, meshes, etc) into single traingles. It also issues a provoking vertex command which the Delta unit uses as the basis for selecting the vertex from which to take the shading parameters. ## **ProvokingVertexMask** | Name | Туре | Offset | Format | |---------------------|------------------|--------|----------| | ProvokingVertexMask | Delta | 0x9358 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |-------|----------|------|-------|-------|--------------------------| | 0 | R | 1 | 1 | X | Red | | 1 | G | 1 | 1 | Х | Green | | 2 | В | 1 | 1 | Х | Blue | | 3 | A | 1 | 1 | Х | Alpha | | 4 | Reserved | 0 | 0 | х | | | 5 | KsR | 1 | 1 | Х | Red specular component | | 6 | KsG | 1 | 1 | Х | Green specular component | | 7 | KsB | 1 | 1 | х | Blue specular component | | 8 | Reserved | 0 | 0 | х | | | 9 | KdR | 1 | 1 | х | Red diffuse component | | 10 | KdG | 1 | 1 | х | Green diffuse component | | 11 | KdB | 1 | 1 | х | Blue diffuse component | | 12-31 | Reserved | 0 | 0 | х | • | Notes: If UseProvoking vertex is enabled, certain parameters (defined by the ProvokingVertexMask) are flat shaded using the vertex specified by the provoking vertex register. The mask is used to select which parameters are constant and should have the deltas set to zero, and which should be interpolated. #### Q1Start | Name | Туре | Offset | Format | |---------|------------------|--------|-------------| | Q1Start | Texture | 0x8430 | Fixed point | | | Control register | | • | | | Bits | Name | Read | Write | Reset | Description | |---|------|----------|------|-------|-------|-------------| | П | 0n | Fraction | ✓ | ✓ | X | | | Г | n31 | Integer | ✓ | ✓ | X | | Notes: Initial Q1 value for texture map. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location but must be consistent for all S1, T1 and Q1 values. #### **QStart** | Name | Туре | Offset | Format | |--------|------------------|--------|-------------| | QStart | Texture | 0x83B8 | Fixed point | | | Control register | | • | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | ✓ | ✓ | X | | | n31 | Integer | ✓ | ✓ | X | | Notes: Initial Q value for texture map. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location but must be consistent for all S, T and Q values. # RasterizerMode RasterizerModeAnd RasterizerModeOr **Type** Rasterizer Name Offset **Format** 0x80A0 RaasterizerMode Bitfield RaasterizerModeAnd Rasterizer 0xABA0 Bitfield RaasterizerModeOr Rasterizer 0xABA8 Bitfield Control register | Bits | Name | Read<br>26 | Write | Reset | Description | |------|-----------------------------|------------|----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | MirrorBit Mask | <b>√</b> | <b>√</b> | х | <ul> <li>When set the bit mask bits are consumed from the most significant end towards the least significant end.</li> <li>When reset the bit mask bits are consumed from the least significant end towards the most significant end.</li> </ul> | | 1 | InvertBit Mask | 1 | 1 | Х | When this bit is set the bit mask is inverted first before being tested. | | 2,3 | Fraction Adjust | 1 | 1 | Х | These bits control the action of a ContinueNewLine cmmand and specify how the fraction bits in the Y and XDom DDAs are adjusted. 0: No adjustment is done, 1: Set the fraction bits to zero, 2: Set the fraction bits to half. 3: Set the fraction to nearly half, i.e. 0x7fff | | 4,5 | Bias<br>Coordinates | <b>√</b> | 1 | X | These bits control how much is added onto the SartXDom, StartXSub and StartY values when they are loaded into the DDA units. The original registers are not affected. 0: Zero is added, 1: Half is added, 2: Nearly half, i.e. 0x7fff is added | | 6 | | ✓ | ✓ | X | Reserved | | 7,8 | BitMask<br>ByteSwap<br>Mode | <b>√</b> | <b>√</b> | Х | These bit controls the byte swapping of the BitMask data before it is used. If the bytes are labelled ABCD on input then they are swapped as follows: 0: ABCD (i.e. no swap) 1: BADC 2: CDAB 3: DCBA | | 9 | BitMask<br>Packing | 1 | 1 | х | This bit controls whether the bitMask data is packed or if a new BitMask data is required on every scanline. 0: BitMask data is packed, 1: BitMask data is provided for each scanline. | $<sup>^{\</sup>rm 26}\,{\rm Logic}$ Op register readback is via the main register only | 10-14 | BitMaskOffset | <b>√</b> | <b>/</b> | X | These bits hold the bit position in the BitMask data where the first bit is taken from for the bit mask test for the first BitMask data on a new scanline. Subsequent BitMask data starts from bit 0 until the next scanline. Successive bits are taken from increasing bit positions until the bit mask is consumed (i.e. bit 31 is reached). The least significant bit is bit zero. | |-------|--------------------------|----------|----------|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15,16 | HostDataByteS<br>wapMode | 1 | 1 | х | These bits controls the byte swapping of the BitMask data before it is used. If the bytes are labelled ABCD on input then they are swapped as follows: 0: ABCD (i.e. no swap) 1: BADC 2: CDAB 3: DCBA | | 17 | MultiGLINT | 1 | 1 | X | This bit selects whether the rasterizer is to work in single GLINT mode, or in multi-GLINT mode and consequently only process the scanlines allocated to it. 0: Single GLINT mode 1: Multi-GLINT mode | | 18 | YLimitsEnable | 1 | 1 | Х | This bit, when set, enables the Y limits testing to be done between the minimum and maximum Y values given by the YLimits register. | | 19 | Reserved | ✓ | <b>√</b> | X | | | 2022 | StripeHeight | 1 | 1 | Х | This field specifies the number of scanlines in a stripe. The options are: $0 = 1 \qquad 3 = 8$ $1 = 2 \qquad 4 = 16$ $2 = 4$ | | 23 | WordPacking | <b>√</b> | <b>V</b> | x | This bit controls how the two host words sent during, a span operation are packed into the 64 bit internal span data. 0 = first word in bits 031, second word in 3263 1 = first word in bits 3263, second word in 031 | | 24 | OpaqueSpans | <b>√</b> | <b>✓</b> | X | This bit, when set allows the color of each pixel in the span to be either foreground or background as set by the supplied bit masks. If this bit is 0 then any supplied bit masks are anded with the pixel mask to delete pixels from the span. This bit should be set to 0 for performance reasons when foreground/background processing is not required. | | 25 | Reserved | 0 | 0 | Х | | | 26 | D3DRules | 1 | 1 | X | This bit, if set, uses D3D rules for subpixel correction calculations, otherwise OpenGL rules are used. | | 2731 | Reserved | 0 | 0 | х | Reserved for future use, mask to 0 | Notes: Defines the long term mode of operation of the rasterizer. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. # RectanglePosition | Name | Туре | Offset | Format | |-------------------|------------------|--------|---------| | RectanglePosition | 2DSetup | 0xB600 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------| | 015 | X offset | ✓ | ✓ | X | 2's complement X coordinate | | 1631 | Y offset | ✓ | ✓ | X | 2's complement Y coordinate | Notes: This register defines the rectangle origin for use by the Render2D command. ## Render NameTypeOffsetFormatRenderGlobal0x8038BitfieldCommandCommand | Bits | Name | Read | Write | Reset | Description | |------|-------------------------|------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | AreaStipple<br>Enable | X | 1 | x | This bit, when set, enables area stippling of the fragments produced during rasterisation in the Stipple Unit. Note that area stipple in the Stipple Unit must be enabled as well for stippling to occur. When this bit is reset no area stippling occurs irrespective of the setting of the area stipple enable bit in the Stipple Unit. This bit is useful to temporarily force no area stippling for this primitive. | | 1 | LineStipple<br>Enable | × | <b>✓</b> | X | This bit, when set, enables line stippling of the fragments produced during rasterisation in the Stipple Unit. Note that line stipple in the Stipple Unit must be enabled as well for stippling to occur. When this bit is reset no line stippling occurs irrespective of the setting of the line stipple enable bit in the Stipple Unit. This bit is useful to temporarily force no line stippling for this primitive. | | 2 | ResetLine<br>Stipple | × | 1 | х | This bit, when set, causes the line stipple counters in the Stipple Unit to be reset to zero, and would typically be used for the first segment in a polyline. This action is also qualified by the LineStippleEnable bit and also the stipple enable bits in the Stipple Unit. When this bit is reset the stipple counters carry on from where they left off (if line stippling is enabled) | | 3 | FastFillEnable | × | 7 | х | This bit, when set, causes the span fill mechanisms to be used for the rasterisation process. The type of span filling is specified in the SpanOperation field. When this bit is reset the normal rasterisation process occurs. | | 4, 5 | Un used | 0 | 0 | X | | | 6, 7 | Primitive Type | × | 1 | | This two bit field selects the primitive type to rasterise. The primitives are: 0 = Line 1 = Trapezoid 2 = Point | | 8 | Antialiase<br>Enable | × | 1 | | This bit, when set, causes the generation of sub scanline data and the coverage value to be calculated for each fragment. The number of sub pixel samples to use is controlled by the AntialiasingQuality bit. When this bit is reset normal rasterisation occurs. | | 9 | Antialiasing<br>Quality | × | 1 | | This bit, when set, sets the sub pixel resolution to be 8x8 When this bit is reset the sub pixel resolution is 4x4. | | 10 | UsePoint Table | X | <b>√</b> | | When this bit and the AntialiasingEnable are set, the | |----|--------------------|---|----------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | | dx values used to move from one scanline to the next | | | | | | | are derived from the Point Table. | | 11 | SyncOnBit<br>Mask | × | • | | This bit, when set, causes a number of actions: The least significant bit or most significant bit (depending on the MirrorBitMask bit) in the Bit Mask register is extracted and optionally inverted (controlled by the InvertBitMask bit). If this bit is 0 then any fragments are skipped. After every fragment the BitMask register is rotated by one bit. If all the bits in the BitMask register have been used then rasterisation is suspended until a new BitMaskPattern tag is received. If any other tag is received while the rasterisation is suspended then the rasterisation is aborted. The message which caused the abort is then processed as normal. Note the behaviour is slightly different when the SyncOnHostData bit is set to prevent a deadlock from | | | | | | | occurring. In this case the rasterisation doesn't suspend when all the bits have been used and if new BitMaskPattern tags are not received in a timely manner then the subsequent fragments will just reuse the bit mask. | | 12 | SyncOnHost<br>Data | X | • | | When this bit is set a fragment is produced only when one of the following tags have been received from the host: Depth, Stencil, Color or FBData, FBSourceData. If SyncOnBitMask is reset then any tag other than one of these three is received then the rasterisation is aborted. If SyncOnBitMask is set then any tag other than one of these five or BitMaskPattern is received then the rasterisation is aborted. The tag which caused the abort is then processed as normal for that register type. The <i>BitMaskPattern</i> register doesn't cause any fragments to be generated, but just updates the BitMask register. | | 13 | TextureEnable | × | <b>J</b> | X | This bit, when set, enables texturing of the fragments produced during rasterisation. Note that the Texture Units must be suitably enabled as well for any texturing to occur. When this bit is reset no texturing occurs irrespective of the setting of the Texture Unit controls. This bit is useful to temporarily force no texturing for this primitive. | | 14 | FogEnable | × | • | Х | This bit, when set, enables fogging of the fragments produced during rasterisation. Note that the Fog Unit must be suitably enabled as well for any fogging to occur. When this bit is reset no fogging occurs irrespective of the setting of the Fog Unit controls. This bit is useful to temporarily force no fogging for this primitive. | | 15 | Coverage<br>Enable | × | <b>√</b> | х | This bit, when set, enables the coverage value produced as part of the antialiasing to weight the alpha value in the alpha test unit. Note that this unit must be suitably enabled as well. When this bit is reset no coverage application occurs irrespective of the setting of the AntialiasMode. | |------|----------------------------------|---|----------|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 16 | SubPixel<br>Correction<br>Enable | × | <b>√</b> | х | This bit, when set enables the sub pixel correction of the color, depth, fog and texture values at the start of a scanline. When this bit is reset no correction is done at the start of a scanline. Sub pixel corrections are only applied to aliased trapezoids. | | 17 | Reserved | 0 | 0 | X | | | 18 | SpanOperation | × | <b>√</b> | х | This bit, when clear, indicates the writes are to use the constant color found in the previous FBBlockColor register. When this bit is set write data is variable and is either provided by the host (i.e. SyncOnHostData is set) or is read from the framebuffer. | | 19 | Unused | 0 | 0 | X | | | 2026 | Reserved | X | <b>√</b> | X | | | 27 | FBSourceRead<br>Enable | X | 1 | Х | This bit, when set enables source buffer reads to be done in the Framebuffer Read Unit. Note that the Framebuffer Read Unit must be suitably enabled as well for the source read to occur. When this bit is reset no source reads occur irrespective of the setting of the Framebuffer Read Unit controls. | | 2831 | Unused | 0 | 0 | Х | | Notes: ## Render2D Name Type Offset Format Render2D Global 0xB640 Bitfield Control register | Bits | Name | Read | Write | Reset | Description | |------|--------------------------|------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 011 | Width | × | 1 | Х | Specifies the width of the rectangle in pixels. Its range is 04095. | | 1213 | Operation | × | • | x | This two bits field is encoded as follows: 0 = Normal 1 = SyncOnHostData 2 = SyncOnBitMask 3 = PatchOrderRendering The SyncOnHostData and SyncOnBitMask settings just set the corresponding bit in the Render command. PatchOrderRendering decomposes the input rectangle in to a number of smaller rectangels to make better use of the page structure of patched memory. | | 14 | FBRead<br>SourceEnable | × | 1 | Х | This bit sets the FBReadSourceEnable bit in the Render command. | | 15 | SpanOperation | × | 1 | Х | This bit sets the SpanOperation bit in the Render command. | | 1627 | Height | × | 1 | Х | Specifies the height of the rectangle in pixels. Its range is 04095. | | 28 | Increasing X when set | × | 1 | Х | This bit, when set, specifies the rasterisation is to be done in increasing X direction. | | 29 | Increasing Y<br>when set | × | 1 | Х | This bit, when set, specifies the rasterisation is to be done in increasing Y direction. | | 30 | AreaStipple<br>Enable | × | 1 | Х | This bit sets the AreaStippleEnable bit in the Render command. | | 31 | TextureEnable | × | 1 | Х | This bit sets the TextureEnable bit in the Render command. | Notes: This command starts a rectangle being rendered from the origin given by the *RectanglePosition* register. ## Render2DGlyph | Name | Туре | Offset | Format | |---------------|---------|--------|----------| | Render2DGlyph | Global | 0xB648 | Bitfield | | • • | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|------|-------|-------|---------------------| | 06 | Width | × | 1 | Х | | | 713 | Height | × | 1 | x | | | 1422 | X | × | 1 | x | Signed advance in X | | 2331 | Y | × | 1 | X | Signed advance in Y | Notes: This command starts a glyph being rendered from the position given by (GlyphPosition+Advance(X, Y)). #### RenderPatchOffset | Name | Туре | Offset | Format | |-------------------|------------------|--------|----------| | RenderPatchOffset | Delta | 0xB610 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|-----------------------------| | 015 | X coordinate | ✓ | 1 | X | 2's complement X coordinate | | 1631 | Y coordinate | 1 | 1 | X | 2's complement Y coordinate | Notes: This register holds the amount needed to add to the rectangle origin to recover the memory page alignment for the rectangle when it is rendered in patch order. # RepeatLine | Name | Type | Offset | Format | |------------|---------|--------|--------| | RepeatLine | Delta | 0x9328 | Tag | | - | Command | | · · | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 031 | Reserved | 0 | 0 | X | | Notes: This command causes the previous line drawn with a DrawLine command to be repeated. It would be normal for some mode or other state information to have been changed before the line is repeated. An example of this is to use scissor clipping with the line being repeated for each clip rectangle. The data field used when this command is turned into the *Render command* is taken from the previous Draw register. # RepeatTriangle | Name | Туре | Offset | Format | |----------------|---------|--------|--------| | RepeatTriangle | Delta | 0x9310 | Tag | | | Command | | o o | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 031 | Reserved | 0 | 0 | X | | Notes: This command causes the previous triangle drawn with **DrawTriangle** to be repeated. It would be normal for some mode or other state information to have been changed before the triangle is repeated. An example of this is to use scissor clipping with the triangle being repeated for each clip rectangle. The data field used when this command is turned into the *Render command* is taken from the last Draw register. #### ResetPickResult | Name | Type | Offset | Format | |-----------------|---------|--------|--------| | ResetPickResult | Output | 0x8C20 | Tag | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 031 | Reserved | 0 | 0 | X | | Notes: This register resets the picking result flag. Data field is not used. #### RetainedRender | Name | Туре | Offset | Format | |----------------|---------|--------|----------| | RetainedRender | Input | 0xB7A0 | Bitfield | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|-------------------------------| | 031 | Command | × | ✓ | X | Same as Render command format | Notes: See *Render* command. #### **RLCount** | Name | Туре | Offset | Format | |---------|------------------|--------|---------| | RLCount | 2ĎSetup | 0xB678 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 023 | Count | × | 1 | X | | | 2431 | Reserved | 0 | 0 | X | | Notes: This register starts the run length expansion being done. The data in RLData is written to the register defined in *DownloadTarget* **count** times. The count is held in bits 0...23 of this command. #### **RLData** | Name | Туре | Offset | Format | |--------|------------------|--------|---------| | RLData | Delta | 0xB670 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|----------|-------|-------|--------------| | 031 | RLData | <b>√</b> | ✓ | X | 32 bit value | Notes: This register holds the 32 bits of data to be repeated when the run length decoding is initiated by the RLCount command. #### **RLEMask** | Name | Туре | Offset | Format | |---------|------------------|--------|----------| | RLEMask | Output | 0x8C48 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 031 | Mask | 1 | 1 | 0 | Mask Data | Notes: This register holds the mask to AND with the run length encoded data and allows bits to be discounted from the comparison. It also sets the unwanted bits to zero in the data value returned with the run length. ## RouterMode | Name | Туре | Offset | Format | |------------|------------------|--------|----------| | RouterMode | Router | 0x8840 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|----------------------------------------------------| | 0 | Sequence | 1 | 1 | X | Bit0 may be: 0=Texture, Depth; or 1=Depth, Texture | | 131 | Reserved | 0 | 0 | X | | Notes: Switches the order of some units in the pipeline. #### **RStart** | Name | Туре | Offset | Format | |--------|------------------|--------|--------------------| | RStart | Color | 0x8780 | Fixed point number | | | Control register | | - | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 014 | Fraction | ✓ | ✓ | X | | | 1523 | Integer | ✓ | ✓ | X | | | 2431 | Unused | 0 | 0 | X | | Notes: Used to set the initial Red value for a vertex when in Gouraud shading mode. The value is 24 bit 2's complement fixed point numbers in 9.15 format. ## S1Start | Name | Type | Offset | Format | |---------|------------------|--------|-------------| | S1Start | Texture | 0x8400 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | ✓ | ✓ | X | | | n31 | Integer | ✓ | ✓ | X | | Notes: Initial S1 value for texture map. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location but must be consistent for all S1, T1 and Q1 values. ## **SaveLineStippleCounters** | Name | Туре | Offset | Format | |-------------------------|--------------------|--------|--------| | SaveLineStippleCounters | Stipple<br>Command | 0x81C0 | tag | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 031 | Reserved | 0 | 0 | X | | Notes: Copies the current counter values into an internal register for later restoration using the UpdateLineStippleCounters command. Useful in drawing stippled wide lines. #### **ScissorMaxXY** | Name | Type | Offset | Format | |--------------|---------------|--------|----------| | ScissorMaxXY | Scissor | 0x8190 | Bitfield | | | Control regis | ster | | | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|-----------------------------------------| | 015 | X coordinate | 1 | 1 | X | 2's complement fixed point X coordinate | | 1631 | Y coordinate | ✓ | ✓ | X | 2's complement fixed point Y coordinate | Notes: This register holds the maximum XY scissor coordinate - i.e. the rectangle corner farthest from the screen origin. ## **ScissorMinXY** | Name | Туре | Offset | Format | |--------------|------------------|--------|----------| | ScissorMinXY | Scissor | 0x8188 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|-----------------------------------------| | 015 | X coordinate | ✓ | ✓ | X | 2's complement fixed point X coordinate | | 1631 | Y coordinate | 1 | 1 | X | 2's complement fixed point Y coordinate | Notes: This register holds the minimum XY scissor coordinate - i.e. the rectangle corner closest to the screen origin. # ScissorMode ScissorModeAnd ScissorModeOr | Name | Туре | Offset | Format | |----------------|---------|--------|---------------------| | ScissorMode | Scissor | 0x8180 | Bitfield | | ScissorModeAnd | Scissor | 0xABB0 | Bitfield Logic Mask | | ScissorModeOr | Scissor | 0xABB8 | Bitfield Logic Mask | #### **Control registers** | Bits | Name | Read<br>27 | Write | Reset | Description | |------|-------------------------|------------|----------|-------|-------------------------------------| | 0 | UserScissor<br>Enable | 1 | 1 | х | enables the user scissor clipping | | 1 | ScreenScissor<br>Enable | 1 | <b>✓</b> | х | enables the screen scissor clipping | | 231 | Unused | 0 | 0 | X | | Notes: Controls enabling of the screen and user scissor tests. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. ## **ScreenSize** | Name | Туре | Offset | Format | |------------|--------------|--------|----------| | ScreenSize | Scissor | 0x8198 | Bitfield | | | Control regi | ster | | | Bits | Name | Read | Write | Reset | Description | |------|--------|------|-------|-------|-------------| | 015 | Width | 1 | 1 | х | | | 1631 | Height | ✓ | ✓ | X | | Notes: Screen dimensions for screen scissor clipping. The screen boundaries are (0,0) to (width-1, height-1) inclusive. 3Dlabs Proprietary and Confidential 5-157 <sup>&</sup>lt;sup>27</sup> Logic Op register readback is via the main register only ## **Security** | Name | Туре | Offset | Format | |----------|------------------|--------|----------| | Security | Input | 0x8908 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|------------------------------------| | 0 | Secure | × | 1 | х | 0 = normal mode<br>1 = secure mode | | 131 | Reserved | 0 | 0 | X | | This unit controls the security of the rest of the pipeline by filtering out any register loads that may cause the pipeline to lockup if used incorrectly. If the security mode is Enable, potentially dangerous registers can only be programmed by a direct write to the register, and not through DMA. This avoids the danger of DMA buffers in user address space being corrupted by another application and causing the chip to lockup. The following registers are filtered out of DMA command buffers if the security bit is enabled: - FilterMode - VTGAddress - VTGData - Security - DMARectangleWrite - DMAOutputCount - DMAFeedback - ContextDump - ContextRestore - ContextData ## **SetLogicalTexturePage** | Name | Туре | Offset | Format | |-----------------------|------------------|--------|----------| | SetLogicalTexturePage | Texture | 0xB360 | Bitfield | | 0 | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|---------------------| | 015 | PageNumber | 1 | 1 | X | Logical page number | | 1631 | Unused | 0 | 0 | X | | Notes: This register sets the logical page number to be used in subsequent *UpdateLogicalTextureInfo* commands. The logical page is held in bits 0...15. ## SizeOfFramebuffer | Name | Туре | Offset | Format | |-------------------|------------------|--------|--------| | SizeOfFramebuffer | ffer | | | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|------|-------|-------|------------------------------------| | 0n | Size | ✓ | ✓ | X | integer value in units of 16 bytes | | n31 | Unused | 0 | 0 | X | | Notes: This message holds the size (in units of 16 bytes) of the memory associated with the FB memory interface. Amount of FB Memory SizeOfFramebuffer value: - 8MBytess shown as 0x80000 - 16MBytes shown as 0x100000 #### **SStart** | Name | Туре | Offset | Format | |--------|------------------|--------|-------------| | SStart | Texture | 0x8388 | Fixed point | | | Control register | | - | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | ✓ | ✓ | X | | | n31 | Integer | ✓ | ✓ | X | | Notes: Initial S value for texture map. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location but must be consistent for all S, T and Q values. #### **StartXDom** | Name | Туре | Offset | Format | |------------------|------------------|--------|-------------| | Start X Dominant | Rasterizer | 0x8000 | Fixed point | | | Control register | | • | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 015 | Fraction | ✓ | X | X | | | 1631 | Integer | ✓ | × | X | | Notes: The start X coordinate for the dominant edge: initial X value for the dominant edge in trapezoid filling, or initial X value in line drawing. The value is in 2's complement 16.16 fixed point format.. ## **StartXSub** | Name | Туре | Offset | Format | |---------------------|------------------|--------|-------------| | Start X Subordinate | Rasterizer | 0x8010 | Fixed point | | | Control register | | • | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 015 | Fraction | ✓ | × | Х | | | 1631 | Integer | ✓ | X | X | | Notes: The start X coordinate for the subordinate edge: initial X value for the subordinate edge in trapezoid filling. The value is in 2's complement 16.16 fixed point format. ## **StartY** | Name | Туре | Offset | Format | |---------|------------------|--------|-------------| | Start Y | Rasterizer | 0x8020 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 015 | Fraction | ✓ | X | X | | | 1631 | Integer | ✓ | × | X | | Notes: The start Y coordinate: initial scanline (or sub-scanline) in trapezoid filling, or initial Y position for line drawing. The value is in 2's complement 16.16 fixed point format. ## **StatisticMode StatisticModeAnd StatisticModeOr** | Name | Type | Offset | Format | |------------------|---------|--------|---------------------| | StatisticMode | Output | 0x8C08 | Bitfield | | StatisticModeAnd | Output | 0xAD10 | Bitfield Logic Mask | | StatisticModeOr | Output | 0xAD18 | Bitfield Logic Mask | | | Command | | G | | Bits | Name | Read<br>28 | Write | Reset | Description | |------|---------------------|------------|-------|-------|-----------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | х | When set allows the collection of statistics information. | | 1 | StatsType | 1 | 1 | х | Selects the type of staticstics to gather. The options are: 0 = Picking 1 = Extent | | 2 | ActiveSteps | 1 | 1 | х | When set includes active fragments in the statistics gathering, otherwise they are excluded. | | 3 | PassiveSteps | 1 | 1 | х | When set includes culled fragments in the statistics gathering, otherwise they are excluded. | | 4 | Compare<br>Function | 1 | 1 | х | Selects the type of compare function to use. The options are: 0 = Inside region 1 = Outside region | | 5 | Spans | 1 | 1 | х | When set includes spans in the statistics gathering, otherwise they are excluded. | | 631 | Unused | 0 | 0 | Х | | Notes: Statistic Collection: here the active fragments and spans are used to (a) record the extent of the rectangular region where rasterization has been occurring, or (b) if rasterization has occurred inside a specific rectangular region. These facilities are useful for picking and debug activities. Statistic collecting has two modes of operation: Picking In this mode the active and/or culled fragments, and spans have the associated XY > coordinate compared against the coordinates specified in the MinRegion and MaxRegion registers. If the result is true then the PickResult flag is set otherwise it holds it previous state. The compare function can be either Inside or Outside. Before picking can start the ResetPickResult must be sent to clear the PickResult flag. In this mode the active and/or culled fragments and spans have the associated XY Extent coordinates compared to the MinRegion and MaxRegion registers and if found to be outside the defined rectangular region the appropriate register is updated with the new coordinate(s) to extend the region. The Inside/Outside bit has no effect in this mode. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. <sup>&</sup>lt;sup>28</sup> Logic Op register readback is via the main register only #### **Stencil** | Name | Туре | Offset | Format | |---------|------------|-----------------|----------| | Stencil | Stencil | 0x8998 | Bitfield | | | Command/co | ontrol register | | | Bits | Name | Read | Write | Reset | Description | |------|---------------|------|-------|-------|---------------------| | 07 | Stencil value | 1 | 1 | X | 8 bit stencil value | | 831 | Reserved | 0 | 0 | X | | Notes: The **Stencil** register holds an externally sourced stencil value. It is a 32 bit register of which only the least significant 8 bits are used. The unused most significant bits should be set to zero. Set the register to the 8 bit stencil value to be used in clearing down the stencil buffer, or in drawing a primitive where the host supplies the stencil value. # StencilData StencilDataAnd StencilDataOr | Name | Туре | Offset | Format | |----------------|--------------|--------|---------------------| | StencilData | Stencil | 0x8990 | Bitfield | | StencilDataAnd | Stencil | 0xB3E0 | Bitfield Logic Mask | | StencilDataOr | Stencil | 0xB3E8 | Bitfield Logic Mask | | | Control regi | sters | | | Bits | Name | Read<br>29 | Write | Reset | Description | |------|---------------|------------|-------|-------|---------------------------------------------------| | 07 | Stencil value | 1 | 1 | X | 8 bit stencil test value | | 815 | Compare mask | 1 | 1 | X | Determines which bits are significant in the test | | 1623 | Writemask | 1 | 1 | X | Determines which bits in localbuffer are updated | | 2431 | Reserved | 0 | 0 | X | | Notes: The register holds data used in the Stencil test: - Stencil value is the reference value for the stencil test. - Compare mask is used to determine which bits are significant in the stencil test comparison. - The stencil writemask is used to control which stencil planes are updated as a result of the test. The stencil unit must be enabled to update the stencil buffer. If it is disabled then the stencil buffer will only be updated if ForceLBUpdate is set. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. 3Dlabs Proprietary and Confidential 5-163 <sup>&</sup>lt;sup>29</sup> Logic Op register readback is via the main register only # StencilMode StencilModeAnd StencilModeOr | Name | Туре | Offset | Format | |----------------|---------|--------|---------------------| | StencilMode | Stencil | 0x8988 | Bitfield | | StencilModeAnd | Stencil | 0xAC60 | Bitfield Logic Mask | | StencilModeOr | Stencil | 0xAC68 | Bitfield Logic Mask | #### **Control registers** | Bits | Name | Read<br>30 | Write | Reset | Description | |------|----------------|------------|-------|-------|--------------------------------------------------------------------------| | 0 | Unitenable | 1 | 1 | х | 0 = Disable<br>1 = Enable | | 13 | Update method | 1 | 1 | х | if Depth test passes and Stencil test passes (see table 1) | | 46 | Update method | 1 | ✓ | X | if Depth test fails and Stencil test passes (see table 1) | | 79 | Update method | 1 | ✓ | X | if Stencil test fails (see table 1) | | 1012 | Mode 0-7 | 1 | ✓ | X | Unsigned comparison function (see table 2) | | 1314 | Stencil source | ✓ | 1 | х | 0 = Test Logic<br>1 = Stencil Register<br>2 = LBData<br>3 = LBSourceData | | 1516 | Stencil widths | ✓ | 1 | Х | 0 = 4 bits<br>1 = 8 bits<br>2 = 1 bit | | 1731 | Unused | 0 | 0 | X | | Notes: Controls the stencil test, which conditionally rejects fragments based on the outcome of a comparison between the value in the stencil buffer and a reference value in the *StencilData* register. If the test is LESS and the result is true then the fragment value is less than the source value.. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. 5-164 Proprietary and Confidential 3Dlabs $<sup>^{30}\,\</sup>mathrm{Logic}$ Op register readback is via the main register only Table 1 - Update Method if Stencil Test fails | Mode | Method | Result | |------|-----------|--------------------------------------------------------------| | 0 | Keep | Source stencil | | 1 | Zero | 0 | | 2 | Replace | Reference stencil | | 3 | Increment | Clamp (Source stencil + 1) to 2 <sup>stencil</sup> width - 1 | | 4 | Decrement | Clamp (Source stencil -1) to 0 | | 5 | Invert | | **Table 2 - Unsigned Comparison Function** | Mode | Comparison Function | |------|---------------------| | 0 | NEVER | | 1 | LESS | | 2 | EQUAL | | 3 | LESS OR EQUAL | | 4 | GREATER | | 5 | NOT EQUAL | | 6 | GREATER OR EQUAL | | 7 | ALWAYS | # **StripeOffsetY** | Name<br>StripeOffsetY | Туре | <b>Offset</b><br>0x80C8 | <b>Format</b><br>Fixed point | |-----------------------|------------------|-------------------------|------------------------------| | Surpeonserr | Control veriator | 0.0000 | rixeu politi | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------------|------|-------|-------|------------------------------------| | 015 | Fixed point | ✓ | ✓ | X | 2's complement fixed point value | | 1623 | Reserved | 0 | 0 | X | Reserved for future use, mask to 0 | Notes: This register holds the 16 bit 2's complement Y value added to the raster Y value to determine scanline ownership. # SuspendUntilFrameBlank | Name | Туре | Offset | Format | |------------------------|-------------|--------|----------| | SuspendUntilFrameBlank | Framebuffer | 0x8C78 | Bitfield | | • | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|-----------------------------------------| | 020 | ScreenBase | 1 | 1 | X | Base address of screen in 128 bit units | | 2131 | Reserved | 0 | 0 | X | | Notes: The SuspendUntilFrameBlank command flushes the write combine buffers and then is forwarded onto the Memory Controller where it prevents any further memory writes (normal or span writes) from this port until after the next the Vertical Frame Blank has happened. When frame blank occurs new writes are allowed to proceed. By using this register the host does not need to get involved with waiting for vertical frame blank itself before it can issue new instructions to P3. While waiting for frame blank any data or actions which do not involve writing to the memory via this unit (such as clearing down the depth buffer) can proceed. Attempting to write to the memory while waiting for frame blank will just result in the Write FIFO blocking for the duration and this will ripple back through the chip # Sync | Name | Туре | Offset | Format | |-----------------|------------------|--------|----------| | Synchronization | Output | 0x8C40 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------------------|------|-------|-------|----------------------------------------------| | 030 | User defined | × | ✓ | Х | User defined | | 31 | Interrupt<br>enable | × | ✓ | Х | Interrupt after output FIFO write operations | Notes: This command can be used to synchronize with the host. It is also used to flush outstanding operations such as pending memory accesses. It also causes the current status of the picking result to be passed to the Host Out FIFO unless culled by the statistics bits in the *FilterMode* register. If bit 31 of the input data is set then an interrupt is generated. The data output is the value written to the register by this command. If interrupts are enabled, then the interrupt does not occur until the tag and/or data have been written to the output FIFO. #### T1Start | Name | Туре | Offset | Format | |---------|------------------|--------|-------------| | T1Start | Texture | 0x8418 | Fixed point | | | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | 1 | ✓ | X | | | n31 | Integer | ✓ | ✓ | X | | Notes: Initial T1 value for texture map. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location but must be consistent for all S1, T1 and Q1 values. # TailPhysicalPageAllocation[0...3] | Name | Туре | Offset | Format | |----------------------------|------------------|-----------------|---------| | TailPhysicalPageAllocation | Texture | 0xB4A0, 0xB4A8, | Integer | | [03] | | 0xB4B0, 0xB4B8 | Ü | | | Control register | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|---------------------| | 015 | Address | ✓ | ✓ | X | 16 bit value 065535 | Notes: These registers hold the tail page for memory pools 0...3. This is usually the least recently referenced physical page in the pool of the working set. The range of physical pages is 0...65535. # TextRender2DGlyph0...7 | Name | Туре | Offset | Format | |--------------------|---------|--------|----------| | TextRender2DGlyph0 | Gľobal | 0x8708 | Bitfield | | TextRender2DGlyph1 | Global | 0x8718 | Bitfield | | TextRender2DGlyph2 | Global | 0x8728 | Bitfield | | TextRender2DGlyph3 | Global | 0x8738 | Bitfield | | TextRender2DGlyph4 | Global | 0x8748 | Bitfield | | TextRender2DGlyph5 | Global | 0x8758 | Bitfield | | TextRender2DGlyph6 | Global | 0x8768 | Bitfield | | TextRender2DGlyph7 | Global | 0x8778 | Bitfield | | 31 | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|------|-------|-------|---------------------| | 06 | Width | × | 1 | X | | | 713 | Height | × | 1 | x | | | 1422 | X | × | 1 | x | Signed advance in X | | 2331 | Y | × | 1 | x | Signed advance in Y | Notes: Alias for Render2Dglyph. This command starts a glyph being rendered from the position given by (GlyphPosition+Advance(X, Y)). #### TextGlyphAddr0...7 | Name | Туре | Offset | Format | |----------------|------------------|--------|---------| | TextGlyphAddr0 | Texture | 0x8700 | Integer | | TextGlyphAddr1 | Texture | 0x8710 | Integer | | TextGlyphAddr2 | Texture | 0x8720 | Integer | | TextGlyphAddr3 | Texture | 0x8730 | Integer | | TextGlyphAddr4 | Texture | 0x8740 | Integer | | TextGlyphAddr5 | Texture | 0x8750 | Integer | | TextGlyphAddr6 | Texture | 0x8760 | Integer | | TextGlyphAddr7 | Texture | 0x8770 | Integer | | V.1 | Control register | | O | | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|--------------| | 031 | Base address | 1 | ✓ | X | 32 bit value | Notes: Alias for *TextureBaseAddr0*. These registers hold the base address of each texture map (or level for a mip map). The address should be aligned to the natural size of the texture map, however some layouts impose additional restrictions. #### TextureApplicationMode TextureApplicationModeAnd TextureApplicationModeOr | Name | Туре | Offset | Format | |-------------------------------|---------------------------------------|--------|---------------------| | TextureApplicationMode | Texture<br>Application | 0x8680 | Bitfield | | TextureApplication<br>ModeAnd | Texture<br>Application | 0xAC50 | Bitfield Logic Mask | | TextureApplicationModeOr | Texture Application Control registers | 0xAC58 | Bitfield Logic Mask | | Bits | Name | Read<br>31 | Write | Reset | Description | |------|--------------|------------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | х | When set causes the output to be calculated as defined<br>by the fields in this register, otherwise the fragment's<br>data is passed through. | | 12 | ColorA | 1 | 1 | x | This field selects the source value for A. The options are: 0 = Color.C 1 = Color.A 2 = K.C (TextureEnvColor) 3 = K.A (TextureEnvColor) | | 34 | ColorB | <b>√</b> | 1 | x | This field selects the source value for B. The options are: 0 = Texel.C 1 = Texel.A 2 = K.C (TextureEnvColor) 3 = K.A (TextureEnvColor) | | 56 | ColorI | <b>√</b> | 1 | x | This field selects the source value for I. The options are: 0 = Color.A 1 = K.A (TextureEnvColor) 2 = Texel.C 3 = Texel.A | | 7 | ColorInvertI | 1 | 1 | х | This bit, if set, will invert the selected I value before it is used. | 5-170 Proprietary and Confidential 3Dlabs $<sup>^{</sup>m 31}$ Logic Op register readback is via the main register only | 810 | Color<br>Operation | 1 | • | х | This field defines how the three inputs (A, B and I) are combined. Note the I inputs can be optionally inverted before being combined. The 8 bit inputs are unsigned 0.8 fixed point format, but 255 is treated as if it were 1.0 for the calculations. The possible operations are: 0 = PassA (A) 1 = PassB (B) 2 = Add (A + B) 3 = Modulate (A * B) 4 = Lerp (A * (1.0 - I) + B * I) 5 = ModulateColorAddAlpha (A * B + I) 6 = ModulateAlphaAddColor (A * I + B) 7 = ModulateBIAddA (B * I + A) | |------|--------------------|----------|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1112 | AlphaA | 7 | 7 | Х | This field selects the source value for A. The options are: 0 = Color.C (effectively Color.A) 1 = Color.A 2 = K.C (TextureEnvColor) (effectively K.A) 3 = K.A (TextureEnvColor) | | 1314 | AlphaB | <b>√</b> | 1 | х | This field selects the source value for B. The options are: 0 = Texel.C (effectively T.A) 1 = Texel.A 2 = K.C (TextureEnvColor) (effectively K.A) 3 = K.A (TextureEnvColor) | | 1516 | AlphaI | 1 | 1 | х | This field selects the source value for I. The options are: 0 = Color.A 1 = K.A (TextureEnvColor) 2 = Texel.C (effectively T.A) 3 = Texel.A | | 17 | Alpha InvertI | 1 | 1 | X | This bit, if set, will invert the selected I value before it is used. | | 1820 | Alpha<br>Operation | 1 | 1 | x | This field defines how the three inputs (A, B and I) are combined. Note the I inputs can be optionally inverted before being combined. The 8 bit inputs are unsigned 0.8 fixed point format, but 255 is treated as if it were 1.0 for the calculations. The possible operations are: 0 = PassA (A) 1 = PassB (B) 2 = Add (A + B) 3 = Modulate (A * B) 4 = Lerp (A * (1.0 - I) + B * I) 5 = ModulateABAddI (A * B + I) 6 = ModulateAIAddB (A * I + B) 7 = ModulateBIAddA (B * I + A) | | 21 | KdEnable | 1 | 1 | X | When set this bit causes the RGB results of the texture application to be multiplied by the Kd DDA values. It also enables the Kd DDA sto be updated. | | 22 | KsEnable | ✓ | ✓ | х | When set this bit causes the RGB results of the texture application (or Kd processing) to be added with the Ks DDA values. It also enables the Ks DDAs to be updated. | |------|-----------------------|----------|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 23 | Motion Comp<br>Enable | <b>√</b> | 1 | х | This bit, when set causes the color field to be interpreted as holding YUV difference values as three 9 bit 2's complement numbers. These are subtracted from the RGB channels of the texel value (after all previous processing) and the result clamped. This is used as part of MPEG Motion Compensation processing. | | 2431 | Unused | 0 | 0 | X | | Notes: Formerly known as *TextureColorMode*. Defines the operation for the color channels in applying texture. Note that the TextureEnable bit in the *Render* command must be set for a primitive to be texture mapped. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. #### TextureBaseAddr[0...15] | Name | Туре | Offset | Format | | | |----------------------|---------|--------|---------|--|--| | Texture Base Address | Texture | 0x8500 | Integer | | | | [015] | | | | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | 1 | ✓ | X | 32 bit value | Notes: This register holds the base address of each texture map (or level for a mip map). The address should be aligned to the natural size of the texture map, however some layouts impose additional restrictions. The MapBaseRegister field of the *TextureReadMode* register defines which TextureBaseAddr register should be used to hold the address for map level 0 when mip mapping, or the texture map when not mip mapping. Successive map levels are at increasing *TextureBaseAddr* registers upto (and including) the MapMaxLevel. 3D textures always use *TextureBaseAddr0*. #### **TextureCacheReplacementMode** NameTypeOffsetFormatTextureCacheReplacementInput0xB430BitfieldMode Control register | Bits | Name | Read | Write | Reset | Description | |------|---------------|------|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | KeepOldest0 | 1 | 1 | X | This bit, when set, will keep the oldest texels on the scanline when the cache bank 0 is about to wrap and just re-use a set of scratch lines. | | 15 | ScratchLines0 | 1 | 1 | Х | This field holds the number of cache lines to use as scratch lines when the cache bank 0 wraps and the KeepOldest mode bit is set. The value in this field has a MIN_SCRATCH_SIZE value (currently 8) added to it so we can guarantee the scratch line size can always accommodate the cache lines the current fragments requires with some left over. Failure to make this provision would lead to deadlock. | | 6 | KeepOldest1 | 1 | 1 | Х | This bit, when set, will keep the oldest texels on the scanline when the cache bank 1 is about to wrap and just re-use a set of scratch lines. | | 711 | ScratchLines1 | 1 | 1 | х | This field holds the number of cache lines to use as scratch lines when the cache bank 1 wraps and the KeepOldest mode bit is set. The value in this field has a MIN_SCRATCH_SIZE value (currently 8) added to it so we can guarantee the scratch line size can always accommodate the cache lines the current fragments requires with some left over. Failure to make this provision would lead to deadlock. | Notes: This command defines the replacement mode for the two banks of the cache. ## TextureChromaLower0 TextureChromaUpper0 NameTypeOffsetFormatTextureChromaLower0Texture0x84F0BitfieldTextureChromaUpper00x84E8 Control register | Bits | Name | Read | Write | Reset | Description | |------|------|----------|----------|-------|-------------| | 07 | R | <b>√</b> | <b>√</b> | X | Red | | 815 | G | ✓ | ✓ | X | Green | | 1623 | В | ✓ | ✓ | X | Blue | | 91 | 91 | ٨ | | | | Almha | |----|----|---|----------|----------|-----|---------| | | 31 | A | / | / | l X | l Alpha | | | | | <b>√</b> | <b>√</b> | | | Notes: These registers hold the lower and upper chroma colors to use when the chroma test is enabled for texels from texture map 0. The format is 8 bit ABGR components packed into a 32 bit word with R in the ls byte. ### TextureChromaUpper1 TextureChromaLower1 | Name | Туре | Offset | Format | |---------------------|------------------|--------|----------| | TextureChromaUpper1 | Texture | 0x8600 | Bitfield | | TextureChromaLower1 | Texture | 0x8608 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 07 | R | 1 | 1 | Х | Red | | 815 | G | ✓ | ✓ | X | Green | | 1623 | В | ✓ | ✓ | X | Blue | | 2431 | A | 1 | 1 | X | Alpha | Notes: These registers hold the upper and lower chroma colors to use when the chroma test is enabled for texels T4...T7. Its format is 8 bit ABGR components packed into a 32 bit word with R in the ls byte. #### TextureCompositeAlphaMode0 TextureCompositeAlphaMode0And TextureCompositeAlphaMode0Or | 1 | Name | Туре | Offset | Format | |---|-----------------------|---------|--------|---------------------| | 7 | ГextureCompositeAlpha | Texture | 0xB310 | Bitfield | | N | Mode0 | | | | | 7 | TextureCompositeAlpha | Texture | 0xB390 | Bitfield Logic Mask | | N | Mode0And | | | Ö | | 7 | ΓextureCompositeAlpha | Texture | 0xB398 | Bitfield Logic Mask | | | Mode0Or | | | | | - | .104001 | | | | Control registers | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | I | When set causes the output to be calculated as defined<br>by the fields in this register, otherwise the texel0 data<br>is passed through for stage0 and Output data is passed<br>through for stage 1. | | 14 | Arg1 | • | • | I | This field selects the source value for Arg1. The options are: 0 = Output.C of the previous stage or height if the first stage 1 = Output.A of the previous stage or height if the first stage 2 = Color.C 3 = Color.A 4 = TextureCompositeFactor0.C 5 = TextureCompositeFactor0.A 6 = Texel0.C 7 = Texel0.A 8 = Texel1.C 9 = Texel1.A 10 = Sum of the color components of the previous stage or 0 if the first stage. where C is the RGB or A depending on the channel. height is defined as clamp (Texel0.A - Texel1.A + 128) | | 5 | InvertArg1 | 1 | 1 | х | This bit, if set, will invert the selected Arg1 value before it is used. | | 69 | Arg2 | 1 | 1 | l v | This field selects the source value for Arg2. The | |------|------------|---|----------|----------|--------------------------------------------------------------| | 00 | 11182 | • | <b>•</b> | X | options are: | | | | | | | 0 = Output.C of the previous stage or | | | | | | | height if the first stage | | | | | | | 1 = Output.A of the previous stage or | | | | | | | height if the first stage | | | | | | | 2 = Color.C | | | | | | | 3 = Color.A | | | | | | | 4 = TextureCompositeFactor0 C | | | | | | | | | | | | | | 5 = TextureCompositeFactor0 A<br>6 = Texel0.C | | | | | | | 6 = 1 exelo.C $7 = Texel0.A$ | | | | | | | | | | | | | | 8 = Texel1.C<br>9 = Texel1.A | | | | | | | | | | | | | | 10 = Sum of the color components of the | | | | | | | previous stage or 0 if the first stage. | | | | | | | where C is the RGB or A depending on the | | | | | | | channel, and height is defined as clamp (Texel0.A - | | 10 | T .A O | | | | Texel1.A + 128) | | 10 | InvertArg2 | ✓ | ✓ | X | This bit, if set, will invert the selected Arg2 value | | | _ | | | | before it is used. | | 1113 | I | ✓ | <b>√</b> | X | This field selects what is used as the interpolation | | | | | | | factor when the Operation field is set to Lerp, for | | | | | | | example. The options are: | | | | | | | 0 = Output.A of the previous stage or 0 if | | | | | | | the first stage | | | | | | | 1 = Color.A | | | | | | | 2 = TextureCompositeFactor0.A | | | | | | | 3 = Texel0.A | | | | | | | 4 = Texel1.A | | | | | | | where C is the RGB or A depending on the channel. | | 14 | InvertI | ✓ | ✓ | X | This bit, if set, will invert the selected I value before it | | | | | | | is used. | | 15 | A | ✓ | ✓ | X | This bit selects which Arg (after any inversion) is to be | | | | | | | used as A in the Operation. The options are: | | | | | | | 0 = Arg1 | | | | | <u></u> | <u> </u> | 1 = Arg2 | | 16 | В | ✓ | <b>√</b> | X | This bit selects which Arg (after any inversion) is to be | | | | | | | used as B in the Operation. The options are: | | | | | | | 0 = Arg1 | | | 1 | | | | 1 = Arg2 | | 1720 | Operation | | • | X | This field defines how the three inputs (A, B and I) are combined. Note the inputs can be optionally inverted before being combined. The 8 bit inputs are unsigned 0.8 fixed point format, but 255 is treated as if it were 1.0 for the calculations. The possible operations are: 0 = Pass (A) 1 = Add (A + B) 2 = AddSigned (A + B - 128) 3 = Subtract (A - B) 4 = Modulate (A * B) 5 = Lerp (A * (1.0 - I) + B * I) 6 = ModulateColorAddAlpha (A * B + I) 7 = ModulateColorAddAlpha (A * B + B) 8 = AddSmoothSaturate (A + B - A * B) 9 = ModulateSigned (A * B, but A and B are biased 8 bit numbers) | |------|-----------|---|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2122 | Scale | 0 | 0 | х | This field selects the scale factor to apply to the final result before it is clamped. The options are: $0 = 0.5$ $1 = 1$ $2 = 2$ $3 = 4$ | | 2331 | Reserved | 0 | 0 | X | | Notes: The Texture unit composites the Color, Texel0 and Texel1 fragment's values with one or two constant color values held in registers and passes the result on to the next unit as a texture value. The compositing is done in two stages and is controlled separately for the RGB channels and the Alpha channel. This register defines the operation for the alpha channels in compositing stage 0 for this unit. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. #### TextureCompositeAlphaMode1 TextureCompositeAlphaMode1And TextureCompositeAlphaMode1Or | Name | Туре | Offset | Format | |------------------------------------------------------------|---------|--------|---------------------| | TextureCompositeAlpha | Texture | 0xB320 | Bitfield | | Mode1 | | | | | TextureCompositeAlpha | Texture | 0xB3B0 | Bitfield Logic Mask | | Mode1And 1 | | | 8 | | TextureCompositeAlpha | Texture | 0xB3B8 | Bitfield Logic Mask | | Mode1Or | | | 8 | | TextureCompositeAlpha<br>Mode1And<br>TextureCompositeAlpha | | | O . | Control registers | Bits | Name | Read<br>32 | Write | Reset | Description | |------|------------|------------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | х | When set causes the output to be calculated as defined<br>by the fields in this register, otherwise the texel0 data<br>is passed through for stage0 and Output data is passed<br>through for stage 1. | | 14 | Arg1 | • | • | X | This field selects the source value for Arg1. The options are: 0 = Output.C of the previous stage or height if the first stage 1 = Output.A of the previous stage or height if the first stage 2 = Color.C 3 = Color.A 4 = TextureCompositeFactor1C 5 = TextureCompositeFactor1A 6 = Texel0.C 7 = Texel0.A 8 = Texel1.C 9 = Texel1.A 10 = Sum of the color components of the previous stage or 0 if the first stage. where C is the RGB or A depending on the channel. height is defined as clamp (Texel0.A - Texel1.A + 128) | | 5 | InvertArg1 | 1 | 1 | х | This bit, if set, will invert the selected Arg1 value before it is used. | 3Dlabs Proprietary and Confidential 5-179 $<sup>^{</sup>m 32}$ Logic Op register readback is via the main register only | 69 | Arg9 | | | | This field selects the source value for Arg2. The | |------|------------|---|---|-----|--------------------------------------------------------------| | 09 | Arg2 | ✓ | ✓ | X | i e | | | | | | | options are: | | | | | | | 0 = Output.C of the previous stage or height | | | | | | | if the first stage | | | | | | | 1 = Output.A of the previous stage or height | | | | | | | if the first stage | | | | | | | 2 = Color.C | | | | | | | 3 = Color.A | | | | | | | 4 = TextureCompositeFactor1C | | | | | | | 5 = TextureCompositeFactor1A | | | | | | | 6 = Texel0.C | | | | | | | 7 = Texel0.A | | | | | | | 8 = Texel1.C | | | | | | | 9 = Texel1.A | | | | | | | 10 = Sum of the color components of the | | | | | | | previous stage or 0 if the first stage. | | | | | | | where C is the RGB or A depending on the channel. | | | | | | | height is defined as clamp (Texel0.A - Texel1.A + | | | | | | | 128) | | 10 | InvertArg2 | 1 | 1 | х | This bit, if set, will invert the selected Arg2 value | | | 8 | • | • | ^ | before it is used. | | 1113 | I | 1 | 1 | х | This field selects what is used as the interpolation | | | | | • | A | factor when the Operation field is set to Lerp, | | | | | | | for example. The options are: | | | | | | | 0 = Output.A of the previous stage or 0 if the | | | | | | | first stage | | | | | | | 1 = Color.A | | | | | | | 2 = TextureCompositeFactor1.A | | | | | | | 3 = Texel0.A | | | | | | | 4 = Texel1.A | | | | | | | where C is the RGB or A depending on the channel. | | 14 | InvertI | 1 | 1 | х | This bit, if set, will invert the selected I value before it | | _ | | • | • | , x | is used. | | 15 | A | 1 | 1 | х | This bit selects which Arg (after any inversion) is to be | | | | • | • | ^ | used as A in the Operation. The options are: | | | | | | | $0 = \operatorname{Arg1}$ | | | | | | | 1 = Arg2 | | 16 | В | 1 | 1 | x | This bit selects which Arg (after any inversion) is to be | | | | • | • | l x | used as B in the Operation. The options are: | | | | | | | 0 = Arg1 | | | | | | | 1 = Arg2 | | | 1 | | | | | | 1720 | Operation | <b>✓</b> | | x | This field defines how the three inputs (A, B and I) are combined. Note the inputs can be optionally inverted before being combined. The 8 bit inputs are unsigned 0.8 fixed point format, but 255 is treated as if it were 1.0 for the calculations. The possible operations are: 0 = Pass (A) 1 = Add (A + B) 2 = AddSigned (A + B - 128) 3 = Subtract (A - B) 4 = Modulate (A * B) 5 = Lerp (A * (1.0 - I) + B * I) 6 = ModulateColorAddAlpha (A * B + I) 7 = ModulateAlphaAddColor (A * I + B) 8 = AddSmoothSaturate (A + B - A * B) 9 = ModulateSigned (A * B, but A and B are biased 8 bit numbers) | |------|-----------|----------|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2122 | Scale | 1 | ✓ | х | This field selects the scale factor to apply to the final result before it is clamped. The options are: $0 = 0.5$ $1 = 1$ $2 = 2$ $3 = 4$ | | 2331 | Reserved | 0 | 0 | X | | Notes: The Texture unit composites the fragment's Color, Texel0 and Texel1 values with one or two constant color values held in registers and passes the result on to the next unit as a texture value. The compositing is done in two stages and is controlled separately for the RGB channels and the Alpha channel. This register defines the operation for the alpha channels in compositing stage 0 for this unit. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. # TextureCompositeColorMode0And TextureCompositeColorMode0And TextureCompositeColorMode0Or | Name | Type | Offset | Format | |-----------------------|---------|--------|---------------------| | TextureCompositeColor | Texture | 0xB308 | Bitfield | | Mode0 | | | | | TextureCompositeColor | Texture | 0xB380 | Bitfield Logic Mask | | Mode0And 1 | | | 8 | | TextureCompositeColor | Texture | 0xB388 | Bitfield Logic Mask | | Mode0Or | | | 8 | | 111040001 | | | | Control registers | Bits | Name | Read | Write | Reset | Description | |------|------------|----------|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | X | When set causes the output to be calculated as defined by the fields in this register, otherwise the texel0 data is passed through for stage0 and Output data is passed through for stage 1. | | 14 | Arg1 | <b>1</b> | • | X | This field selects the source value for Arg1. The options are: 0 = Output.C of the previous stage or height if the first stage 1 = Output.A of the previous stage or height if the first stage 2 = Color.C 3 = Color.A 4 = TextureCompositeFactor0.C 5 = TextureCompositeFactor0.A 6 = Texel0.C 7 = Texel0.A 8 = Texel1.C 9 = Texel1.A 10 = Sum of the color components of the previous stage or 0 if the first stage. where C is the RGB or A depending on the channel. Height is defined as clamp (Texel0.A - Texel1.A + 128) | | 5 | InvertArg1 | 1 | ✓ | х | This bit, if set, will invert the selected Arg1 value before it is used. | | 69 | Arg2 | | | T | This field selects the source value for Arg2. The | |------|------------|----|----------|-----|--------------------------------------------------------------| | 00 | 11182 | • | • | X | options are: | | | | | | | 0 = Output.C of the previous stage or height | | | | | | | if the first stage | | | | | | | 1 = Output.A of the previous stage or height | | | | | | | if the first stage | | | | | | | 2 = Color.C | | | | | | | z = Color.C<br>3 = Color.A | | | | | | | | | | | | | | 4 = TextureCompositeFactor0.C | | | | | | | 5 = TextureCompositeFactor0.A | | | | | | | 6 = Texel0.C | | | | | | | 7 = Texel0.A | | | | | | | 8 = Texel1.C | | | | | | | 9 = Texel 1.A | | | | | | | 10 = Sum of the color components of the | | | | | | | previous stage or 0 if the first stage. | | | | | | | where C is the RGB or A depending on the channel. | | | | | | | height is defined as clamp (Texel0.A - Texel1.A + | | | | | | | 128) | | 10 | InvertArg2 | 1 | 1 | Х | This bit, if set, will invert the selected Arg2 value | | | | | • | 1. | before it is used. | | 1113 | I | 1 | 1 | х | This field selects what is used as the interpolation | | | | • | | 1 | factor when the Operation field is set to Lerp, for | | | | | | | example. The options are: | | | | | | | 0 = Output.A of the previous stage or 0 if the | | | | | | | first stage | | | | | | | 1 = Color.A | | | | | | | 2 = TextureCompositeFactor0.A | | | | | 1 | | 3 = Texel 0.A | | | | | 1 | | 4 = Texel 1.A | | | | | | | where C is the RGB or A depending on the channel. | | 14 | InvertI | 1 | 1 | v | This bit, if set, will invert the selected I value before it | | _ | | • | • | X | is used. | | 15 | Α | , | 1 | х | This bit selects which Arg (after any inversion) is to be | | | | 1 | <b>'</b> | , x | used as A in the Operation. The options are: | | | | | | | 0 = Arg1 | | | | | 1 | | 1 = Arg2 | | 16 | В | +, | 1 | 1 | This bit selects which Arg (after any inversion) is to be | | 10 | b | ✓ | <b>•</b> | X | used as B in the Operation. The options are: | | | | | | | 0 = Arg1 | | | | | | | 0 = Arg1 $1 = Arg2$ | | | | | | | $I = AIg \iota$ | | 1720 | Operation | <b>✓</b> | | x | This field defines how the three inputs (A, B and I) are combined. Note the inputs can be optionally inverted before being combined. The 8 bit inputs are unsigned 0.8 fixed point format, but 255 is treated as if it were 1.0 for the calculations. The possible operations are: 0 = Pass (A) 1 = Add (A + B) 2 = AddSigned (A + B - 128) 3 = Subtract (A - B) 4 = Modulate (A * B) 5 = Lerp (A * (1.0 - I) + B * I) 6 = ModulateColorAddAlpha (A * B + I) 7 = ModulateAlphaAddColor (A * I + B) 8 = AddSmoothSaturate (A + B - A * B) 9 = ModulateSigned (A * B, but A and B are biased 8 bit numbers) | |------|-----------|----------|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2122 | Scale | 1 | ✓ | х | This field selects the scale factor to apply to the final result before it is clamped. The options are: $0 = 0.5$ $1 = 1$ $2 = 2$ $3 = 4$ | | 2331 | Reserved | 0 | 0 | X | | Notes: The Texture unit composites the framgent's Color, Texel0 and Texel1 values with one or two constant color values held in registers and passes the result on to the next unit as a texture value. The compositing is done in two stages and is controlled separately for the RGB channels and the Alpha channel. This register defines the operation for the alpha channels in compositing stage 0 for this unit. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. ## TextureCompositeColorMode1And TextureCompositeColorMode1And TextureCompositeColorMode1Or | Name | Type | Offset | Format | |-----------------------|---------|--------|---------------------| | TextureCompositeColor | Texture | 0xB318 | Bitfield | | Mode1 | | | | | TextureCompositeColor | Texture | 0xB3A0 | Bitfield Logic Mask | | Mode1And 1 | | | 8 | | TextureCompositeColor | Texture | 0xB3A8 | Bitfield Logic Mask | | Mode1Or | | | 8 | | | | | | Control registers | Bits | Name | Read | Write | Reset | Description | |------|------------|------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | X | When set causes the output to be calculated as defined<br>by the fields in this register, otherwise the texel0 data<br>is passed through for stage0 and Output data is passed<br>through for stage 1. | | 14 | Arg1 | | • | х | This field selects the source value for Arg1. The options are: 0 = Output.C of the previous stage or height if the first stage 1 = Output.A of the previous stage or height if the first stage 2 = Color.C 3 = Color.A 4 = TextureCompositeFactor1.C 5 = TextureCompositeFactor1.A 6 = Texel0.C 7 = Texel0.A 8 = Texel1.C 9 = Texel1.A 10 = Sum of the color components of the previous stage or 0 if the first stage. where n is the same as the message suffix and C is the RGB or A depending on the channel. height is defined as clamp (Texel0.A - Texel1.A + 128) | | 5 | InvertArg1 | 1 | 1 | х | This bit, if set, will invert the selected Arg1 value before it is used. | | 69 | Arg2 | , | | 1 | This field selects the source value for Arg2. The | |------|------------|--------------|----------|----------|--------------------------------------------------------------| | 00 | 11152 | ✓ | <b>√</b> | X | options are: | | | | | | | 0 = Output.C of the previous stage or height | | | | | | | if the first stage | | | | | | | 1 = Output.A of the previous stage or height | | | | | | | if the first stage | | | | | | | 2 = Color.C | | | | | | | z = Color.C<br>3 = Color.A | | | | | | | | | | | | | | 4 = TextureCompositeFactor1.C | | | | | | | 5 = TextureCompositeFactor1.A | | | | | | | 6 = Texel0.C | | | | | | | 7 = Texel0.A | | | | | | | 8 = Texel1.C | | | | | | | 9 = Texel 1.A | | | | | 1 | | 10 = Sum of the color components of the | | | | | | | previous stage or 0 if the first stage. | | | | | | | where C is the RGB or A depending on the channel. | | | | | | | height is defined as clamp (Texel0.A - Texel1.A + | | | | | | | 128) | | 10 | InvertArg2 | 1 | 1 | х | This bit, if set, will invert the selected Arg2 value | | | | | • | | before it is used. | | 1113 | I | 1 | 1 | х | This field selects what is used as the interpolation | | | | • | | , a | factor when the Operation field is set to Lerp, for | | | | | | | example. The options are: | | | | | | | 0 = Output.A of the previous stage or 0 if the | | | | | | | first stage | | | | | | | 1 = Color.A | | | | | | | 2 = TextureCompositeFactor1.A | | | | | | | 3 = Texel0.A | | | | | 1 | | 4 = Texel 1.A | | | | | | | where C is the RGB or A depending on the channel. | | 14 | InvertI | 1 | 1 | х | This bit, if set, will invert the selected I value before it | | _ | | • | • | l X | is used. | | 15 | Α | , | 1 | х | This bit selects which Arg (after any inversion) is to be | | | | <b>•</b> | <b>'</b> | l X | used as A in the Operation. The options are: | | | | | | | 0 = Arg1 | | | | | 1 | | 1 = Arg2 | | 16 | В | <del> </del> | 1 | <u> </u> | This bit selects which Arg (after any inversion) is to be | | 10 | b | ✓ | <b>•</b> | X | used as B in the Operation. The options are: | | | | | | | 0 = Arg1 | | | | | | | 0 = Arg1 $1 = Arg2$ | | | | | | 1 | I = AIgL | | 1720 | Operation | | | X | This field defines how the three inputs (A, B and I) are combined. Note the inputs can be optionally inverted before being combined. The 8 bit inputs are unsigned 0.8 fixed point format, but 255 is treated as if it were 1.0 for the calculations. The possible operations are: 0 = Pass (A) 1 = Add (A + B) 2 = AddSigned (A + B - 128) 3 = Subtract (A - B) 4 = Modulate (A * B) 5 = Lerp (A * (1.0 - I) + B * I) 6 = ModulateColorAddAlpha (A * B + I) 7 = ModulateAlphaAddColor (A * I + B) 8 = AddSmoothSaturate (A + B - A * B) 9 = ModulateSigned (A * B, but A and B are biased 8 bit numbers) | |------|-----------|---|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2122 | Scale | 1 | 1 | х | This field selects the scale factor to apply to the final result before it is clamped. The options are: $0 = 0.5$ $1 = 1$ $2 = 2$ $3 = 4$ | | 2331 | Reserved | 0 | 0 | X | | Notes: The Texture unit composites the fragment's Color, Texel0 and Texel1 values with one or two constant color values held in registers and passes the result on to the next unit as a texture value. The compositing is done in two stages and is controlled separately for the RGB channels and the Alpha channel. This register defines the operation for the alpha channels in compositing stage 0 for this unit. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. #### TextureCompositeFactor0 | Name | Туре | Offset | Format | |-------------------------|---------|--------|----------| | TextureCompositeFactor0 | Global | 0xB328 | Bitfield | | - | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|-------------| | 07 | red | 1 | 1 | X | red | | 815 | green | 1 | 1 | x | green | | 1623 | blue | ✓ | 1 | X | blue | | 2431 | alpha | 1 | 1 | X | alpha | Notes: The Texture unit composites the fragment's Color, Texel0 and Texel1 values with one or two constant color values held in registers and passes the result on to the next unit as a texture value. The compositing is done in two stages and is controlled separately for the RGB channels and the Alpha channel. This register holds the constant factor to use with compositing stage 0. #### TextureCompositeFactor1 | Name | Туре | Offset | Format | |-------------------------|---------|--------|----------| | TextureCompositeFactor1 | Texture | 0xB330 | Bitfield | | - | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|-------------| | 07 | red | ✓ | 1 | x | red | | 815 | green | 1 | ✓ | x | green | | 1623 | blue | 1 | ✓ | X | blue | | 2431 | alpha | 1 | 1 | X | alpha | Notes: The Texture unit composites the Color, Texel0 and Texel1 from a step message with one or two constant color values held in registers and passes the result on to the next unit as a texture value. The compositing is done in two stages and is controlled separately for the RGB channels and the Alpha channel. This register holds the constant factor to use with compositing stage 1. #### **TextureCompositeMode** | Name | Туре | Offset | Format | |----------------------|---------|--------|----------| | TextureCompositeMode | Texture | 0xB300 | Bitfield | | • | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|------|-------|-------|-----------------------------------------------| | 0 | Enable | ✓ | ✓ | X | Global enable/disable for Texture Composition | | 131 | Unused | 0 | 0 | X | | Notes: Global enable/disable for Texture Composite operation. Setting Bit0 causes the compositing operation to be calculated and to replace the texture0 value sent to the next unit, otherwise the texture value remains unchanged. This enable is also qualified by the TextureEnable bit in the *Render* command. #### TextureCoordModeAnd TextureCoordModeAnd TextureCoordModeOr | Name | Туре | Offset | Format | |---------------------|------------------|--------|----------| | TextureCoordMode | Texture | 0x8380 | Bitfield | | TextureCoordModeAnd | Texture | 0xAC20 | Bitfield | | TextureCoordModeOr | Texture | 0xAC28 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------------------------|------|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | х | When set causes the output to be calculated as defined by the fields in this register, otherwise the output values are set to zero. The TextureEnable bit in the Render command must also be set to enable this unit. | | 12 | WrapS | ✓ | 1 | х | This field determines how the s coordinate is brought into the range 0.01.0 when it is outside this range. The options are: 0 = Clamp 1 = Repeat 2 = Mirror | | 34 | WrapT | 1 | 1 | х | This field determines how the t coordinate is brought into the range 0.01.0 when it is outside this range. The options are: 0 = Clamp 1 = Repeat 2 = Mirror | | 5 | Operation | 1 | 1 | x | This bit selects if the texture coordinates are to be treated as 2D coordinates and ignore perspective correction, or a 3D coordinates and be perspectively corrected. 0 = 2D mode 1 = 3D mode When reset the addresses are calculated in '2D mode' so no perspective correction is done. This will typically run twice as fast as '3D mode' where perspective correction is done. In the 2D case the wrap operation is always "repeat" as the DDA units are allowed to wrap around and have the fixed 0.32 fixed point format. Level of detail calculation is not done in 2D mode. | | 6 | InhibitDDAInit ialisation | ✓ | 1 | х | This bit, when set, prevents the DDA from being updated from the Start registers at the start of a primitive. This is useful when the texture mapping is being used to provide the pattern or stipple along a polyline and it is desirable that the pattern continues smoothly from one line to the next. | | 7 | EnableLOD | 1 | 1 | х | This bit, when set, causes the level of detail calculation to be calculated. This also involves setting the start values of the S1, T1 and Q1 DDAs as a function of the DY gradients and the S, T and Q start values. | |------|---------------------|----------|---|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 8 | EnableDY | 1 | 1 | х | This bit, when set, causes the DY gradients of S, T and Q to be calculated, otherwise they are provided by some external source. | | 912 | Width | 1 | 1 | x | This field holds the width, as a power of 2, of the highest resolution texture map when mip mapping. Its legal range is 011 inclusive and is only used when the EnableLOD bit is 1. | | 1316 | Height | 1 | 1 | x | This field holds the height, as a power of 2, of the highest resolution texture map when mip mapping. Its legal range is 011 inclusive and is only used when the EnableLOD bit is 1. | | 17 | Type | <b>√</b> | 1 | X | This bit selects type of texture map and is only used to disable the t derivatives from influencing the level of detail calculations when a 1D texture map is being used. $0 = 1D$ map $1 = 2D$ map | | 1819 | WrapS1 | 1 | 1 | X | This field determines how the s1 coordinate is brought into the range 0.01.0 when it is outside this range. The options are: 0 = Clamp 1 = Repeat 2 = Mirror | | 2021 | WrapT1 | 1 | 1 | х | This field determines how the t1 coordinate is brought into the range 0.01.0 when it is outside this range. The options are: 0 = Clamp 1 = Repeat 2 = Mirror | | 22 | Duplicate<br>Coords | 1 | 1 | Х | This bit, when set, causes any loading one of the DDA start, dx or dyDom registers to load the corresponding registers for both texture 0 and texture 1 DDA | | 2331 | Uused | 0 | 0 | X | | Notes: Provides overall control of the generation of texel addresses. #### **TextureEnvColor** | Name | Туре | Offset | Format | |-------------------------|------------------|--------|----------| | TextureEnvironmentColor | Texture | 0x8688 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 07 | R | 1 | 1 | Х | Red | | 815 | G | 1 | 1 | X | Green | | 1623 | В | 1 | 1 | X | Blue | | 2431 A | 1 | 1 | X | Alpha | |--------|---|---|---|-------| |--------|---|---|---|-------| Notes: Constant color value used in blend texturing mode.. ### TextureFilterModeAnd TextureFilterModeOr | Name | Туре | Offset | Format | |-------------------|-------------|--------|----------| | TextureFilterMode | Alpha Blend | 0x84E0 | Bitfield | TextureFilterModeAnd Alpha Blend 0xAD50 Bitfield Logic Mask ChromaTestModeOr Alpha Blend 0xAD58 Bitfield Logic Mask **Control registers** | Bits | Name | Read<br>33 | Write | Reset | Description | |------|---------------------|------------|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | х | When set causes the output to be calculated as defined by the fields in this register, otherwise the texel0 and texel1 values are set to zero. The TextureEnable bit in the <i>Render</i> command must also be set to enable this unit. | | 14 | Format0 | <b>✓</b> | <b>✓</b> | x | This field selects the format of the texel data T0T3. The options are 0 = A4L4 1 = L8 2 = I8 3 = A8 4 = 332 5 = A8I8 6 = 5551 7 = 565 8 = 4444 9 = 888 10 = 8888 or YUV | | 5 | ColorOrder0 | ✓ | 1 | х | This bit selects the color component order of the texel data T0T3. The two options are: 0 = AGBR 1 = ARGB | | 6 | AlphaMapEnab<br>le0 | 1 | 1 | х | This bit, when set, enables the alpha value of texels T0T3 to be forced to zero based on testing the color values. | | 7 | AlphaMapSense<br>0 | ✓ | 1 | х | This bit selects if the alpha value for texels T0T3 should be set to zero when the colors are in range or out of range. The options are: 0 = Out of range 1 = In range | | 8 | Combine<br>Caches | ✓ | 1 | х | This bit, when set, combines both banks of the cache so they are used for texture 0. This is an optimisation and allows larger textures to be handled before scanline coherency starts to break down. | $<sup>^{</sup>m 33}$ Logic Op register readback is via the main register only 3Dlabs Proprietary and Confidential 5-193 | 0 19 | Format1 | | 1 - | 1 | This field selects the format of the toyal deta T4 T7 | |------|----------------|---|----------|----------|---------------------------------------------------------| | 912 | Format1 | ✓ | ✓ | X | This field selects the format of the texel data T4T7. | | | | | | | The options are | | | | | | | 0 = A4L4 | | | | | | | 1 = L8 | | | | | | | 2 = I8 | | | | | | | 3 = A8 | | | | | | | 4 = 332 | | | | | | | 5 = A8I8 | | | | | | | 6 = 5551 | | | | | | | 7 = 565 | | | | | | | 8 = 4444 | | | | | | | 9 = 888 | | | | | | | 10 = 8888 or YUV | | 10 | ColorOrder1 | | | | | | 13 | ColorOrder1 | ✓ | ✓ | X | This bit selects the color component order of the texel | | | | | | | data T4T7. The two options are: | | | | | | | 0 = AGBR | | | | | | | 1 = ARGB | | 14 | AlphaMapEnab | 1 | 1 | X | This bit, when set, enables the alpha value of texels | | | le1 | Ŭ | • | | T4T7 to be forced to zero based on testing the | | | | | | | color values. | | 15 | AlphaMapSense | 1 | 1 | х | This bit selects if the alpha value for texels T4T7 | | | 1 | • | • | ^ | should be set to zero when the colors are in range or | | | | | | | out of range. The options are: | | | | | | | 0 = Out of range | | | | | | | 1 = In range | | 16 | AlphaMapEiltan | | | | This bit when set will allow the alpha manned toyals | | 16 | AlphaMapFilter | ✓ | ✓ | X | This bit, when set, will allow the alpha mapped texels | | | ing | | | | (AlphaMapEnable must be set) to cause the fragment | | | | | | | to be discarded depending on the comparison of the | | | | | | | number of texels to be alpha mapped with the | | | | | | | following three limit fields. | | 1719 | AlphaMapFilter | 1 | 1 | X | This field holds the number of alpha mapped texels in | | | Limit0 | - | | | the group T0T3 which must be exceeded for the | | | | | | | fragment to be discarded. | | 2022 | AlphaMapFilter | 1 | 1 | х | This field holds the number of alpha mapped texels in | | | Limit1 | • | • | ^ | the group T4T7 which must be exceeded for the | | | | | | | fragment to be discarded. | | 2326 | AlphaMapFilter | 1 | , | v | This field holds the number of alpha mapped texels in | | 2020 | Limit01 | ✓ | ✓ | X | the group T0T7 which must be exceeded for the | | | Lillitoi | | | | fragment to be discarded. | | 97 | MultiTest | - | _ | ļ | | | 27 | MultiTexture | ✓ | ✓ | X | This bit, when set, prevents the Alpha Map Filtering | | | | | | | logic from testing the I4 interpolant and maybe | | | | | | | disregarding the alpha map result of T0T3 or | | | | | | | T4T7. This bit should be set for multi texture | | | | | | | operation when alpha map filtering is required. It | | | | | | | should be clear otherwise. | | 28 | ForceAlphaTo | 1 | 1 | х | This bit, when set, will force the alpha channel of | | | One0 | | • | ^ | T0T3 to be set to 1.0 (255) regardless of the color | | | | | | | format or the presence of a real alpha channel. | | 29 | ForceAlphaTo | , | , | v | This bit, when set, will force the alpha channel of | | ~0 | One1 | ✓ | ✓ | X | T4T7 to be set to 1.0 (255) regardless of the color | | | One i | | | | format or the presence of a real alpha channel. | | | | | <u> </u> | <u> </u> | TOTHIAL OF THE PIESCHICE OF A TEAL AIPHA CHAIHIEL. | | 30 | Shift0 | | This bit, when set, causes the conversion of T0T3 | |----|--------|--|-------------------------------------------------------| | | | | for color components less than 8 bits wide to be done | | | | | by a shift operation, otherwise a scale operation is | | | | | needed. The shift operation is useful where the exact | | | | | color (after dithering) is to be preserved for flat | | | | | shaded areas, such as in a stretch blit. | | 31 | Shift1 | | This bit, when set, causes the conversion of T4T7 | | | | | for color components less than 8 bits wide to be done | | | | | by a shift operation, otherwise a scale operation is | | | | | needed. The shift operation is useful where the exact | | | | | color (after dithering) is to be preserved for flat | | | | | shaded areas, such as in a stretch blit. | Notes: The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. #### TextureIndexMode0 TextureIndexMode0And TextureIndexMode0Or | Name | Туре | Offset | Format | | |-------------------|---------|--------|----------|--| | TextureIndexMode0 | Texture | 0xB338 | Bitfield | | | | | | | | TextureIndexMode0And Texture 0xB3C0 Bitfield Logic Mask TextureIndexMode0Or Texture 0xB3C8 Bitfield Logic Mask **Control registers** | Bits | Name | Read<br>34 | Write | Reset | Description | |------|-------------------------|------------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | х | When set causes the output to be calculated as defined<br>by the fields in this register, otherwise the fragment's<br>index and interpolation data is set to zero. | | 14 | Width | 1 | 1 | х | This field holds the width of the map as a power of two. The legal range of values for this field is 0 (map width = 1) to 11 (map width = 2048). | | 58 | Height | 1 | 1 | х | This field holds the height of the map as a power of two. The legal range of values for this field is 0 (map width = 1) to 11 (map width = 2048). | | 9 | Border | 1 | 1 | х | This bit, when set indicates there is a one texel border surrounding the texture map. | | 1011 | WrapU | <b>√</b> | 1 | х | This field selects how the u coordinate is to be wrapped to fit on the texture map. The options are: 0 = Clamp 1 = Repeat 2 = Mirror 3 = ClampEdge | | 1213 | WrapV | 1 | 1 | x | This field selects how the v coordinate is to be wrapped to fit on the texture map. The options are: 0 = Clamp 1 = Repeat 2 = Mirror 3 = ClampEdge | | 14 | МарТуре | 1 | 1 | х | This bit selects the type of texture map. The options are $0 = 1D$ $1 = 2D$ | | 15 | MagnificationFi<br>lter | 1 | 1 | Х | This field selects the magnification filter to use. The options are $0 = \text{Nearest}$ $1 = \text{Linear}$ | $<sup>^{34}</sup>$ Logic Op register readback is via the main register only | 1618 | MinificationFilt | 1 | 1 | x | This field selects the minification filter to use. The | |------|------------------|---|----------|---|------------------------------------------------------------------| | | er | • | • | X | options are | | | | | | | 0 = Nearest | | | | | | | 1 = Linear | | | | | | | 2 = NearestMipNearest | | | | | | | 3 = NearestMipLinear | | | | | | | 4 = LinearMipNearest | | | | | | | 5 = LinearMipLinear | | | | | | | This field only has an effect when Texture3DEnable | | | | | | | or MipMapEnable are true. | | 19 | Texture3DEna | , | , | | This bit, when set, enables 3D texture index | | 10 | ble | ✓ | ✓ | X | generation. | | 20 | MipMapEnable | , | , | | This bit, when set, enables mip map index generation. | | 2122 | NearestBias | ✓ | <b>√</b> | X | This field defines the bias to add to the u and or v | | 2122 | ivealestbias | ✓ | ✓ | X | | | | | | | | coordinates (after the map's width and height have | | | | | | | been taken into account) for nearest neighbour | | | | | | | filtering. This can be used to move the texel sample | | | | | | | point. The options are: $0 = -0.5$ | | | | | | | 1 | | | | | | | 1 = 0 Use this for OpenGL<br>2 = +0.5 | | 2324 | LinearBias | | | | z = +0.5<br>This field defines the bias to add to the u and or v | | 2324 | Linearbias | ✓ | ✓ | X | | | | | | | | coordinates (after the map's width and height have | | | | | | | been taken into account) for linear filtering. This can | | | | | | | be used to move the texel sample point. The options | | | | | | | are: | | | | | | | 0 = -0.5 Use this for OpenGL<br>1 = 0 | | | | | | | 1 | | 0.5 | C T IT | | 1 | | 2 = +0.5 | | 25 | SourceTexelEn | ✓ | ✓ | X | When set this bit causes the calculated index (i0, j0) to | | | able | | | | be passed to the Framebuffer Read Unit to be used as | | | | | | | a source pixel coordinates. This allows the | | | | | | | framebuffer to do stretch blits, rotates, etc. | | 2631 | Reserved | 0 | 0 | X | | Notes: The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. #### TextureIndexMode1 TextureIndexMode1And TextureIndexMode1Or | Name | Туре | Offset | Format | |-------------------|---------|--------|----------| | TextureIndexMode1 | Texture | 0xB340 | Bitfield | TextureIndexMode1And Texture 0xB3D0 Bitfield Logic Mask TextureIndexMode1Or Texture 0xB3D8 Bitfield Logic Mask **Control registers** | Bits | Name | Read<br>35 | Write | Reset | Description | |------|-------------------------|------------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | х | When set causes the output to be calculated as defined<br>by the fields in this register, otherwise the fragment's<br>index and interpolation data is set to zero. | | 14 | Width | 1 | 1 | х | This field holds the width of the map as a power of two. The legal range of values for this field is 0 (map width = 1) to 11 (map width = 2048). | | 58 | Height | 1 | 1 | х | This field holds the height of the map as a power of two. The legal range of values for this field is 0 (map width = 1) to 11 (map width = 2048). | | 9 | Border | 1 | 1 | х | This bit, when set indicates there is a one texel border surrounding the texture map. | | 1011 | WrapU | 1 | 1 | х | This field selects how the u coordinate is to be wrapped to fit on the texture map. The options are: 0 = Clamp 1 = Repeat 2 = Mirror 3 = ClampEdge | | 1213 | WrapV | 1 | 1 | х | This field selects how the v coordinate is to be wrapped to fit on the texture map. The options are: 0 = Clamp 1 = Repeat 2 = Mirror 3 = ClampEdge | | 14 | МарТуре | 1 | 1 | х | This bit selects the type of texture map. The options are $0 = 1D$ $1 = 2D$ | | 15 | MagnificationFi<br>lter | 1 | 1 | Х | This field selects the magnification filter to use. The options are $0 = \text{Nearest} \\ 1 = \text{Linear}$ | $<sup>^{35}</sup>$ Logic Op register readback is via the main register only | filter to use. The | |---------------------------| | inter to use. The | | | | | | est | | r | | it | | ol. | | n Teatum 2DEnoble | | n Texture3DEnable | | | | | | map index generation. | | l to the u and or v | | th and height have | | rest neighbour | | ove the texel sample | | • | | | | OpenGL | | 1 | | l to the u and or v | | th and height have | | ar filtering. This can | | le point. The options | | · r · · · · · · · · · · · | | OpenGL . | | - T · | | | | ulated index (i0, j0) to | | ead Unit to be used as | | allows the | | otates, etc. | | | | | Notes: The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. #### **TextureLodBiasS** | Name | Type | Offset | Format | |-----------------|------------------|--------|-------------| | TextureLodBiasS | Texture | 0x8450 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 07 | Fraction | 1 | ✓ | x | | | 812 | Integer | ✓ | ✓ | X | | | 1231 | Reserved | 0 | 0 | X | | Notes: This register holds the 2's complement bias value in 5.8 fixed point format for the S components in the level of detail calculation. Its default value should be zero #### **TextureLodBiasT** | Name | Type | Offset | Format | |-----------------|------------------|--------|-------------| | TextureLodBiasT | Texture | 0x8458 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|----------|----------|-------|-------------| | 07 | Fraction | <b>√</b> | <b>√</b> | X | | | 812 | Integer | ✓ | ✓ | X | | | 1231 | Reserved | 0 | 0 | X | | Notes: This register holds the 2's complement bias value in 5.8 fixed point format for the T components in the level of detail calculation. Its default value should be zero #### **TextureLODScale** | Name | Type | Offset | Format | |-----------------|------------------|--------|--------| | TextureLODScale | Texture | 0x9340 | Float | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|-----------------------| | 031 | Scale values | 1 | 1 | X | 32 bit floating point | Notes: Holds the scale values used when calculating the level of detail for a whole triangle. IEEE single precision floating point value #### **TextureLODScale1** | Name | Туре | Offset | Format | |------------------|------------------|--------|--------| | TextureLODScale1 | Texture | 0x9348 | Float | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|-----------------------| | 031 | Scale values | 1 | 1 | X | 32 bit floating point | Notes: Holds the scale values used when calculating the level of detail for a whole triangle. IEEE single precision floating point value #### **TextureMapSize** | Name | Type | Offset | Format | |----------------|------------------|--------|---------| | TextureMapSize | Texture | 0xB428 | Integer | | _ | Control register | | _ | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------| | 023 | Offset | 1 | 1 | X | 24 bit unsigned integer | | 2431 | Reserved | 0 | 0 | X | | Notes: This register holds the texel offset between adjacent 2D slices in a 3D texture map. It is a 24 bit unsigned number. #### TextureMapWidth[0...15] | Name | Type | Offset | Format | |----------------------|------------------|--------|----------| | TextureMapWidth[015] | Texture | 0x8580 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|---------------|------|-------|-------|------------------------------| | 011 | Width | 1 | 1 | 0 | Width (excluding any border) | | 12 | Border enable | 1 | 1 | 0 | Border present, if set | | 1314 | Layout | 1 | 1 | 0 | Layout | | 15 | Host Texture | 1 | 1 | 0 | HostTexture enabled if set | Notes: These registers hold the width, border, layout and memory type for of each mip map level: - The width is normally the power of 2 width corresponding to the level, but can be any value in the range 0...4095. - If a border is present then all mip levels should have the bit set. - The layout field selects the layout of the texel data in memory for the texture map using *TextureBaseAddr0* register. The options are: 0 = Linear 1 = Patch64 Color buffer 2 = Patch32\_2 Large texture maps 3 = Patch2 Small texture maps • The HostTexture bit is only used if the texture is a physical texture. Logical textures use a bit in the Logical Page Table to identify if a texture is a Host Texture. #### TextureReadMode0And TextureReadMode0And TextureReadMode0Or NameTypeOffsetFormatTextureReadMode0Texture0xB400Bitfield TextureReadMode0And Texture 0xAC30 Bitfield Logic Mask TextureReadMode0Or Texture 0xAC38 Bitfield Logic Mask Control registers | Bits | Name | Read<br>36 | Write | Reset | Description | |------|-------------------|------------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | х | When set causes any texels needed by the fragment to be read. This is also qualified by the TextureEnable bit in the <i>Render</i> command. | | 14 | Width | 1 | 1 | х | This field holds the width of the map as a power of two. The legal range of values for this field is 0 (map width = 1) to 11 (map width = 2048). This is only used when Texture3D is enabled and then is only used for cache management purposes and <i>not</i> for address calculations. | | 58 | Height | ✓ | 1 | X | This field holds the height of the map as a power of two. The legal range of values for this field is 0 (map height = 1) to 11 (map height = 2048). This is only used when Texture3D is enabled and then is only used for cache management purposes and <i>not</i> for address calculations. | | 910 | TexelSize | 1 | 1 | X | This field holds the size of the texels in the texture map. The options are: $0 = 8 \text{ bits}$ $1 = 16 \text{ bits}$ $2 = 32 \text{ bits}$ $3 = 64 \text{ bits (Only valid for spans)}$ | | 11 | Textue3D | 1 | 1 | х | This bit, when set, enables 3D texture index generation. The CombinedCache mode bit should not be set when 3D textures are being used. | | 12 | Combine<br>Caches | 1 | 1 | х | This bit, when set, causes the two banks of the Primary Cache to be joined together, thereby increasing the size of a single texture map which can be efficiently handled. | | 1316 | MapBaseLevel | 1 | 1 | х | This field defines which TextureBaseAddr register should be used to hold the address for map level 0 when mip mapping or the texture map when not mip mapping. Successive map levels are at increasing TextureBaseAddr registers upto (and including) the MaxMaxLevel (next field). 3D textures always use TextureBaseAddr0. | 3Dlabs Proprietary and Confidential 5-203 $<sup>^{36}\,\</sup>mathrm{Logic}$ Op register readback is via the main register only | 1720 | MapMaxLevel | 1 | 1 | х | This field defines the maximum TextureBaseAddr register this texture should use when mip mapping. Any attempt to use beyond this level will clamp to this level. | |------|----------------|---|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 21 | LogicalTexture | 1 | 1 | х | This bit, when set, defines this texture or all mip map levels, if mip mapping, to be logically mapped so undergo logical to physical translation of the texture addresses. | | 22 | Origin | ✓ | 1 | X | This field selects where the origin is for a texture map with a Linear or Patch64 layout. The options are: 0 = Top Left. 1 = Bottom Left A Patch32_2 or Patch2 texture map is always bottom left origin. | | 2324 | TextureType | 1 | 1 | х | This field defines any special processing needed on the texel data before it can be used. The options are: 0 = Normal. | | 2527 | ByteSwap | 1 | 1 | x | This field defines the byte swapping, if any, to be done on texel data when it is used as a bitmap. This is automatically done when spans are used. Bit 27, when set, causes adjacent bytes to be swapped, bit 26 adjacent 16 bit words to be swapped and bit 27 adjacent 32 bit words to be swapped. In combination this byte swap the input (ABCDEFGH) as follows: 0 ABCDEFGH 1 BADCFEHG 2 CDABGHEF 3 ABCDEFGH 4 EFGHABCD 5 FEHGBADC 6 GHEFCDAB 7 HGFEDCBA | | 28 | Mirror | 1 | 1 | х | This bit, when set will mirror any bitmap data. This only works for spans. | | 29 | Invert | ✓ | 1 | х | This bit, when set will invert any bitmap data. This only works for spans. | | 30 | OpaqueSpan | 1 | 1 | х | This bit, when set, will cause the Span color mask to be modified rather than the pixel mask | | 31 | Reserved | 0 | 0 | Х | | Notes: The unit is controlled by the <code>TextureReadMode0</code> and <code>TextureReadMode1</code> registers for texture 0 and texture 1 respectively. Not all combinations of modes across both registers are supported and where there is a clash the modes in <code>TextureReadMode0</code> take priority. For per pixel mip mapping the <code>TextureRead0</code> and <code>TextureReadMode1</code> register should be set up the same as should the <code>TextureMapWidth0</code> and <code>TextureMapWidth1</code> registers. N.B. The layout and use of the *TextureReadMode* register is not compatible with GLINT MX: 1, 2, and 4 bit textures are no longer supported. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. # TextureReadMode1 TextureReadMode1And TextureReadMode1Or NameTypeOffsetFormatTextureReadMode1Texture0xB408Bitfield TextureReadMode1And Texture 0xAD40 Bitfield Logic Mask TextureReadMode1Or Texture 0xAD48 Bitfield Logic Mask Control registers | Bits | Name | Read<br>37 | Write | Reset | Description | |--------|----------------|------------|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | X | When set causes any texels needed by the fragment to be read. This is also qualified by the TextureEnable bit in the <i>Render</i> command. | | 18 | Reserved | 1 | × | Х | | | 910 | TexelSize | 1 | 1 | х | This field holds the size of the texels in the texture map. The options are: $0 = 8 \text{ bits}$ $1 = 16 \text{ bits}$ $2 = 32 \text{ bits}$ $3 = 64 \text{ bits (Only valid for spans)}$ | | 11, 12 | Reserved | 1 | × | х | ` ' ' | | 1316 | MapBaseLevel | 1 | 1 | X | This field defines which TextureBaseAddr register should be used to hold the address for map level 0 when mip mapping or the texture map when not mip mapping. Successive map levels are at increasing TextureBase registers upto (and including) the MapMaxLevel (next field). 3D textures always use TextureBaseAddr0. | | 1720 | MapMaxLevel | 1 | 1 | Х | This field defines the maximum TextureBaseAddr register this texture should use when mip mapping. Any attempt to use beyond this level will clamp to this level. | | 21 | LogicalTexture | 1 | 1 | х | This bit, when set, defines this texture or all mip map levels, if mip mapping, to be logically mapped so undergo logical to physical translation of the texture addresses. | | 22 | Origin | 1 | 1 | х | This field selects where the origin is for a texture map with a Linear or Patch64 layout. The options are: 0 = Top Left. 1 = Bottom Left A Patch32_2 or Patch2 texture map is always bottom left origin. | 3Dlabs Proprietary and Confidential 5-205 $<sup>^{</sup>m 37}$ Logic Op register readback is via the main register only | 2324 | TextureType | • | <b>√</b> | x | This field defines any special processing needed on the texel data before it can be used. The options are: 0 = Normal. 1 = Eight bit indexed texture. 2 = Sixteen bit YVYU texture in 422 format. 3 = Sixteen bit VYUY texture in 422 format. | |------|-------------|----------|----------|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2527 | ByteSwap | <b>✓</b> | • | x | This field defines the byte swapping, if any, to be done on texel data when it is used as a bitmap. This is automatically done when spans are used. Bit 27, when set, causes adjacent bytes to be swapped, bit 26 adjacent 16 bit words to be swapped and bit 27 adjacent 32 bit words to be swapped. In combination this byte swap the input (ABCDEFGH) as follows: 0 ABCDEFGH 1 BADCFEHG 2 CDABGHEF 3 ABCDEFGH 4 EFGHABCD 5 FEHGBADC 6 GHEFCDAB 7 HGFEDCBA | | 28 | Mirror | 1 | 1 | X | This bit, when set, mirrors any bitmap data. This only works for spans. | | 29 | Invert | 1 | 1 | х | This bit, when set, inverts any bitmap data. This only works for spans. | | 30 | OpaqueSpan | 1 | 1 | х | This bit, when set, causes the Span color mask to be modified rather than the pixel mask. | | 31 | Reserved | 0 | 0 | Х | | Notes: Texture reading is controlled by the TextureReadMode0 and TextureReadMode1 registers for texture 0 and texture 1 respectively. Not all combinations of modes across both registers are supported and where there is a clash the modes in TextureReadMode0 take priority. For per pixel mip mapping the TextureRead0 and TextureReadMode1 register should be set up the same as should the TextureMapWidth0 and TextureMapWidth1 registers. Note: The layout and use of the *TextureReadMode* register is not compatible with GLINT MX: 1, 2, and 4 bit textures are no longer supported. The logic operator equivalents behave the same way but the new mode is AND'd or OR'd with the former mode before replacing it. ## **TouchLogicalPage** | Name | Туре | Offset | Format | |------------------|---------|--------|----------| | TouchLogicalPage | Texture | 0xB370 | Bitfield | | 6 6 | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|--------------|----------|-------|-------|-----------------------------------------------------------------------------------------------------| | 015 | logical page | 1 | 1 | X | The first Logical Page to mark as stale | | 1529 | count | <b>√</b> | 1 | X | The number of pages to mark as stale. | | 3031 | mode | ✓ | 1 | х | 0 = Make page(s) non resident<br>1 = Load page(s) unconditionally.<br>2 = Make page(s) non resident | | | | | | | 3 = Touch page(s) and load if not resident | Notes: This command can be used to touch or mark as non resident a range of pages in the Logical Page Table. This is useful for preloading and when editing texture maps. For preloading, the command allows you to preload only non-resident pages (mode 3). When editing, the command allows you to mark pages as stale without immediately reloading by setting the mode to "non resident" (mode 2). #### **TStart** | Name | Туре | Offset | Format | |--------|------------------|--------|-------------| | TStart | Texture | 0x83A0 | Fixed point | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------| | 0n | Fraction | ✓ | ✓ | X | | | n31 | Integer | 1 | 1 | X | | Notes: Initial T value for texture map. The format is 32 bit 2's complement fixed point numbers. The binary point is at an arbitrary location but must be consistent for all S, T and Q values. # **UpdateLineStippleCounters** | Type | Offset | Format | |---------|---------|----------| | Stipple | 0x81B8 | Bitfield | | | Stipple | -JP | | Bits | Name | Read | Write | Reset | Description | |------|-------------------------------|------|-------|-------|--------------------------------------------------------| | 0 | Update<br>Counters<br>Control | 1 | ✓ | X | 0=reset counters to 0<br>1=load from segment register. | | 131 | Reserved | 0 | 0 | X | | Notes: This *Command* updates the current line stipple counters: If bit 0 is zero then the counters are set to zero, otherwise they are loaded from the segment register. Useful in drawing stippled wide lines. # **UpdateLogicalTextureInfo** | Name | Туре | Offset | Format | |--------------------------|---------|--------|--------| | UpdateLogicalTextureInfo | Texture | 0xB368 | Tag | | | Command | | · · | | | Bits | Name | Read | Write | Reset | Description | |---|------|----------|------|-------|-------|-------------| | ĺ | 031 | Reserved | 0 | 0 | X | | Notes: This command updates the Logical Texture Page Table at the page previously set up in the SetLogicalPageInfo command. After the update has been done the logical page number is incremented. The Resident bit is cleared and the Length, MemoryPool, VirtualHostPage and HostPage are set up. V0FloatR V0FloatB V0FloatA V0FloatF V0FloatX V0FloatY V0FloatZ | Name | Туре | Offset | Format | |----------|-------|--------|--------| | V0FloatR | Delta | 0x91A8 | Float | | V0FloatG | Delta | 0x91B0 | Float | | V0FloatB | Delta | 0x91B8 | Float | | V0FloatA | Delta | 0x91C0 | Float | | V0FloatF | Delta | 0x91C8 | Float | | V0FloatX | Delta | 0x91D0 | Float | | V0FloatY | Delta | 0x91D8 | Float | | V0FloatZ | Delta | 0x91E0 | Float | #### Control registers | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|----------------------------------------------| | 031 | | 1 | 1 | X | Vertex RGB color, alpha, fog, X, Y and depth | Notes: The R, G, B, Alpha, Fog, X, Y coordinates and Depth values for vertex 0 as IEEE single-precision floating point numbers. # V0FloatKdR V0FloatKdG V0FloatKdB | Name | Type | Offset | Format | |------------|-------|--------|--------| | V0FloatKdR | Delta | 0x9068 | Float | | V0FloatKdG | Delta | 0x9070 | Float | | V0FloatKdB | Delta | 0x9078 | Float | #### **Control registers** | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|------------------------------| | 031 | Diffuse | ✓ | ✓ | X | Vertex diffuse texture value | Notes: The diffuse KdR, G and B texture values for vertex 0 as IEEE single-precision floating point numbers. # V0FloatKsR V0FloatKsG V0FloatKsB | Name | Туре | Offset | Format | |------------|-------|--------|--------| | V0FloatKsR | Delta | 0x9050 | Float | | V0FloatKsG | Delta | 0x9058 | Float | | V0FloatKsB | Delta | 0x9060 | Float | #### **Control registers** | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------------| | 031 | Specular | 1 | 1 | X | Vertex specular texture value | Notes: The specular KsR, G and B texture values for vertex 0 as IEEE single-precision floating point numbers. #### V0FloatPackedColor NameTypeOffsetFormatV0FloatPackedColorDelta0x91F0BitfieldControl register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 07 | R | 0 | 1 | Х | | | 815 | G | 0 | 1 | x | | | 1623 | В | 0 | 1 | x | | | 2431 | A | 0 | 1 | X | | Notes: Vertex 0 color definition - the packed color registers hold the red, green, blue and alpha components in the same 32 bit word. When written to, the components are separated, converted to floating point format, and loaded into the registers. The color order in the registers is set by bit 18 in the *DeltaMode* register: Bit31... Bit0 0 = Alpha (or Fog), Blue, Green, Red 1 = Alpha (or Fog), Red, Green, Blue Reading back from the packed color registers returns zero. #### **V0FloatPackedDiffuse** NameTypeOffsetFormatV0FloatPackedDiffuseDelta0x9048BitfieldControl register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 07 | R | 0 | 1 | X | | | 815 | G | 0 | 1 | X | | | 1623 | В | 0 | 1 | X | | | 2431 | A | 0 | 1 | X | | Notes: The color order in the registers is set by bit 18 in the *DeltaMode* register: Bit31... Bit0 0 = Alpha (or Fog), Blue, Green, Red 1 = Alpha (or Fog), Red, Green, Blue Reading back from the packed color registers returns zero. # V0FloatPackedSpecularFog | Name | Type | Offset | Format | |--------------------------|------------------|--------|----------| | V0FloatPackedSpecularFog | Delta | 0x91F8 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 07 | R | 0 | 1 | Х | | | 815 | G | 0 | 1 | x | | | 1623 | В | 0 | 1 | x | | | 2431 | Fog | 0 | 1 | X | | Notes: Vertex 0 specular definition - packed specular registers are treated in the same way as packed color registers: the RGB components are separated, converted to the internal floating point format, and loaded into the registers. When loaded from a packed register, the specular range is 0 to 1.0. The A component is converted into an internal format and loaded into the fog register - when loaded from the packed register, the fog range is 0 to 1.0. The color order in the registers is set by bit 18 in the DeltaMode register: Bit31... Bit0 0 = Alpha (or Fog), Blue, Green, Red 1 = Alpha (or Fog), Red, Green, Blue Reading back from the packed color registers returns zero. # V0FloatS V0FloatT V0FloatQ | Name | Туре | Offset | Format | |----------|-------|--------|--------| | V0FloatS | Delta | 0x9180 | Float | | V0FloatT | Delta | 0x9188 | Float | | V0FloatQ | Delta | 0x9190 | Float | #### **Control registers** | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|-----------------------| | 031 | Texture | ✓ | ✓ | X | Vertex texture values | Notes: The texture S, T and Q values for vertex 0 as IEEE single-precision floating point numbers. # V0FloatS1 V0FloatT1 V0FloatQ1 | Name | Туре | Offset | Format | |-----------|-------|--------|--------| | V0FloatS1 | Delta | 0x9000 | Float | | V0FloatT1 | Delta | 0x9008 | Float | | V0FloatQ1 | Delta | 0x9010 | Float | #### **Control registers** | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|----------------------| | 031 | Texture | 1 | 1 | X | Vertex texture value | Notes: The texture S1, T1 and Q1 values for vertex 0 as IEEE single-precision floating point numbers. V1FloatR V1FloatB V1FloatA V1FloatF V1FloatX V1FloatY V1FloatZ | Name | Туре | Offset | Format | |----------|-------------------|--------|--------| | V1FloatR | Delta | 0x9228 | Float | | V1FloatG | Delta | 0x9230 | Float | | V1FloatB | Delta | 0x9238 | Float | | V1FloatA | Delta | 0x9240 | Float | | V1FloatF | Delta | 0x9248 | Float | | V1FloatX | Delta | 0x9250 | Float | | V1FloatY | Delta | 0x9258 | Float | | V1FloatZ | Delta | 0x9260 | Float | | | Control registers | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|----------|-------|----------------------------------------------| | 031 | | ✓ | <b>\</b> | X | Vertex RGB color, alpha, fog, X, Y and depth | Notes: The R, G, B, Alpha, Fog, X, Y coordinates and Depth values for vertex 1 as IEEE single-precision floating point numbers. # V1FloatKdR V1FloatKdG V1FloatKdB | Name | Туре | Offset | Format | |------------|------------------|--------|--------| | V1FloatKdR | Delta | 0x90E8 | Float | | V1FloatKdG | Delta | 0x90F0 | Float | | V1FloatKdB | Delta | 0x90F8 | Float | | | Control register | S | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|-------------------------------| | 031 | Diffuse | 1 | 1 | X | Vertex diffuse texture values | Notes: The diffuse KdR, G and B texture values for vertex 1 as IEEE single-precision floating point numbers. # V1FloatKsR V1FloatKsG V1FloatKsB | Name | Type | Offset | Format | |------------|-------|--------|--------| | V1FloatKsR | Delta | 0x90D0 | Float | | V1FloatKsG | Delta | 0x90D8 | Float | | V1FloatKsB | Delta | 0x90E0 | Float | | | Ct1tt | _ | | Control registers | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|------------------------------| | 031 | Diffuse | ✓ | ✓ | X | Vertex diffuse texture value | Notes: The diffuse KdR, G and B texture values for vertex 1 as IEEE single-precision floating point numbers. #### V1FloatPackedColor | Name | Туре | Offset | Format | |--------------------|------------------|--------|----------| | V1FloatPackedColor | Delta | 0x9270 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 07 | R | 0 | 1 | Х | | | 815 | G | 0 | 1 | x | | | 1623 | В | 0 | 1 | X | | | 2431 | Fog | 0 | 1 | х | | Notes: Vertex 1 color definition - the packed color registers hold the red, green, blue and alpha components in the same 32 bit word. When written to, the components are separated, converted to the internal floating point format, and loaded into the registers. The color order in the registers is set by bit 18 in the *DeltaMode* register: Bit31... Bit0 0 = Alpha (or Fog), Blue, Green, Red 1 = Alpha (or Fog), Red, Green, Blue Reading back from the packed color registers returns zero. #### V1FloatPackedDiffuse | Name | Type | Offset | Format | |----------------------|------------------|--------|----------| | V1FloatPackedDiffuse | Delta | 0x90C8 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 07 | R | 0 | 1 | X | | | 815 | G | 0 | 1 | x | | | 1623 | В | 0 | 1 | X | | | 2431 | A | 0 | 1 | х | | Notes: The color order in the registers is set by bit 18 in the *DeltaMode* register: Bit31... Bit 0 = Alpha (or Fog), Blue, Green, Red 1 = Alpha (or Fog), Red, Green, Blue Reading back from the packed color registers returns zero. # V1FloatPackedSpecularFog | Name | Type | Offset | Format | |--------------------------|------------------|--------|----------| | V1FloatPackedSpecularFog | Delta | 0x9278 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 07 | R | 0 | 1 | X | | | 815 | G | 0 | 1 | х | | | 1623 | В | 0 | 1 | x | | | 2431 | A | 0 | 1 | х | | Notes: Vertex 1 specular definition - packed specular registers are treated in the same way as packed color registers: the RGB components are separated, converted to the internal floating point format, and loaded into the registers. When loaded from a packed register, the specular range is 0 to 1.0. The A component is converted into an internal format and loaded into the fog register - when loaded from the packed register, the fog range is 0 to 1.0. The color order in the registers is set by bit 18 in the *DeltaMode* register: Bit31... Bit( 0 = Alpha (or Fog), Blue, Green, Red 1 = Alpha (or Fog), Red, Green, Blue Reading back from the packed color registers returns zero. # V1FloatS V1FloatT V1FloatQ | Name | Type | Offset | Format | |----------|------------------|--------|--------| | V1FloatS | Delta | 0x9200 | Float | | V1FloatT | Delta | 0x9208 | Float | | V1FloatQ | Delta | 0x9210 | Float | | • | Control modiston | | | Control registers | Bits | Name | Read | Write | Reset | Description | |------|---------|----------|-------|-------|-----------------------| | 031 | Texture | <b>\</b> | ✓ | X | Vertex texture values | Notes: The texture S, T and Q values for vertex 1 as IEEE single-precision floating point numbers. # V1FloatS1 V1FloatT1 V1FloatQ1 | Name | Type | Offset | Format | |-----------|------------------|--------|--------| | V1FloatS1 | Delta | 0x9080 | Float | | V1FloatT1 | Delta | 0x9088 | Float | | V1FloatQ1 | Delta | 0x9090 | Float | | · | Control register | S | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|-----------------------| | 031 | Texture | ✓ | ✓ | X | Vertex texture values | Notes: The texture S1, T1 and Q1 values for vertex 1 as IEEE single-precision floating point numbers. V2FloatR V2FloatG V2FloatB V2FloatA V2FloatF V2FloatX V2FloatY V2FloatZ | Name | Type | Offset | Format | |----------|-------------------|--------|--------| | V2FloatR | Delta | 0x92A8 | Float | | V2FloatG | Delta | 0x92B0 | Float | | V2FloatB | Delta | 0x92B8 | Float | | V2FloatA | Delta | 0x92C0 | Float | | V2FloatF | Delta | 0x92C8 | Float | | V2FloatX | Delta | 0x92D0 | Float | | V2FloatY | Delta | 0x92D8 | Float | | V2FloatZ | Delta | 0x92E0 | Float | | | Control register: | S | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|----------------------------------------------| | 031 | | 1 | 1 | X | Vertex RGB color, alpha, fog, X, Y and depth | Notes: The R, G, B, Alpha, Fog, X, Y coordinates and Depth values for vertex 2 as IEEE single-precision floating point numbers. # V2FloatKdR V2FloatKdG V2FloatKdB | Name | Туре | Offset | Format | |------------|-------------------|--------|--------| | V2FloatKdR | Delta | 0x9168 | Float | | V2FloatKdG | Delta | 0x9170 | Float | | V2FloatKdB | Delta | 0x9178 | Float | | | Control register. | S | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|-------------------------------| | 031 | Diffuse | 1 | 1 | X | Vertex diffuse texture values | Notes: The diffuse KdR, G and B texture values for vertex 2 as IEEE single-precision floating point numbers. # V2FloatKsR V2FloatKsG V2FloatKsB | Name | Туре | Offset | Format | |------------|-------|--------|--------| | V2FloatKsR | Delta | 0x9150 | Float | | V2FloatKsG | Delta | 0x9158 | Float | | V2FloatKsB | Delta | 0x9160 | Float | #### Control registers | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|-------------------------------| | 031 | Diffuse | ✓ | ✓ | X | Vertex diffuse texture values | Notes: The specular KsR, G and B texture values for vertex 2 as IEEE single-precision floating point numbers. #### V2FloatPackedColor | Name | Type | Offset | Format | |--------------------|------------------|--------|----------| | V2FloatPackedColor | Delta | 0x92F0 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 07 | R | 0 | 1 | X | | | 815 | G | 0 | ✓ | х | | | 1623 | В | 0 | 1 | X | | | 2431 | A | 0 | 1 | X | | Notes: Vertex 2 color definition - the packed color registers hold the red, green, blue and alpha components in the same 32 bit word. When written to, the components are separated, converted to an internal format, and loaded into the registers. The color order in the registers is set by bit 18 in the *DeltaMode* register: \*\*Bit31...\*\* Bit0 0 = Alpha (or Fog), Blue, Green, Red 1 = Alpha (or Fog), Red, Green, Blue Reading back from the packed color registers returns zero. #### V2FloatPackedDiffuse NameTypeOffsetFormatV2FloatPackedDiffuseDelta0x9148BitfieldControl register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 07 | R | 0 | 1 | X | | | 815 | G | 0 | ✓ | х | | | 1623 | В | 0 | ✓ | х | | | 2431 | A | 0 | 1 | X | | Notes: The color order in the registers is set by bit 18 in the *DeltaMode* register: Bit31... Bit 0 = Alpha (or Fog), Blue, Green, Red 1 = Alpha (or Fog), Red, Green, Blue Reading back from the packed color registers returns zero. # V2FloatPackedSpecularFog NameTypeOffsetFormatV2FloatPackedSpecularFogDelta0x92F8BitfieldControl register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 07 | R | 0 | 1 | X | | | 815 | G | 0 | 1 | x | | | 1623 | В | 0 | 1 | X | | | 2431 | A | 0 | 1 | X | | Notes: Vertex 2 specular definition - packed specular registers are treated in the same way as packed color registers: the RGB components are separated, converted to the internal floating point format, and loaded into the registers. When loaded from a packed register, the specular range is 0 to 1.0. The A component is converted into an internal format and loaded into the fog register - when loaded from the packed register, the fog range is 0 to 1.0. The color order in the registers is set by bit 18 in the *DeltaMode* register: Bit31... Bit( 0 = Alpha (or Fog), Blue, Green, Red 1 = Alpha (or Fog), Red, Green, Blue Reading back from the packed color registers returns zero. # V2FloatS V2FloatT V2FloatQ | Name | Туре | Offset | Format | |----------|-------|--------|--------| | V2FloatS | Delta | 0x9280 | Float | | V2FloatT | Delta | 0x9288 | Float | | V2FloatQ | Delta | 0x9290 | Float | #### **Control registers** | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|-----------------------| | 031 | Texture | ✓ | ✓ | X | Vertex texture values | Notes: The texture S, T and Q values for vertex 2 as IEEE single-precision floating point numbers. # V2FloatS1 V2FloatT1 V2FloatQ1 | Name | Type | Offset | Format | |-----------|------------------|--------|--------| | V2FloatS1 | Delta | 0x9100 | Float | | V2FloatT1 | Delta | 0x9108 | Float | | V2FloatQ1 | Delta | 0x9110 | Float | | • | Control register | S | | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|-----------------------| | 031 | Texture | 1 | 1 | X | Vertex texture values | Notes: The texture S1, T1 and Q1 values for vertex 2 as IEEE single-precision floating point numbers. #### Vertex0 | Name | Туре | Offset | Format | |---------|------------------|--------|---------| | Vertex0 | Input | 0xB7B8 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|----------|-------|-------|--------------------------| | 031 | Index | <b>✓</b> | ✓ | X | Index into Vertex buffer | Notes: The vertex data can be loaded without using one of the primitive types using the Vertex0, Vertex1, and Vertex2 registers. These registers specify the vertex store to load, and the data field holds the index into the array. #### Vertex1 | Name | Type | Offset | Format | |---------|------------------|--------|---------| | Vertex1 | Input | 0xB7C0 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|------|-------|-------|--------------------------| | 031 | Vertex | ✓ | ✓ | X | Index into Vertex buffer | Notes: The vertex data can be loaded without using one of the primitive types using the Vertex0, Vertex1, and Vertex2 registers. These registers specify the vertex store to load, and the data field holds the index into the array. #### Vertex2 | Name | Туре | Offset | Format | |---------|------------------|--------|---------| | Vertex2 | Input | 0xB7C8 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|----------|-------|-------|--------------------------| | 031 | Index | <b>√</b> | ✓ | X | Index into Vertex buffer | Notes: The vertex data can be loaded without using one of the primitive types using the Vertex0, Vertex1, and Vertex2 registers. These registers specify the vertex store to load, and the data field holds the index into the array. #### **VertexBaseAddress** | Name | Туре | Offset | Format | |-------------------|------------------|--------|---------| | VertexBaseAddress | Input | 0xB708 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|----------------------------------| | 01 | Reserved | 0 | 0 | X | | | 231 | Address | ✓ | ✓ | X | 32 bit address of base of buffer | | Notes: | | | | |--------|--|--|--| #### **VertexControl** | Name | Type | Offset | Format | |---------------|------------------|--------|----------| | VertexControl | Input | 0xB798 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |-------|-------------|------|-------|-------|--------------------------------------------------------------| | 0-4 | Size | 1 | 1 | X | Size of vertex in 32 words | | 5 | CacheEnable | 1 | 1 | х | 0 = cache off, 1 = cache on | | 6 | Flat | 1 | 1 | X | 0 = off, 1 = on | | 7 | ReadAll | 1 | 1 | X | 0 = off, 1 = on | | 8 | SkipFlags | 1 | 1 | X | 0 = off, 1 = on | | 9 | OGL | 1 | 1 | х | 0 = D3D, 1 = OGL (used to define provoking vertex behaviour) | | 10 | Line2D | 1 | 1 | X | 0 = off, 1 = 0n | | 11-31 | Reserved | 0 | 0 | X | | Notes: #### **VertexData** | Name | Type | Offset | Format | |------------|------------------|--------|---------| | VertexData | Input | 0xB7E8 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 031 | Data | ✓ | ✓ | X | Vertex data | Notes: The vertex data can be loaded without using one of the primitive types using the Vertex0, Vertex1, and Vertex2 registers. These registers specify the vertex store to load, and the data field holds the index into the array. The VertexData register is used for inline vertex data. PERMEDIA3 Reference Guide Hardware Registers #### VertexData0 | Name | Type | Offset | Format | |-------------|------------------|--------|---------| | VertexData0 | Input | 0xB7D0 | Integer | | | Control register | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|------|----------|-------|-------|-------------| | 031 | Data | <b>√</b> | ✓ | X | Vertex data | Notes: #### VertexData1 | Name | Туре | Offset | Format | |-------------|---------------------------|--------|---------| | VertexData1 | Input<br>Control register | 0xB7D8 | Integer | | | 0 | | | | Bits | Name | Read | Write | Reset | Description | |------|------|-------------|-------------|-------|-------------| | 031 | Data | <b>&gt;</b> | <b>&gt;</b> | X | Vertex data | | Motor | | | |--------|--|--| | Notes: | | | | | | | #### VertexData2 | Name | Туре | Offset | Format | |-------------|------------------|--------|---------| | VertexData2 | Input | 0xB7E0 | Integer | | | Control register | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 031 | Data | ✓ | ✓ | X | Vertex data | Notes: #### **VertexFormat** | Name | Type | Offset | Format | |--------------|------------------|--------|---------| | VertexFormat | Input | 0xB790 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|------------------------------| | 031 | Mask | ✓ | ✓ | X | Mask of data valid in vertex | Notes: # VertexLineList | Name | Туре | Offset | Format | |----------------|------------------|--------|---------| | VertexLineList | Input | 0xB760 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|---------------------------------| | 031 | Count | X | ✓ | X | Number of vertices in primitive | Notes: # VertexLineStrip | Name | Type | Offset | Format | |-----------------|------------------|--------|---------| | VertexLineStrip | Input | 0xB768 | Integer | | | Control register | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|---------------------------------| | 031 | Count | × | ✓ | X | Number of vertices in primitive | Notes: ## VertexPointList | Name | Type | Offset | Format | | |-----------------|------------------|--------|---------|--| | VertexPointList | Input | 0xB770 | Integer | | | | Control register | | | | Control register | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|---------------------------------| | 031 | Count | × | ✓ | X | Number of vertices in primitive | Notes: # VertexPolygon | Name | Туре | Offset | Format | |---------------|------------------|--------|---------| | VertexPolygon | Input | 0xB778 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|---------------------------------| | 031 | Count | × | ✓ | X | Number of vertices in primitive | | Notes: | | | | |--------|--|--|--| # VertexTagList[0...15] | Name | Туре | Offset | Format | |--------------------|------------------|--------|----------| | VertexTagList[015] | Input | 0xB800 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------------------------| | 010 | Tag | 1 | ✓ | X | Tag to use for corresponding vertex data item | | 1131 | Reserved | 0 | 0 | X | | Notes: Typical usage would use the TagList to define the order in which data is delivered; the format mask and vertex size are used to set which modes are enabled (so if z is enabled the z bit in the format mask is set and the vertex size increased by 1). # VertexTagList[16...31] | Name | Туре | Offset | Format | |---------------------|------------------|--------|----------| | VertexTagList[1631] | Input | 0xB880 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-----------------------------------------------| | 010 | Tag | 1 | 1 | X | Tag to use for corresponding vertex data item | | 1131 | Reserved | 0 | 0 | X | | Notes: Typical usage would use the TagList to define the order in which data is delivered; the format mask and vertex size are used to set which modes are enabled (so if z is enabled the z bit in the format mask is set and the vertex size increased by 1). # VertexTriangleFan | Name | Туре | Offset | Format | |-------------------|------------------|--------|---------| | VertexTriangleFan | Input | 0xB750 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|---------------------------------| | 031 | Count | × | ✓ | X | Number of vertices in primitive | Notes: # VertexTriangleList | Name | Туре | Offset | Format | |--------------------|------------------|--------|---------| | VertexTriangleList | Input | 0xB748 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|---------------------------------| | 031 | Count | × | ✓ | X | Number of vertices in primitive | Notes: # VertexTriangleStrip | Name | Type | Offset | Format | |---------------------|------------------|--------|---------| | VertexTriangleStrip | Input | 0xB750 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|---------------------------------| | 031 | Count | X | ✓ | X | Number of vertices in primitive | | Notes: | | | |--------|--|--| #### **VertexValid** | Name | Type | Offset | Format | |-------------|------------------|--------|---------| | VertexValid | Input | 0xB788 | Integer | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|----------|-------|-------|------------------------------| | 031 | Mask | <b>✓</b> | ✓ | X | Mask of data valid in vertex | Notes: #### **VTGAddress** | Name | Type | Offset | Format | |------------|-------------|--------|---------| | VTGAddress | Framebuffer | 0xB0B0 | Integer | | | Command | | · · | | Bits | Name | Read | Write | Reset | Description | |------|---------|------|-------|-------|--------------| | 031 | Address | ✓ | ✓ | X | 32 bit value | Notes: The VTG and RAMDAC can be read and written via the PCI bypass, but sometimes it is useful to control them synchronously with core rendering activities. This can be done by using the VTGAddress and VTGData commands. The address is sent first followed by the data. The address and data are the same as would be used if the VTG, Ramdac or any other device on the PCI bypass were accessed via the bypass. The core does not interpret the data in any way and is just the communications path. The VTG data and address is routed via the FB Memory Interface. #### **VTGData** | Name | Type | Offset | Format | |------------|-------------|--------|---------| | VTGAddress | Framebuffer | 0xB0B8 | Integer | | | Command | | o o | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|--------------| | 031 | VTG Data | ✓ | ✓ | X | 32 bit value | Notes: This register holds the data for the VTG or bypass write and instigates the action via the FB Memory Controller. The VTG and RAMDAC can be read and written via the PCI bypass, but sometimes it is useful to control them synchronously with core rendering activities. This can be done by using the VTGAddress and VTGData commands. The address is sent first followed by the data. The address and data are the same as would be used if the VTG, Ramdac or any other device on the PCI bypass were accessed via the bypass. The core does not interpret the data in any way and is just the communications path. The VTG data and address is routed via the FB Memory Interface. # WaitforCompletion | Name | Type | Offset | Format | |-------------------|------------|--------|----------| | WaitforCompletion | Rasterizer | 0x80B8 | Bitfield | | - | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|------|----------|-------|---------------------------------------------------------------------------------------------------------------------| | 0, 1 | Event | 0 | <b>√</b> | х | 0 = LB Reads and writes and FB reads and writes<br>1 = LB Reads and FB Reads<br>2 = RenderSync<br>3 = ScanlineSyncU | | 231 | Unused | 0 | 0 | X | | Notes: Command: This is used to suspend core graphics processing until outstanding reads and writes in both localbuffer and framebuffer memory have completed, or some other combination of events described above has taken place. This is intended to prevent a new primitive from starting to be rasterized before the previous primitive is completely finished. It would be used, for example, to separate texture downloads from the surrounding primitives. The same functionality can be achieved using the Sync register and waiting for it in the Host Out FIFO; however, this method doesn't involve the host and can be inserted into a DMA buffer. #### Window NameTypeOffsetFormatWindowLocalbuffer0x8980BitfieldControl register | Bits | Name | Read | Write | Reset | Description | |------|----------------------------|------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------| | 02 | Reserved | 0 | 0 | х | | | 3 | ForceLB<br>Update | 1 | 1 | х | This bit, when set, disregards the results of the stencil and depth tests and forced the local buffer to be updated. | | 4 | LBUpdate<br>Source | 1 | 1 | Х | This bit selects the data to be written to the local buffer. The two options are: 0 = LB data. 1 = Registers. | | 58 | Reserved | 0 | 0 | X | | | 916 | FrameCount | 1 | 1 | х | Reserved | | 17 | Stencil FCP | 1 | 1 | x | This bit, when set, enables the FCP tests and substitution to occur for the Stencil field. | | 18 | DepthFCP | 1 | 1 | х | This bit, when set, enables the FCP tests and substitution to occur for the Depth field. | | 19 | OverrideWrite<br>Filtering | 1 | 1 | Х | This bit, when set, prevents writes to the local buffer from being filtered out because this unit has not changed the data. | | 2031 | Reserved | 0 | 0 | X | | Notes: Stencil operation generally is under control of the Window register: - The Force LB Update bit, when set overrides all the tests done in the Stencil and Depth units and the per unit enables to force the local buffer to be updated. When this bit is clear any update is conditional on the outcome of the stencil and depth tests. The main use of this bit is during window initialisation or copy. It may also be useful for hardware diagnostics. - The data used during ForceLBUpdate depends on the settings in the LBUpdateSource bit. When this bit is 0 the data is taken from the local buffer. Note that either destination or source local buffer data can be used depending on which is enabled. If both are enabled then the destination local buffer data will be used. - When the LBUpdateSource bit is set the source of the stencil and depth data is determined by the StencilMode and DepthMode registers respectively. - The Override Write Filtering control bit, when set causes the testing of LBData = LBWriteData to always fail. This is mainly used when the GID field needs to be changed. It also allows the LBReadFormat to be different to the LBWriteFormat so the write data as seen by the memory is really different to the data that was read. # WindowOrigin | Name | Type | Offset | Format | |--------------|---------|--------|----------| | WindowOrigin | Scissor | 0x81C8 | Bitfield | | 3 | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|--------------|------|-------|-------|---------------------------------------| | 015 | X coordinate | | | | X coordinate as 2's complement number | | 1631 | Y coordinate | | | | Y coordinate as 2's complement number | Notes: This register holds the window origin. As each fragment is generated by the rasterizer, this origin is added to the coordinates of the fragment to generate its localbuffer coordinate when the depth and stencil buffers are patched. #### **XBias** | Name | Type | Offset | Format | |-------|------------------|--------|--------| | XBias | Delta | 0x9480 | Float | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|------|----------|-------|-------------| | 031 | Offset | ✓ | <b>√</b> | X | | Notes: This register holds the single precision floating point bias added to the vertices' X coordinate (if enabled) just before rasterization. #### **YBias** NameTypeOffsetFormatYBiasDelta0x9488FloatControl register | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|-------------| | 031 | | ✓ | ✓ | X | | Notes: This register holds the single precision floating point bias added to the vertices' Y coordinate (if enabled) just before rasterization. #### **YLimits** | Name | Туре | Offset | Format | |---------|------------|--------|----------| | YLimits | Rasterizer | 0x80A8 | Bitfield | | | Command | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|----------------------------| | 015 | Ymin | 1 | 1 | X | 2's complement min Y value | | 1631 | Ymax | 1 | 1 | X | 2's complement max Y value | Notes: Defines the Y extent the Rasterizer should fill between. A scanline is filled if its Y value satisifies Ymin<Y<Ymax. # YUVMode | Name | Type | Offset | Format | |---------|------------------|--------|----------| | YUVMode | YŬV | 0x8F00 | Bitfield | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Enable | 1 | 1 | х | When set causes the fragment's color values to be converted from YUV to RGB. If this bit is clear then the fragment's color is passed unchanged | | 131 | Reserved | 0 | 0 | x | | | Notes: | The conversion goes from the YCbCr color space to RGB. The term YCbCr is used interchangeably | |--------|-----------------------------------------------------------------------------------------------| | | with YUV. | | | The output of the conversion is an RGB triple with each component 8 bits wide. The alpha | | | component is passed through unchanged. | #### **ZBias** | Name | Туре | Offset | Format | |-------|------------------|--------|--------| | ZBias | Delta | 0x94F8 | Float | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|--------|------|-------|-------|-------------| | 031 | Offset | ✓ | ✓ | X | | Notes: This register holds the single precision floating point bias added to the vertices' Z coordinate (if enabled) just before rasterization. # **ZFogBias** | Name | Туре | Offset | Format | |----------|------------------|--------|--------| | ZFogBias | Delta | 0x86B8 | Float | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|------|------|-------|-------|----------------------------| | 031 | Bias | ✓ | ✓ | X | 2's complement value for Z | Notes: This register holds the 32 bit 2's complement value to add to the Z value extracted from the fog DDA before it is clamped and scaled. The bias essentially is used to set the Z value below which no blending occurs. #### **ZStartL** | Name | Type | Offset | Format | |---------|------------------|--------|------------------| | ZStartL | Depth | 0x89B8 | Fixed point pair | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|----------|------|-------|-------|-------------------------------------------| | 015 | Reserved | 0 | 0 | X | LSBs all 0 | | 1631 | Integer | ✓ | ✓ | X | 16bit LSB part of 32.16 fixed point value | Notes: This register holds the lower 16 bits of the 48 bit 2's complement Z start value. These bits are held in bits 16...31 of the data field. With ZstartU, it sets the start value for depth interpolation. ZStartU holds the most significant bits, and ZStartL the least significant bits. The value is in 2's complement 32.16 fixed point format. #### **ZStartU** | Name | Туре | Offset | Format | |---------|------------------|--------|------------------| | ZStartU | Stencil | 0x89B0 | Fixed point pair | | | Control register | | | | Bits | Name | Read | Write | Reset | Description | |------|-------|------|-------|-------|----------------| | 031 | dZdxU | ✓ | ✓ | X | 32 bit integer | Notes: This register holds the upper 32 bits of the 48 bit 2's complement Z start value. With ZstartL, it sets the start value for depth interpolation. ZStartU holds the most significant bits, and ZStartL the least significant bits. The value is in 2's complement 32.16 fixed point format. 6 # Register Cross Reference This chapter provides alphabetically- and offset-sorted Region 0 register listings. # 6.1 Registers Alphabetically Sorted | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |------------------------|---------------|----------|-----------------------------------|--------|----------------|----------|--------------| | AALineWidth | ~ | ~ | Delta | 94C0 | х | float | X | | AAPointSize | ~ | ~ | Delta | 94A0 | х | float | X | | AGPControl | ~ | <b>'</b> | Control<br>Status | 0078 | | bitfield | | | AlphaBlendAlphaMode | ~ | ~ | Alpha<br>blend | AFA8 | х | bitfield | × | | AlphaBlendAlphaModeAnd | × | ~ | Alpha<br>blend | AD30 | х | bitfield | × | | AlphaBlendAlphaModeOr | × | ~ | Alpha<br>blend | AD38 | х | bitfield | × | | AlphaBlendColorMode | ~ | ~ | Alpha<br>blend | AFA0 | x | bitfield | × | | AlphaBlendColorModeAnd | × | ~ | Alpha<br>blend | ACB0 | х | bitfield | × | | AlphaBlendColorModeOr | × | ~ | Alpha<br>blend | ACB8 | х | bitfield | × | | AlphaDestColor | ~ | ~ | Alpha<br>blend | AF88 | х | bitfield | × | | AlphaSourceColor | ~ | ~ | Alpha<br>blend | AF80 | х | integer | × | | AlphaTestMode | V | ~ | Alpha<br>Blend &<br>Alpha<br>Test | 8800 | x | bitfield | X | | AlphaTestModeAnd | × | ~ | Alpha<br>Blend &<br>Alpha<br>Test | ABF0 | х | bitfield | X | | AlphaTestModeOr | X | <b>'</b> | Alpha<br>Blend &<br>Alpha<br>Test | ABF8 | x | bitfield | X | | AntialiasMode | ~ | <b>'</b> | Alpha<br>test | 8808 | Х | bitfield | × | **3D**/abs Proprietary and Confidential 6-1 Register Descriptions PERMEDIA3 Reference Guide | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |---------------------------|---------------|----------|-------------------|--------|----------------|----------|--------------| | AntialiasModeAnd | X | ~ | Alpha | AC00 | Х | bitfield | × | | | | | test | 1000 | | 1.70 | | | AntialiasModeOr | × | • | Alpha<br>test | AC08 | X | bitfield | × | | ApertureOne | ~ | <b>'</b> | Control<br>Status | 0050 | | bitfield | | | ApertureTwo | ~ | ~ | Control<br>Status | 0058 | | bitfield | | | AreaStippleMode | <b>/</b> | / | Stipple | 81A0 | х | Bitfield | X | | AreaStippleModeAnd | X | / | Stipple | ABD0 | х | bitfield | X | | AreaStippleModeOr | X | / | Stipple | ABD8 | х | bitfield | X | | AreaStipplePattern[015] | <b>/</b> | ~ | Stipple | 8200 | х | Bitfield | X | | AreaStipplePattern[1631] | <b>/</b> | / | Stipple | 8280 | х | Bitfield | X | | AStart | ~ | ~ | Color<br>DDA | 87C8 | х | fixed | × | | BackgroundColor | ~ | ~ | Logic<br>Ops | B0C8 | х | integer | × | | BasePageOfWorking Set | ~ | ~ | Texture<br>Read | B4C8 | х | integer | × | | BasePageOfWorking SetHost | ~ | ~ | Texture<br>Read | B4E0 | х | integer | × | | BitMaskPattern | × | ~ | Raster-<br>izer | 8068 | х | Integer | <b>✓</b> × | | BorderColor0 | ~ | ~ | Texture<br>filter | 84A8 | х | bitfield | × | | BorderColor1 | ~ | ~ | Texture<br>filter | 84F8 | х | bitfield | × | | BStart | ~ | ~ | Color<br>DDA | 87B0 | x | fixed | × | | ByAperture1Mode | ~ | ~ | Bypass<br>Control | 0300 | | Bitfield | | | ByAperture1Stride | ~ | ~ | Bypass<br>Control | 0308 | | Integer | | | ByAperture1UStart | ~ | ~ | Bypass<br>Control | 0318 | | Integer | | | ByAperture1VStart | ~ | ~ | Bypass<br>Control | 0320 | | Integer | | | ByAperture1YStart | ~ | ~ | Bypass<br>Control | 0310 | | Integer | | | ByAperture2Mode | ~ | ~ | Bypass<br>Control | 0328 | | Bitfield | | | ByAperture2Stride | ~ | ~ | Bypass<br>Control | 0330 | | Integer | | | ByAperture2UStart | ~ | ~ | Bypass<br>Control | 0340 | | Integer | | | ByAperture2VStart | ~ | ~ | Bypass<br>Control | 0348 | | Integer | | | ByAperture2YStart | ~ | <b>'</b> | Bypass<br>Control | 0338 | | Integer | | | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |------------------------|---------------|----------|----------------------------------|--------|----------------|----------|--------------| | ByDMAReadCommandBase | ~ | ~ | Bypass<br>Control | 0378 | | Integer | | | ByDMAReadCommandCount | ~ | ~ | Bypass<br>Control | 0380 | | Integer | | | ByDMAReadMode | ~ | ~ | Bypass<br>Control | 0350 | | Bitfield | | | ByDMAReadStride | ~ | ~ | Bypass<br>Control | 0358 | | Integer | | | ByDMAReadUStart | ~ | ~ | Bypass<br>Control | 0368 | | Integer | | | ByDMAReadVStart | ~ | ~ | Bypass<br>Control | 0370 | | Integer | | | ByDMAReadYStart | ~ | ~ | Bypass<br>Control | 0360 | | Integer | | | ByDMAWriteCommandBase | ~ | ~ | Bypass<br>Control | 03B0 | | Integer | | | ByDMAWriteCommandCount | ~ | ~ | Bypass<br>Control | 03B8 | | Integer | | | ByDMAWriteMode | ~ | ~ | Bypass<br>Control | 0388 | | Bitfield | | | ByDMAWriteStride | ~ | ~ | Bypass<br>Control | 0390 | | Integer | | | ByDMAWriteUStart | ~ | ~ | Bypass<br>Control | 03A0 | | Integer | | | ByDMAWriteVStart | ~ | ~ | Bypass<br>Control | 03A8 | | Integer | | | ByDMAWriteYStart | ~ | <b>'</b> | Bypass<br>Control | 0398 | | Integer | | | ChipConfig | ~ | <b>'</b> | Control<br>Status | 0070 | | bitfield | | | ChromaFailColor | ~ | <b>'</b> | Color<br>DDA &<br>Alpha<br>Blend | AF98 | x | bitfield | X | | ChromaLower | ~ | <b>'</b> | Color<br>DDA &<br>Alpha<br>Blend | 8F10 | x | bitfield | X | | ChromaPassColor | ~ | ~ | Color<br>DDA &<br>Alpha<br>Blend | AF90 | x | bitfield | X | | ChromaTestMode | ~ | • | Color<br>DDA &<br>Alpha<br>Blend | 8F18 | x | bitfield | X | | ChromaTestModeAnd | × | • | Color<br>DDA &<br>Alpha<br>Blend | ACC0 | x | bitfield | X | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |-------------------|---------------|----------|----------------------------------|--------|----------------|----------|--------------| | ChromaTestModeOr | X | ~ | Color<br>DDA &<br>Alpha<br>Blend | ACC8 | x | bitfield | X | | ChromaUpper | • | • | Color<br>DDA &<br>Alpha<br>Blend | 8F08 | x | bitfield | X | | Color | <b>~</b> | <b>/</b> | | 87F0 | x | bitfield | × | | ColorDDAMode | • | • | Color<br>DDA | 87E0 | x | bitfield | | | ColorDDAModeAnd | × | • | Color<br>DDA | ABE0 | x | bitfield | × | | ColorDDAModeOr | × | • | Color<br>DDA | ABE8 | x | bitfield | × | | Command Interrupt | X | <b>'</b> | Host In | A990 | х | bitfield | X | | Config2D | X | <b>'</b> | Global | B618 | х | bitfield | X | | ConstantColor | • | • | Color<br>DDA | 87E8 | X | bitfield | | | ConstantColorDDA | × | • | Color<br>DDA | AFB0 | X | bitfield | × | | ContextData | X | <b>/</b> | Global | 8DD0 | x | bitfield | × | | ContextDump | X | <b>/</b> | Global | 8DC0 | х | bitfield | <b>/</b> | | ContextRestore | X | <b>/</b> | Global | 8DC8 | x | bitfield | ~ | | Continue | × | <b>'</b> | Raster-<br>izer | 8058 | x | Integer | <b>/</b> | | ContinueNewDom | × | • | Raster-<br>izer | 8048 | x | Integer | <b>/</b> | | ContinueNewLine | × | • | Raster-<br>izer | 8040 | x | Integer | ~ | | ContinueNewSub | × | ~ | Raster-<br>izer | 8050 | х | Integer | ~ | | ControlDMAAddress | ~ | ~ | Control<br>Status | 0028 | | integer | | | ControlDMAControl | ~ | - | Control<br>Status | 0060 | | bitfield | | | ControlDMACount | ~ | - | Control<br>Status | 0030 | | integer | | | Count | ~ | × | Raster-<br>izer | 8030 | x | Integer | × | | dAdx | ~ | ~ | Color<br>DDA | 87D0 | х | fixed | X | | dAdyDom | ~ | - | Color<br>DDA | 87D8 | х | fixed | | | dBdx | ~ | • | Color<br>DDA | 87B8 | x | fixed | × | | dBdyDom | ~ | ~ | Color<br>DDA | 87C0 | x | fixed | × | | DeltaControl | <b>/</b> | ~ | Delta | 9350 | х | bitfield | X | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |----------------------------|---------------|----------|------------------|--------|----------------|----------|--------------| | DeltaControlAnd | × | <b>'</b> | Delta | AB20 | Х | bitfield | X | | DeltaControlOr | × | / | Delta | AB28 | х | bitfield | X | | DeltaMode | ~ | <b>/</b> | Delta | 9300 | х | bitfield | X | | DeltaModeAnd | × | / | Delta | AAD0 | х | bitfield | X | | DeltaModeOr | X | / | Delta | AAD8 | х | bitfield | X | | <u>Depth</u> | ~ | / | Depth | 89A8 | х | integer | <b>✓</b> × | | DepthMode | <b>'</b> | / | Depth | 89A0 | Х | bitfield | X | | DepthModeAnd | × | / | Depth | AC70 | х | bitfield | X | | DepthModeOr | × | / | Depth | AC78 | х | bitfield | X | | dFdx | ~ | / | Fog | 86A8 | х | fixed | X | | dFdyDom | ~ | <b>/</b> | Fog | 86B0 | x | fixed | X | | dGdx | • | • | Color<br>DDA | 87A0 | x | fixed | × | | dGdyDom | <b>'</b> | • | Color<br>DDA | 87A8 | x | fixed | × | | DisplayData | | | Video<br>Control | 3068 | | bitfield | | | DitherMode | ~ | ~ | Dither | 8818 | х | bitfield | X | | DitherModeAnd | × | <b>/</b> | Dither | ACD0 | Х | bitfield | X | | DitherModeOr | × | <b>'</b> | Dither | ACD8 | Х | bitfield | X | | dKdBdx | • | <b>'</b> | Texture | 8D38 | Х | fixed | X | | dKdBdyDom | ~ | <b>'</b> | Texture | 8D40 | Х | fixed | X | | dKdGdx | ~ | <b>/</b> | Texture | 8D20 | Х | fixed | X | | dKdGdyDom | ~ | <b>'</b> | Texture | 8D28 | Х | fixed | X | | dKdRdx | • | <b>/</b> | Texture | 8D08 | Х | fixed | X | | dKdRdyDom | ~ | <b>/</b> | Texture | 8D10 | Х | fixed | X | | dKsBdx | ~ | <b>'</b> | Texture | 8CB8 | Х | fixed | X | | dKsBdyDom | ~ | <b>/</b> | Texture | 8CC0 | Х | fixed | X | | dKsdx | ~ | <b>/</b> | Texture | 86D0 | Х | fixed | X | | dKsdyDom | ~ | <b>'</b> | Texture | 86D8 | Х | fixed | X | | dKsGdx | ~ | <b>/</b> | Texture | 8CA0 | Х | fixed | X | | dKsGdyDom | <b>'</b> | <b>/</b> | Texture | 8CA8 | Х | fixed | X | | dKsRdx | ~ | ~ | Texture | 8C88 | Х | fixed | X | | dKsRdyDom | ~ | <b>/</b> | Texture | 8C90 | Х | fixed | X | | DMAAddr | X | <b>'</b> | Host In | A980 | Х | integer | X | | DMAContinue | X | <b>'</b> | Host In | A9F8 | Х | integer | <b>'</b> | | DMACount | X | <b>'</b> | Host In | A988 | Х | integer | X | | DMAFeedback | X | <b>'</b> | Host In | AA10 | Х | integer | X | | DMAMemoryControl | <b>/</b> | <b>'</b> | Host In | B780 | Х | bitfield | X | | DMAOutput Address | X | ~ | Host In | A9E0 | Х | integer | X | | DMAOutputCount | X | <b>'</b> | Host In | A9E8 | Х | integer | X | | DMARectangle Read | X | <b>'</b> | Host In | A9A8 | Х | bitfield | X | | DMARectangleRead LinePitch | <b>/</b> | <b>'</b> | Host In | A9B8 | Х | integer | X | | DMARectangleRead Target | <b>'</b> | <b>'</b> | Host In | A9C0 | Х | bitfield | X | | DMARectangleReadAddress | • | ~ | Host In | A9B0 | Х | integer | X | | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |----------------------------|---------------|----------|-----------------------|--------|----------------|----------|--------------| | DMARectangleWrite | × | / | Host In | A9C8 | х | bitfield | X | | DMARectangleWrite Address | ~ | <b>'</b> | Host In | A9D0 | х | integer | X | | DMARectangleWriteLinePitch | ~ | <b>'</b> | Host In | A9D8 | х | integer | X | | DownloadGlyphWidth | ~ | ~ | 2D Set<br>Up | B658 | х | integer | × | | DownloadTarget | ~ | ~ | 2D Set<br>Up | B650 | х | | ~ | | dQ1dx | ~ | ~ | Texture coord | 8438 | х | fixed | × | | dQ1dyDom | ~ | ~ | Texture coord | 8440 | х | fixed | × | | dQdx | ~ | ~ | Texture coord | 83C0 | х | fixed | × | | DQdy | ~ | <b>'</b> | Texture coord | 83E8 | x | fixed | X | | dQdyDom | ~ | <b>'</b> | Texture coord | 83C8 | х | | × | | DrawLine0 | × | <b>'</b> | Delta | 9318 | х | fixed | ~ | | DrawLine1 | × | <b>'</b> | Delta | 9320 | х | fixed | ~ | | DrawLine2D01 | X | <b>'</b> | Delta | 9778 | х | bitfield | <b>'</b> | | DrawLine2D10 | × | <b>'</b> | Delta | 9768 | х | bitfield | ~ | | DrawPoint | X | <b>'</b> | Delta | 9330 | х | bitfield | ~ | | DrawTriangle | X | <b>'</b> | Delta | 9308 | х | bitfield | <b>/</b> | | dRdx | ~ | ~ | Color<br>DDA | 8788 | х | fixed | × | | dRdyDom | ~ | - | Color<br>DDA<br>Delta | 8790 | x | fixed | × | | dS1dx | ~ | ~ | Texture coord | 8408 | х | fixed | × | | dS1dyDom | ~ | ~ | Texture coord | 8410 | х | fixed | × | | dSdx | ~ | ~ | Texture coord | 8390 | х | fixed | × | | dSdy | ~ | ~ | Texture coord | 83D8 | х | fixed | × | | dSdyDom | ~ | <b>'</b> | Texture coord | 8398 | х | fixed | × | | dT1dx | ~ | ~ | Texture coord | 8420 | х | fixed | × | | dT1dyDom | ~ | ~ | Texture coord | 8428 | х | fixed | × | | dTdx | ~ | <b>'</b> | Texture coord | 83A8 | x | fixed | × | | dTdy | ~ | <b>'</b> | Texture coord | 83E0 | х | fixed | × | | dTdyDom | ~ | <u> </u> | Texture coord | 83B0 | х | fixed | X | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |----------------------------|---------------|----------|-------------------|--------|----------------|----------|--------------| | dXDom | ~ | × | Raster-<br>izer | 8008 | х | fixed | X | | dXSub | ~ | × | Raster-<br>izer | 8018 | х | fixed | × | | dY | ~ | × | Raster-<br>izer | 8028 | х | fixed | × | | dZdxL | ~ | ~ | Depth &<br>Fog | 89C8 | x | fixed | × | | dZdxU | | • | Depth & Fog | 89C0 | X | fixed | × | | dZdyDomL | ~ | ~ | Depth &<br>Fog | 89D8 | х | bitfield | × | | dZdyDomU | ~ | ~ | Depth &<br>Fog | 89D0 | х | fixed | × | | EndOfFeedback | ~ | <b>/</b> | Host Out | 8FF8 | х | unused | X | | ErrorFlags | | | Control<br>Status | 0038 | | bitfield | | | FastClearDepth | ~ | ~ | Depth | 89E0 | х | integer | X | | FBBlockColor | ~ | X | FB Read | 8AC8 | х | integer | X | | FBBlockColor[03] | ~ | <b>/</b> | FB Write | | x | integer | X | | FBBlockColorBack | ~ | <b>/</b> | FB Write | | х | integer | X | | FBBlockColorBack[03] | ~ | <b>/</b> | FB Write | | X | integer | X | | FBColor | 0 | X | FB Write | | X | n/a | X | | FBDestReadBufferAddr[03] | ~ | <b>/</b> | FB Read | AE80 | x | integer | X | | FBDestReadBufferOffset[03] | ~ | <b>'</b> | FB Read | | X | integer | X | | FBDestReadBufferWidth[03] | ~ | <b>'</b> | FB Read | AEC0 | X | integer | X | | FBDestReadEnables | <b>'</b> | <b>'</b> | FB Read | AEE8 | X | bitfield | X | | FBDestReadEnablesAnd | X | <b>/</b> | FB Read | AD20 | X | bitfield | X | | FBDestReadEnablesOr | X | <b>'</b> | FB Read | | X | bitfield | X | | FBDestReadMode | ~ | <b>'</b> | FB Read | | X | bitfield | X | | FBDestReadModeAnd | X | <b>'</b> | FB Read | | х | bitfield | X | | FBDestReadModeOr | × | <b>'</b> | FB Read | | x | bitfield | X | | FBHardwareWriteMask | <b>'</b> | <b>'</b> | FB Write | | Х | mask | × | | FBSoftwareWriteMask | <b>'</b> | | Logic<br>Ops | 8820 | х | integer | × | | FBSourceReadBufferAddr | <b>'</b> | <b>/</b> | FB Read | | х | integer | × | | FBSourceReadBufferOffset | ~ | <b>/</b> | FB Read | | х | integer | X | | FBSourceReadBufferWidth | <b>'</b> | | FB Read | | х | integer | X | | FBSourceReadMode | <b>'</b> | | FB Read | | Х | bitfield | X | | FBSourceReadModeAnd | X | | FB Read | | Х | bitfield | X | | FBSourceReadModeOr | X | | FB Read | | х | bitfield | X | | FBWriteBufferAddr[03] | <b>'</b> | | FB Write | | Х | integer | X | | FBWriteBufferOffset[03] | <b>/</b> | <b>'</b> | FB Write | | х | integer | X | | FBWriteBufferWidth[03] | <b>/</b> | <b>'</b> | FB Write | | х | integer | X | | FBWriteMode | <b>V</b> | <b>'</b> | FB Write | | х | bitfield | | | FBWriteModeAnd | X | <b>'</b> | FB Write | ACF0 | X | bitfield | X | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |------------------------------|---------------|----------|-------------------|--------|----------------|----------|--------------| | FBWriteModeOr | X | ~ | FB Write | ACF8 | х | bitfield | X | | FeedbackX | | / | Host Out | 8F88 | х | integer | X | | FeedbackY | | ~ | Host Out | 8F90 | х | integer | X | | FifoControl | ~ | ~ | Video<br>Control | 3078 | | bitfield | | | FIFODiscon | ~ | ~ | Control<br>Status | 0068 | | bitfield | | | FillBackgroundColor | × | ~ | 2D Set<br>Up | 8330 | х | integer | × | | FillConfig2D0 | × | ~ | 2D Set<br>Up | 8338 | х | bitfield | × | | FillConfig2D1 | × | ~ | 2D Set<br>Up | 8360 | х | bitfield | | | FillFBDestReadBufferAddr0 | × | ~ | 2D Set<br>Up | 8310 | х | integer | × | | FillFBSourceReadBufferAddr | × | ~ | 2D Set<br>Up | 8308 | x | integer | × | | FillFBSourceReadBufferOffset | × | ~ | 2D Set<br>Up | 8340 | х | integer | × | | FillFBWriteBufferAddr0 | × | ~ | 2D Set<br>Up | 8300 | х | integer | × | | FillForegroundColor0 | × | ~ | 2D Set<br>Up | 8328 | х | integer | × | | FillForegroundColor1 | × | ~ | 2D Set<br>Up | 8358 | х | integer | × | | FillGlyphPosition | × | ~ | 2D Set<br>Up | 8368 | х | integer | × | | FillRectanglePosition | × | ~ | 2D Set<br>Up | 8348 | х | integer | × | | FillRender2D | × | ~ | 2D Set<br>Up | 8350 | х | bitfield | × | | FillScissorMaxXY | × | ~ | 2D Set<br>Up | 8320 | х | fixed | × | | FillScissorMinXY | × | ~ | 2D Set<br>Up | 8318 | х | fixed | × | | FilterMode | ~ | ~ | Host Out | 8C00 | х | bitfield | X | | FilterModeAnd | X | ~ | Host Out | AD00 | х | bitfield | X | | FilterModeOr | × | ~ | Host Out | AD08 | х | bitfield | X | | FlushSpan | × | ~ | Raster-<br>izer | 8060 | x | tag | ~ | | FlushWriteCombining | X | ~ | Host In | 8910 | х | integer | X | | FogColor | ~ | <b>'</b> | Fog | 8698 | х | fixed | X | | FogMode | ~ | <b>'</b> | Fog | 8690 | х | bitfield | X | | FogModeAnd | × | ~ | Fog | AC10 | х | bitfield | X | | FogModeOr | × | <b>'</b> | Fog | AC18 | х | bitfield | X | | FogTable[015] | ~ | <b>'</b> | Fog | B100 | х | bitfield | X | | FogTable[1631] | ~ | ~ | Fog | B180 | х | bitfield | X | | FogTable[3247] | <b>'</b> | <b>'</b> | Fog | B200 | Х | bitfield | × | | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |------------------------------------|---------------|----------|-------------------|--------|----------------|----------|--------------| | FogTable[4863] | <b>/</b> | <b>'</b> | Fog | B280 | х | bitfield | X | | ForegroundColor | • | • | Logic<br>Ops | B0C0 | X | integer | × | | <b>FStart</b> | ~ | <b>'</b> | Fog | 86A0 | х | fixed | X | | GIDMode | ~ | <b>'</b> | LB Read | B538 | х | bitfield | X | | GIDModeAnd | × | / | | B5B0 | x | bitfield | X | | GIDModeOr | X | / | | B5B8 | х | bitfield | X | | GlyphData | X | <b>'</b> | 2D Set<br>Up | B660 | X | integer | × | | GlyphPosition | ~ | <b>'</b> | 2D Set<br>Up | B608 | X | integer | × | | GPOutDMAAddress | <b>'</b> | × | Control<br>Status | 0800 | | integer | | | GStart | <b>'</b> | ′ | Color<br>DDA | 8798 | x | fixed | × | | HbEnd | <b>'</b> | ′ | Video<br>Control | 3020 | | integer | | | HeadPhysicalPage<br>Allocation[03] | • | • | Texture<br>Read | B480 | X | integer | × | | HgEnd | <b>'</b> | • | Video<br>Control | 3018 | | integer | | | HostInDMAAddress | ~ | X | Host In | 8938 | х | integer | X | | HostInID | ~ | <b>'</b> | Host In | 8900 | х | | X | | HostInState | ~ | <b>'</b> | Host In | 8918 | Х | integer | X | | HostInState2 | <b>/</b> | <b>'</b> | Host In | 8940 | Х | integer | X | | HostTextureAddress | ~ | × | Control<br>Status | 0100 | | integer | | | HsEnd | ~ | <b>'</b> | Video<br>Control | 3030 | | integer | | | HsStart | ~ | <b>'</b> | Video<br>Control | 3028 | | integer | | | HTotal | ~ | ′ | Video<br>Control | 3010 | | integer | | | IndexBaseAddress | ~ | / | Host In | B700 | х | integer | X | | IndexedDoubleVertex | × | / | Host In | B7B0 | х | integer | X | | IndexedLineList | X | <b>'</b> | Host In | B728 | х | integer | X | | IndexedLineStrip | × | <b>'</b> | Host In | B730 | х | integer | X | | IndexedPointList | X | <b>'</b> | Host In | B738 | x | integer | X | | IndexedPolygon | X | ~ | Host In | B740 | x | integer | X | | IndexedTriangleFan | X | ~ | Host In | B718 | x | integer | X | | IndexedTriangleList | X | ~ | Host In | B710 | x | integer | X | | IndexedTriangleStrip | × | ~ | Host In | B720 | x | integer | X | | IndexedVertex | X | ~ | Host In | B7A8 | x | integer | X | | InFIFOSpace | <b>'</b> | × | Control<br>Status | 0018 | | integer | | | IntEnable | <b>'</b> | ~ | Control<br>Status | 8000 | | bitfield | | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |--------------------------|---------------|----------|------------------------------|--------|----------------|----------|--------------| | InterruptLine | ~ | ~ | | 3060 | | integer | | | IntFlags | ~ | ~ | Control<br>Control<br>Status | 0010 | | bitfield | | | InvalidateCache | × | ~ | | B358 | x | bitfield | ~ | | KdBStart | ~ | <b>'</b> | | 8D30 | х | fixed | × | | KdGStart | <b>'</b> | <b>/</b> | Texture | 8D18 | х | fixed | X | | KdRStart | ~ | <b>'</b> | | 8D00 | х | fixed | X | | KdStart | <b>/</b> | <b>'</b> | Texture | 86E0 | Х | fixed | X | | KsBStart | • | • | Texture<br>Applicatio<br>n | 8CB0 | x | fixed | × | | KsGStart | ~ | <b>'</b> | Texture<br>Applicatio<br>n | 8C98 | х | fixed | × | | KsRStart | ~ | ~ | Texture<br>Applicatio<br>n | 8C80 | x | fixed | × | | KsStart | ~ | <b>'</b> | Texture | 86C8 | х | fixed | X | | LBClearDataL | ~ | <b>'</b> | LB Read | B550 | х | integer | X | | LBClearDataU | <b>'</b> | <b>/</b> | LB Read | B558 | х | integer | X | | LBDepth | × | <b>'</b> | LB<br>Read/Ho<br>st Out | 88B0 | x | integer | × | | LBDestReadBufferAddr | ~ | <b>'</b> | LB Read | B510 | х | integer | | | LBDestReadBufferOffset | ~ | <b>'</b> | LB Read | B518 | х | integer | | | LBDestReadEnables | <b>/</b> | <b>'</b> | LB Read | B508 | х | bitfield | X | | LBDestReadEnables And | X | <b>/</b> | LB Read | B590 | х | bitfield | X | | LBDestReadEnables Or | X | <b>'</b> | LB Read | B598 | х | bitfield | X | | LBDestReadMode | <b>/</b> | <b>'</b> | LB Read | B500 | Х | integer | X | | LBDestReadModeAnd | X | 1 | | B580 | Х | bitfield | X | | LBDestReadModeOr | X | | | B588 | Х | bitfield | X | | LBReadFormat | ~ | _ | | 8888 | х | bitfield | × | | LBSourceReadBufferAddr | ~ | <b>'</b> | | B528 | х | integer | X | | LBSourceReadBufferOffset | <b>'</b> | | LB Read | | х | bitfield | X | | LBSourceReadMode | <b>'</b> | | LB Read | | х | integer | X | | LBSourceReadMode And | X | | LB Read | | х | bitfield | X | | LBSourceReadModeOr | X | | LB Read | | Х | bitfield | X | | LBStencil | X | | Host Out | | х | bitfield | X | | LBWriteBufferAddr | <b>/</b> | - | LB Write | | X | integer | X | | LBWriteBufferOffset | <b>/</b> | <b>'</b> | LB Write | | Х | integer | X | | LBWriteFormat | <b>/</b> | <b>'</b> | LB Write | | X | bitfield | X | | LBWriteMode | <b>/</b> | | LB Write | | X | bitfield | X | | LBWriteModeAnd | X | <b>/</b> | LB Write | | X | bitfield | X | | LBWriteModeOr | X | <b>'</b> | LB Write | AC88 | X | bitfield | X | | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |--------------------------------|---------------|----------|-------------------|--------|----------------|----------|--------------| | LineCoord0 | X | ~ | Delta | 9760 | х | bitfield | X | | LineCoord1 | X | / | Delta | 9770 | х | bitfield | X | | LineMode | ~ | <b>/</b> | Delta | 94A8 | х | bitfield | X | | LineModeAnd | X | <b>/</b> | Delta | AAF0 | х | bitfield | X | | LineModeOr | X | / | Delta | AAF8 | х | bitfield | X | | LineStippleMode | ~ | <b>/</b> | Stipple | 81A8 | х | Bitfield | | | LineStippleModeAnd | X | <b>/</b> | Stipple | ABC0 | х | bitfield | X | | LineStippleModeOr | X | / | Stipple | ABC8 | х | bitfield | X | | LineWidth | <b>'</b> | / | Delta | 94B0 | х | integer | X | | LineWidthOffset | <b>'</b> | / | Delta | 94B8 | х | integer | X | | LoadLineStippleCounters | <b>'</b> | / | Stipple | 81B0 | х | Bitfield | <b>/</b> | | LocalMemCaps | ~ | <b>'</b> | Memory<br>Control | 1018 | | Bitfield | | | LocalMemControl | ~ | ~ | Memory<br>Control | 1028 | | Bitfield | | | LocalMemPowerDown | <b>'</b> | <b>'</b> | Memory<br>Control | 1038 | | Bitfield | | | LocalMemRefresh | • | • | Memory<br>Control | 1030 | | Bitfield | | | LocalMemTiming | • | • | Memory<br>Control | 1020 | | Bitfield | | | LOD | | • | Texture<br>Index | 83D0 | x | fixed | × | | LOD1 | • | ~ | Texture<br>Index | 8448 | х | fixed | X | | LodRange0 | ~ | <b>'</b> | Texture<br>Index | B348 | x | bitfield | × | | LodRange1 | ~ | ~ | Texture<br>Index | B350 | х | fixed | × | | LogicalOpMode | <b>'</b> | / | Logic Op | 8828 | х | bitfield | X | | LogicalOpModeAnd | × | ~ | Logic Op | ACE0 | х | bitfield | X | | LogicalOpModeOr | X | <b>/</b> | Logic Op | ACE8 | х | bitfield | X | | LogicalTexturePage | ~ | × | Control<br>Status | 0118 | | integer | | | LogicalTexturePage TableAddr | ~ | ~ | Texture<br>Read | B4D0 | x | integer | × | | LogicalTexturePage TableLength | <b>'</b> | <b>'</b> | Texture<br>Read | B4D8 | х | integer | X | | LUT[015] | ~ | 1 | LUT | 8E80 | х | bitfield | X | | LUTAddress | ~ | ~ | Texture<br>Read | 84D0 | х | integer | × | | LUTData | ~ | ~ | LUT | 84C8 | х | integer | X | | LUTIndex | ~ | ~ | LUT | 84C0 | х | integer | X | | LUTMode | <b>/</b> | <b>/</b> | LUT | B378 | х | bitfield | X | | LUTModeAnd | X | <b>/</b> | LUT | AD70 | х | bitfield | X | | LUTModeOr | X | <b>'</b> | LUT | AD78 | х | bitfield | X | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |---------------------------------|---------------|----------|-------------------|--------|----------------|----------|--------------| | LUTTransfer | <b>'</b> | • | Texture<br>Read | 84D8 | х | bitfield | × | | MaxHitRegion | X | <b>/</b> | Host Out | 8C30 | х | bitfield | <b>/</b> | | MaxRegion | <b>/</b> | <b>/</b> | Host Out | 8C18 | х | bitfield | | | MemBypassWriteMask | <b>'</b> | ~ | Memory<br>Control | 1008 | | Integer | | | MemCounter | ~ | × | Memory<br>Control | 1000 | | Integer | | | MemScratch | <b>'</b> | <b>'</b> | Memory<br>Control | 1010 | | Integer | | | MinHitRegion | × | <b>/</b> | Host Out | 8C28 | x | bitfield | ~ | | MinRegion | <b>/</b> | / | Host Out | 8C10 | х | bitfield | × | | MiscControl | <b>'</b> | • | Video<br>Control | 3088 | | Bitfield | | | OutPutFIFOWords | <b>'</b> | × | Control<br>Status | 0020 | | integer | | | Packed16Pixels | X | • | 2D Set<br>Up | B638 | X | integer | • | | Packed4Pixels | X | • | 2D Set<br>Up | B668 | X | integer | • | | Packed8Pixels | X | • | 2D Set<br>Up | B630 | х | integer | • | | PCIAbortAddress | <b>'</b> | × | Control<br>Status | 0098 | | integer | | | PCIAbortStatus | <b>'</b> | × | Control<br>Status | 0090 | | bitfield | | | PCIFeedbackCount | <b>'</b> | × | Control<br>Status | 8800 | | integer | | | PCIPLLStatus | <b>'</b> | • | Control<br>Status | 00F0 | | bitfield | | | PhysicalPageAllocationTableAddr | | • | Texture<br>Read | B4C0 | x | integer | X | | PickResult | X | <b>'</b> | Host Out | | x | bitfield | ~ | | PixelSize | <b>'</b> | • | Raster-<br>izer | 80C0 | х | Bitfield | • | | PointSize | <b>'</b> | <b>'</b> | Delta | 9498 | х | integer | X | | PointTable[03] | <b>/</b> | • | Raster-<br>izer | 8080 | X | bitfield | × | | ProvokingVertex | <b>'</b> | <b>'</b> | Delta | 9338 | Х | bitfield | ~ | | ProvokingVertexMask | <b>'</b> | <b>'</b> | Delta | 9358 | Х | bitfield | X | | Q1Start Q1Start | <u> </u> | <u> </u> | Texture<br>Coord | 8430 | х | fixed | X | | QStart | <b>'</b> | <b>'</b> | Texture<br>Coord | 83B8 | x | fixed | × | | RasterizerMode | <b>'</b> | <b>'</b> | Raster-<br>izer | 80A0 | х | Bitfield | X | | RasterizerModeAnd | X | ~ | Raster-<br>izer | ABA0 | х | bitfield | × | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|----------|-------------------|--------------|----------------|----------|--------------| | RasterizerModeOr | X | ~ | Raster- | ABA8 | Х | bitfield | × | | BDIndeyCentral | ~ | ~ | izer<br>RAMDAC | 1038 | | Integer | | | RDIndexControl | | | Control | 4036 | | integer | | | RDIndexedData | ~ | <b>/</b> | RAMDAC | 4030 | | Integer | | | | - | | Control | | | | | | RDIndexHigh | ~ | <b>/</b> | RAMDAC | 4028 | | Integer | | | | | | Control | | | | | | RDIndexLow | ~ | ~ | RAMDAC | 4020 | | Integer | | | DDD-1-44-D-4- | | | Control | 4000 | | lata san | | | RDPaletteData | | | RAMDAC<br>Control | 4008 | | Integer | | | RDPaletteReadAddress | | ~ | RAMDAC | <b>4</b> 018 | | Integer | | | NDF alettereau Audi ess | | | Control | 4010 | | integer | | | RDPaletteWriteAddress | / | <b>/</b> | RAMDAC | 4000 | | Integer | | | The diotion into the dioco | - | | Control | | | ogo. | | | RDPixelMask | ~ | <b>'</b> | RAMDAC | 4010 | | Integer | | | | | | Control | | | _ | | | RectangleHeight | ~ | <b>'</b> | | 94E0 | х | float | X | | RectanglePosition | | • | 2D Set<br>Up | B600 | x | integer | × | | RemoteMemControl | ~ | ′ | | 1100 | | Integer | | | Render | X | ~ | | 8038 | х | Bitfield | ~ | | Render2D | X | / | 2D Set | B640 | х | bitfield | X | | Ttorido:25 | | | Up | | | 2.1 | | | Render2DGlyph | × | <b>'</b> | 2D Set | B648 | х | bitfield | X | | | | | Up | | | | | | RenderPatchOffset | ~ | <b>'</b> | | B610 | X | bitfield | X | | Daniel de la companya | · · | | Up<br>Dalta | 0000 | | 4 | _ | | RepeatLine | X | <b>/</b> | Delta | 9328 | Х | tag | ~ | | RepeatTriangle | X | <i>V</i> | Delta | 9310 | X | tag | ~ | | ResetPickResult | X | <i>V</i> | Host Out | | X | tag | • | | ResetStatus | | | Status | 0000 | | integer | | | RetainedRender | ~ | <b>'</b> | | B7A0 | X | bitfield | <b>/</b> | | RLCount | X | | 2D Set<br>Up | B678 | X | integer | X | | RLData | ~ | ~ | | B670 | х | integer | X | | RLEMask | ~ | ~ | Host Out | 8C48 | х | bitfield | X | | RouterMode | ~ | / | Router | 8840 | х | bitfield | X | | RStart | ~ | ~ | Color<br>DDA | 8780 | х | fixed | × | | S1Start | ~ | ~ | Texture<br>Coord | 8400 | x | fixed | × | | SaveLineStippleCounters | X | ~ | Stipple | 81C0 | х | tag | <b>/</b> | | | | 1 | | 1 | | , - | 1 | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |---------------------------------|---------------|----------|----------------------------------|--------|----------------|----------|--------------| | ScissorMaxXY | <b>'</b> | ~ | Scissor | 8190 | х | Bitfield | X | | ScissorMinXY | ~ | <b>/</b> | Scissor | 8188 | x | Bitfield | X | | ScissorMode | ~ | <b>/</b> | | 8180 | x | Bitfield | X | | ScissorModeAnd | × | <b>/</b> | Scissor | ABB0 | x | bitfield | X | | ScissorModeOr | × | / | Scissor | ABB8 | x | bitfield | X | | ScreenBase | • | • | Video<br>Control | 3000 | | integer | | | ScreenBaseRight | ~ | • | Video<br>Control | 3080 | | Integer | | | ScreenSize | ~ | <b>/</b> | Scissor | 8198 | х | Bitfield | • | | ScreenStride | ~ | • | Video<br>Control | 3008 | | Integer | | | Security | × | <b>/</b> | Host In | 8908 | х | bitfield | X | | SetLogicalTexturePage | ~ | • | Texture<br>Read | B360 | x | bitfield | × | | SizeOfFramebuffer | <b>/</b> | | LB Read,<br>FB Read,<br>FB Write | | x | integer | × | | SStart | • | • | Coord | 8388 | x | fixed | × | | StartXDom | • | × | izer | 8000 | x | fixed | × | | StartXSub | • | × | Raster-<br>izer | 8010 | х | fixed | × | | StartY | × | × | Raster-<br>izer | 8020 | X | fixed | × | | StatisticMode | ~ | <b>/</b> | Host Out | | X | bitfield | X | | StatisticModeAnd | × | <b>/</b> | Host Out | | X | bitfield | X | | StatisticModeOr | × | <b>/</b> | Host Out | | X | bitfield | X | | Stencil | <b>/</b> | <b>/</b> | Stencil | 8998 | X | bitfield | <b>✓</b> × | | StencilData | <b>/</b> | <b>/</b> | Stencil | 8990 | X | bitfield | | | StencilDataAnd | × | <b>/</b> | Stencil | B3E0 | X | bitfield | X | | StencilDataOr | × | <b>'</b> | | B3E8 | X | bitfield | X | | StencilMode | ~ | <b>/</b> | Stencil | 8988 | X | bitfield | X | | StencilModeAnd | × | <b>/</b> | Stencil | AC60 | X | bitfield | X | | StencilModeOr | × | <b>/</b> | Stencil | AC68 | X | bitfield | X | | StripeOffsetY | • | • | Raster-<br>izer | 80C8 | x | fixed | × | | SuspendUntilFrameBlank | × | ~ | Framebuf<br>fer Write | 8C78 | x | bitfield | ~ | | Sync | X | <b>'</b> | Host Out | 8C40 | х | bitfield | ~ | | T1Start | ~ | ~ | Texture<br>coord | 8418 | x | fixed | × | | TailPhysicalPage Allocation[03] | ~ | - | | B4A0 | x | integer | × | | TexDMAAddress | ~ | × | Control<br>Status | 0120 | | integer | | | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |----------------------------|---------------|----------|----------------------------|--------|----------------|----------|--------------| | TexFIFOSpace | ~ | X | Control<br>Status | 0128 | | integer | | | TextRender2DGlyph0 | X | ~ | | 8708 | х | bitfield | ~ | | TextRender2DGlyph1 | × | ~ | | 8718 | х | bitfield | ~ | | TextRender2DGlyph2 | × | ~ | | 8728 | x | bitfield | ~ | | TextRender2DGlyph3 | X | ~ | | 8738 | х | bitfield | ~ | | TextRender2DGlyph4 | × | ~ | | 8748 | х | bitfield | ~ | | TextRender2DGlyph5 | × | ~ | | 8758 | x | bitfield | ~ | | TextRender2DGlyph6 | × | ~ | | 8768 | x | bitfield | ~ | | TextRender2DGlyph7 | × | ~ | Raster-<br>izer | 8778 | х | bitfield | ~ | | TextTGlyphAddr0 | × | ~ | Raster-<br>izer | 8700 | x | integer | × | | TextTGlyphAddr1 | × | ~ | Raster-<br>izer | 8710 | x | integer | × | | TextTGlyphAddr2 | × | ~ | Raster-<br>izer | 8720 | x | integer | × | | TextTGlyphAddr3 | × | • | Raster-<br>izer | 8730 | x | integer | × | | TextTGlyphAddr4 | × | • | Raster-<br>izer | 8740 | x | integer | × | | TextTGlyphAddr5 | × | <b>'</b> | Raster-<br>izer | 8750 | x | integer | × | | TextTGlyphAddr6 | × | <b>'</b> | Raster-<br>izer | 8760 | x | integer | × | | TextTGlyphAddr7 | × | • | Raster-<br>izer | 8770 | x | integer | × | | TextureApplication ModeAnd | × | | Texture<br>Applicatio<br>n | | x | bitfield | × | | TextureApplication ModeOr | × | • | Texture<br>Applicatio<br>n | AC58 | x | bitfield | × | | TextureApplicationMode | ~ | - | Texture<br>Applicatio<br>n | 8680 | x | bitfield | × | | TextureBaseAddr[16] | ~ | ~ | Texture<br>Read | 8500 | x | integer | X | | TextureCacheControl | ~ | <b>'</b> | | 8490 | х | bitfield | X | | TextureChromaLower0 | ~ | ~ | Color<br>DDA | 84F0 | x | bitfield | × | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |-----------------------------------|---------------|----------|--------------------------|--------|----------------|----------|--------------| | TextureChromaLower1 | / | <b>'</b> | Texture<br>Filter | 8608 | х | bitfield | × | | TextureChromaUpper0 | <b>'</b> | ~ | | 84E8 | х | bitfield | × | | TextureChromaUpper1 | <b>'</b> | <b>'</b> | | 8600 | x | bitfield | × | | TextureCompositeAlphaMode0 | ~ | ~ | Texture<br>Composit<br>e | B310 | х | bitfield | × | | TextureCompositeAlphaMode0An<br>d | × | ~ | Texture<br>Composit<br>e | B390 | х | bitfield | × | | TextureCompositeAlphaMode0Or | × | ~ | Texture<br>Composit<br>e | B398 | x | bitfield | × | | TextureCompositeAlphaMode1 | ~ | ~ | Texture<br>Composit<br>e | B320 | x | | X | | TextureCompositeAlphaMode1An<br>d | × | ~ | Texture<br>Composit<br>e | B3B0 | x | bitfield | × | | TextureCompositeAlphaMode1Or | × | ~ | Texture<br>Composit<br>e | B3B8 | x | bitfield | × | | TextureCompositeColorMode0 | ~ | • | Texture<br>Composit<br>e | B308 | х | bitfield | × | | TextureCompositeColorMode0And | × | ~ | Texture<br>Composit<br>e | B380 | х | bitfield | × | | TextureCompositeColorMode0Or | × | ~ | Texture<br>Composit<br>e | B388 | x | bitfield | X | | TextureCompositeColorMode1 | ~ | ~ | - | B318 | x | bitfield | × | | TextureCompositeColorMode1And | × | ~ | Texture<br>Composit<br>e | B3A0 | x | bitfield | × | | TextureCompositeColorMode1Or | × | - | Texture<br>Composit<br>e | B3A8 | x | bitfield | × | | TextureCompositeFactor0 | ~ | ~ | Texture<br>Composit<br>e | B328 | x | bitfield | | | TextureCompositeFactor1 | ~ | ~ | Texture<br>Composit<br>e | B330 | x | bitfield | × | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |------------------------|---------------|----------|--------------------------|--------|----------------|----------|--------------| | TextureCompositeMode | ~ | ~ | Texture<br>Composit<br>e | B300 | x | bitfield | × | | TextureCoordMode | ~ | ~ | Texture coord | 8380 | х | bitfield | × | | TextureCoordModeAnd | × | ~ | Texture coord | AC20 | х | | × | | TextureCoordModeOr | X | ~ | Texture coord | AC28 | х | bitfield | × | | TextureData | × | <b>'</b> | Localbuff<br>er R/W | 88E8 | X | integer | × | | TextureDownloadControl | ~ | X | Status | 0108 | | bitfield | | | TextureDownloadOffset | ~ | • | Localbuff<br>er R/W | | X | | × | | TextureEnvColor | ~ | <b>'</b> | | 8688 | Х | bitfield | X | | TextureFilterMode | ~ | <b>'</b> | Texture | 84E0 | Х | bitfield | X | | TextureFilterModeAnd | × | <b>'</b> | Texture | AD50 | Х | bitfield | X | | TextureFilterModeOr | × | <b>/</b> | Texture | AD58 | x | bitfield | X | | TextureIndexMode0 | ~ | <b>'</b> | Texture<br>Index | B338 | X | bitfield | × | | TextureIndexMode0And | × | <b>'</b> | Texture<br>Index | B3C0 | x | bitfield | × | | TextureIndexMode0Or | × | <b>'</b> | Texture<br>Index | B3C8 | х | bitfield | × | | TextureIndexMode1 | ~ | <b>'</b> | Texture<br>Index | B340 | x | bitfield | × | | TextureIndexMode1And | × | <b>'</b> | Texture<br>Index | B3D0 | x | bitfield | × | | TextureIndexMode1Or | × | <b>'</b> | Texture<br>Index | B3D8 | х | bitfield | × | | TextureLodBiasS | ~ | <b>'</b> | Texture<br>Index | 8450 | x | fixed | × | | TextureLodBiasT | ~ | ~ | Texture<br>Index | 8458 | х | fixed | × | | TextureLODScale | • | • | Texture<br>coord | 9340 | x | float | × | | TextureLODScale1 | ~ | ~ | Texture coord | 9348 | х | float | × | | TextureMapSize | ~ | ~ | Texture<br>Read | B428 | х | integer | X | | TextureMapWidth[16] | ~ | ~ | Texture<br>Read | 8580 | х | bitfield | × | | TextureOperation | ~ | × | Control<br>Status | 0110 | | integer | | | TextureReadMode0 | ~ | ~ | Texture<br>Read | B400 | х | bitfield | × | | TextureReadMode0And | X | ~ | Texture<br>Read | AC30 | х | bitfield | × | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |----------------------------------|---------------|----------|-----------------|--------|----------------|----------|--------------| | TextureReadMode0Or | × | ~ | Texture<br>Read | AC38 | Х | bitfield | X | | TextureReadMode1 | ~ | ~ | Texture<br>Read | B408 | x | bitfield | × | | TextureReadMode1And | X | ~ | Texture<br>Read | AD40 | x | bitfield | × | | TextureReadMode1Or | X | • | Texture<br>Read | AD48 | x | bitfield | × | | TouchLogicalPage | X | <b>'</b> | Texture<br>Read | B370 | х | bitfield | ~ | | TStart | <b>'</b> | <b>'</b> | Texture coord | 83A0 | x | fixed | × | | <b>UpdateLineStippleCounters</b> | X | / | Stipple | 81B8 | х | Bitfield | ~ | | UpdateLogicalTextureInfo | X | ~ | Texture<br>Read | B368 | х | tag | ~ | | V0FloatA | <b>'</b> | <b>/</b> | Delta | 91C0 | х | float | X | | V0FloatB | ~ | <b>/</b> | Delta | 91B8 | х | float | X | | V0FloatF | ~ | / | Delta | 91C8 | Х | float | X | | V0FloatG | <b>'</b> | <b>'</b> | Delta | 91B0 | Х | float | X | | V0FloatKdB | ~ | <b>'</b> | Delta | 9078 | Х | float | X | | V0FloatKdG | ~ | <b>'</b> | Delta | 9070 | Х | float | X | | V0FloatKdR | ~ | <b>'</b> | Delta | 9068 | х | float | X | | V0FloatKsB | ~ | <b>'</b> | Delta | 9060 | Х | float | | | V0FloatKsG | ~ | <b>'</b> | Delta | 9058 | Х | float | X | | V0FloatKsR | ~ | <b>'</b> | Delta | 9050 | Х | float | X | | V0FloatPackedColor | X | <b>'</b> | Delta | 91F0 | Х | bitfield | X | | V0FloatPackedDiffuse | X | <b>'</b> | Delta | 9048 | Х | bitfield | X | | V0FloatPackedSpecularFog | X | <b>'</b> | Delta | 91F8 | Х | bitfield | X | | V0FloatQ | ~ | <b>'</b> | Delta | 9190 | Х | float | X | | V0FloatQ1 | ~ | <b>'</b> | Delta | 9010 | Х | float | X | | V0FloatR | ~ | <b>'</b> | Delta | 91A8 | Х | float | X | | V0FloatS | ~ | <b>'</b> | Delta | 9180 | х | float | X | | V0FloatS1 | <b>'</b> | <b>/</b> | Delta | 9000 | х | float | × | | V0FloatT | <b>/</b> | <b>'</b> | Delta | 9188 | х | float | X | | V0FloatT1 | <b>'</b> | <b>/</b> | Delta | 9008 | Х | float | X | | V0FloatX | <b>'</b> | <b>/</b> | Delta | 91D0 | Х | float | X | | V0FloatY | <b>/</b> | <b>/</b> | Delta | 91D8 | Х | float | × | | V0FloatZ | <b>'</b> | <b>'</b> | Delta | 91E0 | Х | float | X | | V1FloatA | <b>/</b> | <b>'</b> | Delta | 9240 | Х | float | X | | V1FloatB | <b>'</b> | <b>'</b> | Delta | 9238 | Х | float | X | | V1FloatF | <b>/</b> | <b>'</b> | Delta | 9248 | х | float | X | | V1FloatG | <b>V</b> | <b>'</b> | Delta | 9230 | х | float | X | | V1FloatKdB | <b>/</b> | <b>V</b> | Delta | 90F8 | х | float | X | | V1FloatKdG | <b>/</b> | <b>'</b> | Delta | 90F0 | Х | float | X | | V1FloatKdR | <b>'</b> | <b>'</b> | Delta | 90E8 | х | float | X | | V1FloatKsB | <b>'</b> | ~ | Delta | 90E0 | Х | float | X | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |--------------------------|---------------|----------|-------------------|--------|----------------|----------|--------------| | V1FloatKsG | V | | Delta | 90D8 | х | float | X | | V1FloatKsR | ~ | <b>/</b> | Delta | 90D0 | х | float | X | | V1FloatPackedColor | × | <b>/</b> | Delta | 9270 | х | bitfield | X | | V1FloatPackedDiffuse | × | <b>/</b> | Delta | 90C8 | х | bitfield | X | | V1FloatPackedSpecularFog | × | <b>/</b> | Delta | 9278 | х | bitfield | X | | V1FloatQ | / | <b>/</b> | Delta | 9210 | х | float | X | | V1FloatQ1 | / | <b>/</b> | Delta | 9090 | х | float | X | | V1FloatR | ~ | <b>/</b> | Delta | 9228 | х | float | X | | V1FloatS | / | <b>/</b> | Delta | 9200 | х | float | X | | V1FloatS1 | / | <b>/</b> | Delta | 9080 | х | float | X | | V1FloatT | <b>/</b> | <b>/</b> | Delta | 9208 | х | float | X | | V1FloatT1 | / | <b>/</b> | Delta | 9088 | х | float | X | | V1FloatX | ~ | <b>/</b> | Delta | 9250 | х | float | X | | V1FloatY | / | <b>/</b> | Delta | 9258 | х | float | X | | V1FloatZ | ~ | <b>/</b> | Delta | 9260 | Х | float | X | | V2FloatA | ~ | <b>/</b> | Delta | 92C0 | Х | float | X | | V2FloatB | ~ | <b>/</b> | Delta | 92B8 | х | float | X | | V2FloatF | ~ | | Delta | 92C8 | х | float | X | | V2FloatG | ~ | <b>/</b> | Delta | 92B0 | Х | float | X | | V2FloatKdB | ~ | <b>/</b> | Delta | 9178 | х | float | X | | V2FloatKdG | ~ | <b>/</b> | Delta | 9170 | х | float | X | | V2FloatKdR | ~ | <b>/</b> | Delta | 9168 | Х | float | X | | V2FloatKsB | ~ | <b>/</b> | Delta | 9160 | х | float | X | | V2FloatKsG | ~ | <b>/</b> | Delta | 9158 | Х | float | X | | V2FloatKsR | ~ | <b>/</b> | Delta | 9150 | Х | float | X | | V2FloatPackedColor | × | <b>/</b> | Delta | 92F0 | х | bitfield | X | | V2FloatPackedDiffuse | × | <b>/</b> | Delta | 9148 | х | bitfield | X | | V2FloatPackedSpecularFog | × | <b>/</b> | Delta | 92F8 | х | bitfield | X | | V2FloatQ | ~ | <b>/</b> | Delta | 9290 | х | float | X | | V2FloatQ1 | <b>/</b> | <b>/</b> | Delta | 9110 | х | float | X | | V2FloatR | <b>/</b> | <b>/</b> | Delta | 92A8 | х | float | X | | V2FloatS | ~ | <b>/</b> | Delta | 9280 | х | float | X | | V2FloatS1 | <b>/</b> | <b>/</b> | Delta | 9100 | х | float | X | | V2FloatT | ~ | <b>/</b> | Delta | 9288 | х | float | X | | V2FloatT1 | <b>/</b> | <b>/</b> | Delta | 9108 | х | float | X | | V2FloatX | <b>/</b> | <b>/</b> | Delta | 92D0 | х | float | X | | V2FloatY | <b>/</b> | ~ | Delta | 92D8 | х | float | X | | V2FloatZ | <b>/</b> | <b>'</b> | Delta | 92E0 | х | float | X | | VbEnd | <b>/</b> | <b>/</b> | Video | 3040 | х | integer | | | | | | Control | | | | | | VCIkRDacCtl | • | • | Control<br>Status | 0040 | 0 | bitfield | | | Vertex0 | X | ~ | Host In | B7B8 | х | integer | X | | Vertex1 | X | <b>/</b> | Host In | B7C0 | х | integer | X | | Vertex2 | X | <b>/</b> | Host In | B7C8 | х | integer | X | | Name | Read-<br>back | Write | Name | Offset | Reset<br>Value | Format | Com-<br>mand | |--------------------------|---------------|----------|-----------------------------|--------|----------------|----------|--------------| | VertexBaseAddress | ~ | ~ | Host In | B708 | х | integer | X | | VertexControl | <b>/</b> | <b>'</b> | Host In | B798 | х | bitfield | X | | VertexData | X | <b>'</b> | Host In | B7E8 | х | integer | X | | VertexData0 | X | <b>'</b> | Host In | B7D0 | х | integer | X | | VertexData1 | X | <b>'</b> | Host In | B7D8 | х | integer | X | | VertexData2 | X | <b>'</b> | Host In | B7E0 | х | integer | X | | VertexFormat | <b>/</b> | <b>'</b> | Host In | B790 | х | integer | X | | VertexLineList | X | <b>'</b> | Host In | B760 | х | integer | X | | VertexLineStrip | X | <b>'</b> | Host In | B768 | х | integer | X | | VertexPointList | X | <b>'</b> | Host In | B770 | х | integer | X | | VertexPolygon | X | <b>'</b> | Host In | B778 | х | integer | X | | VertexTagList[015] | <b>/</b> | <b>'</b> | Host In | B800 | х | bitfield | X | | VertexTagList[1631] | ~ | <b>'</b> | Host In | B880 | х | bitfield | X | | VertexTriangleFan | × | <b>'</b> | Host In | B750 | х | integer | × | | VertexTriangleList | × | <b>'</b> | Host In | B748 | х | integer | X | | VertexTriangleStrip | X | <b>'</b> | Host In | B758 | х | integer | X | | VertexValid | ~ | <b>'</b> | Host In | B788 | х | integer | X | | VerticalLineCount | ~ | × | Video<br>Control | 3070 | | integer | | | VideoControl | ~ | ~ | Video<br>Control | 3058 | | bitfield | | | VideoOverlayBase0 | - | ~ | Video<br>Overlay<br>Control | 3120 | | bitfield | | | VideoOverlayBase1 | - | ~ | Video<br>Overlay<br>Control | 3128 | | bitfield | | | VideoOverlayBase2 | ~ | - | Video<br>Overlay<br>Control | 3130 | | bitfield | | | VideoOverlayFieldOffset | ~ | ~ | Video<br>Overlay<br>Control | 3170 | | bitfield | | | VideoOverlayFIFO Control | | • | Video<br>Overlay<br>Control | 3110 | | bitfield | | | VideoOverlayHeight | | • | Video<br>Overlay<br>Control | 3148 | | integer | | | VideoOverlayIndex | <u> </u> | | Video<br>Overlay<br>Control | 3118 | | bitfield | | | VideoOverlayMode | <b>'</b> | <u> </u> | Video<br>Overlay<br>Control | 3108 | | bitfield | | | VideoOverlayOrigin | <b>'</b> | <b>'</b> | Video<br>Overlay<br>Control | 3150 | | bitfield | | | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |--------------------------|---------------|-------|-----------------------------|--------|----------------|----------|--------------| | VideoOverlayShrinkXDelta | • | ~ | Video<br>Overlay<br>Control | 3158 | | bitfield | | | VideoOverlayStatus | ~ | ~ | Video<br>Overlay<br>Control | 3178 | | bitfield | | | VideoOverlayStride | ~ | ~ | Video<br>Overlay<br>Control | 3138 | | integer | | | VideoOverlayUpdate | ~ | - | Video<br>Overlay<br>Control | 3100 | | integer | | | VideoOverlayWidth | ~ | ~ | Video<br>Overlay<br>Control | 3140 | | integer | | | VideoOverlayYDelta | • | • | Video<br>Overlay<br>Control | 3168 | | Integer | | | VideoOverlayZoomXDelta | <b>~</b> | • | Video<br>Overlay<br>Control | 3160 | | integer | | | VSAControl | | | Video<br>Stream<br>Control | 5900 | | bitfield | | | VSACurrentLine | | × | Video<br>Stream<br>Control | 5910 | | integer | | | VSAFifoControl | • | ~ | Video<br>Stream<br>Control | 59B8 | | bitfield | | | VSAInterruptLine | ~ | ~ | Video<br>Stream<br>Control | 5908 | | Integer | | | VSATimeStamp0 | ~ | × | Video<br>Stream<br>Control | 59C0 | | integer | | | VSATimeStamp1 | ~ | × | Video<br>Stream<br>Control | 59C8 | | integer | | | VSATimeStamp2 | • | × | Video<br>Stream<br>Control | 59D0 | | integer | | | VSAVBIAddress0 | ~ | ~ | Video<br>Stream<br>Control | 5978 | | integer | | | VSAVBIAddress1 | <b>'</b> | • | Video<br>Stream<br>Control | 5980 | | integer | | | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |----------------------|---------------|----------|----------------------------|--------|----------------|---------|--------------| | VSAVBIAddress2 | ~ | <b>'</b> | Video<br>Stream<br>Control | 5988 | | integer | | | VSAVBIAddressHost | <b>~</b> | • | Video<br>Stream<br>Control | 5968 | | integer | | | VSAVBIAddressIndex | <b>~</b> | × | Video<br>Stream<br>Control | 5970 | | integer | | | VSAVBIEndData | | • | Video<br>Stream<br>Control | 59B0 | | integer | | | VSAVBIEndLine | ~ | <b>'</b> | Video<br>Stream<br>Control | 59A0 | | integer | | | VSAVBIStartData | ~ | <b>'</b> | Video<br>Stream<br>Control | 59A8 | | integer | | | VSAVBIStartLine | ~ | <u> </u> | Video<br>Stream<br>Control | 5998 | | integer | | | VSAVBIStride | ~ | ~ | Video<br>Stream<br>Control | 5990 | | integer | | | VSAVideoAddress0 | ~ | ~ | Video<br>Stream<br>Control | 5928 | | integer | | | VSAVideoAddress1 | ~ | ~ | Video<br>Stream<br>Control | 5930 | | integer | | | VSAVideoAddress2 | ~ | • | Video<br>Stream<br>Control | 5938 | | integer | | | VSAVideoAddressHost | ~ | - | Video<br>Stream<br>Control | 5918 | | integer | | | VSAVideoAddressIndex | ~ | • | Video<br>Stream<br>Control | 5920 | | integer | | | VSAVideoEndData | ~ | • | Video<br>Stream<br>Control | 5960 | | integer | | | VSAVideoEndLine | ~ | - | Video<br>Stream<br>Control | 5950 | | integer | | | VSAVideoStartData | ~ | • | Video<br>Stream<br>Control | 5958 | | integer | | | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |--------------------|---------------|----------|----------------------------|--------|----------------|----------|--------------| | VSAVideoStartLine | ~ | ~ | Video<br>Stream<br>Control | 5948 | | integer | | | VSAVideoStride | V | ~ | Video<br>Stream<br>Control | 5940 | | integer | | | VSBControl | V | • | Video<br>Stream<br>Control | 5A00 | | bitfield | | | VSBCurrentLine | V | - | Video<br>Stream<br>Control | 5A10 | | integer | | | VSBFifoControl | ~ | ~ | Video<br>Stream<br>Control | 5AB8 | | bitfield | | | VSBInterruptLine | V | <b>'</b> | Video<br>Stream<br>Control | 5A08 | | integer | | | VSBVBIAddress0 | <b>V</b> | • | Video<br>Stream<br>Control | 5A78 | | integer | | | VSBVBIAddress1 | <b>V</b> | • | Video<br>Stream<br>Control | 5A80 | | integer | | | VSBVBIAddress2 | <b>'</b> | ~ | Video<br>Stream<br>Control | 5A88 | | integer | | | VSBVBIAddressHost | <b>'</b> | ~ | Video<br>Stream<br>Control | 5A68 | | integer | | | VSBVBIAddressIndex | <b>'</b> | × | Video<br>Stream<br>Control | 5A70 | 0x2 | integer | | | VSBVBIEndData | <b>'</b> | ~ | Video<br>Stream<br>Control | 5AB0 | | integer | | | VSBVBIEndLine | V | ~ | Video<br>Stream<br>Control | 5AA0 | | integer | | | VSBVBIStartData | V | <b>'</b> | Video<br>Stream<br>Control | 5AA8 | | integer | | | VSBVBIStartLine | V | • | Video<br>Stream<br>Control | 5A98 | | integer | | | VSBVBIStride | V | <b>'</b> | Video<br>Stream<br>Control | 5A90 | | integer | | | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |----------------------|---------------|----------|----------------------------|--------|----------------|----------|--------------| | VSBVideoAddress0 | <u> </u> | • | Video<br>Stream<br>Control | 5A28 | 74.40 | integer | mana | | VSBVideoAddress1 | • | <b>/</b> | Video<br>Stream<br>Control | 5A30 | | integer | | | VSBVideoAddress2 | | | Video<br>Stream<br>Control | 5A38 | | integer | | | VSBVideoAddressHost | | - | Video<br>Stream<br>Control | 5A18 | | integer | | | VSBVideoAddressIndex | | × | Video<br>Stream<br>Control | 5A20 | | integer | | | VSBVideoEndData | <b>~</b> | | Video<br>Stream<br>Control | 5A60 | | integer | | | VSBVideoEndLine | <b>~</b> | • | Video<br>Stream<br>Control | 5A50 | | integer | | | VSBVideoStartData | <b>~</b> | | Video<br>Stream<br>Control | 5A58 | | integer | | | VSBVideoStartLine | <b>~</b> | • | Video<br>Stream<br>Control | 5A48 | | integer | | | VSBVideoStride | <b>~</b> | | Video<br>Stream<br>Control | 5A40 | | integer | | | VSConfiguration | <b>~</b> | • | Video<br>Stream<br>Control | 5800 | | bitfield | | | VSDMACommandBase | <b>~</b> | | Video<br>Stream<br>Control | 5AC8 | | integer | | | VSDMACommandCount | <b>~</b> | | Video<br>Stream<br>Control | 5AD0 | | integer | | | VSDMAMode | | | Video<br>Stream<br>Control | 5AC0 | | bitfield | | | VsEnd | • | - | Video<br>Control | 3050 | | integer | | | VSSerialBusControl | • | х | Video<br>Stream<br>Control | 5810 | | bitfield | | | VsStart | • | • | Video<br>Control | 3048 | | integer | | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |-------------------|---------------|----------|----------------------------|--------|----------------|----------|--------------| | VSStatus | ~ | × | Video<br>Stream<br>Control | 5808 | | bitfield | | | VTGAddress | <b>/</b> | / | FB Write | B0B0 | Х | integer | <b>/</b> | | VTGData | <b>'</b> | / | FB Write | B0B8 | x | integer | ~ | | VTotal | ~ | ~ | Video<br>Control | 3038 | | integer | | | WaitForCompletion | × | • | Raster-<br>izer | 80B8 | x | Bitfield | <b>/</b> | | Window | <b>'</b> | / | Stencil | 8980 | x | bitfield | X | | WindowAnd | × | / | Stencil | AB80 | x | bitfield | X | | WindowOr | × | <b>/</b> | Stencil | AB88 | х | bitfield | X | | WindowOrigin | <b>'</b> | <b>/</b> | Scissor | 81C8 | x | Bitfield | X | | XBias | <b>'</b> | <b>/</b> | Delta | 9480 | х | float | X | | YBias | ~ | <b>/</b> | Delta | 9488 | х | float | X | | YLimits | ~ | ~ | Raster-<br>izer | 8A08 | x | Bitfield | × | | YUVMode | <b>'</b> | <b>/</b> | YUV Unit | 8F00 | x | bitfield | X | | ZFogBias | <b>'</b> | <b>/</b> | Fog | 86B8 | x | float | X | | Zstart | ~ | ~ | Fog | ADD8 | х | integer | X | | ZStartL | ~ | ~ | Depth &<br>Fog | 89B8 | x | fixed | × | | ZStartU | ~ | <b>'</b> | Depth | 89B0 | х | fixed | X | ## 6.2 Registers Sorted by Offset | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |---------------------------|---------------|----------|--------------|--------|----------------|----------|--------------| | ResetStatus | Juon | | Control | 0000 | | integer | 7114114 | | | | | Status | | | | | | IntEnable | <b>/</b> | / | Control | 8000 | | bitfield | | | | | | Status | | | | | | IntFlags | <b>/</b> | ~ | Control | 0010 | | bitfield | | | 5 | | | Status | | | | | | InFIFOSpace | <b>/</b> | X | Control | 0018 | | integer | | | • | | | Status | | | | | | OutPutFIFOWords | ~ | X | Control | 0020 | | integer | | | | | | Status | | | | | | ControlDMAAddress | ~ | 1 | Control | 0028 | | integer | | | | | | Status | | | | | | ControlDMACount | ~ | / | Control | 0030 | | integer | | | | | | Status | | | | | | ErrorFlags | | | Control | 0038 | | bitfield | | | 5 | | | Status | | | | | | VClkRDacCtl | <b>/</b> | <b>/</b> | Control | 0040 | 0 | bitfield | | | | | | Status | | | | | | ApertureOne | <b>V</b> | <b>/</b> | Control | 0050 | | bitfield | | | • | | | Status | | | | | | ApertureTwo | <b>/</b> | / | Control | 0058 | | bitfield | | | • | | | Status | | | | | | ControlDMAControl | <b>/</b> | <b>/</b> | Control | 0060 | | bitfield | | | | | | Status | | | | | | FIFODiscon | <b>/</b> | / | Control | 0068 | | bitfield | | | | | | Status | | | | | | ChipConfig | <b>/</b> | / | Control | 0070 | | bitfield | | | 3 | | | Status | | | | | | AGPControl | <b>/</b> | / | Control | 0078 | | bitfield | | | - / | | | Status | | | | | | GPOutDMAAddress | <b>/</b> | X | Control | 0080 | | integer | | | | | | Status | | | | | | PCIFeedbackCount | <b>/</b> | X | Control | 0088 | | integer | | | | | | Status | | | | | | PCIAbortStatus | ~ | X | Control | 0090 | | bitfield | | | | | | Status | | | | | | PCIAbortAddress | <b>/</b> | X | Control | 0098 | | integer | | | | | | Status | | | | | | PCIPLLStatus PCIPLLStatus | <b>/</b> | <b>/</b> | Control | 00F0 | | bitfield | | | | | | Status | | | | | | HostTextureAddress | <b>/</b> | X | Control | 0100 | | integer | | | | 1 | | Status | | | | | | TextureDownloadControl | <b>/</b> | X | Control | 0108 | | bitfield | | | | 1 | | Status | | | | | | TextureOperation | <b>/</b> | X | Control | 0110 | | integer | | | · catalog polation | Ī | - | Status | | | | | | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |-----------------------|---------------|----------|-----------------------------|--------|----------------|----------|--------------| | LogicalTexturePage | ~ | X | Control | 0118 | | integer | | | TexDMAAddress | ~ | X | Status<br>Control<br>Status | 0120 | | integer | | | TexFIFOSpace | ~ | X | Control<br>Status | 0128 | | integer | | | ByAperture1Mode | ~ | ~ | Bypass<br>Control | 0300 | | Bitfield | | | ByAperture1Stride | ~ | ~ | Bypass<br>Control | 0308 | | Integer | | | ByAperture1YStart | ~ | ~ | Bypass<br>Control | 0310 | | Integer | | | ByAperture1UStart | ~ | ~ | Bypass<br>Control | 0318 | | Integer | | | ByAperture1VStart | ~ | ~ | Bypass<br>Control | 0320 | | Integer | | | ByAperture2Mode | ~ | ~ | Bypass<br>Control | 0328 | | Bitfield | | | ByAperture2Stride | ~ | ~ | Bypass<br>Control | 0330 | | Integer | | | ByAperture2YStart | ~ | ~ | Bypass<br>Control | 0338 | | Integer | | | ByAperture2UStart | ~ | ~ | Bypass<br>Control | 0340 | | Integer | | | ByAperture2VStart | ~ | ~ | Bypass<br>Control | 0348 | | Integer | | | ByDMAReadMode | ~ | <b>'</b> | Bypass<br>Control | 0350 | | Bitfield | | | ByDMAReadStride | ~ | <b>'</b> | Bypass<br>Control | 0358 | | Integer | | | ByDMAReadYStart | ~ | <b>'</b> | Bypass<br>Control | 0360 | | Integer | | | ByDMAReadUStart | ~ | ~ | Bypass<br>Control | 0368 | | Integer | | | ByDMAReadVStart | ~ | ~ | Bypass<br>Control | 0370 | | Integer | | | ByDMAReadCommandBase | ~ | ~ | Bypass<br>Control | 0378 | | Integer | | | ByDMAReadCommandCount | ~ | ~ | Bypass<br>Control | 0380 | | Integer | | | ByDMAWriteMode | ~ | <b>'</b> | Bypass<br>Control | 0388 | | Bitfield | | | ByDMAWriteStride | <b>'</b> | <b>'</b> | Bypass<br>Control | 0390 | | Integer | | | ByDMAWriteYStart | ~ | ~ | Bypass<br>Control | 0398 | | Integer | | | ByDMAWriteUStart | ~ | ~ | Bypass<br>Control | 03A0 | | Integer | | | ByDMAWriteVStart | <b>'</b> | <b>'</b> | Bypass<br>Control | 03A8 | | Integer | | | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |------------------------|---------------|----------|-------------------|--------|----------------|----------|--------------| | ByDMAWriteCommandBase | ~ | ~ | Bypass<br>Control | 03B0 | | Integer | | | ByDMAWriteCommandCount | ~ | ~ | Bypass<br>Control | 03B8 | | Integer | | | MemCounter | ~ | × | Memory<br>Control | 1000 | | Integer | | | MemBypassWriteMask | ~ | ~ | Memory<br>Control | 1008 | | Integer | | | MemScratch | ~ | <b>'</b> | Memory<br>Control | 1010 | | Integer | | | LocalMemCaps | • | • | Memory<br>Control | 1018 | | Bitfield | | | LocalMemTiming | • | • | Memory<br>Control | 1020 | | Bitfield | | | LocalMemControl | ~ | • | Memory<br>Control | 1028 | | Bitfield | | | LocalMemRefresh | • | • | Memory<br>Control | 1030 | | Bitfield | | | LocalMemPowerDown | ~ | • | Memory<br>Control | 1038 | | Bitfield | | | RemoteMemControl | • | • | Memory<br>Control | 1100 | | Integer | | | ScreenBase | • | • | Video<br>Control | 3000 | | integer | | | ScreenStride | • | • | Video<br>Control | 3008 | | Integer | | | HTotal | • | • | Video<br>Control | 3010 | | integer | | | HgEnd | • | • | Video<br>Control | 3018 | | integer | | | HbEnd | • | • | Video<br>Control | 3020 | | integer | | | HsStart | • | • | Video<br>Control | 3028 | | integer | | | HsEnd | • | • | Video<br>Control | 3030 | | integer | | | VTotal | • | <b>'</b> | Video<br>Control | 3038 | | integer | | | VbEnd | _ | <u> </u> | Video<br>Control | 3040 | х | integer | | | VsStart | ~ | <b>'</b> | Video<br>Control | 3048 | | integer | | | VsEnd | ~ | <u> </u> | Video<br>Control | 3050 | | integer | | | VideoControl | ~ | ~ | Video<br>Control | 3058 | | bitfield | | | InterruptLine | ~ | ~ | Video<br>Control | 3060 | | integer | | | DisplayData | | | Video<br>Control | 3068 | | bitfield | | | VerticalLineCount ✓ X Video Control 3070 integer Control FifoControl ✓ Video Control 3078 bitfield ScreenBaseRight ✓ Video Control 3080 Integer MiscControl ✓ Video Control 3088 Bitfield VideoOverlayUpdate ✓ Video Control 3100 integer VideoOverlayMode ✓ Video Overlay Control 3108 bitfield VideoOverlayFIFO Control ✓ Video Overlay Control 3110 bitfield VideoOverlayBase0 ✓ Video Overlay Control 3120 bitfield VideoOverlayBase1 ✓ Video Overlay Control 3128 bitfield VideoOverlayBase2 ✓ Video Overlay Control Video Overlay Control VideoOverlayWidth ✓ Video Overlay Control 3138 integer Overlay Control VideoOverlayHeight ✓ Video Overlay Control 3148 integer Overlay Control VideoOverlayShrinkXDelta ✓ Video Overlay Control Vid | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|----------|--------------|--------|----------------|----------------|--------------| | FifoControl ScreenBaseRight Video Control Overlay Control VideoOverlayFIFO Control VideoOverlayFIFO Control VideoOverlay Control VideoOverlay Control VideoOverlayBase0 Video Overlay Control VideoOverlayHeight Video Overlay Control Video Overlay Control VideoOverlay | VerticalLineCount | ~ | X | | 3070 | | integer | | | Control Video ScreenBaseRight Video Sontrol So | = | | | | 0070 | | i- ;tt; - i -i | | | ScreenBaseRight Wideo Control Video OverlayUpdate Video Overlay Control Video Overlay Gontrol Video Overlay FIFO Control Video Overlay Control Video Overlay Control Video Overlay Control Video Overlay Control Video Overlay Control Video Overlay Gontrol Video Overlay Control Video Overlay Gontrol Video Overlay Control Video Overlay Base0 Video Overlay Control Video Overlay Control Video Overlay Base1 Video Overlay Control Video Overlay Control Video Overlay Gontrol | FifoControl | | | | 3078 | | Dittield | | | MiscControl VideoOverlayUpdate VideoOverlayMode VideoOverlayFIFO Control VideoOverlayFIFO Control VideoOverlayIndex VideoOverlayBase0 VideoOverlayBase1 VideoOverlayBase1 VideoOverlayBase2 VideoOverlayBase2 VideoOverlayBase2 VideoOverlayBase2 VideoOverlayStride VideoOverlayWidth VideoOverlayControl VideoOverlayWidth VideoOverlayWidth VideoOverlayWidth VideoOverlayWidth VideoOverlayWidth VideoOverlayControl VideoOverlayHeight VideoOverlayOrigin VideoOverlayOrigin VideoOverlayOrigin VideoOverlayShrinkXDelta VideoOverlayControl VideoOverlayShrinkXDelta VideoOverlayControl VideoOverlayShrinkXDelta VideoOverlayControl VideoOverlayShrinkXDelta VideoOverlayControl VideoOverlayShrinkXDelta VideoOverlayControl VideoOverlayControl VideoOverlayControl VideoOverlayControl VideoOverlayShrinkXDelta VideoOverlayControl VideoOverlayCon | ScreenBasePight | ./ | ·/ | | 3080 | | Integer | | | MiscControl VideoOverlayUpdate VideoOverlayUpdate VideoOverlayControl VideoOverlayMode VideoOverlayControl VideoOverlayFIFO Control VideoOverlayIndex VideoOverlayBase0 VideoOverlayBase0 VideoOverlayBase1 VideoOverlayBase2 VideoOverlayBase2 VideoOverlayBase2 VideoOverlayStride VideoOverlayWideoOverlayWideoOverlayStride VideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayBase2 VideoOverlayStride VideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayWideoOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlayOverlay | Scieenbaserright | | | | 3000 | | integer | | | Control Video Video 3100 integer Overlay Control Video Con | MiscControl | <b>/</b> | / | | 3088 | | Bitfield | | | VideoOverlayUpdate Video Overlay Control 3100 integer VideoOverlayMode Video Overlay Control 3108 Overlay Control VideoOverlayFIFO Control Video Overlay Control 3110 overlay Control VideoOverlayIndex Video Overlay Control 3118 overlay Control VideoOverlayBase0 Video Overlay Control 3120 overlay Control VideoOverlayBase1 Video Overlay Control 3128 overlay Control VideoOverlayBase2 Video Overlay Control 3130 overlay Control VideoOverlayStride Video Overlay Control 3138 overlay Control VideoOverlayWidth Video Overlay Control 3140 overlay Control VideoOverlayHeight Video Overlay Control 3148 overlay Control VideoOverlayFrinkXDelta Video Overlay Control 3150 overlay Control VideoOverlayShrinkXDelta Video Overlay Control 3158 overlay Control VideoOverlayZoomXDelta Video Overlay Control 3150 overlay Control VideoOverlayZoomXDelta Video Overlay Control Video Overlay Control | | | | | | | 2 | | | VideoOverlayFIFO Control VideoOverlayFIFO Control VideoOverlayIndex VideoOverlayIndex VideoOverlay Control VideoOverlayBase0 VideoOverlayBase1 VideoOverlayBase2 VideoOverlayBase2 VideoOverlayBase2 VideoOverlayBase2 VideoOverlayBase3 VideoOverlayBas | VideoOverlayUpdate | ~ | <b>/</b> | Video | 3100 | | integer | | | VideoOverlayMode ✓ Video Overlay Control bitfield VideoOverlayFIFO Control ✓ Video Overlay Control bitfield VideoOverlayIndex ✓ Video Overlay Control bitfield VideoOverlayBase0 ✓ Video Overlay Control bitfield VideoOverlayBase1 ✓ Video Overlay Control bitfield VideoOverlayBase2 ✓ Video Overlay Control bitfield VideoOverlayStride ✓ Video Overlay Control bitfield VideoOverlayWidth ✓ Video Overlay Control bitfield VideoOverlayWidth ✓ Video Overlay Control bitfield VideoOverlayHeight ✓ Video Overlay Control bitfield VideoOverlayOrigin ✓ Video Overlay Control bitfield VideoOverlayShrinkXDelta ✓ Video Overlay Control bitfield VideoOverlayZoomXDelta ✓ Video Overlay Control bitfield VideoOverlayZoomXDelta ✓ Video Overlay Control bitfield | | | | | | | | | | Overlay Control Video Overlay FIFO Control Video Overlay Video Overlay Control Video Overlay Video Overlay Control Video Overlay V | | | | | | | | | | Control Video Video Salar Sa | VideoOverlayMode | <b>'</b> | • | | 3108 | | bittield | | | VideoOverlayFIFO Control ✓ Video Overlay Control bitfield VideoOverlayIndex ✓ Video Overlay Control 3118 Overlay Control VideoOverlayBase0 ✓ Video Overlay Control 3120 Overlay Control VideoOverlayBase1 ✓ Video Overlay Control 3128 Overlay Control VideoOverlayBase2 ✓ Video Overlay Control 3130 Overlay Control VideoOverlayStride ✓ Video Overlay Control 3138 Overlay Control VideoOverlayWidth ✓ Video Overlay Control 3140 Overlay Control VideoOverlayHeight ✓ Video Overlay Control 3148 Overlay Control VideoOverlayOrigin ✓ Video Overlay Control 3150 Overlay Control VideoOverlayShrinkXDelta ✓ Video Overlay Control 3158 Overlay Control VideoOverlayZoomXDelta ✓ Video Overlay Control 3160 Overlay Control | | | | | | | | | | VideoOverlayIndex VideoOverlayIndex VideoOverlay Control VideoOverlayBase0 VideoOverlayBase1 VideoOverlayBase2 VideoOverlay Control VideoOverlayBase2 VideoOverlay Control VideoOverlayStride VideoOverlay Control VideoOverlayWidth VideoOverlayWidth VideoOverlay Control VideoOverlayHeight VideoOverlayOverlay Control VideoOverlayHeight VideoOverlayOverlay Control VideoOverlayOverlay Control VideoOverlayHeight VideoOverlayOverlay Control VideoOverlayOverlay Control VideoOverlayOverlay Control VideoOverlayOverlayOverlay Control VideoOverlayOverlayOverlay Control VideoOverlayOverlayOverlay Control VideoOverlayOverlay Control VideoOverlayShrinkXDelta VideoOverlayZoomXDelta VideoOverlayZoomXDelta VideoOverlayZoomXDelta VideoOverlay Video Overlay | Vista a Ossanlas (FIFO Construct | | | | 2440 | | اماندان ما ما | | | VideoOverlayIndex VideoOverlayBase0 VideoOverlayBase1 VideoOverlayBase2 VideoOverlayBase2 VideoOverlayBase2 VideoOverlayBase2 VideoOverlayControl VideoOverlayStride VideoOverlayControl VideoOverlayStride VideoOverlayControl VideoOverlayWidth VideoOverlayBase2 VideoOverlayBase2 VideoOverlayBase2 VideoOverlayBase3 Video | videoOverlayFIFO Control | • | • | | 3110 | | DITTIEID | | | VideoOverlayIndex Video Overlay Control bitfield VideoOverlayBase0 Video Overlay Control 3120 bitfield VideoOverlayBase1 Video Overlay Control bitfield VideoOverlayBase2 Video Overlay Control bitfield VideoOverlayStride Video Overlay Control 3138 bitfield VideoOverlayWidth Video Overlay Control 3140 bitfield VideoOverlayHeight Video Overlay Control 3140 bitfield VideoOverlayHeight Video Overlay Control 3148 bitfield VideoOverlayOrigin Video Overlay Control 3150 bitfield VideoOverlayShrinkXDelta Video Overlay Control 3158 bitfield VideoOverlayZoomXDelta Video Overlay Control 3160 bitfield | | | | | | | | | | VideoOverlayBase0 VideoOverlayBase1 VideoOverlayBase2 VideoOverlayBase2 VideoOverlayStride VideoOverlayControl VideoOverlayStride VideoOverlayControl VideoOverlayWidth VideoOverlayControl VideoOverlayHeight VideoOverlayOverlayControl VideoOverlayHeight VideoOverlayOverlayControl VideoOverlayOverlayControl VideoOverlayHeight VideoOverlayOverlayControl VideoOverlayOverlayOverlayControl VideoOverlayOverlayOverlayControl VideoOverlayOverlayOverlayControl VideoOverlayOverlayOverlayControl VideoOverlayShrinkXDelta VideoOverlayShrinkXDelta VideoOverlayZoomXDelta VideoOverlayZoomXDelta VideoOverlay Control VideoOverlayZoomXDelta | VideoOverlayIndex | ./ | ./ | | 3110 | | hitfiold | | | VideoOverlayBase0 ✓ Video Overlay Overlay Control 3120 bitfield VideoOverlayBase1 ✓ Video Overlay Control 3128 bitfield VideoOverlayBase2 ✓ Video Overlay Control 3130 bitfield VideoOverlayStride ✓ Video Overlay Control 3138 bitfield VideoOverlayWidth ✓ Video Overlay Control 3140 bitfield VideoOverlayHeight ✓ Video Overlay Control 3148 bitfield VideoOverlayOrigin ✓ Video Overlay Control 3150 bitfield VideoOverlayShrinkXDelta ✓ Video Overlay Control 3158 bitfield VideoOverlayZoomXDelta ✓ Video Overlay Control 3160 bitfield | videoOverlayindex | | • | | 3110 | | bitlield | | | VideoOverlayBase0 Video Overlay Control 3120 bitfield VideoOverlayBase1 Video Overlay Control 3128 bitfield VideoOverlayBase2 Video Overlay Control 3130 bitfield VideoOverlayStride Video Overlay Control 3138 integer VideoOverlayWidth Video Overlay Control 3140 integer VideoOverlayHeight Video Overlay Control 3148 integer VideoOverlayOrigin Video Overlay Control 3150 bitfield VideoOverlayShrinkXDelta Video Overlay Control 3158 bitfield VideoOverlayZoomXDelta Video Overlay Control 3160 integer | | | | | | | | | | VideoOverlayBase1 ✓ Video Overlay Control 3128 bitfield VideoOverlayBase2 ✓ Video Overlay Control 3130 bitfield VideoOverlayStride ✓ Video Overlay Control 3138 integer VideoOverlayWidth ✓ Video Overlay Control 3140 integer VideoOverlayHeight ✓ Video Overlay Control 3148 integer VideoOverlayOrigin ✓ Video Overlay Control 3150 bitfield VideoOverlayShrinkXDelta ✓ Video Overlay Control 3158 bitfield VideoOverlayZoomXDelta ✓ Video Overlay Control 3160 bitfield | VideoOverlayBase0 | ~ | / | | 3120 | | hitfield | | | VideoOverlayBase1 VideoOverlayBase2 VideoOverlayControl VideoOverlayStride VideoOverlayWidth VideoOverlayWidth VideoOverlayHeight VideoOverlayHeight VideoOverlayControl VideoOverlayHeight VideoOverlayControl VideoOverlayOverlayOverlayControl VideoOverlayOverlayOverlayControl VideoOverlayOverlayOverlayOverlayControl VideoOverlayOverlayOverlayOverlayControl VideoOverlayOverlayOverlayOverlayControl VideoOverlayShrinkXDelta VideoOverlayZoomXDelta | Videooverlaybaseo | | | | 0120 | | Ditticia | | | VideoOverlayBase1 V Video Overlay Control 3128 bitfield VideoOverlayBase2 V Video Overlay Control 3130 bitfield VideoOverlayStride V Video Overlay Control 3138 overlay Control VideoOverlayWidth V Video Overlay Control 3140 overlay Control VideoOverlayHeight V Video Overlay Control 3148 overlay Control VideoOverlayOrigin V Video Overlay Control 3150 overlay Control VideoOverlayShrinkXDelta V Video Overlay Control 3158 overlay Control VideoOverlayZoomXDelta V Video Overlay Control 3160 overlay Control | | | | | | | | | | VideoOverlayBase2 VideoOverlayBase2 VideoOverlayControl VideoOverlayStride VideoOverlayControl VideoOverlayWidth VideoOverlayControl VideoOverlayHeight VideoOverlayControl VideoOverlayHeight VideoOverlayControl VideoOverlayOrigin VideoOverlayOrigin VideoOverlayControl VideoOverlayShrinkXDelta VideoOverlayControl VideoOverlayShrinkXDelta VideoOverlayControl VideoOverlayZoomXDelta VideoOverlay Control VideoOverlayZoomXDelta VideoOverlay Control VideoOverlay Control VideoOverlayZoomXDelta | VideoOverlavBase1 | <b>/</b> | / | | 3128 | | bitfield | | | VideoOverlayBase2 VideoOverlayBase2 VideoOverlay Control VideoOverlayStride VideoOverlay Control VideoOverlayWidth VideoOverlay Control VideoOverlayHeight VideoOverlayOverlay Control VideoOverlayOverlayOverlay Control VideoOverlayOverlayOverlay Control VideoOverlayOverlayOverlay Control VideoOverlayOverlayOverlay Control VideoOverlayShrinkXDelta VideoOverlayControl VideoOverlayShrinkXDelta VideoOverlayControl VideoOverlayZoomXDelta VideoOverlay VideoOverlayZoomXDelta VideoOverlay | Tidooo Toniay Baso I | | | | 0.20 | | 2 | | | Overlay Control VideoOverlayStride ✓ Video Overlay Control VideoOverlayWidth ✓ Video Overlay Control VideoOverlayHeight ✓ Video Overlay Control VideoOverlayOrigin ✓ Video Overlay Control VideoOverlayOrigin ✓ Video Overlay Control VideoOverlayShrinkXDelta ✓ Video Overlay Control VideoOverlayShrinkXDelta ✓ Video Overlay Control VideoOverlayZoomXDelta ✓ Video Overlay Control VideoOverlayZoomXDelta ✓ Video Overlay Control VideoOverlayZoomXDelta ✓ Video Overlay Overlay Control VideoOverlayZoomXDelta | | | | | | | | | | VideoOverlayStride VideoOverlayStride VideoOverlayControl VideoOverlayWidth VideoOverlayHeight VideoOverlayHeight VideoOverlayOrigin VideoOverlayOrigin VideoOverlayShrinkXDelta VideoOverlayShrinkXDelta VideoOverlayZoomXDelta VideoOverlay Control VideoOverlayZoomXDelta VideoOverlay Control | VideoOverlavBase2 | <b>'</b> | / | Video | 3130 | | bitfield | | | VideoOverlayStride ✓ Video Overlay Control 3138 integer VideoOverlayWidth ✓ Video Overlay Control 3140 integer VideoOverlayHeight ✓ Video Overlay Control 3148 integer VideoOverlayOrigin ✓ Video Overlay Control 3150 overlay Control VideoOverlayShrinkXDelta ✓ Video Overlay Control 3158 overlay Control VideoOverlayZoomXDelta ✓ Video Overlay Overlay 3160 overlay integer | , | | | Overlay | | | | | | Overlay Control VideoOverlayWidth ✓ Video Overlay Control VideoOverlayHeight ✓ Video Overlay Control VideoOverlayOrigin ✓ Video Overlay Control VideoOverlayShrinkXDelta ✓ Video Overlay Control VideoOverlayShrinkXDelta ✓ Video Overlay Control VideoOverlayShrinkXDelta ✓ Video Overlay Control VideoOverlayZoomXDelta ✓ Video Overlay Control VideoOverlayZoomXDelta | | | | Control | | | | | | Control VideoOverlayWidth | VideoOverlayStride | <b>/</b> | / | | 3138 | | integer | | | VideoOverlayWidth ✓ Video Overlay Control 3140 integer VideoOverlayHeight ✓ Video Overlay Control 3148 integer VideoOverlayOrigin ✓ Video Overlay Control bitfield VideoOverlayShrinkXDelta ✓ Video Overlay Control bitfield VideoOverlayZoomXDelta ✓ Video Overlay Control bitfield Video Overlay Control Video Overlay Control bitfield | | | | | | | | | | Overlay Control VideoOverlayHeight ✓ Video Overlay Control VideoOverlayOrigin ✓ Video Overlay Control VideoOverlayShrinkXDelta ✓ Video Overlay Control VideoOverlayShrinkXDelta ✓ Video Overlay Control VideoOverlayZoomXDelta ✓ Video Overlay Control VideoOverlayZoomXDelta | | | | | | | | | | Control VideoOverlayHeight ✓ Video Overlay Control VideoOverlayOrigin ✓ Video Overlay Control VideoOverlayShrinkXDelta ✓ Video Overlay Control VideoOverlayZoomXDelta ✓ Video Overlay Control VideoOverlayZoomXDelta ✓ Video Overlay Overlay Overlay Overlay Overlay VideoOverlayZoomXDelta ✓ Video Overlay | VideoOverlayWidth | ~ | <b>/</b> | | 3140 | | integer | | | VideoOverlayHeight ✓ Video Overlay Control 3148 integer VideoOverlayOrigin ✓ Video Overlay Control bitfield VideoOverlayShrinkXDelta ✓ Video Overlay Control bitfield VideoOverlayZoomXDelta ✓ Video Overlay integer Video Overlay Video Overlay 3160 overlay integer | | | | | | | | | | VideoOverlayOrigin Video Overlay Control VideoOverlayShrinkXDelta Video Overlay Control VideoOverlayShrinkXDelta Video Overlay Control VideoOverlayZoomXDelta Video Overlay Control VideoOverlayZoomXDelta | | | | | | | | | | Control VideoOverlayOrigin ✓ Video 3150 bitfield Overlay Control VideoOverlayShrinkXDelta ✓ Video 3158 bitfield Overlay Control VideoOverlayZoomXDelta ✓ Video 3160 integer Overlay | VideoOverlayHeight | | <b>/</b> | | 3148 | | integer | | | VideoOverlayOrigin Video Overlay Control VideoOverlayShrinkXDelta Video Overlay Control VideoOverlayZoomXDelta Video Overlay Control VideoOverlayZoomXDelta Video Overlay Overlay Video Overlay | | | | | | | | | | Overlay Control VideoOverlayShrinkXDelta Video Overlay Control VideoOverlayZoomXDelta Video Overlay Control Video Overlay Control Video Overlay | | | , | | 0450 | | 1.00 | | | VideoOverlayShrinkXDelta Video Overlay Control VideoOverlayZoomXDelta Video Overlay Control Video Overlay Overlay Video Overlay | videoOverlayOrigin | • | | | 3150 | | DITTIEID | | | VideoOverlayShrinkXDelta Video Overlay Control VideoOverlayZoomXDelta Video Overlay Control Video Overlay Video Overlay Video Overlay | | | | | | | | | | Overlay Control VideoOverlayZoomXDelta ✓ Video Overlay Overlay integer Overlay | VidooOyorlayShrinkVDalta | | ./ | | 3159 | | hitfield | | | Control VideoOverlayZoomXDelta ✓ Video Overlay integer Overlay | videooveriayənrinkxDeita | | • | | 3136 | | Dittiela | | | VideoOverlayZoomXDelta Video 3160 integer Overlay | | | | | | | | | | Overlay | VideoOverlayZoomXDelta | ~ | / | | 3160 | | integer | | | | TIGOTO VOI IA JEDONIA DEILA | | Ī | | 0.00 | | | | | | | | | Control | | | | | | VideoOverlayYDelta V Video 3168 Integer | VideoOverlavYDelta | <b>/</b> | / | | 3168 | | Integer | | | Overlay | - Income to the state of st | | | | | | | | | Control | | | | | | | | | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |-------------------------|---------------|----------|-----------------------------|--------|----------------|----------|--------------| | VideoOverlayFieldOffset | • | ~ | Video<br>Overlay<br>Control | 3170 | | bitfield | | | VideoOverlayStatus | ~ | ~ | Overlay<br>Control | 3178 | | bitfield | | | RDPaletteWriteAddress | ~ | <b>'</b> | RAMDAC<br>Control | 4000 | | Integer | | | RDPaletteData | ~ | ~ | RAMDAC<br>Control | 4008 | | Integer | | | RDPixelMask | ~ | ~ | RAMDAC<br>Control | 4010 | | Integer | | | RDPaletteReadAddress | ~ | ~ | RAMDAC<br>Control | 4018 | | Integer | | | RDIndexLow | ~ | ~ | RAMDAC<br>Control | 4020 | | Integer | | | RDIndexHigh | ~ | ~ | RAMDAC<br>Control | 4028 | | Integer | | | RDIndexedData | ~ | ~ | RAMDAC<br>Control | | | Integer | | | RDIndexControl | <b>'</b> | • | RAMDAC<br>Control | | | Integer | | | VSConfiguration | | - | Video<br>Stream<br>Control | 5800 | | bitfield | | | VSStatus | | × | Video<br>Stream<br>Control | 5808 | | bitfield | | | VSSerialBusControl | | х | Video<br>Stream<br>Control | 5810 | | bitfield | | | VSAControl | ~ | ~ | Video<br>Stream<br>Control | 5900 | | bitfield | | | VSAInterruptLine | ~ | ~ | Video<br>Stream<br>Control | 5908 | | Integer | | | VSACurrentLine | ~ | × | Video<br>Stream<br>Control | 5910 | | integer | | | VSAVideoAddressHost | ~ | <b>'</b> | Video<br>Stream<br>Control | 5918 | | integer | | | VSAVideoAddressIndex | ~ | <u> </u> | Video<br>Stream<br>Control | 5920 | | integer | | | VSAVideoAddress0 | ~ | <b>/</b> | Video<br>Stream<br>Control | 5928 | | integer | | | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |--------------------------|---------------|----------|----------------------------|--------|----------------|---------|--------------| | VSAVideoAddress1 | ~ | ~ | Video<br>Stream<br>Control | 5930 | | integer | | | VSAVideoAddress2 | ~ | • | Video<br>Stream<br>Control | 5938 | | integer | | | VSAVideoStride | ~ | • | Video<br>Stream<br>Control | 5940 | | integer | | | <b>VSAVideoStartLine</b> | <b>'</b> | ~ | Video<br>Stream<br>Control | 5948 | | integer | | | VSAVideoEndLine | <b>'</b> | <b>'</b> | Video<br>Stream<br>Control | 5950 | | integer | | | VSAVideoStartData | V | <u> </u> | Video<br>Stream<br>Control | 5958 | | integer | | | VSAVideoEndData | • | • | Video<br>Stream<br>Control | 5960 | | integer | | | VSAVBIAddressHost | <b>~</b> | | Video<br>Stream<br>Control | 5968 | | integer | | | VSAVBIAddressIndex | | × | Video<br>Stream<br>Control | 5970 | | integer | | | VSAVBIAddress0 | <u> </u> | - | Video<br>Stream<br>Control | 5978 | | integer | | | VSAVBIAddress1 | ~ | • | Video<br>Stream<br>Control | 5980 | | integer | | | VSAVBIAddress2 | <u> </u> | - | Video<br>Stream<br>Control | 5988 | | integer | | | VSAVBIStride | ~ | ~ | Video<br>Stream<br>Control | 5990 | | integer | | | <b>VSAVBIStartLine</b> | ~ | ~ | Video<br>Stream<br>Control | 5998 | | integer | | | VSAVBIEndLine | V | - | Video<br>Stream<br>Control | 59A0 | | integer | | | VSAVBIStartData | ~ | <b>'</b> | Video<br>Stream<br>Control | 59A8 | | integer | | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |-----------------------|---------------|----------|----------------------------|--------|----------------|----------|--------------| | VSAVBIEndData | ~ | / | Video<br>Stream<br>Control | 59B0 | | integer | | | VSAFifoControl | V | <b>'</b> | Video<br>Stream<br>Control | 59B8 | | bitfield | | | VSATimeStamp0 | ~ | × | Video<br>Stream<br>Control | 59C0 | | integer | | | VSATimeStamp1 | V | × | Video<br>Stream<br>Control | 59C8 | | integer | | | VSATimeStamp2 | ~ | × | Video<br>Stream<br>Control | 59D0 | | integer | | | VSBControl | ~ | <b>/</b> | Video<br>Stream<br>Control | 5A00 | | bitfield | | | VSBInterruptLine | ~ | <b>/</b> | Video<br>Stream<br>Control | 5A08 | | integer | | | VSBCurrentLine | <b>~</b> | <b>/</b> | Video<br>Stream<br>Control | 5A10 | | integer | | | VSBVideoAddressHost | ~ | <b>'</b> | Video<br>Stream<br>Control | 5A18 | | integer | | | VSBVideo AddressIndex | ~ | × | Video<br>Stream<br>Control | 5A20 | | integer | | | VSBVideoAddress0 | <b>'</b> | <b>'</b> | Video<br>Stream<br>Control | 5A28 | | integer | | | VSBVideoAddress1 | <b>'</b> | <b>'</b> | Video<br>Stream<br>Control | 5A30 | | integer | | | VSBVideoAddress2 | ~ | <b>'</b> | Video<br>Stream<br>Control | 5A38 | | integer | | | VSBVideoStride | ~ | ~ | Video<br>Stream<br>Control | 5A40 | | integer | | | VSBVideoStartLine | ~ | ~ | Video<br>Stream<br>Control | 5A48 | | integer | | | VSBVideoEndLine | ~ | <b>'</b> | Video<br>Stream<br>Control | 5A50 | | integer | | | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |------------------------|---------------|-------|----------------------------|--------|----------------|----------|--------------| | VSBVideoStartData | ~ | ~ | Video<br>Stream<br>Control | 5A58 | | integer | | | <b>VSBVideoEndData</b> | ~ | • | Video<br>Stream<br>Control | 5A60 | | integer | | | VSBVBIAddressHost | | • | Video<br>Stream<br>Control | 5A68 | | integer | | | VSBVBIAddressIndex | | × | Video<br>Stream<br>Control | 5A70 | 0x2 | integer | | | VSBVBIAddress0 | ~ | • | Video<br>Stream<br>Control | 5A78 | | integer | | | VSBVBIAddress1 | ~ | • | Video<br>Stream<br>Control | 5A80 | | integer | | | VSBVBIAddress2 | | • | Video<br>Stream<br>Control | 5A88 | | integer | | | VSBVBIStride | | • | Video<br>Stream<br>Control | 5A90 | | integer | | | VSBVBIStartLine | | • | Video<br>Stream<br>Control | 5A98 | | integer | | | VSBVBIEndLine | | • | Video<br>Stream<br>Control | 5AA0 | | integer | | | VSBVBIStartData | | • | Video<br>Stream<br>Control | 5AA8 | | integer | | | VSBVBIEndData | | • | Video<br>Stream<br>Control | 5AB0 | | integer | | | VSBFifoControl | | • | Video<br>Stream<br>Control | 5AB8 | | bitfield | | | VSDMAMode | • | • | Video<br>Stream<br>Control | 5AC0 | | bitfield | | | VSDMACommandBase | | • | Video<br>Stream<br>Control | 5AC8 | | integer | | | VSDMACommandCount | ~ | • | Video<br>Stream<br>Control | 5AD0 | | integer | | | StartXDom | ~ | × | Raster-<br>izer | 8000 | x | fixed | × | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |---------------------------|---------------|----------|-------------------------|--------|----------------|----------|--------------| | dXDom | ~ | × | Raster- | 8008 | х | fixed | × | | StartXSub | ~ | × | izer<br>Raster-<br>izer | 8010 | х | fixed | × | | dXSub | ~ | × | Raster-<br>izer | 8018 | x | fixed | X | | StartY | × | X | Raster-<br>izer | 8020 | х | fixed | × | | dY | ~ | × | Raster-<br>izer | 8028 | х | fixed | × | | Count | <b>'</b> | × | Raster-<br>izer | 8030 | x | Integer | × | | Render | × | <b>'</b> | Raster-<br>izer | 8038 | x | Bitfield | • | | ContinueNewLine | X | <b>'</b> | Raster-<br>izer | 8040 | x | Integer | ~ | | ContinueNewDom | X | • | Raster-<br>izer | 8048 | x | Integer | • | | ContinueNewSub | X | _ | Raster-<br>izer | 8050 | x | Integer | • | | Continue | X | | Raster-<br>izer | 8058 | x | Integer | <i>'</i> | | FlushSpan | X | | Raster-<br>izer | 8060 | Х | tag | <b>/</b> | | BitMaskPattern | X | <b>'</b> | Raster-<br>izer | 8068 | x | Integer | <b>✓</b> × | | PointTable[03] | • | | Raster-<br>izer | 8080 | x | bitfield | × | | RasterizerMode | | | Raster-<br>izer | 80A0 | x | Bitfield | X | | YLimits | _ | | Raster-<br>izer | 80A8 | X | Bitfield | × | | WaitForCompletion | X | | Raster-<br>izer | 80B8 | x | Bitfield | <b>'</b> | | PixelSize | • | | Raster-<br>izer | 80C0 | X | Bitfield | • | | StripeOffsetY | | | Raster-<br>izer | 80C8 | x | fixed | X | | ScissorMode | <b>'</b> | <b>V</b> | Scissor | 8180 | Х | Bitfield | X | | ScissorMinXY | <b>'</b> | <b>'</b> | Scissor | 8188 | Х | Bitfield | X | | ScissorMaxXY | <b>'</b> | <b>'</b> | Scissor | 8190 | х | Bitfield | X | | ScreenSize | <b>'</b> | <b>'</b> | Scissor | 8198 | Х | Bitfield | 1 | | <u>AreaStippleMode</u> | <b>'</b> | <b>V</b> | Stipple | 81A0 | х | Bitfield | × | | LineStippleMode | <b>/</b> | <b>'</b> | Stipple | 81A8 | х | Bitfield | | | LoadLineStippleCounters | <b>/</b> | <b>V</b> | Stipple | 81B0 | х | Bitfield | <b>'</b> | | UpdateLineStippleCounters | X | <b>V</b> | Stipple | 81B8 | х | Bitfield | <b>/</b> | | SaveLineStippleCounters | X | <b>'</b> | Stipple | 81C0 | x | tag | <b>/</b> | | WindowOrigin | <b>~</b> | <b>'</b> | Scissor | 81C8 | x | Bitfield | X | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |------------------------------|---------------|----------|------------------|--------|----------------|----------|--------------| | AreaStipplePattern[015] | ~ | / | Stipple | 8200 | х | Bitfield | X | | AreaStipplePattern[1631] | <b>V</b> | <b>/</b> | Stipple | 8280 | х | Bitfield | X | | FillFBWriteBufferAddr0 | X | ~ | 2D Set<br>Up | 8300 | х | integer | × | | FillFBSourceReadBufferAddr | × | ~ | 2D Set<br>Up | 8308 | х | integer | × | | FillFBDestReadBufferAddr0 | X | ~ | 2D Set<br>Up | 8310 | х | integer | × | | FillScissorMinXY | X | • | 2D Set<br>Up | 8318 | х | fixed | X | | FillScissorMaxXY | × | ~ | 2D Set<br>Up | 8320 | x | fixed | × | | FillForegroundColor0 | × | • | 2D Set<br>Up | 8328 | x | integer | × | | FillBackgroundColor | × | ~ | 2D Set<br>Up | 8330 | х | integer | × | | FillConfig2D0 | × | ~ | 2D Set<br>Up | 8338 | x | bitfield | × | | FillFBSourceReadBufferOffset | × | ~ | 2D Set<br>Up | 8340 | х | integer | × | | FillRectanglePosition | × | • | 2D Set<br>Up | 8348 | x | integer | × | | FillRender2D | X | • | 2D Set<br>Up | 8350 | X | bitfield | × | | FillForegroundColor1 | × | • | 2D Set<br>Up | 8358 | x | integer | × | | FillConfig2D1 | X | • | 2D Set<br>Up | 8360 | х | bitfield | | | FillGlyphPosition | × | • | 2D Set<br>Up | 8368 | X | integer | × | | TextureCoordMode | • | • | Texture coord | 8380 | х | bitfield | X | | SStart | ~ | • | Texture<br>Coord | 8388 | X | fixed | × | | dSdx | <b>'</b> | • | Texture coord | 8390 | x | fixed | × | | dSdyDom | | • | Texture coord | 8398 | X | fixed | × | | TStart | <b>'</b> | • | Texture coord | 83A0 | х | fixed | × | | dTdx | ~ | • | Texture coord | 83A8 | x | fixed | × | | dTdyDom | <b>'</b> | • | Texture coord | 83B0 | x | fixed | × | | QStart | ~ | • | Texture<br>Coord | 83B8 | x | fixed | × | | dQdx | <b>'</b> | • | Texture coord | 83C0 | x | fixed | × | | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |---------------------|---------------|----------|-------------------|--------|----------------|----------|--------------| | dQdyDom | V | ~ | Texture | 83C8 | Х | | X | | LOD | <b>/</b> | <b>/</b> | coord | 83D0 | x | fixed | X | | LOD | | | Texture<br>Index | 8300 | <b>X</b> | lixeu | ^ | | dSdy | ~ | ~ | Texture<br>coord | 83D8 | х | fixed | × | | dTdy | ~ | ~ | Texture<br>coord | 83E0 | х | fixed | × | | DQdy | ~ | ~ | Texture coord | 83E8 | x | fixed | × | | S1 Start | V | • | Texture<br>Coord | 8400 | x | fixed | × | | dS1dx | ~ | ~ | Texture coord | 8408 | х | fixed | X | | dS1dyDom | ~ | • | Texture<br>coord | 8410 | x | fixed | X | | T1Start | ~ | <u> </u> | Texture<br>coord | 8418 | х | fixed | × | | dT1dx | ~ | • | Texture coord | 8420 | x | fixed | × | | dT1dyDom | • | • | Texture coord | 8428 | х | fixed | × | | Q1Start | <b>'</b> | • | Texture<br>Coord | 8430 | х | fixed | × | | dQ1dx | ~ | • | Texture coord | 8438 | x | fixed | × | | dQ1dyDom | ~ | • | Texture coord | 8440 | х | fixed | × | | LOD1 | | • | Texture<br>Index | 8448 | X | fixed | × | | TextureLodBiasS | ~ | • | Texture<br>Index | 8450 | x | fixed | × | | TextureLodBiasT | • | • | Texture<br>Index | 8458 | х | fixed | × | | TextureCacheControl | <b>'</b> | <b>/</b> | Texture | 8490 | х | bitfield | X | | BorderColor0 | | - | Texture<br>filter | 84A8 | X | bitfield | X | | LUTIndex | <b>V</b> | / | LUT | 84C0 | х | integer | X | | LUTData | <b>V</b> | <b>/</b> | LUT | 84C8 | x | integer | X | | LUTAddress | ~ | ~ | Texture<br>Read | 84D0 | x | integer | × | | LUTTransfer | ~ | ~ | Texture<br>Read | 84D8 | x | bitfield | × | | TextureFilterMode | ~ | ~ | Texture | 84E0 | х | bitfield | X | | TextureChromaUpper0 | ~ | ~ | Color<br>DDA | 84E8 | х | bitfield | × | | TextureChromaLower0 | ~ | <b>'</b> | Color<br>DDA | 84F0 | x | bitfield | × | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |------------------------|---------------|----------|----------------------------|--------|----------------|----------|--------------| | BorderColor1 | ~ | ~ | | 84F8 | X | bitfield | X | | TextureBaseAddr[16] | ~ | ~ | | 8500 | х | integer | X | | TextureMapWidth[16] | ~ | ~ | | 8580 | x | bitfield | X | | TextureChromaUpper1 | ~ | ~ | Texture<br>Filter | 8600 | х | bitfield | × | | TextureChromaLower1 | <b>'</b> | <b>'</b> | Texture<br>Filter | 8608 | x | bitfield | × | | TextureApplicationMode | | | Texture<br>Applicatio<br>n | 8680 | x | bitfield | × | | TextureEnvColor | <b>/</b> | / | Texture | 8688 | х | bitfield | X | | FogMode | <b>/</b> | / | Fog | 8690 | х | bitfield | X | | FogColor | <b>/</b> | / | Fog | 8698 | х | fixed | X | | FStart | ~ | / | Fog | 86A0 | х | fixed | X | | dFdx | ~ | / | Fog | 86A8 | х | fixed | X | | dFdyDom | <b>/</b> | / | Fog | 86B0 | х | fixed | X | | ZFogBias | <b>/</b> | / | Fog | 86B8 | х | float | X | | KsStart | <b>/</b> | / | | 86C8 | х | fixed | X | | dKsdx | <b>/</b> | / | Texture | 86D0 | х | fixed | X | | dKsdyDom | ~ | / | Texture | 86D8 | х | fixed | X | | KdStart | <b>/</b> | / | | 86E0 | х | fixed | X | | TextTGlyphAddr0 | X | ~ | | 8700 | х | integer | × | | TextRender2DGlyph0 | × | ~ | | 8708 | x | bitfield | ~ | | TextTGlyphAddr1 | X | ~ | Raster-<br>izer | 8710 | х | integer | × | | TextRender2DGlyph1 | X | ~ | Raster-<br>izer | 8718 | x | bitfield | ~ | | TextTGlyphAddr2 | × | • | Raster-<br>izer | 8720 | x | integer | × | | TextRender2DGlyph2 | X | • | Raster-<br>izer | 8728 | х | bitfield | • | | TextTGlyphAddr3 | × | <b>'</b> | Raster-<br>izer | 8730 | x | integer | X | | TextRender2DGlyph3 | × | ′ | izer | 8738 | x | bitfield | ~ | | TextTGlyphAddr4 | × | · | izer | 8740 | x | integer | × | | TextRender2DGlyph4 | × | ′ | Raster-<br>izer | 8748 | x | bitfield | ~ | | TextTGlyphAddr5 | × | ′ | izer | 8750 | x | integer | × | | TextRender2DGlyph5 | × | • | Raster-<br>izer | 8758 | x | bitfield | | Register Descriptions Permedia Reference Guide | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |---------------------|---------------|----------|-----------------------------------|--------|----------------|----------|--------------| | TextTGlyphAddr6 | × | ~ | Raster-<br>izer | 8760 | х | integer | × | | TextRender2DGlyph6 | × | ~ | Raster-<br>izer | 8768 | х | bitfield | ~ | | TextTGlyphAddr7 | X | ~ | Raster-<br>izer | 8770 | х | integer | X | | TextRender2DGlyph7 | × | ~ | Raster-<br>izer | 8778 | х | bitfield | ~ | | RStart | <b>'</b> | ~ | Color<br>DDA | 8780 | х | fixed | × | | dRdx | ~ | ~ | Color<br>DDA | 8788 | x | fixed | × | | dRdyDom | • | <b>'</b> | Color<br>DDA<br>Delta | 8790 | x | fixed | × | | GStart | ~ | ~ | Color<br>DDA | 8798 | х | fixed | × | | dGdx | ~ | ~ | Color<br>DDA | 87A0 | х | fixed | X | | dGdyDom | ~ | ~ | Color<br>DDA | 87A8 | х | fixed | × | | BStart | ~ | ~ | Color<br>DDA | 87B0 | х | fixed | × | | dBdx | ~ | ~ | Color<br>DDA | 87B8 | х | fixed | X | | dBdyDom | ~ | ~ | Color<br>DDA | 87C0 | х | fixed | × | | AStart | ~ | ~ | Color<br>DDA | 87C8 | х | fixed | × | | dAdx | ~ | ~ | Color<br>DDA | 87D0 | х | fixed | X | | dAdyDom | ~ | ~ | Color<br>DDA | 87D8 | х | fixed | | | ColorDDAMode | ~ | ~ | Color<br>DDA | 87E0 | х | bitfield | | | ConstantColor | • | • | Color<br>DDA | 87E8 | x | bitfield | | | Color | ~ | <b>/</b> | | 87F0 | x | bitfield | | | AlphaTestMode | ~ | <b>✓</b> | Alpha<br>Blend &<br>Alpha<br>Test | 8800 | x | bitfield | X | | AntialiasMode | ~ | - | Alpha<br>test | 8808 | х | bitfield | × | | DitherMode | <b>'</b> | ~ | Dither | 8818 | х | bitfield | X | | FBSoftwareWriteMask | ~ | • | Logic<br>Ops | 8820 | х | integer | × | | LogicalOpMode | <b>/</b> | <b>/</b> | Logic Op | 8828 | х | bitfield | X | | RouterMode | <b>'</b> | <b>'</b> | Router | 8840 | х | bitfield | X | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |-------------------------|---------------|----------|-------------------------|--------|----------------|----------|--------------| | LBReadFormat | ~ | <b>'</b> | LB Read | 8888 | х | bitfield | X | | LBStencil | × | <b>/</b> | Host Out | 88A8 | х | bitfield | X | | LBDepth | X | | LB<br>Read/Ho<br>st Out | 88B0 | х | integer | × | | LBWriteMode | ~ | <b>/</b> | LB Write | 88C0 | х | bitfield | X | | LBWriteFormat | ~ | <b>/</b> | LB Write | 88C8 | х | bitfield | X | | TextureData | X | | Localbuff<br>er R/W | | x | integer | × | | TextureDownloadOffset | <b>'</b> | | Localbuff<br>er R/W | | х | | × | | HostInID | ~ | | Host In | 8900 | Х | | X | | Security | X | | Host In | 8908 | Х | bitfield | X | | FlushWriteCombining | X | | Host In | 8910 | Х | integer | × | | HostInState | <b>/</b> | | Host In | 8918 | Х | integer | X | | <u>HostInDMAAddress</u> | ~ | | Host In | 8938 | Х | integer | X | | HostInState2 | ~ | | Host In | 8940 | Х | integer | × | | Window | / | <b>/</b> | Stencil | 8980 | Х | bitfield | X | | StencilMode | / | <b>/</b> | Stencil | 8988 | Х | bitfield | X | | StencilData | ~ | <b>/</b> | Stencil | 8990 | Х | bitfield | | | Stencil | ~ | <b>/</b> | Stencil | 8998 | Х | bitfield | <b>✓</b> X | | DepthMode | <b>/</b> | | Depth | 89A0 | Х | bitfield | X | | <u>Depth</u> | <b>/</b> | | Depth | 89A8 | Х | integer | <b>✓</b> X | | ZStartU | <b>/</b> | | Depth | 89B0 | Х | fixed | X | | ZStartL | • | | Fog | 89B8 | x | fixed | × | | dZdxU | • | | Fog | 89C0 | x | fixed | × | | dZdxL | <b>'</b> | <b>'</b> | Fog | 89C8 | x | fixed | × | | dZdyDomU | <b>'</b> | | Depth &<br>Fog | 89D0 | x | fixed | × | | dZdyDomL | • | | Fog | 89D8 | x | bitfield | × | | FastClearDepth | <b>/</b> | | | 89E0 | Х | integer | X | | FBColor | 0 | | FB Write | | Х | n/a | X | | FBWriteMode | <b>~</b> | | FB Write | | Х | bitfield | | | FBHardwareWriteMask | ~ | | FB Write | | Х | mask | X | | FBBlockColor | <b>/</b> | | FB Read | | Х | integer | X | | FilterMode | ~ | | Host Out | | х | bitfield | X | | StatisticMode | ~ | | Host Out | | х | bitfield | X | | MinRegion | ~ | | Host Out | | Х | bitfield | X | | MaxRegion | <b>/</b> | | Host Out | | Х | bitfield | | | ResetPickResult | × | | Host Out | | Х | tag | <b>'</b> | | MinHitRegion | × | | Host Out | | Х | bitfield | <b>'</b> | | MaxHitRegion | X | <b>/</b> | Host Out | 8C30 | х | bitfield | <b>/</b> | | Sync X | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|---------------|----------|-------------------------|--------|----------------|----------|--------------| | Name | PickResult | X | ~ | Host Out | 8C38 | х | bitfield | ~ | | SuspendUntilFrameBlank | Sync | X | ~ | | | х | bitfield | / | | Fe Write | RLEMask | <b>/</b> | / | | | Х | bitfield | X | | Applicatio Roths | SuspendUntilFrameBlank | × | <b>'</b> | | 8C78 | x | bitfield | <b>'</b> | | | KsRStart | • | <b>/</b> | Applicatio | | x | fixed | × | | Texture Application | dKsRdx | <b>/</b> | <b>'</b> | | | Х | fixed | X | | Applicatio No. Application No. Application No. N | dKsRdyDom | ~ | <b>/</b> | Texture | 8C90 | X | fixed | | | Texture | KsGStart | • | <b>'</b> | Applicatio<br>n | | x | | | | KSBStart V Texture Application n dKsBdx V Texture 8CB8 x fixed X dKsBdyDom V Texture 8CC0 x fixed X dKdRStart V Texture 8D00 x fixed X dKdRdx V Texture 8D00 x fixed X dKdRdyDom V Texture 8D10 x fixed X dKdRdyDom V Texture 8D10 x fixed X dKdGdyDom V Texture 8D10 x fixed X dKdGdx V Texture 8D10 x fixed X dKdGdx V Texture 8D10 x fixed X dKdGdx V Texture 8D20 x fixed X dKdGdyDom V Texture 8D20 x fixed X dKdBStart V Texture 8D20 x fixed X dKdBStart V Texture 8D30 x fixed X dKdBStart V Texture 8D30 x fixed X dKdBdyDom dWddyDom V Texture 8D30 x fixed X dWddddyDom V Texture 8D30 x fixed X dWdddyDom V Texture 8D30 x fixed X dWddyDom V Texture 8D30 x fixed X dWddyDom V Texture 8D30 x fixed X dWddyDom V Texture 8D30 x fixed X dWddyDom V Texture 8D30 x fixed X dWddyDom V Texture 8D30 x fixed X dWddyDom V Texture 8D30 x fixed | dKsGdx | <b>/</b> | <b>'</b> | | | | | | | Applicatio R | dKsGdyDom | - | ~ | | | | | | | | KsBStart | • | • | Applicatio<br>n | | x | fixed | X | | Texture BD00 x fixed X | dKsBdx | ~ | <b>/</b> | | | X | fixed | | | | dKsBdyDom | <b>/</b> | <b>'</b> | | | Х | | | | MKdRdyDom | | <b>~</b> | <b>'</b> | Texture | 8D00 | X | | | | Texture | dKdRdx | ~ | <b>/</b> | | | | fixed | | | dKdGdx / / Texture 8D20 x fixed X dKdGdyDom / / Texture 8D28 x fixed X KdBStart / / Texture 8D30 x fixed X dKdBdx / / Texture 8D38 x fixed X dKdBdyDom / / Texture 8D40 x fixed X dKdBdyDom / / Texture 8D40 x fixed X dKdBdyDom / / Global 8DC0 x bitfield X ContextDump X Global 8DC8 x bitfield X ContextData X Global 8D00 x bitfield X LUT[015] Y LUT 8E80 x bitfield X YUVMode Y YUVUMIT 8F00 x bitfield X | dKdRdyDom | <b>/</b> | <b>'</b> | | | | | | | Texture BD28 X fixed X | | <b>/</b> | <b>'</b> | | | | | | | KdBStart dKdBdx v Texture 8D30 x fixed X dKdBdyDom v Texture 8D40 x fixed X ContextDump X Global 8DC0 x bitfield v ContextRestore X Global 8DC8 x bitfield v ContextData X Global 8DD0 x bitfield X LUT[015] v LUT 8E80 x bitfield X YUVMode v YUV Unit 8F00 x bitfield X ChromaUpper v Color 8F08 x bitfield X ChromaLower ChromaTestMode v Color 8F10 x bitfield X ChromaTestMode v Color 8F10 x bitfield X ChromaTestMode v Color 8F10 x bitfield X ChromaTestMode | | ~ | <b>'</b> | | | | | | | dKdBdx ✓ Texture 8D38 x fixed X dKdBdyDom ✓ Texture 8D40 x fixed X ContextDump X ✓ Global 8DC0 x bitfield ✓ ContextRestore X ✓ Global 8DC8 x bitfield ✓ ContextData X ✓ Global 8DD0 x bitfield X LUT 8E80 x bitfield X YUVMode ✓ YUV Unit 8F00 x bitfield X ChromaUpper ✓ Color<br>DDA &<br>Alpha<br>Blend X bitfield X ChromaLower ✓ Color<br>DDA &<br>Alpha<br>Blend 8F10<br>Blend X bitfield X ChromaTestMode ✓ Color<br>DDA &<br>Alpha<br>Blend X bitfield X | dKdGdyDom | ~ | <b>/</b> | | | | | | | dKdBdyDom V Texture 8D40 x fixed X ContextDump X V Global 8DC0 x bitfield V ContextRestore X V Global 8DC8 x bitfield V ContextData X V Global 8DD0 x bitfield X LUT[015] V LUT 8E80 x bitfield X YUVMode V YUV Unit 8F00 x bitfield X ChromaUpper V Color DDA & Alpha Blend X bitfield X ChromaLower V Color DDA & Alpha Blend X bitfield X ChromaTestMode V Color DDA & Alpha Blend X bitfield X | | ~ | <b>/</b> | | | | | | | ContextDump ContextRestore X Global BDC0 x bitfield ContextData X Global BDC0 x bitfield ContextData X Global BDD0 x bitfield X LUT BE80 X YUV Unit BF00 ChromaUpper V Color DDA & Alpha Blend ChromaTestMode ChromaTestMode X Global BDC0 x bitfield X Cloor DDA & Alpha Blend ChromaTestMode X Color DDA & Alpha Blend ChromaTestMode X Color DDA & Alpha Blend ChromaTestMode X Color DDA & Alpha Blend ChromaTestMode X Color DDA & Alpha Blend ChromaTestMode | | ~ | <b>'</b> | | | Х | | | | ContextRestore X | | | <b>/</b> | | | X | | | | ContextData X Global 8DD0 x bitfield X LUT[015] V LUT 8E80 x bitfield X YUVMode V YUV Unit 8F00 x bitfield X ChromaUpper V Color 8F08 x bitfield X DDA & Alpha Blend ChromaTestMode V Color 8F10 x bitfield X ChromaTestMode V Color 8F10 x bitfield X ChromaTestMode V Color 8F10 x bitfield X DDA & Alpha Blend ChromaTestMode | | | <b>/</b> | | | x | | ~ | | LUT[015] V LUT 8E80 x bitfield X YUVMode V YUV Unit 8F00 x bitfield X ChromaUpper V Color 8F08 x bitfield X DDA & Alpha Blend ChromaLower V Color 8F10 x bitfield X DDA & Alpha Blend ChromaTestMode V Color 8F10 x bitfield X DDA & Alpha Blend ChromaTestMode | | | <b>'</b> | | | | | | | YUVMode ChromaUpper V YUV Unit 8F00 x bitfield X Color 8F08 x bitfield X DDA & Alpha Blend ChromaLower V Color 8F10 x bitfield X DDA & Alpha Blend ChromaTestMode V Color 8F10 x bitfield X DDA & Alpha Blend ChromaTestMode | | | ļ . | | | | | | | ChromaUpper ChromaLower ChromaLower ChromaTestMode ChromaTestMode ChromaUpper Color DDA & Alpha Blend ChromaTestMode Color BF10 x bitfield X Color BF10 x bitfield X Color BF10 x bitfield X Color BF18 x bitfield X Color BF18 x bitfield X Color BF18 x bitfield X Color BF18 x bitfield X Color BF18 x bitfield X Color BF18 x bitfield X | | | Ţ., | | | | | | | DDA & Alpha Blend ChromaLower ChromaTestMode DDA & Alpha Blend ChromaTestMode DDA & Alpha Blend ChromaTestMode DDA & Alpha Blend Blend ChromaTestMode | | ~ | <b>'</b> | | | | | | | DDA & Alpha Blend ChromaTestMode V Color 8F18 x bitfield X DDA & Alpha Blend | ChromaUpper | • | • | DDA &<br>Alpha<br>Blend | | X | bitfield | X | | DDA &<br>Alpha<br>Blend | ChromaLower | | <b>'</b> | DDA &<br>Alpha<br>Blend | | X | | | | FeedbackX | ChromaTestMode | | ✓ | DDA &<br>Alpha<br>Blend | | x | bitfield | X | | | FeedbackX | | <b>/</b> | Host Out | 8F88 | х | integer | X | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |----------------------|---------------|----------|--------------|--------|----------------|-----------|--------------| | FeedbackY | Duon | | Host Out | 8F90 | X | integer | X | | EndOfFeedback | <b>/</b> | / | Host Out | | x | unused | X | | V0FloatS1 | ~ | <b>/</b> | Delta | 9000 | X | float | X | | V0FloatT1 | ~ | / | Delta | 9008 | х | float | X | | V0FloatQ1 | ~ | / | Delta | 9010 | х | float | X | | V0FloatPackedDiffuse | X | / | Delta | 9048 | х | bitfield | X | | V0FloatKsR | ~ | / | Delta | 9050 | х | float | X | | V0FloatKsG | ~ | / | Delta | 9058 | х | float | X | | V0FloatKsB | ~ | / | Delta | 9060 | х | float | | | V0FloatKdR | ~ | / | Delta | 9068 | х | float | X | | V0FloatKdG | ~ | / | Delta | 9070 | х | float | X | | V0FloatKdB | ~ | / | Delta | 9078 | х | float | X | | V1FloatS1 | ~ | / | Delta | 9080 | х | float | X | | V1FloatT1 | ~ | / | Delta | 9088 | х | float | X | | V1FloatQ1 | ~ | / | Delta | 9090 | x | float | X | | V1FloatPackedDiffuse | × | / | Delta | 90C8 | x | bitfield | X | | V1FloatKsR | ~ | <b>/</b> | Delta | 90D0 | X | float | X | | V1FloatKsG | ~ | / | Delta | 90D8 | x | float | X | | V1FloatKsB | <b>/</b> | / | Delta | 90E0 | x | float | X | | V1FloatKdR | <b>/</b> | <b>/</b> | Delta | 90E8 | X | float | X | | V1FloatKdG | <b>/</b> | / | Delta | 90F0 | x | float | X | | V1FloatKdB | <u> </u> | / | Delta | 90F8 | x | float | X | | V2FloatS1 | <u> </u> | / | Delta | 9100 | x | float | X | | V2FloatT1 | <b>/</b> | / | Delta | 9108 | x | float | X | | V2FloatQ1 | <b>/</b> | / | Delta | 9110 | x | float | X | | V2FloatPackedDiffuse | X | <b>/</b> | Delta | 9148 | x | bitfield | X | | V2FloatKsR | ~ | / | Delta | 9150 | X | float | X | | V2FloatKsG | ~ | <b>/</b> | Delta | 9158 | x | float | X | | V2FloatKsB | ~ | / | Delta | 9160 | х | float | X | | V2FloatKdR | ~ | / | Delta | 9168 | х | float | X | | V2FloatKdG | ~ | / | Delta | 9170 | х | float | X | | V2FloatKdB | <b>/</b> | / | Delta | 9178 | х | float | X | | V0FloatS | ~ | / | Delta | 9180 | х | float | X | | V0FloatT | ~ | / | Delta | 9188 | х | float | X | | V0FloatQ | ~ | / | Delta | 9190 | х | float | X | | V0FloatR | ~ | / | Delta | 91A8 | х | float | X | | V0FloatG | ~ | / | Delta | 91B0 | х | float | X | | V0FloatB | ~ | ~ | Delta | 91B8 | х | float | X | | V0FloatA | ~ | / | Delta | 91C0 | х | float | X | | V0FloatF | ~ | / | Delta | 91C8 | х | float | X | | V0FloatX | ~ | ~ | Delta | 91D0 | х | float | X | | V0FloatY | ~ | / | Delta | 91D8 | х | float | X | | V0FloatZ | ~ | / | Delta | 91E0 | х | float | X | | V0FloatPackedColor | X | / | Delta | 91F0 | х | bitfield | X | | TO IOULI UDICUODIDI | | <u> </u> | _ 0 | J U | Γ, | Ditti Old | r • | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |--------------------------|---------------|----------|---------------|--------|----------------|----------|--------------| | V0FloatPackedSpecularFog | X | <b>'</b> | Delta | 91F8 | Х | bitfield | X | | V1FloatS | ~ | <b>'</b> | Delta | 9200 | Х | float | X | | V1FloatT | <b>✓</b> | <b>/</b> | Delta | 9208 | X | float | X | | V1FloatQ | ~ | <b>/</b> | Delta | 9210 | x | float | X | | V1FloatR | ~ | / | Delta | 9228 | x | float | X | | V1FloatG | ~ | <b>/</b> | Delta | 9230 | x | float | X | | V1FloatB | ~ | <b>/</b> | Delta | 9238 | x | float | X | | V1FloatA | ~ | <b>/</b> | Delta | 9240 | х | float | X | | V1FloatF | ~ | <b>/</b> | Delta | 9248 | х | float | X | | V1FloatX | ~ | <b>/</b> | Delta | 9250 | х | float | X | | V1FloatY | ~ | <b>/</b> | Delta | 9258 | х | float | X | | V1FloatZ | ~ | <b>/</b> | Delta | 9260 | х | float | X | | V1FloatPackedColor | X | <b>/</b> | Delta | 9270 | х | bitfield | X | | V1FloatPackedSpecularFog | X | <b>/</b> | Delta | 9278 | х | bitfield | X | | V2FloatS | ~ | <b>'</b> | Delta | 9280 | х | float | X | | V2FloatT | ~ | <b>'</b> | Delta | 9288 | х | float | X | | V2FloatQ | ~ | <b>/</b> | Delta | 9290 | х | float | X | | V2FloatR | ~ | <b>/</b> | Delta | 92A8 | х | float | X | | V2FloatG | ~ | <b>/</b> | Delta | 92B0 | х | float | X | | V2FloatB | <b>/</b> | <b>/</b> | Delta | 92B8 | х | float | X | | V2FloatA | <b>/</b> | <b>/</b> | Delta | 92C0 | х | float | X | | V2FloatF | ~ | <b>/</b> | Delta | 92C8 | х | float | X | | V2FloatX | ~ | <b>/</b> | Delta | 92D0 | х | float | X | | V2FloatY | ~ | <b>/</b> | Delta | 92D8 | х | float | X | | V2FloatZ | ~ | <b>'</b> | Delta | 92E0 | х | float | X | | V2FloatPackedColor | X | <b>'</b> | Delta | 92F0 | х | bitfield | X | | V2FloatPackedSpecularFog | X | <b>/</b> | Delta | 92F8 | х | bitfield | X | | DeltaMode | ~ | <b>/</b> | Delta | 9300 | х | bitfield | X | | DrawTriangle | X | <b>/</b> | Delta | 9308 | х | bitfield | <b>/</b> | | RepeatTriangle | X | <b>/</b> | Delta | 9310 | х | tag | <b>/</b> | | DrawLine0 | X | <b>'</b> | Delta | 9318 | х | fixed | <b>/</b> | | DrawLine1 | X | <b>/</b> | Delta | 9320 | х | fixed | <b>/</b> | | RepeatLine | X | <b>'</b> | Delta | 9328 | х | tag | <b>/</b> | | DrawPoint | X | ~ | Delta | 9330 | х | bitfield | ~ | | ProvokingVertex | ~ | <b>'</b> | Delta | 9338 | х | bitfield | ~ | | TextureLODScale | ~ | ~ | Texture coord | 9340 | x | float | × | | TextureLODScale1 | ~ | • | Texture coord | 9348 | х | float | × | | DeltaControl | ~ | ~ | Delta | 9350 | х | bitfield | X | | ProvokingVertexMask | ~ | ~ | Delta | 9358 | X | bitfield | X | | XBias | ~ | / | Delta | 9480 | X | float | X | | YBias | ~ | / | Delta | 9488 | X | float | X | | PointSize | ~ | ~ | Delta | 9498 | x | integer | X | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |----------------------------|---------------|----------|-----------------|--------|----------------|----------|--------------| | AAPointSize | V V | | Delta | 94A0 | X | float | X | | LineMode | ~ | | Delta | 94A8 | x | bitfield | X | | LineWidth | ~ | <b>/</b> | Delta | 94B0 | X | integer | X | | LineWidthOffset | ~ | <b>/</b> | Delta | 94B8 | х | integer | X | | AALineWidth | ~ | / | Delta | 94C0 | х | float | X | | RectangleHeight | ~ | <b>/</b> | Delta | 94E0 | х | float | X | | LineCoord0 | X | <b>/</b> | Delta | 9760 | х | bitfield | X | | DrawLine2D10 | X | <b>/</b> | Delta | 9768 | х | bitfield | / | | LineCoord1 | X | <b>/</b> | Delta | 9770 | х | bitfield | X | | DrawLine2D01 | × | <b>/</b> | Delta | 9778 | х | bitfield | <b>/</b> | | DMAAddr | × | <b>/</b> | Host In | A980 | х | integer | X | | DMACount | × | | Host In | A988 | х | integer | X | | Command Interrupt | × | ~ | Host In | A990 | х | bitfield | X | | DMARectangle Read | × | ~ | Host In | A9A8 | х | bitfield | × | | DMARectangleReadAddress | ~ | ~ | Host In | A9B0 | х | integer | X | | DMARectangleRead LinePitch | ~ | <b>/</b> | Host In | A9B8 | х | integer | X | | DMARectangleRead Target | ~ | <b>/</b> | Host In | A9C0 | х | bitfield | X | | DMARectangleWrite | X | <b>/</b> | Host In | A9C8 | х | bitfield | X | | DMARectangleWrite Address | ~ | <b>/</b> | Host In | A9D0 | х | integer | X | | DMARectangleWriteLinePitch | ~ | <b>/</b> | Host In | A9D8 | х | integer | X | | DMAOutput Address | X | <b>'</b> | Host In | A9E0 | х | integer | X | | DMAOutputCount | X | <b>'</b> | Host In | A9E8 | х | integer | X | | DMAContinue | X | <b>'</b> | Host In | A9F8 | х | integer | / | | DMAFeedback | X | <b>'</b> | Host In | AA10 | х | integer | X | | DeltaModeAnd | X | <b>/</b> | Delta | AAD0 | х | bitfield | X | | DeltaModeOr | × | <b>/</b> | Delta | AAD8 | х | bitfield | X | | LineModeAnd | X | <b>/</b> | Delta | AAF0 | х | bitfield | X | | LineModeOr | × | <b>/</b> | Delta | AAF8 | х | bitfield | X | | DeltaControlAnd | × | <b>/</b> | Delta | AB20 | х | bitfield | X | | DeltaControlOr | × | <b>/</b> | Delta | AB28 | х | bitfield | X | | WindowAnd | × | <b>/</b> | Stencil | AB80 | х | bitfield | X | | WindowOr | × | <b>/</b> | Stencil | AB88 | х | bitfield | × | | RasterizerModeAnd | × | ~ | Raster-<br>izer | ABA0 | x | bitfield | × | | RasterizerModeOr | X | ~ | Raster-<br>izer | ABA8 | х | bitfield | X | | ScissorModeAnd | × | ~ | Scissor | ABB0 | х | bitfield | X | | ScissorModeOr | × | ~ | Scissor | ABB8 | х | bitfield | X | | LineStippleModeAnd | × | ~ | Stipple | ABC0 | х | bitfield | X | | LineStippleModeOr | × | ~ | Stipple | ABC8 | х | bitfield | X | | AreaStippleModeAnd | × | ~ | Stipple | ABD0 | х | bitfield | X | | AreaStippleModeOr | × | ~ | Stipple | ABD8 | х | bitfield | X | | ColorDDAModeAnd | X | ~ | Color<br>DDA | ABE0 | х | bitfield | X | | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |----------------------------|---------------|----------|----------------------------------|---------|----------------|-------------|--------------| | ColorDDAModeOr | X | ~ | | ABE8 | X | bitfield | X | | | | | DDA | | | | | | AlphaTestModeAnd | × | • | Alpha<br>Blend &<br>Alpha | ABF0 | X | bitfield | × | | | | | Test | | | | | | AlphaTestModeOr | X | / | | ABF8 | х | bitfield | × | | | | | Blend & | | | | | | | | | Alpha | | | | | | Audalanda I. Aud | · · | | Test | A C 0 0 | | L:46: - L-I | \ <u>'</u> | | AntialiasModeAnd | × | • | Alpha<br>test | AC00 | x | bitfield | × | | AntialiasModeOr | X | ~ | | AC08 | х | bitfield | X | | Antianasinoacoi | | ľ | test | , 1000 | | bitiloid | | | FogModeAnd | × | / | Fog | AC10 | х | bitfield | × | | FogModeOr | × | / | Fog | AC18 | х | bitfield | X | | TextureCoordModeAnd | X | ~ | Texture | AC20 | х | | × | | | | | coord | | | | | | TextureCoordModeOr | × | • | | AC28 | X | bitfield | × | | TextureReadMode0And | × | / | coord<br>Texture | AC30 | X | bitfield | × | | TextureReadivioueUAnd | ^ | | Read | AC30 | ^ | bittield | ^ | | TextureReadMode0Or | X | ~ | | AC38 | x | bitfield | × | | TextureApplication ModeAnd | × | - | Texture<br>Applicatio<br>n | AC50 | x | bitfield | × | | TextureApplication ModeOr | × | - | Texture<br>Applicatio<br>n | AC58 | x | bitfield | × | | StencilModeAnd | X | ~ | Stencil | AC60 | х | bitfield | × | | StencilModeOr | X | <b>'</b> | Stencil | AC68 | х | bitfield | X | | DepthModeAnd | X | ~ | Depth | AC70 | х | bitfield | × | | DepthModeOr | X | / | | AC78 | х | bitfield | X | | LBWriteModeAnd | × | 1 | | AC80 | х | bitfield | X | | LBWriteModeOr | X | <b>'</b> | | AC88 | Х | bitfield | × | | FBDestReadModeAnd | X | <b>'</b> | | AC90 | х | bitfield | × | | FBDestReadModeOr | × | ~ | | AC98 | x | bitfield | X | | FBSourceReadModeAnd | X | <b>'</b> | FB Read | | х | bitfield | × | | FBSourceReadModeOr | X | <b>'</b> | FB Read | | Х | bitfield | X | | AlphaBlendColorModeAnd | × | • | blend | ACB0 | X | bitfield | × | | AlphaBlendColorModeOr | × | • | blend | ACB8 | X | bitfield | X | | ChromaTestModeAnd | X | <b>'</b> | Color<br>DDA &<br>Alpha<br>Blend | ACC0 | x | bitfield | X | | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |----------------------------|---------------|----------|----------------------------------|--------|----------------|----------|--------------| | <b>ChromaTestModeOr</b> | × | • | Color<br>DDA &<br>Alpha<br>Blend | ACC8 | X | bitfield | × | | DitherModeAnd | × | <b>/</b> | Dither | ACD0 | х | bitfield | X | | DitherModeOr | × | <b>/</b> | Dither | ACD8 | х | bitfield | X | | LogicalOpModeAnd | × | <b>/</b> | Logic Op | ACE0 | х | bitfield | X | | LogicalOpModeOr | × | <b>/</b> | Logic Op | ACE8 | х | bitfield | X | | FBWriteModeAnd | X | <b>/</b> | FB Write | ACF0 | х | bitfield | X | | FBWriteModeOr | × | <b>/</b> | FB Write | ACF8 | х | bitfield | X | | FilterModeAnd | × | <b>/</b> | Host Out | AD00 | х | bitfield | X | | FilterModeOr | X | / | Host Out | AD08 | х | bitfield | X | | StatisticModeAnd | X | <b>/</b> | Host Out | AD10 | х | bitfield | X | | StatisticModeOr | X | <b>/</b> | Host Out | AD18 | х | bitfield | X | | FBDestReadEnablesAnd | X | <b>/</b> | FB Read | AD20 | х | bitfield | X | | FBDestReadEnablesOr | X | <b>/</b> | FB Read | AD28 | х | bitfield | X | | AlphaBlendAlphaModeAnd | × | ~ | Alpha<br>blend | AD30 | x | bitfield | × | | AlphaBlendAlphaModeOr | × | ~ | Alpha<br>blend | AD38 | х | bitfield | × | | TextureReadMode1And | × | <b>'</b> | Texture<br>Read | AD40 | х | bitfield | × | | TextureReadMode1Or | × | <b>'</b> | Texture<br>Read | AD48 | x | bitfield | × | | TextureFilterModeAnd | × | <b>/</b> | Texture | AD50 | X | bitfield | × | | TextureFilterModeOr | × | <b>/</b> | Texture | AD58 | X | bitfield | × | | LUTModeAnd | × | <b>'</b> | LUT | AD70 | Х | bitfield | X | | LUTModeOr | × | <b>/</b> | LUT | AD78 | X | bitfield | × | | Zstart | ~ | <b>/</b> | Fog | ADD8 | X | integer | × | | FBDestReadBufferAddr[03] | ~ | <b>'</b> | FB Read | | Х | integer | X | | FBDestReadBufferOffset[03] | ~ | <b>'</b> | FB Read | | х | integer | × | | FBDestReadBufferWidth[03] | ~ | / | FB Read | | х | integer | X | | FBDestReadMode | ~ | <b>/</b> | FB Read | | X | bitfield | X | | FBDestReadEnables | <b>'</b> | <b>'</b> | FB Read | | Х | bitfield | X | | FBSourceReadMode | ~ | <b>/</b> | FB Read | | х | bitfield | X | | FBSourceReadBufferAddr | ~ | <b>'</b> | FB Read | | х | integer | X | | FBSourceReadBufferOffset | ~ | <b>'</b> | FB Read | | х | integer | X | | FBSourceReadBufferWidth | ~ | <b>'</b> | FB Read | | х | integer | X | | AlphaSourceColor | ~ | <b>'</b> | Alpha<br>blend | AF80 | x | integer | × | | AlphaDestColor | • | <b>'</b> | Alpha<br>blend | AF88 | x | bitfield | × | | ChromaPassColor | | | Color<br>DDA &<br>Alpha<br>Blend | AF90 | X | bitfield | × | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |----------------------------|---------------|----------|----------------------------------|--------|----------------|----------|--------------| | ChromaFailColor | ~ | ~ | Color<br>DDA &<br>Alpha<br>Blend | AF98 | X | bitfield | × | | AlphaBlendColorMode | ~ | ~ | Alpha<br>blend | AFA0 | х | bitfield | × | | AlphaBlendAlphaMode | ~ | • | Alpha<br>blend | AFA8 | x | bitfield | × | | ConstantColorDDA | × | • | Color<br>DDA | AFB0 | x | bitfield | × | | FBWriteBufferAddr[03] | / | <b>/</b> | FB Write | B000 | х | integer | X | | FBWriteBufferOffset[03] | ~ | <b>/</b> | FB Write | B020 | х | integer | × | | FBWriteBufferWidth[03] | ~ | / | FB Write | B040 | х | integer | X | | FBBlockColor[03] | / | <b>/</b> | FB Write | B060 | х | integer | X | | FBBlockColorBack[03] | ~ | <b>/</b> | FB Write | B080 | х | integer | × | | FBBlockColorBack | ~ | <b>/</b> | FB Write | B0A0 | х | integer | X | | SizeOfFramebuffer | - | <b>'</b> | LB Read,<br>FB Read,<br>FB Write | | х | integer | × | | VTGAddress | ~ | <b>/</b> | FB Write | | X | integer | <b>~</b> | | VTGData | ~ | <b>/</b> | FB Write | B0B8 | х | integer | ~ | | ForegroundColor | <b>'</b> | • | Logic<br>Ops | B0C0 | x | integer | × | | BackgroundColor | • | • | Logic<br>Ops | B0C8 | x | integer | × | | FogTable[015] | ~ | <b>/</b> | Fog | B100 | х | bitfield | × | | FogTable[1631] | ~ | <b>/</b> | Fog | B180 | х | bitfield | × | | FogTable[3247] | ~ | <b>/</b> | Fog | B200 | х | bitfield | × | | FogTable[4863] | ~ | <b>/</b> | Fog | B280 | х | bitfield | X | | TextureCompositeMode | - | <b>'</b> | Texture<br>Composit<br>e | B300 | x | bitfield | × | | TextureCompositeColorMode0 | ~ | ~ | Texture<br>Composit<br>e | B308 | x | bitfield | × | | TextureCompositeAlphaMode0 | ~ | - | Texture<br>Composit<br>e | B310 | x | bitfield | × | | TextureCompositeColorMode1 | ~ | <b>'</b> | | B318 | x | bitfield | × | | TextureCompositeAlphaMode1 | ~ | ~ | | B320 | x | | × | | TextureCompositeFactor0 | ~ | ~ | | B328 | x | bitfield | | | Name | Read-<br>back | | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |-----------------------------------|---------------|----------|--------------------------|--------|----------------|----------|--------------| | TextureCompositeFactor1 | ~ | ~ | Texture<br>Composit<br>e | B330 | x | bitfield | × | | TextureIndexMode0 | <b>'</b> | ~ | Texture<br>Index | B338 | x | bitfield | × | | TextureIndexMode1 | <b>'</b> | ~ | Texture<br>Index | B340 | x | bitfield | × | | LodRange0 | <b>'</b> | ~ | Texture<br>Index | B348 | x | bitfield | X | | LodRange1 | <b>'</b> | • | Index | B350 | x | fixed | × | | InvalidateCache | X | • | Texture<br>Read | B358 | x | bitfield | • | | SetLogicalTexturePage | <b>'</b> | • | Read | B360 | х | bitfield | × | | UpdateLogicalTextureInfo | × | • | Read | B368 | x | tag | ~ | | TouchLogicalPage | X | • | Read | B370 | x | bitfield | ~ | | LUTMode | <b>/</b> | <b>/</b> | | B378 | X | bitfield | X | | TextureCompositeColorMode0And | X | <b>'</b> | Texture<br>Composit<br>e | B380 | x | bitfield | × | | TextureCompositeColorMode0Or | X | <b>'</b> | Texture<br>Composit<br>e | B388 | х | bitfield | × | | TextureCompositeAlphaMode0An<br>d | X | ~ | Texture<br>Composit<br>e | B390 | х | bitfield | × | | TextureCompositeAlphaMode0Or | × | - | Texture<br>Composit<br>e | B398 | x | bitfield | × | | TextureCompositeColorMode1And | × | <b>'</b> | Texture<br>Composit<br>e | B3A0 | х | bitfield | × | | TextureCompositeColorMode1Or | X | <b>'</b> | Texture<br>Composit<br>e | B3A8 | х | bitfield | × | | TextureCompositeAlphaMode1An<br>d | × | <u></u> | Texture<br>Composit<br>e | B3B0 | x | bitfield | × | | TextureCompositeAlphaMode1Or | × | ~ | Texture<br>Composit<br>e | B3B8 | x | bitfield | × | | TextureIndexMode0And | × | - | Texture<br>Index | B3C0 | x | bitfield | × | | TextureIndexMode0Or | X | • | Texture<br>Index | B3C8 | x | bitfield | X | | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |---------------------------------|---------------|----------|-----------------|--------|----------------|----------|--------------| | TextureIndexMode1And | X | ~ | Texture | B3D0 | Х | bitfield | X | | | | | Index | | | | | | TextureIndexMode1Or | X | / | Texture | B3D8 | х | bitfield | X | | 01 | ., | | Index | DOFO | | bitfield | ., | | StencilDataAnd | X<br>X | <b>/</b> | Stencil | B3E0 | X | | X | | StencilDataOr | | <b>/</b> | Stencil | B3E8 | х | bitfield | X | | TextureReadMode0 | <b>'</b> | • | Texture<br>Read | B400 | x | bitfield | × | | TextureReadMode1 | • | • | Texture<br>Read | B408 | X | bitfield | × | | TextureMapSize | <b>'</b> | ′ | Texture<br>Read | B428 | х | integer | × | | HeadPhysicalPage | <b>'</b> | <b>/</b> | Texture | B480 | х | integer | X | | Allocation[03] | | | Read | | | | | | TailPhysicalPage Allocation[03] | <b>'</b> | • | Texture<br>Read | B4A0 | х | integer | × | | PhysicalPageAllocationTableAddr | <b>'</b> | ~ | Texture<br>Read | B4C0 | х | integer | × | | BasePageOfWorking Set | <b>'</b> | ~ | Texture<br>Read | B4C8 | х | integer | X | | LogicalTexturePage TableAddr | ~ | ~ | Texture<br>Read | B4D0 | x | integer | × | | LogicalTexturePage TableLength | <b>'</b> | ~ | Texture<br>Read | B4D8 | х | integer | × | | BasePageOfWorking SetHost | <b>'</b> | ~ | Texture<br>Read | B4E0 | x | integer | × | | LBDestReadMode | / | ~ | | B500 | х | integer | X | | LBDestReadEnables | <b>/</b> | <b>/</b> | | B508 | х | bitfield | X | | LBDestReadBufferAddr | <b>'</b> | <b>/</b> | | B510 | х | integer | | | LBDestReadBufferOffset | ~ | <b>/</b> | | B518 | х | integer | | | LBSourceReadMode | ~ | <b>/</b> | | B520 | х | integer | X | | LBSourceReadBufferAddr | ~ | <b>/</b> | | B528 | х | integer | X | | LBSourceReadBufferOffset | <b>'</b> | <b>/</b> | | B530 | х | bitfield | X | | GIDMode | <b>/</b> | <b>/</b> | LB Read | B538 | х | bitfield | X | | LBWriteBufferAddr | <b>/</b> | <b>/</b> | LB Write | B540 | х | integer | X | | LBWriteBufferOffset | <b>/</b> | <b>'</b> | LB Write | B548 | х | integer | X | | LBClearDataL | <b>'</b> | ~ | LB Read | B550 | х | integer | X | | LBClearDataU | <b>'</b> | ~ | | B558 | х | integer | X | | LBDestReadModeAnd | X | <b>'</b> | | B580 | х | bitfield | X | | LBDestReadModeOr | X | ~ | LB Read | B588 | х | bitfield | X | | LBDestReadEnables And | X | <b>/</b> | | B590 | х | bitfield | X | | LBDestReadEnables Or | X | | | B598 | х | bitfield | X | | LBSourceReadMode And | X | | | B5A0 | х | bitfield | X | | LBSourceReadModeOr | X | ~ | | B5A8 | х | bitfield | X | | GIDModeAnd | X | ~ | | B5B0 | х | bitfield | X | | GIDModeOr | X | ~ | | B5B8 | х | bitfield | X | | L | 1 | 1 | 1 | 1 | | -1 | 1 | | Name | Read-<br>back | Write | Unit<br>Name | Offset | Reset<br>Value | Format | Com-<br>mand | |----------------------|---------------|----------|--------------------|--------|----------------|----------|--------------| | RectanglePosition | ~ | ~ | 2D Set | B600 | х | integer | X | | GlyphPosition | ~ | ~ | Up<br>2D Set<br>Up | B608 | х | integer | × | | RenderPatchOffset | <b>'</b> | ~ | 2D Set<br>Up | B610 | х | bitfield | × | | Config2D | X | <b>'</b> | Global | B618 | х | bitfield | × | | Packed8Pixels | X | • | 2D Set<br>Up | B630 | x | integer | | | Packed16Pixels | × | ~ | 2D Set<br>Up | B638 | х | integer | ~ | | Render2D | X | ~ | 2D Set<br>Up | B640 | х | bitfield | × | | Render2DGlyph | × | ~ | 2D Set<br>Up | B648 | х | bitfield | × | | DownloadTarget | ~ | ~ | 2D Set<br>Up | B650 | х | | ~ | | DownloadGlyphWidth | ~ | ~ | 2D Set<br>Up | B658 | x | integer | × | | GlyphData | × | ~ | 2D Set<br>Up | B660 | х | integer | × | | Packed4Pixels | X | ~ | 2D Set<br>Up | B668 | x | integer | ~ | | RLData | <b>'</b> | ~ | 2D Set<br>Up | B670 | х | integer | × | | RLCount | X | • | 2D Set<br>Up | B678 | х | integer | × | | IndexBaseAddress | <b>/</b> | ~ | Host In | B700 | х | integer | × | | VertexBaseAddress | ~ | <b>/</b> | Host In | B708 | х | integer | X | | IndexedTriangleList | × | <b>/</b> | Host In | B710 | х | integer | X | | IndexedTriangleFan | × | | Host In | B718 | х | integer | X | | IndexedTriangleStrip | × | <b>'</b> | Host In | B720 | Х | integer | X | | IndexedLineList | × | <b>'</b> | Host In | B728 | Х | integer | X | | IndexedLineStrip | × | | Host In | B730 | х | integer | X | | IndexedPointList | × | | Host In | B738 | х | integer | X | | IndexedPolygon | × | | Host In | B740 | х | integer | X | | VertexTriangleList | × | <b>'</b> | Host In | B748 | х | integer | X | | VertexTriangleFan | × | <b>'</b> | Host In | B750 | х | integer | X | | VertexTriangleStrip | X | <b>'</b> | Host In | B758 | x | integer | × | | VertexLineList | X | | Host In | B760 | Х | integer | X | | VertexLineStrip | X | | Host In | B768 | Х | integer | X | | VertexPointList | X | | Host In | B770 | х | integer | X | | VertexPolygon | X | | Host In | B778 | Х | integer | X | | DMAMemoryControl | <b>/</b> | | Host In | B780 | х | bitfield | X | | VertexValid | ~ | ~ | Host In | B788 | х | integer | X | | VertexFormat | ~ | ~ | Host In | B790 | x | integer | X | | VertexControl | <b>'</b> | <b>'</b> | Host In | B798 | x | bitfield | X | | Name | Read- | 1 | | Offset | Reset | Format | Com- | |---------------------|-------|----------|---------|--------|-------|----------|------| | | back | | Name | | Value | | mand | | RetainedRender | ~ | <b>/</b> | Host In | B7A0 | x | bitfield | ~ | | IndexedVertex | × | <b>/</b> | Host In | B7A8 | x | integer | × | | IndexedDoubleVertex | × | / | Host In | B7B0 | х | integer | X | | Vertex0 | × | / | Host In | B7B8 | х | integer | X | | Vertex1 | × | / | Host In | B7C0 | х | integer | X | | Vertex2 | × | / | Host In | B7C8 | х | integer | X | | VertexData0 | × | / | Host In | B7D0 | х | integer | X | | VertexData1 | × | ~ | Host In | B7D8 | х | integer | X | | VertexData2 | × | / | Host In | B7E0 | х | integer | X | | VertexData | × | / | Host In | B7E8 | х | integer | X | | VertexTagList[015] | ~ | / | Host In | B800 | х | bitfield | X | | VertexTagList[1631] | ~ | ~ | Host In | B880 | х | bitfield | X | 7 ## **Package Diagrams** The package is a standard 456 ball PBGA. The chamfered corner indicates pin 1AF. Figure 7-1 Package Diagram (Bottom View) Figure 7-2 Package Diagram (Top View) **Table 7-1 Mechanical Diagrams** | Dimension | | mm | |-----------|------------|-----------------| | A) | Ball Pitch | 1.27 | | B) | Lead Width | $0.63 \pm 0.03$ | | C) | Height | 2.33 | | D) | Body Width | 35 | ## **Pin Assignment** Figure 8-1 Package Diagram (Bottom View) ## 8.1 Pinlist by Number The table below provides a brief description of each pin. It is organized alphabetically by pin number. The pin type definitions used are: - I/O: Input Signal - GND: Ground - VSS 3.3: Power at 3.3V - VSS 2.5: Power at 2.5 Volts Where AGP pins are unused, the following terminations are recommended: AGPSBA(7:0) No connection - output only AGPPipeN No connection - output only AGPADSTB(1:0) Tie high (input only) AGPADSTBN(1:0) Tie low (input only) AGPADSTB No connection - output only AGPADSTBN No connection - output only AGPADSt(2:0) Tie high - input only AGPVREF As per AGP termination AGPRbfN No connection (output only) Table 8-1 Pinlist by Number | NO. | NAME | DESCRIPTION | |-----|-------------|-----------------------| | A1 | VCC_2.5 | | | A2 | VCC_2.5 | | | A3 | MDat_124 | Memory data line 124 | | A4 | MDat_98 | Memory data line 98 | | A5 | MDat_113 | Memory data line 113 | | A6 | MDat_112 | Memory data line 112 | | A7 | MDat_119 | Memory data line 119 | | A8 | MDat_111 | Memory data line 111 | | A9 | MDat_104 | Memory data line 104 | | A10 | MemClkRet_3 | Memory Clock Return 3 | Table 8-1 Pinlist by Number | NO. | NAME | DESCRIPTION | |-----|-------------|-----------------------| | A11 | MDat_90 | Memory data line 90 | | A12 | MDat_91 | Memory data line 91 | | A13 | MDat_70 | Memory data line 70 | | A14 | MDat_82 | Memory data line 82 | | A15 | MDat_83 | Memory data line 83 | | A16 | MDat_77 | Memory data line 77 | | A17 | MDat_76 | Memory data line 76 | | A18 | MDat_75 | Memory data line 75 | | A19 | MemClkRet_2 | Memory Clock Return 2 | | A20 | MDat_60 | Memory data line 60 | | A21 | MDat_59 | Memory data line 59 | | A22 | MDat_35 | Memory data line 35 | | A23 | MDat_36 | Memory data line 36 | | A24 | MDat_38 | Memory data line 38 | | A25 | VCC_2.5 | | | A26 | VCC_2.5 | | | B1 | VCC_2.5 | | | B2 | VCC_2.5 | | | В3 | MDat_99 | Memory data line 99 | | B4 | MDat_97 | Memory data line 97 | | B5 | MDat_115 | Memory data line 115 | | В6 | MDat_116 | Memory data line 116 | | B7 | MDat_108 | Memory data line 108 | | B8 | MDat_107 | Memory data line 107 | | B9 | MByte_15 | Memory byte select 15 | | B10 | MDat_93 | Memory data line 93 | | B11 | MDat_89 | Memory data line 89 | | B12 | MDat_66 | Memory data line 66 | | B13 | MDat_69 | Memory data line 69 | | B14 | MDat_81 | Memory data line 81 | Table 8-1 Pinlist by Number | NO. | NAME | DESCRIPTION | |-----|----------|-----------------------| | B15 | MDat_85 | Memory data line 85 | | B16 | MDat_78 | Memory data line 78 | | B17 | MDat_74 | Memory data line 74 | | B18 | MByte_11 | Memory byte select 11 | | B19 | MByte_9 | Memory byte select 9 | | B20 | MDat_61 | Memory data line 61 | | B21 | MDat_58 | Memory data line 58 | | B22 | MDat_34 | Memory data line 34 | | B23 | MDat_37 | Memory data line 37 | | B24 | MDat_39 | Memory data line 39 | | B25 | VCC_2.5 | | | B26 | VCC_2.5 | | | C1 | MDat_123 | Memory data line 123 | | C2 | MDat_125 | Memory data line 125 | | C3 | VCC_2.5 | | | C4 | MDat_96 | Memory data line 96 | | C5 | MDat_114 | Memory data line 114 | | C6 | MDat_117 | Memory data line 117 | | C7 | MDat_109 | Memory data line 109 | | C8 | MDat_106 | Memory data line 106 | | C9 | MByte_13 | Memory byte select 13 | | C10 | MDat_94 | Memory data line 94 | | C11 | MDat_88 | Memory data line 88 | | C12 | MDat_65 | Memory data line 65 | | C13 | MDat_67 | Memory data line 67 | | C14 | MDat_80 | Memory data line 80 | | C15 | MDat_86 | Memory data line 86 | | C16 | MDat_79 | Memory data line 79 | | C17 | MDat_73 | Memory data line 73 | | C18 | MByte_8 | Memory byte select 8 | Table 8-1 Pinlist by Number | NO. | NAME | DESCRIPTION | |-----|--------------|---------------------------| | C19 | MByte_10 | Memory byte select 10 | | C20 | MDat_62 | Memory data line 62 | | C21 | MDat_57 | Memory data line 57 | | C22 | MDat_33 | Memory data line 33 | | C23 | MDat_48 | Memory data line 48 | | C24 | VCC_2.5 | | | C25 | MDat_49 | Memory data line 49 | | C26 | MDat_50 | Memory data line 50 | | D1 | MDat_122 | Memory data line 122 | | D2 | MDat_100 | Memory data line 100 | | D3 | MDat_126 | Memory data line 126 | | D4 | VCC_2.5 | | | D5 | MDat_118 | Memory data line 118 | | D6 | MDat_110 | Memory data line 110 | | D7 | MDat_105 | Memory data line 105 | | D8 | MByte_12 | Memory byte select 12 | | D9 | MByte_14 | Memory byte select 14 | | D10 | MDat_95 | Memory data line 95 | | D11 | MDat_92 | Memory data line 92 | | D12 | MDat_64 | Memory data line 64 | | D13 | MDat_71 | Memory data line 71 | | D14 | MDat_68 | Memory data line 68 | | D15 | MDat_87 | Memory data line 87 | | D16 | MDat_84 | Memory data line 84 | | D17 | MDat_72 | Memory data line 72 | | D18 | RenderSyncN | Multi-rasterizer i/o sync | | D19 | MDat_63 | Memory data line 63 | | D20 | MDat_56 | Memory data line 56 | | D21 | MDat_32 | Memory data line 32 | | D22 | VideoExtCtrl | Video External control | Table 8-1 Pinlist by Number | NO. | NAME | DESCRIPTION | |-----|----------|----------------------| | D23 | VCC_2.5 | | | D24 | MDat_51 | Memory data line 51 | | D25 | MDat_52 | Memory data line 52 | | D26 | MDat_53 | Memory data line 53 | | E1 | MDat_121 | Memory data line 121 | | E2 | MDat_101 | Memory data line 101 | | E3 | MDat_102 | Memory data line 102 | | E4 | MDat_127 | Memory data line 127 | | E5 | GND | | | E6 | GND | | | E7 | VCC_3.3 | | | E8 | VCC_3.3 | | | E9 | GND | | | E10 | GND | | | E11 | VCC_3.3 | | | E12 | VCC_3.3 | | | E13 | GND | | | E14 | GND | | | E15 | VCC_3.3 | | | E16 | VCC_3.3 | | | E17 | GND | | | E18 | GND | | | E19 | VCC_3.3 | | | E20 | VCC_3.3 | | | E21 | GND | | | E22 | GND | | | E23 | MDat_47 | Memory data line 47 | | E24 | MDat_46 | Memory data line 46 | | E25 | MDat_55 | Memory data line 55 | | E26 | MDat_54 | Memory data line 54 | Table 8-1 Pinlist by Number | NO. | NAME | DESCRIPTION | |-----|-------------|---------------------------| | F1 | MDat_120 | Memory data line 120 | | F2 | VSBResetN | Video Stream B Reset Out | | F3 | MDat_103 | Memory data line 103 | | F4 | VSBData_0 | VideoStream B data line 0 | | F5 | GND | | | F22 | GND | | | F23 | MDat_45 | Memory data line 45 | | F24 | MDat_44 | Memory data line 44 | | F25 | MDat_43 | Memory data line 43 | | F26 | MDat_42 | Memory data line 42 | | G1 | VSBData_1 | VideoStream B data line 1 | | G2 | VSBData_2 | VideoStream B data line 2 | | G3 | VSBData_3 | VideoStream B data line 3 | | G4 | VSBData_4 | VideoStream B data line 4 | | G5 | VCC_3.3 | | | G22 | VCC_3.3 | | | G23 | MByte_4 | Memory byte select 4 | | G24 | MByte_7 | Memory byte select 7 | | G25 | MDat_40 | Memory data line 40 | | G26 | MDat_41 | Memory data line 41 | | H1 | VSBData_5 | VideoStream B data line 5 | | H2 | VSBData_6 | VideoStream B data line 6 | | Н3 | VSBData_7 | VideoStream B data line 7 | | H4 | VSBClk | VideoStream B clock | | H5 | VCC_3.3 | | | H22 | VCC_3.3 | | | H23 | MDat_31 | Memory data line 31 | | H24 | MByte_6 | Memory byte select 6 | | H25 | MByte_5 | Memory byte select 5 | | H26 | MemClkRet_1 | Memory Clock Return 1 | Table 8-1 Pinlist by Number | NO. | NAME | DESCRIPTION | |-----|------------------|-----------------------------| | J1 | VSGPDataStrob eN | VS GP bus data strobe | | J2 | VSGPReadWrit eN | VS GP bus read/write signal | | J3 | VSBClkOut | Video Streams B Clock Out | | J4 | SPARE | | | J5 | GND | | | J22 | GND | | | J23 | MDat_30 | Memory data line 30 | | J24 | MDat_29 | Memory data line 29 | | J25 | MDat_28 | Memory data line 28 | | J26 | MBank_3 | Memory bank select 3 | | K1 | VSCtl_0 | VideoStreams Control line 0 | | K2 | VSCtl_1 | VideoStreams Control line 1 | | К3 | VSGPChipSelectN | VS GP bus chip select | | K4 | VSGPDataAckN | VS GP bus data ack | | K5 | GND | | | K22 | GND | | | K23 | MDat_24 | Memory data line 24 | | K24 | MDat_25 | Memory data line 25 | | K25 | MDat_26 | Memory data line 26 | | K26 | MDat_27 | Memory data line 27 | | L1 | VSCtl_3 | VideoStreams Control line 3 | | L2 | VSCtl_4 | VideoStreams Control line 4 | | L3 | VSCtl_5 | VideoStreams Control line 5 | | L4 | VSCtl_2 | VideoStreams Control line 2 | | L5 | VCC_3.3 | | | L11 | GND | | | L12 | GND | | | L13 | GND | | | L14 | GND | | | L15 | GND | | Table 8-1 Pinlist by Number | NO. | NAME | DESCRIPTION | |-----|-------------|-----------------------------| | L16 | GND | | | L22 | VCC_3.3 | | | L23 | MDat_3 | Memory data line 3 | | L24 | MDat_0 | Memory data line 0 | | L25 | MDat_1 | Memory data line 1 | | L26 | MDat_2 | Memory data line 2 | | M1 | TestSel_0_ | Test Mode Select 1 | | M2 | TestSel_2_ | Test Mode Select 2 | | M3 | VSCtl_6 | VideoStreams Control line 6 | | M4 | VSCtl_7 | VideoStreams Control line 7 | | M5 | VCC_3.3 | | | M11 | GND | | | M12 | GND | | | M13 | GND | | | M14 | GND | | | M15 | GND | | | M16 | GND | | | M22 | VCC_3.3 | | | M23 | MDat_7 | Memory data line 7 | | M24 | MDat_6 | Memory data line 6 | | M25 | MDat_5 | Memory data line 5 | | M26 | MDat_4 | Memory data line 4 | | N1 | DacAVDD | Analog/video DAC | | N2 | vidRed | Analog red signal | | N3 | vidGreen | Analog green signal | | N4 | VidRightEye | Right signal for stereo | | N5 | GND | | | N11 | GND | | | N12 | GND | | | N13 | GND | | Table 8-1 Pinlist by Number | NO. | NAME | DESCRIPTION | |-----|-----------|---------------------| | N14 | GND | | | N15 | GND | | | N16 | GND | | | N22 | GND | | | N23 | MDat_16 | Memory data line 16 | | N24 | MDat_19 | Memory data line 19 | | N25 | MDat_18 | Memory data line 18 | | N26 | MDat_17 | Memory data line 17 | | P1 | VidVRef | Voltage reference | | P2 | DacComp | Compensation pin | | Р3 | vidBlue | Analog blue signal | | P4 | vidResRef | Reference resistor | | P5 | GND | | | P11 | GND | | | P12 | GND | | | P13 | GND | | | P14 | GND | | | P15 | GND | | | P16 | GND | | | P22 | GND | | | P23 | MDat_20 | Memory data line 20 | | P24 | MDat_23 | Memory data line 23 | | P25 | MDat_22 | Memory data line 22 | | P26 | MDat_21 | Memory data line 21 | | R1 | TestMode | Test Mode control | | R2 | VidHSync | Horizontal sync | | R3 | TestSel_1 | Test Mode Select 1 | | R4 | DacAGnd | DAC Power/Gnd pin | | R5 | VCC_3.3 | | | R11 | GND | | Table 8-1 Pinlist by Number | NO. | NAME | DESCRIPTION | |-----|------------|---------------------| | R12 | GND | | | R13 | GND | | | R14 | GND | | | R15 | GND | | | R16 | GND | | | R22 | VCC_3.3 | | | R23 | MDat_15 | Memory data line 15 | | R24 | MDat_14 | Memory data line 14 | | R25 | MDat_13 | Memory data line 13 | | R26 | MDat_12 | Memory data line 12 | | T1 | Xtal1 | Crystal i/p 1 | | T2 | VidVsync | Vertical sync | | Т3 | PLLDISABLE | PLL Disable | | T4 | Xtal2 | Crystal i/p 2 | | T5 | VCC_3.3 | | | T11 | GND | | | T12 | GND | | | T13 | GND | | | T14 | GND | | | T15 | GND | | | T16 | GND | | | T22 | VCC_3.3 | | | T23 | MDat_11 | Memory data line 11 | | T24 | MDat_8 | Memory data line 8 | | T25 | MDat_9 | Memory data line 9 | | T26 | MDat_10 | Memory data line 10 | | U1 | ROMWeN | ROM Write Enable | | U2 | ROMSelN | ROM Select signal | | U3 | VidDDCData | Data line for DDC | | U4 | VidDDCClk | Clock line for DDC | Table 8-1 Pinlist by Number | NO. | NAME | DESCRIPTION | |-----|-------------|---------------------------| | U5 | GND | | | U22 | GND | | | U23 | MBank_2 | Memory bank select 2 | | U24 | MByte_0 | Memory byte select 0 | | U25 | MByte_3 | Memory byte select 3 | | U26 | MByte_1 | Memory byte select 1 | | V1 | SBClk | Serial bus clock | | V2 | SPARE | | | V3 | VSAClk | VideoStream A clock | | V4 | VSAResetN | Video Stream reset | | V5 | GND | | | V22 | GND | | | V23 | MBank_0 | Memory bank select 0 | | V24 | MBank_1 | Memory bank select 1 | | V25 | MByte_2 | Memory byte select 2 | | V26 | MemClkRet_0 | Memory Clock Return 0 | | W1 | PLLPower | PLL Power/Gnd pin | | W2 | VSAData_5 | VideoStream A data line 5 | | W3 | VSAData_7 | VideoStream A data line 7 | | W4 | SBData | serial bus data | | W5 | VCC_3.3 | | | W22 | VCC_3.3 | | | W23 | MDSF | Memory DSF line | | W24 | MRAS | Memory RAS line | | W25 | MCAS | Memory CAS line | | W26 | MClkE | Memory clock enable | | Y1 | VSAData_3 | VideoStream A data line 3 | | Y2 | VSAData_6 | VideoStream A data line 6 | | Y3 | VSAData_4 | VideoStream A data line 4 | | Y4 | PLLGND | PLL Power/Gnd pin | Table 8-1 Pinlist by Number | NO. | NAME | DESCRIPTION | |------|---------------|---------------------------| | Y5 | VCC_3.3 | | | Y22 | VCC_3.3 | | | Y23 | MAddr_9 | Memory address line 9 | | Y24 | MAddr_10 | Memory address line 10 | | Y25 | MAddr_11 | Memory address line 11 | | Y26 | MWE | Memory write enable | | AA1 | RESERVED | No Connect | | AA2 | VSAdata_2 | VideoStream A data line 2 | | AA3 | VSAData_1 | VideoStream A data line 1 | | AA4 | VSAData_0 | VideoStream A data line 0 | | AA5 | GND | | | AA22 | GND | | | AA23 | MAddr_5 | Memory address line 5 | | AA24 | MAddr_6 | Memory address line 6 | | AA25 | MAddr_7 | Memory address line 7 | | AA26 | MAddr_8 | Memory address line 8 | | AB1 | PCIFIFOInDis | Delta control | | AB2 | PCIFIFOOutDis | Delta control | | AB3 | PCIRSTN | PCI reset | | AB4 | RESERVED | No Connect | | AB5 | GND | | | AB6 | GND | | | AB7 | VCC_3.3 | | | AB8 | VCC_3.3 | | | AB9 | GND | | | AB10 | GND | | | AB11 | VCC_3.3 | | | AB12 | VCC_3.3 | | | AB13 | GND | | | AB14 | GND | | Pin Assignment Permedia Reference Guide Table 8-1 Pinlist by Number | NO. | NAME | DESCRIPTION | |------|-------------|--------------------------| | AB15 | VCC_3.3 | | | AB16 | VCC_3.3 | | | AB17 | GND | | | AB18 | GND | | | AB19 | VCC_3.3 | | | AB20 | VCC_3.3 | | | AB21 | GND | | | AB22 | GND | | | AB23 | MemClkOut_0 | Memory Clock Out 0 | | AB24 | MAddr_2 | Memory address line 2 | | AB25 | MAddr_3 | Memory address line 3 | | AB26 | MAddr_4 | Memory address line 4 | | AC1 | PCIClkSel | 33/66 MHz PCI Select | | AC2 | PCICLK | PCI clock | | AC3 | VDDQ_5 | | | AC4 | VCC_2.5 | | | AC5 | AGPSt_2 | AGP status 2 | | AC6 | AGPSBA_0 | AGP Sideband Address 0 | | AC7 | AGPSBA_3 | AGP Sideband Address 3 | | AC8 | AGPSBA_4 | AGP Sideband Address 4 | | AC9 | VDDQ_6 | | | AC10 | PCIAD_29 | PCI address/data line 29 | | AC11 | PCIAD_26 | PCI address/data line 26 | | AC12 | PCIAD_23 | PCI address/data line 23 | | AC13 | PCIAD_21 | PCI address/data line 21 | | AC14 | PCIAD_20 | PCI address/data line 20 | | AC15 | PCICBEN_2 | PCI byte enable 2 | | AC16 | PCIFrameN | PCI frame signal | | AC17 | VDDQ_7 | | | AC18 | PCIAD_15 | PCI address/data line 15 | Table 8-1 Pinlist by Number | NO. | NAME | DESCRIPTION | |------|-------------|--------------------------------| | AC19 | PCIAD_12 | PCI address/data line 12 | | AC20 | PCIAD_8 | PCI address/data line 8 | | AC21 | AGPADSTB0N | AGP AD 2X strobe | | AC22 | PCIAD_4 | PCI address/data line 4 | | AC23 | VCC_2.5 | | | AC24 | MemClkOut_1 | Memory clock out 1 | | AC25 | MAddr_0 | Memory address line 0 | | AC26 | MAddr_1 | Memory address line 1 | | AD1 | PCIIntAN | PCI interrupt | | AD2 | GND_0 | | | AD3 | VCC_2.5 | | | AD4 | AGPSt_0 | AGP status 0 | | AD5 | AGPRbfN | AGP Read Data Buffer full | | AD6 | GND_1 | | | AD7 | AGPSBSTB | AGP Sideband Address 2X strobe | | AD8 | AGPSBA_5 | AGP Sideband Address 5 | | AD9 | AGPSBA_7 | AGP Sideband Address 7 | | AD10 | GND_2 | | | AD11 | PCIAD_25 | PCI address/data line 25 | | AD12 | PCIAD_24 | PCI address/data line 24 | | AD13 | PCIAD_22 | PCI address/data line 22 | | AD14 | VDDQ_3 | | | AD15 | PCIAD_16 | PCI address/data line 16 | | AD16 | PCIDevSelN | PCI device select | | AD17 | PCIStopN | PCI stop | | AD18 | GND_4 | | | AD19 | PCIAD_11 | PCI address/data line 11 | | AD20 | PCICBEN_0 | PCI byte enable 0 | | AD21 | PCIAD_7 | PCI address/data line 7 | | AD22 | VDDQ_8 | | Table 8-1 Pinlist by Number | NO. | NAME | DESCRIPTION | |------|-------------|--------------------------| | AD23 | AGPvREF | not connected | | AD24 | VCC_2.5 | | | AD25 | MemClkOut_2 | Memory Clock Out 2 | | AD26 | MemClkOut_3 | Memory Clock Out 3 | | AE1 | VCC_2.5 | | | AE2 | VCC_2.5 | | | AE3 | PCIReqN | PCI request | | AE4 | AGPSt_1 | AGP status 1 | | AE5 | AGPPipeN | AGP Pipelined Address | | AE6 | AGPSBA_1 | AGP Sideband Address 1 | | AE7 | AGPSBSTEN | | | AE8 | AGPSBA_6 | AGP Sideband Address 6 | | AE9 | PCIAD_31 | PCI address/data line 31 | | AE10 | PCIAD_28 | PCI address/data line 28 | | AE11 | AGPADSTB1N | | | AE12 | PCICBEN_3 | PCI byte enable 3 | | AE13 | PCIAD_19 | PCI address/data line 19 | | AE14 | PCIAD_17 | PCI address/data line 17 | | AE15 | PCIIRdyN | PCI parity | | AE16 | PCITRdyN | PCI T ready | | AE17 | PCIPar | PCI ready | | AE18 | PCIAD_14 | PCI address/data line 14 | | AE19 | PCIAD_10 | PCI address/data line 10 | | AE20 | AGPADSTB0 | AGP AD 2X strobe | | AE21 | PCIAD_6 | PCI address/data line 6 | | AE22 | PCIAD_3 | PCI address/data line 3 | | AE23 | PCIAD_1 | PCI address/data line 1 | | AE24 | RESERVED | | | AE25 | VCC_2.5 | | | AE26 | VCC_2.5 | | Table 8-1 Pinlist by Number | NO. | NAME | DESCRIPTION | |------|------------|--------------------------| | AF1 | VCC_2.5 | | | AF2 | VCC_2.5 | | | AF3 | PCIGntN | PCI grant signal | | AF4 | VDDQ_0 | | | AF5 | WbfN | | | AF6 | AGPSBA_2 | AGP Sideband Address 2 | | AF7 | PINAGPTol0 | | | AF8 | VDDQ_1 | | | AF9 | PCIAD_30 | PCI address/data line 30 | | AF10 | PCIAD_27 | PCI address/data line 27 | | AF11 | AGPADSTB1 | AGP AD 2X strobe | | AF12 | VDDQ_2 | | | AF13 | PCIIdSel | PCI ID select | | AF14 | PCIAD_18 | PCI address/data line 18 | | AF15 | AGPtol1 | V tolerant AGP I/Os | | AF16 | GND_3 | | | AF17 | PCICBEN_1 | PCI byte enable 1 | | AF18 | PCIAD_13 | PCI address/data line 13 | | AF19 | PCIAD_9 | PCI address/data line 9 | | AF20 | VDDQ_4 | | | AF21 | PCIAD_5 | PCI address/data line 5 | | AF22 | PCIAD_2 | PCI address/data line 2 | | AF23 | PCIAD_0 | PCI address/data line 0 | | AF24 | GND_5 | | | AF25 | VCC_2.5 | | | AF26 | VCC_2.5 | | ## 8.2 Pinlist by Name The table below provides a brief description of each pin. It is organized alphabetically by pin name. The pin type definitions used are: - I/O: Input Signal - GND: Ground - <u>VSS 3.3: Power at 3.3V</u> - VSS 2.5: Power at 2.5 Volts Table 8-2 Pinlist by Name | NAME | NO. | DESCRIPTION | |------------|------|--------------------------------| | AGPADSTB0 | AE20 | AGP AD 2X strobe | | AGPADSTB1 | AF11 | AGP AD 2X strobe | | AGPADSTB0N | AC21 | AGP AD 2x strobe | | AGPADSTB1N | AE11 | | | AGPPipeN | AE5 | AGP Pipelined address | | AGPRÉIN | AD5 | AGP Read Data Buffer full | | AGPSBA_0 | AC6 | AGP Sideband Address 0 | | AGPSBA_1 | AE6 | AGP Sideband Address 1 | | AGPSBA_2 | AF6 | AGP Sideband Address 2 | | AGPSBA_3 | AC7 | AGP Sideband Address 3 | | AGPSBA_4 | AC8 | AGP Sideband Address 4 | | AGPSBA_5 | AD8 | AGP Sideband Address 5 | | AGPSBA_6 | AE8 | AGP Sideband Address 6 | | AGPSBA_7 | AD9 | AGP Sideband Address 7 | | AGPSBSTB | AD7 | AGP Sideband Address 2X strobe | | AGPSBSTEN | AE7 | | | AGPSt_0 | AD4 | AGP status 0 | | AGPSt_1 | AE4 | AGP status 1 | | AGPSt_2 | AC5 | AGP status 2 | | AGPtol1 | AF15 | V tolerant AGP I/Os | | AGPvREF | AD23 | no connection | | DacAGnd | R4 | DAC Power/Gnd pin | | DacAVDD | N1 | Analog Video DAĈ | | DacComp | P2 | Compensation pin | | GND | E5 | • | | GND | E6 | | | GND | E9 | | | GND | E10 | | | GND | E13 | | | GND | E14 | | | GND | E17 | | | GND | E18 | | | GND | E21 | | | GND | E22 | | | GND | F5 | | Table 8-2 Pinlist by Name | NAME | NO. | DESCRIPTION | |------|------|-------------| | GND | F22 | | | GND | J5 | | | GND | J22 | | | GND | K5 | | | GND | K22 | | | GND | L11 | | | GND | L12 | | | GND | L13 | | | GND | L14 | | | GND | L15 | | | GND | L16 | | | GND | M11 | | | GND | M12 | | | GND | M13 | | | GND | M14 | | | GND | M15 | | | GND | M16 | | | GND | N5 | | | GND | N11 | | | GND | N12 | | | GND | N13 | | | GND | N14 | | | GND | N15 | | | GND | N16 | | | GND | N22 | | | GND | P5 | | | GND | P11 | | | GND | P12 | | | GND | P13 | | | GND | P14 | | | GND | P15 | | | GND | P16 | | | GND | P22 | | | GND | R11 | | | GND | R12 | | | GND | R13 | | | GND | R14 | | | GND | R15 | | | GND | R16 | | | GND | T11 | | | GND | T12 | | | GND | T13 | | | GND | T14 | | | GND | T15 | | | GND | T16 | | | GND | U5 | | | GND | U22 | | | GND | V5 | | | GND | V22 | | | GND | AA5 | | | GND | AA22 | | | GND | AB5 | | Table 8-2 Pinlist by Name | NAME | NO. | DESCRIPTION | |----------------|--------------|------------------------| | GND | AB6 | BESSIUI IIOIV | | GND | AB9 | | | GND | AB10 | | | GND | AB13 | | | GND | AB14 | | | GND | AB17 | | | GND | AB18 | | | GND | AB21 | | | GND | AB21<br>AB22 | | | GND 0 | AD22 | | | GND_0<br>GND_1 | AD2<br>AD6 | | | GND_1<br>GND_2 | AD10 | | | | AF16 | | | GND_3 | AP16<br>AD18 | | | GND_4 | | | | GND_5 | AF24 | Manager C. O | | MAddr_0 | AC25 | Memory address line 0 | | MAddr_1 | AC26 | Memory address line 1 | | MAddr_2 | AB24 | Memory address line 2 | | MAddr_3 | AB25 | Memory address line 3 | | MAddr_4 | AB26 | Memory address line 4 | | MAddr_5 | AA23 | Memory address line 5 | | MAddr_6 | AA24 | Memory address line 6 | | MAddr_7 | AA25 | Memory address line 7 | | MAddr_8 | AA26 | Memory address line 8 | | MAddr_9 | Y23 | Memory address line 9 | | MAddr_10 | Y24 | Memory address line 10 | | MAddr_11 | Y25 | Memory address line 11 | | MBank_0 | V23 | Memory bank select 0 | | MBank_1 | V24 | Memory bank select 1 | | MBank_2 | U23 | Memory bank select 2 | | MBank_3 | J26 | Memory bank select 3 | | MByte_0 | U24 | Memory byte select 0 | | MByte_1 | U26 | Memory byte select 1 | | MByte_2 | V25 | Memory byte select 2 | | MByte_3 | U25 | Memory byte select 3 | | MByte_4 | G23 | Memory byte select 4 | | MByte_5 | H25 | Memory byte select 5 | | MByte_6 | H24 | Memory byte select 6 | | MByte_7 | G24 | Memory byte select 7 | | MByte_8 | C18 | Memory byte select 8 | | MByte_9 | B19 | Memory byte select 9 | | MByte_10 | C19 | Memory byte select 10 | | MByte_11 | B18 | Memory byte select 11 | | MByte_12 | D8 | Memory byte select 12 | | MByte_13 | C9 | Memory byte select 13 | | MByte_14 | D9 | Memory byte select 14 | | MByte_15 | В9 | Memory byte select 15 | | MCAS | W25 | Memory CAS line | | MCIkE | W26 | Memory clock enable | | MDat_0 | L24 | Memory data line 0 | | MDat_1 | L25 | Memory data line 1 | | MDat_2 | L26 | Memory data line 2 | | _ | | | Table 8-2 Pinlist by Name | MDat_3 | NAME | NO. | DESCRIPTION | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----|---------------------| | MDat | | | | | MDat_5 M25 Memory data line 5 | MDat 4 | M26 | | | MDat_6 M24 Memory data line 6 MDat_7 M23 Memory data line 7 MDat_8 T24 Memory data line 8 MDat_9 T25 Memory data line 9 MDat_10 T26 Memory data line 10 MDat_11 T23 Memory data line 11 MDat_12 R26 Memory data line 12 MDat_13 R25 Memory data line 13 MDat_14 R24 Memory data line 14 MDat_15 R23 Memory data line 16 MDat_16 N23 Memory data line 16 MDat_17 N26 Memory data line 16 MDat_17 N26 Memory data line 18 MDat_19 N24 Memory data line 19 MDat_20 P23 Memory data line 20 MDat_21 P26 Memory data line 21 MDat_22 P25 Memory data line 21 MDat_23 P24 Memory data line 23 MDat_23 P24 Memory data line 23 MDat_24 K23 Memory data line 25 MDat_26 K24 Memory data line 25 MDat_26 K25 Memory data line 26 MDat_27 K26 Memory data line 27 MDat_28 J25 Memory data line 28 MDat_29 J24 Memory data line 29 MDat_30 J23 Memory data line 29 MDat_30 J23 Memory data line 30 MDat_31 H23 Memory data line 30 MDat_31 H23 Memory data line 31 MDat_34 B22 Memory data line 32 MDat_35 A22 Memory data line 34 MDat_36 A23 Memory data line 35 MDat_37 B23 Memory data line 36 MDat_38 A24 Memory data line 37 MDat_38 A24 Memory data line 38 MDat_39 B24 Memory data line 38 MDat_39 B24 Memory data line 39 MDat_38 A24 Memory data line 38 MDat_40 G25 Memory data line 39 MDat_41 G26 Memory data line 40 MDat_41 G26 Memory data line 40 MDat_41 G26 Memory data line 40 MDat_44 F24 Memory data line 48 MDat_45 F25 Memory data line 49 MDat_46 E24 Memory data line 49 MDat_47 E23 Memory data line 49 MDat_50 C26 Memory data line 50 MDat_51 D24 Memory data line 50 MDat_51 D24 Memory data line 50 MDat_51 D26 Memory data line 50 MDat_51 D26 Memory data line 50 MDat_53 D26 Memory data line 50 MDat_53 D26 Memory data line 50 MDat_53 D26 Memory data line 50 | _ | M25 | | | MDat | _ | | | | MDat | | | Memory data line 7 | | MDat_10 | | | | | MDat 10 | | | | | MDat_12 | | | | | MDat_12 | | | Memory data line 11 | | MDat_13 R25 Memory data line 13 MDat_14 R24 Memory data line 14 MDat_15 R23 Memory data line 15 MDat_16 N23 Memory data line 16 MDat_17 N26 Memory data line 17 MDat_18 N25 Memory data line 18 MDat_19 N24 Memory data line 20 MDat_20 P23 Memory data line 20 MDat_21 P26 Memory data line 21 MDat_22 P25 Memory data line 22 MDat_23 P24 Memory data line 23 MDat_24 K23 Memory data line 24 MDat_25 K24 Memory data line 25 MDat_26 K25 Memory data line 26 MDat_27 K26 Memory data line 27 MDat_28 J25 Memory data line 28 MDat_30 J23 Memory data line 30 MDat_31 H23 Memory data line 31 MDat_32 D21 Memory data line 32 MDat_33 G22 Memory data line 33 | | | | | MDat_15 R23 Memory data line 14 MDat_16 N23 Memory data line 15 MDat_17 N26 Memory data line 16 MDat_18 N25 Memory data line 18 MDat_19 N24 Memory data line 19 MDat_20 P23 Memory data line 20 MDat_21 P26 Memory data line 21 MDat_22 P25 Memory data line 22 MDat_23 P24 Memory data line 23 MDat_24 K23 Memory data line 24 MDat_25 K24 Memory data line 25 MDat_26 K25 Memory data line 26 MDat_27 K26 Memory data line 27 MDat_28 J25 Memory data line 28 MDat_30 J23 Memory data line 30 MDat_31 H23 Memory data line 30 MDat_33 C22 Memory data line 32 MDat_34 B22 Memory data line 33 MDat_35 A22 Memory data line 35 MDat_36 A23 Memory data line 36 | | | | | MDat_15 R23 Memory data line 15 MDat_16 N23 Memory data line 16 MDat_17 N26 Memory data line 17 MDat_18 N25 Memory data line 18 MDat_19 N24 Memory data line 19 MDat_20 P23 Memory data line 20 MDat_21 P26 Memory data line 21 MDat_22 P25 Memory data line 22 MDat_23 P24 Memory data line 23 MDat_24 K23 Memory data line 24 MDat_25 K24 Memory data line 25 MDat_26 K25 Memory data line 26 MDat_27 K26 Memory data line 27 MDat_28 J25 Memory data line 28 MDat_30 J23 Memory data line 30 MDat_31 H23 Memory data line 31 MDat_32 D21 Memory data line 32 MDat_33 C22 Memory data line 33 MDat_34 B22 Memory data line 34 MDat_35 A22 Memory data line 36 | | | | | MDat_16 | · · · · - | | | | MDat_18 N26 Memory data line 17 MDat_18 N25 Memory data line 18 MDat_19 N24 Memory data line 20 MDat_20 P23 Memory data line 20 MDat_21 P26 Memory data line 21 MDat_22 P25 Memory data line 23 MDat_23 P24 Memory data line 23 MDat_24 K23 Memory data line 24 MDat_25 K24 Memory data line 25 MDat_26 K25 Memory data line 26 MDat_27 K26 Memory data line 28 MDat_28 J25 Memory data line 29 MDat_30 J23 Memory data line 30 MDat_31 H23 Memory data line 31 MDat_32 D21 Memory data line 32 MDat_33 C22 Memory data line 33 MDat_34 B22 Memory data line 34 MDat_35 A22 Memory data line 35 MDat_36 A23 Memory data line 36 MDat_37 B23 Memory data line 39 | | | | | MDat_18 N25 Memory data line 18 MDat_19 N24 Memory data line 19 MDat_20 P23 Memory data line 20 MDat_21 P26 Memory data line 21 MDat_22 P25 Memory data line 22 MDat_23 P24 Memory data line 23 MDat_24 K23 Memory data line 24 MDat_25 K24 Memory data line 25 MDat_26 K25 Memory data line 26 MDat_27 K26 Memory data line 28 MDat_28 J25 Memory data line 29 MDat_30 J23 Memory data line 30 MDat_31 H23 Memory data line 31 MDat_32 D21 Memory data line 32 MDat_33 C22 Memory data line 34 MDat_34 B22 Memory data line 34 MDat_35 A22 Memory data line 35 MDat_36 A23 Memory data line 37 MDat_38 A24 Memory data line 39 MDat_40 G25 Memory data line 40 | _ | | | | MDat_19 N24 Memory data line 19 MDat_20 P23 Memory data line 20 MDat_21 P26 Memory data line 21 MDat_22 P25 Memory data line 22 MDat_23 P24 Memory data line 23 MDat_24 K23 Memory data line 24 MDat_25 K24 Memory data line 25 MDat_26 K25 Memory data line 26 MDat_27 K26 Memory data line 27 MDat_28 J25 Memory data line 29 MDat_29 J24 Memory data line 30 MDat_30 J23 Memory data line 30 MDat_31 H23 Memory data line 31 MDat_32 D21 Memory data line 32 MDat_33 C22 Memory data line 33 MDat_34 B22 Memory data line 34 MDat_35 A22 Memory data line 35 MDat_36 A23 Memory data line 37 MDat_38 A24 Memory data line 38 MDat_39 B24 Memory data line 40 | _ | | | | MDat_21 P23 Memory data line 20 MDat_21 P26 Memory data line 21 MDat_23 P24 Memory data line 23 MDat_24 K23 Memory data line 24 MDat_25 K24 Memory data line 26 MDat_26 K25 Memory data line 26 MDat_27 K26 Memory data line 28 MDat_28 J25 Memory data line 29 MDat_29 J24 Memory data line 30 MDat_30 J23 Memory data line 30 MDat_31 H23 Memory data line 31 MDat_32 D21 Memory data line 32 MDat_33 C22 Memory data line 33 MDat_34 B22 Memory data line 34 MDat_35 A22 Memory data line 35 MDat_36 A23 Memory data line 36 MDat_37 B23 Memory data line 37 MDat_38 A24 Memory data line 38 MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 | _ | | | | MDat_21 P26 Memory data line 21 MDat_23 P24 Memory data line 23 MDat_24 K23 Memory data line 24 MDat_25 K24 Memory data line 25 MDat_26 K25 Memory data line 26 MDat_27 K26 Memory data line 27 MDat_28 J25 Memory data line 29 MDat_29 J24 Memory data line 30 MDat_30 J23 Memory data line 30 MDat_31 H23 Memory data line 31 MDat_32 D21 Memory data line 32 MDat_33 C22 Memory data line 33 MDat_34 B22 Memory data line 34 MDat_35 A22 Memory data line 35 MDat_36 A23 Memory data line 36 MDat_37 B23 Memory data line 38 MDat_39 B24 Memory data line 39 MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 | | | | | MDat_23 P25 Memory data line 23 MDat_24 K23 Memory data line 24 MDat_25 K24 Memory data line 25 MDat_26 K25 Memory data line 26 MDat_27 K26 Memory data line 27 MDat_28 J25 Memory data line 28 MDat_29 J24 Memory data line 29 MDat_30 J23 Memory data line 30 MDat_31 H23 Memory data line 31 MDat_32 D21 Memory data line 32 MDat_33 C22 Memory data line 33 MDat_34 B22 Memory data line 34 MDat_35 A22 Memory data line 35 MDat_36 A23 Memory data line 36 MDat_37 B23 Memory data line 38 MDat_39 B24 Memory data line 39 MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 MDat_43 F25 Memory data line 44 | | | | | MDat_23 P24 Memory data line 23 MDat_24 K23 Memory data line 24 MDat_25 K24 Memory data line 25 MDat_26 K25 Memory data line 26 MDat_27 K26 Memory data line 27 MDat_28 J25 Memory data line 28 MDat_29 J24 Memory data line 29 MDat_30 J23 Memory data line 30 MDat_31 H23 Memory data line 31 MDat_32 D21 Memory data line 32 MDat_33 C22 Memory data line 33 MDat_34 B22 Memory data line 34 MDat_35 A22 Memory data line 35 MDat_36 A23 Memory data line 36 MDat_37 B23 Memory data line 38 MDat_39 B24 Memory data line 39 MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 MDat_43 F23 Memory data line 43 | | | | | MDat_25 K24 Memory data line 24 MDat_26 K25 Memory data line 25 MDat_27 K26 Memory data line 27 MDat_28 J25 Memory data line 28 MDat_29 J24 Memory data line 29 MDat_30 J23 Memory data line 30 MDat_31 H23 Memory data line 31 MDat_32 D21 Memory data line 32 MDat_33 C22 Memory data line 33 MDat_34 B22 Memory data line 34 MDat_35 A22 Memory data line 35 MDat_36 A23 Memory data line 36 MDat_37 B23 Memory data line 38 MDat_39 B24 Memory data line 39 MDat_39 B24 Memory data line 39 MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 MDat_43 F25 Memory data line 43 MDat_44 F24 Memory data line 44 | _ | | | | MDat_25 K24 Memory data line 25 MDat_26 K25 Memory data line 26 MDat_27 K26 Memory data line 27 MDat_28 J25 Memory data line 28 MDat_29 J24 Memory data line 29 MDat_30 J23 Memory data line 30 MDat_31 H23 Memory data line 31 MDat_32 D21 Memory data line 32 MDat_33 C22 Memory data line 33 MDat_34 B22 Memory data line 34 MDat_35 A22 Memory data line 35 MDat_36 A23 Memory data line 36 MDat_37 B23 Memory data line 37 MDat_38 A24 Memory data line 38 MDat_39 B24 Memory data line 39 MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 MDat_43 F25 Memory data line 44 MDat_44 F24 Memory data line 44 | | | | | MDat_26 K25 Memory data line 26 MDat_27 K26 Memory data line 27 MDat_28 J25 Memory data line 28 MDat_29 J24 Memory data line 29 MDat_30 J23 Memory data line 30 MDat_31 H23 Memory data line 31 MDat_32 D21 Memory data line 32 MDat_33 C22 Memory data line 33 MDat_34 B22 Memory data line 34 MDat_35 A22 Memory data line 35 MDat_36 A23 Memory data line 36 MDat_37 B23 Memory data line 36 MDat_38 A24 Memory data line 39 MDat_39 B24 Memory data line 39 MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 MDat_43 F25 Memory data line 43 MDat_44 F24 Memory data line 44 MDat_45 F23 Memory data line 46 | | | | | MDat_28 J25 Memory data line 28 MDat_29 J24 Memory data line 29 MDat_30 J23 Memory data line 30 MDat_31 H23 Memory data line 31 MDat_32 D21 Memory data line 32 MDat_33 C22 Memory data line 33 MDat_34 B22 Memory data line 34 MDat_35 A22 Memory data line 35 MDat_36 A23 Memory data line 36 MDat_37 B23 Memory data line 38 MDat_38 A24 Memory data line 38 MDat_39 B24 Memory data line 39 MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 MDat_43 F25 Memory data line 43 MDat_44 F24 Memory data line 44 MDat_45 F23 Memory data line 45 MDat_46 E24 Memory data line 46 MDat_48 C23 Memory data line 49 | MDat_26 | | Momory data line 2) | | MDat_28 J25 Memory data line 28 MDat_29 J24 Memory data line 29 MDat_30 J23 Memory data line 30 MDat_31 H23 Memory data line 31 MDat_32 D21 Memory data line 32 MDat_33 C22 Memory data line 33 MDat_34 B22 Memory data line 34 MDat_35 A22 Memory data line 36 MDat_36 A23 Memory data line 36 MDat_37 B23 Memory data line 38 MDat_38 A24 Memory data line 39 MDat_39 B24 Memory data line 39 MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 MDat_43 F25 Memory data line 44 MDat_44 F24 Memory data line 44 MDat_45 F23 Memory data line 45 MDat_46 E24 Memory data line 46 MDat_48 C23 Memory data line 49 | | | | | MDat_29 J24 Memory data line 29 MDat_30 J23 Memory data line 30 MDat_31 H23 Memory data line 31 MDat_32 D21 Memory data line 32 MDat_33 C22 Memory data line 33 MDat_34 B22 Memory data line 34 MDat_35 A22 Memory data line 35 MDat_36 A23 Memory data line 36 MDat_37 B23 Memory data line 38 MDat_38 A24 Memory data line 39 MDat_39 B24 Memory data line 39 MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 MDat_43 F25 Memory data line 44 MDat_44 F24 Memory data line 44 MDat_45 F23 Memory data line 45 MDat_46 E24 Memory data line 46 MDat_48 C23 Memory data line 48 MDat_49 C25 Memory data line 50 | | | | | MDat_30 J23 Memory data line 30 MDat_31 H23 Memory data line 31 MDat_32 D21 Memory data line 32 MDat_33 C22 Memory data line 33 MDat_34 B22 Memory data line 34 MDat_35 A22 Memory data line 35 MDat_36 A23 Memory data line 36 MDat_37 B23 Memory data line 37 MDat_38 A24 Memory data line 38 MDat_39 B24 Memory data line 39 MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 MDat_43 F25 Memory data line 43 MDat_44 F24 Memory data line 44 MDat_45 F23 Memory data line 45 MDat_46 E24 Memory data line 46 MDat_47 E23 Memory data line 48 MDat_49 C25 Memory data line 50 MDat_50 Memory data line 50 MDat | MDat_20 | | | | MDat_31 H23 Memory data line 31 MDat_32 D21 Memory data line 32 MDat_33 C22 Memory data line 33 MDat_34 B22 Memory data line 34 MDat_35 A22 Memory data line 35 MDat_36 A23 Memory data line 36 MDat_37 B23 Memory data line 37 MDat_38 A24 Memory data line 38 MDat_39 B24 Memory data line 39 MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 MDat_43 F25 Memory data line 43 MDat_44 F24 Memory data line 44 MDat_45 F23 Memory data line 45 MDat_46 E24 Memory data line 46 MDat_47 E23 Memory data line 48 MDat_48 C23 Memory data line 48 MDat_49 C25 Memory data line 50 MDat_50 Memory data line 51 MDat | | | | | MDat_32 D21 Memory data line 32 MDat_33 C22 Memory data line 33 MDat_34 B22 Memory data line 34 MDat_35 A22 Memory data line 35 MDat_36 A23 Memory data line 36 MDat_37 B23 Memory data line 37 MDat_38 A24 Memory data line 38 MDat_39 B24 Memory data line 39 MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 MDat_43 F25 Memory data line 43 MDat_44 F24 Memory data line 43 MDat_45 F23 Memory data line 45 MDat_46 E24 Memory data line 46 MDat_47 E23 Memory data line 48 MDat_48 C23 Memory data line 48 MDat_49 C25 Memory data line 50 MDat_50 Memory data line 50 MDat_51 D24 Memory data line 52 MDat | — | , , | | | MDat_33 C22 Memory data line 33 MDat_34 B22 Memory data line 34 MDat_35 A22 Memory data line 35 MDat_36 A23 Memory data line 36 MDat_37 B23 Memory data line 37 MDat_38 A24 Memory data line 38 MDat_39 B24 Memory data line 39 MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 MDat_43 F25 Memory data line 43 MDat_44 F24 Memory data line 44 MDat_45 F23 Memory data line 45 MDat_46 E24 Memory data line 46 MDat_47 E23 Memory data line 48 MDat_48 C23 Memory data line 48 MDat_49 C25 Memory data line 50 MDat_50 Memory data line 51 MDat_51 D24 Memory data line 52 MDat_53 D26 Memory data line 53 | | | | | MDat_34 B22 Memory data line 34 MDat_35 A22 Memory data line 35 MDat_36 A23 Memory data line 36 MDat_37 B23 Memory data line 37 MDat_38 A24 Memory data line 38 MDat_39 B24 Memory data line 39 MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 MDat_43 F25 Memory data line 43 MDat_44 F24 Memory data line 44 MDat_45 F23 Memory data line 45 MDat_46 E24 Memory data line 46 MDat_47 E23 Memory data line 48 MDat_48 C23 Memory data line 48 MDat_49 C25 Memory data line 50 MDat_50 Memory data line 50 MDat_51 D24 Memory data line 52 MDat_53 D26 Memory data line 53 | | | | | MDat_35 A22 Memory data line 35 MDat_36 A23 Memory data line 36 MDat_37 B23 Memory data line 37 MDat_38 A24 Memory data line 38 MDat_39 B24 Memory data line 39 MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 MDat_43 F25 Memory data line 43 MDat_44 F24 Memory data line 44 MDat_45 F23 Memory data line 45 MDat_46 E24 Memory data line 46 MDat_47 E23 Memory data line 47 MDat_48 C23 Memory data line 48 MDat_49 C25 Memory data line 50 MDat_50 C26 Memory data line 50 MDat_51 D24 Memory data line 52 MDat_53 D26 Memory data line 53 | | | | | MDat_36 A23 Memory data line 36 MDat_37 B23 Memory data line 37 MDat_38 A24 Memory data line 38 MDat_39 B24 Memory data line 39 MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 MDat_43 F25 Memory data line 43 MDat_44 F24 Memory data line 44 MDat_45 F23 Memory data line 45 MDat_46 E24 Memory data line 46 MDat_47 E23 Memory data line 47 MDat_48 C23 Memory data line 48 MDat_49 C25 Memory data line 50 MDat_50 C26 Memory data line 50 MDat_51 D24 Memory data line 52 MDat_53 D26 Memory data line 53 | — | | , | | MDat_37 B23 Memory data line 37 MDat_38 A24 Memory data line 38 MDat_39 B24 Memory data line 39 MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 MDat_43 F25 Memory data line 43 MDat_44 F24 Memory data line 44 MDat_45 F23 Memory data line 45 MDat_46 E24 Memory data line 46 MDat_47 E23 Memory data line 48 MDat_48 C23 Memory data line 48 MDat_49 C25 Memory data line 50 MDat_50 C26 Memory data line 50 MDat_51 D24 Memory data line 51 MDat_52 D25 Memory data line 53 MDat_53 D26 Memory data line 53 | | | , | | MDat_38 A24 Memory data line 38 MDat_39 B24 Memory data line 39 MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 MDat_43 F25 Memory data line 43 MDat_44 F24 Memory data line 44 MDat_45 F23 Memory data line 45 MDat_46 E24 Memory data line 46 MDat_47 E23 Memory data line 47 MDat_48 C23 Memory data line 48 MDat_49 C25 Memory data line 50 MDat_50 C26 Memory data line 50 MDat_51 D24 Memory data line 51 MDat_52 D25 Memory data line 52 MDat_53 D26 Memory data line 53 | — | | | | MDat_39 B24 Memory data line 39 MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 MDat_43 F25 Memory data line 43 MDat_44 F24 Memory data line 44 MDat_45 F23 Memory data line 45 MDat_46 E24 Memory data line 46 MDat_47 E23 Memory data line 47 MDat_48 C23 Memory data line 48 MDat_49 C25 Memory data line 50 MDat_50 C26 Memory data line 50 MDat_51 D24 Memory data line 51 MDat_52 D25 Memory data line 52 MDat_53 D26 Memory data line 53 | | | | | MDat_40 G25 Memory data line 40 MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 MDat_43 F25 Memory data line 43 MDat_44 F24 Memory data line 44 MDat_45 F23 Memory data line 45 MDat_46 E24 Memory data line 46 MDat_47 E23 Memory data line 47 MDat_48 C23 Memory data line 48 MDat_49 C25 Memory data line 49 MDat_50 C26 Memory data line 50 MDat_51 D24 Memory data line 51 MDat_52 D25 Memory data line 52 MDat_53 D26 Memory data line 53 | | | | | MDat_41 G26 Memory data line 41 MDat_42 F26 Memory data line 42 MDat_43 F25 Memory data line 43 MDat_44 F24 Memory data line 44 MDat_45 F23 Memory data line 45 MDat_46 E24 Memory data line 46 MDat_47 E23 Memory data line 47 MDat_48 C23 Memory data line 48 MDat_49 C25 Memory data line 49 MDat_50 C26 Memory data line 50 MDat_51 D24 Memory data line 51 MDat_52 D25 Memory data line 52 MDat_53 D26 Memory data line 53 | | | | | MDat_42 F26 Memory data line 42 MDat_43 F25 Memory data line 43 MDat_44 F24 Memory data line 44 MDat_45 F23 Memory data line 45 MDat_46 E24 Memory data line 46 MDat_47 E23 Memory data line 47 MDat_48 C23 Memory data line 48 MDat_49 C25 Memory data line 49 MDat_50 C26 Memory data line 50 MDat_51 D24 Memory data line 51 MDat_52 D25 Memory data line 52 MDat_53 D26 Memory data line 53 | _ | | | | MDat_43 F25 Memory data line 43 MDat_44 F24 Memory data line 44 MDat_45 F23 Memory data line 45 MDat_46 E24 Memory data line 46 MDat_47 E23 Memory data line 47 MDat_48 C23 Memory data line 48 MDat_49 C25 Memory data line 49 MDat_50 C26 Memory data line 50 MDat_51 D24 Memory data line 51 MDat_52 D25 Memory data line 52 MDat_53 D26 Memory data line 53 | | | | | MDat_44 F24 Memory data line 44 MDat_45 F23 Memory data line 45 MDat_46 E24 Memory data line 46 MDat_47 E23 Memory data line 47 MDat_48 C23 Memory data line 48 MDat_49 C25 Memory data line 49 MDat_50 C26 Memory data line 50 MDat_51 D24 Memory data line 51 MDat_52 D25 Memory data line 52 MDat_53 D26 Memory data line 53 | | | | | MDat_45 F23 Memory data line 45 MDat_46 E24 Memory data line 46 MDat_47 E23 Memory data line 47 MDat_48 C23 Memory data line 48 MDat_49 C25 Memory data line 49 MDat_50 C26 Memory data line 50 MDat_51 D24 Memory data line 51 MDat_52 D25 Memory data line 52 MDat_53 D26 Memory data line 53 | | | | | MDat_46 E24 Memory data line 46 MDat_47 E23 Memory data line 47 MDat_48 C23 Memory data line 48 MDat_49 C25 Memory data line 49 MDat_50 C26 Memory data line 50 MDat_51 D24 Memory data line 51 MDat_52 D25 Memory data line 52 MDat_53 D26 Memory data line 53 | | | Memory data line 44 | | MDat_47 E23 Memory data line 47 MDat_48 C23 Memory data line 48 MDat_49 C25 Memory data line 49 MDat_50 C26 Memory data line 50 MDat_51 D24 Memory data line 51 MDat_52 D25 Memory data line 52 MDat_53 D26 Memory data line 53 | | | | | MDat_48 C23 Memory data line 48 MDat_49 C25 Memory data line 49 MDat_50 C26 Memory data line 50 MDat_51 D24 Memory data line 51 MDat_52 D25 Memory data line 52 MDat_53 D26 Memory data line 53 | | | Memory data line 46 | | MDat_49 C25 Memory data line 49 MDat_50 C26 Memory data line 50 MDat_51 D24 Memory data line 51 MDat_52 D25 Memory data line 52 MDat_53 D26 Memory data line 53 | _ | | | | MDat_50 C26 Memory data line 50 MDat_51 D24 Memory data line 51 MDat_52 D25 Memory data line 52 MDat_53 D26 Memory data line 53 | | | | | MDat_51 D24 Memory data line 51 MDat_52 D25 Memory data line 52 MDat_53 D26 Memory data line 53 | | | | | MDat_52 D25 Memory data line 52<br>MDat_53 D26 Memory data line 53 | | | | | MDat_53 D26 Memory data line 53 | | | Memory data line 51 | | MDat_53 D26 Memory data line 53 MDat_54 E26 Memory data line 54 | | | Memory data line 52 | | MDat_54 E26 Memory data line 54 | | | | | | MDat_54 | E26 | Memory data line 54 | Table 8-2 Pinlist by Name | NAME | NO. | DESCRIPTION | |--------------------|-----|-------------------------| | MDat_55 | E25 | Memory data line 55 | | MDat_56 | D20 | Memory data line 56 | | MDat 57 | C21 | Memory data line 57 | | MDat_57<br>MDat_58 | B21 | Memory data line 58 | | MDat_59 | A21 | Memory data line 59 | | MDat 60 | A20 | Memory data line 60 | | MDat 61 | B20 | Memory data line 61 | | MDat 62 | C20 | Memory data line 62 | | MDat 63 | D19 | Memory data line 63 | | MDat_64 | D12 | Memory data line 64 | | MDat_65 | C12 | Memory data line 65 | | MDat 66 | B12 | Memory data line 66 | | MDat 67 | C13 | Memory data line 67 | | MDat 68 | D14 | Memory data line 68 | | MDat 69 | B13 | Memory data line 69 | | MDat_70 | A13 | Memory data line 70 | | MDat 71 | D13 | Memory data line 71 | | MDat_72 | D17 | Memory data line 72 | | MDat_73 | C17 | Memory data line 73 | | MDat_74 | B17 | Memory data line 74 | | MDat_75 | A18 | Memory data line 75 | | MDat 76 | A17 | Memory data line 76 | | MDat_77 | A16 | Memory data line 77 | | MDat 78 | B16 | Memory data line 78 | | MDat 79 | C16 | Memory data line 79 | | MDat 80 | C14 | Memory data line 80 | | MDat 81 | B14 | Memory data line 81 | | MDat_82 | A14 | Memory data line 82 | | MDat 83 | A15 | Memory data line 83 | | MDat_84 | D16 | Memory data line 84 | | MDat 85 | B15 | Memory data line 85 | | MDat_86 | C15 | Memory data line 86 | | MDat 87 | D15 | Memory data line 87 | | MDat 88 | C11 | Memory data line 88 | | MDat 89 | B11 | Memory data line 89 | | MDat 90 | A11 | Memory data line 90 | | MDat_91 | A12 | Memory data line 91 | | MDat 92 | D11 | Memory data line 92 | | MDat_93 | B10 | Memory data line 93 | | MDat_94 | C10 | Memory data line 94 | | MDat_95 | D10 | Memory data line 95 | | MDat_96 | C4 | Memory data line 96 | | MDat_97 | B4 | Memory data line 97 | | MDat_97 | A4 | Memory data line 98 | | MDat_99 | B3 | Memory data line 99 | | MDat_100 | D2 | Memory data line 100 | | MDat_100 | E2 | Memory data line 101 | | MDat_101 | E3 | Memory data line 101 | | MDat 103 | F3 | Memory data line 102 | | MDat_103 | A9 | Memory data line 103 | | MDat 105 | D7 | Memory data line 104 | | MDat 106 | C8 | Memory data line 105 | | MIDat_100 | Co | ivicinory data line 100 | Table 8-2 Pinlist by Name | NAME | NO. | DESCRIPTION | |----------------------|--------------|------------------------------------------------------| | MDat_107 | В8 | Memory data line 107 | | MDat_108 | В7 | Memory data line 108 | | MDat_109 | C7 | Memory data line 109 | | MDat 110 | D6 | Memory data line 110 | | MDat 111 | A8 | Memory data line 111 | | MDat 112 | A6 | Memory data line 112 | | MDat_113 | A5 | Memory data line 113 | | MDat 114 | C5 | Memory data line 114 | | MDat_115 | B5 | Memory data line 115 | | MDat 116 | В6 | Memory data line 116 | | MDat_117 | C6 | Memory data line 117 | | MDat_118 | D5 | Memory data line 118 | | MDat 119 | A7 | Memory data line 119 | | MDat 120 | F1 | Memory data line 120 | | MDat_121 | E1 | Memory data line 121 | | MDat_122 | DI | Memory data line 122 | | MDat 123 | CI | Memory data line 123 | | MDat 124 | A3 | Memory data line 124 | | MDat_125 | C2 | Memory data line 125 | | MDat 126 | D3 | Memory data line 126 | | MDat_120 | E4 | Memory data line 127 | | MDSF | W23 | Memory DSF line | | MemClkOut 0 | AB23 | Memory Clock Out 0 | | MemClkOut 1 | AC24 | Memory Clock Out 1 | | MemClkOut 2 | AD25 | Memory Clock Out 2 | | MemClkOut 3 | AD26 | Memory Clock Out 2 | | MemClkRet 0 | V26 | Memory Clock Return 0 | | MemClkRet_1 | H26 | Memory Clock Return 1 | | MemClkRet 2 | A19 | Memory Clock Return 2 | | MemClkRet 3 | A10 | Memory Clock Return 3 | | MRAS | W24 | Memory RAS line | | MWE | Y26 | Memory write enable | | PCIAD 0 | AF23 | PCI address/data line 0 | | PCIAD_0 | AE23 | PCI address/data line 1 | | PCIAD_10 | AE19 | PCI address/data line 1 | | PCIAD_11 | AD19 | PCI address/data line 10 | | PCIAD_11 | AC19 | PCI address/data line 11 PCI address/data line 12 | | PCIAD_12<br>PCIAD_13 | AF18 | PCI address/data line 12 PCI address/data line 13 | | PCIAD_13 | AF18 | PCI address/data line 15 PCI address/data line 14 | | PCIAD_14 | AC18 | | | PCIAD_15 | AD15 | PCI address/data line 15<br>PCI address/data line 16 | | PCIAD_16<br>PCIAD_17 | AE14 | | | PCIAD_17 | AF14<br>AF14 | PCI address/data line 17 PCI address/data line 18 | | PCIAD_18<br>PCIAD_19 | | | | | AE13 | PCI address/data line 19 | | PCIAD_2 | AF22 | PCI address/data line 2 | | PCIAD_20 | AC14 | PCI address/data line 20 | | PCIAD_21<br>PCIAD_22 | AC13 | PCI address/data line 21 | | PCIAD_22 | AD13 | PCI address/data line 22 | | PCIAD_23 | AC12 | PCI address/data line 23 | | PCIAD_24 | AD12 | PCI address/data line 24 | | PCIAD_25 | AD11 | PCI address/data line 25 | | PCIAD_26 | AC11 | PCI address/data line 26 | Table 8-2 Pinlist by Name | NAME | NO. | DESCRIPTION | |----------------------|------|------------------------------------| | PCIAD_27 | AF10 | PCI address/data line 27 | | PCIAD 28 | AE10 | PCI address/data line 28 | | PCIAD 29 | AC10 | PCI address/data line 29 | | PCIAD_3 | AE22 | PCI address/data line 3 | | PCIAD 30 | AF9 | PCI address/data line 30 | | PCIAD 31 | AE9 | PCI address/data line 31 | | PCIAD_31<br>PCIAD_4 | AC22 | PCI address/data line 4 | | PCIAD 5 | AF21 | PCI address/data line 5 | | PCIAD 6 | AE21 | PCI address/data line 6 | | PCIAD_7 | AD21 | PCI address/data line 7 | | PCIAD 8 | AC20 | PCI address/data line 8 | | PCIAD_8<br>PCIAD_9 | AF19 | PCI address/data line 9 | | PCICBEN 0 | AD20 | PCI byte enable 0 | | PCICBEN_1 | AF17 | PCI byte enable 1 | | PCICBEN_2 | AC15 | PCI byte enable 2 | | PCICBEN 3 | AE12 | PCI byte enable 3 | | PCICLK | AC2 | PCI clock | | PCICIkSel | AC1 | 33/66 MHz PCI select | | PCIDevSelN | AD16 | PCI device select | | PCIFIFOInDis | AB1 | Delta control | | PCIFIFOOutDis | AB2 | Delta control | | PCIFrameN | AC16 | PCI frame signal | | PCIGntN | AF3 | PCI grant signal | | PCIIdSel | AF13 | PCI ID select | | PCIIntAN | AD1 | PCI interrupt | | PCIIRdyN | AE15 | PCI parity PCI ready | | PCIPar | AE17 | PCI ready | | PCIReqN | AE3 | PCI request | | PCIRSTN | AB3 | PCI reset | | PCIStopN | AD17 | PCI stop | | PCIStopN<br>PCITRdyN | AE16 | PCI stop<br>PCI T ready | | PINAGPTol0 | AF7 | · | | PLLDISABLE | Т3 | PLL Disable | | PLLPower | W1 | PLL Power/Gnd pin | | PLLGND | Y4 | PLL Power/Gnd pin | | RenderSyncN | D18 | Multirasterizer i/o sync pin | | RESERVED | AE24 | | | RESERVED | AA1 | No Connect | | RESERVED | AB4 | No Connect | | ROMSelN | U2 | ROM select signal ROM write wnable | | ROMWeN | U1 | ROM write wnable | | SBClk | V1 | serial bus clock | | SBData | W4 | serial bus data | | SPARE | V2 | | | SPARE | J4 | | | TestMode | R1 | Test Mode control | | TestSel_0_ | M1 | Test Mode select 0 | | TestSel_1 | R3 | Test Mode select | | TestSel_2_ | M2 | Test Mode select 1 | | VCC_2.5 | D4 | | | VCC_2.5<br>VCC_2.5 | A1 | | | VCC_2.5 | B1 | | Table 8-2 Pinlist by Name | NAME | NO. | DESCRIPTION | |-------------------------------|-----------|-------------| | VCC 2.5 | AE1 | | | VCC_2.5 | AE2 | | | VCC_2.5<br>VCC_2.5<br>VCC_2.5 | AD3 | | | VCC_2.5 | AC4 | | | VCC_2.5 | AF1 | | | VCC_2.5 | AF2 | | | VCC_2.5 | AF25 | | | L VCC 2.5 | AE25 | | | VCC_2.5 | AD24 | | | VCC_2.5 | AC23 | | | VCC_2.5 | AF26 | | | VCC_2.5 | AE26 | | | VCC_2.5 | B26 | | | VCC_2.5 | B25 | | | VCC_2.5 | C24 | | | VCC_2.5 | D23 | | | VCC_2.5 | A26 | | | VCC_2.5 | A25 | | | VCC_2.5 | B2 | | | VCC_2.5 | A2 | | | VCC_2.5<br>VCC_3.3 | C3 | | | VCC_3.3 | E7 | | | VCC_3.3 | E8 | | | VCC_3.3 | E11 | | | VCC_3.3<br>VCC_3.3 | E12 | | | VCC_3.3<br>VCC_3.3 | E15 | | | VCC_3.3 | E16 | | | VCC_3.3 | E19 | | | VCC_3.3 | E20 | | | VCC_3.3 | G5 | | | VCC_3.3 | G22 | | | VCC_3.3 | H5<br>H22 | | | VCC_3.3 | L5 | | | VCC_3.3<br>VCC_3.3 | | | | VCC 3.3 | L22 | | | VCC_3.3<br>VCC_3.3 | M5<br>M22 | | | VCC 3 3 | R5 | | | VCC_3.3<br>VCC_3.3 | R22 | | | VCC_3.3 | T5 | | | VCC_3.3 | 122 | | | VCC_3.3 | W5 | | | VCC_3.3 | W22 | | | VCC_3.3 | Y5 | | | VCC_3.3 | Y22 | | | VCC_3.3 | AB7 | | | VCC_3.3 | AB8 | | | VCC_3.3 | AB11 | | | VCC_3.3 | AB12 | | | VCC_3.3 | AB15 | | | VCC_3.3 | AB16 | | | VCC_3.3 | AB19 | | | , 00_3.3 | 11111 | | Table 8-2 Pinlist by Name | NAME | NO. | DESCRIPTION | |------------------------|------|---------------------------------------| | VCC_3.3 | AB20 | | | VDDQ_0 | AF4 | | | VDDQ_1 | AF8 | | | VDDQ_2 | AF12 | | | VDDQ 3 | AD14 | | | VDDQ 4 | AF20 | | | VDDQ_5 | AC3 | | | VDDQ_6 | AC9 | | | VDDQ_7 | AC17 | | | VDDQ_8 | AD22 | | | vidBlue | P3 | Analog blue signal | | VidDDCClk | U4 | Analog blue signal Clock line for DDC | | VidDDCData | U3 | Data line for DDC | | VideoExtCtrl | D22 | Video external control | | vidGreen | N3 | Analog green signal | | VidHSync | R2 | Horizontal sync | | vidRed | N2 | Horizontal sync<br>Analog red signal | | vidResRef | P4 | Reference resistor | | VidRightEye | N4 | Right signal for stereo | | VidVRet | PI | Voltage reference | | VidVsync | T2. | Vertical sync | | VSACIk | V3 | VideoStream A clock | | VSAData 0 | AA4 | VideoStream A data line 0 | | VSAData_1 | AA3 | VideoStream A data line 1 | | VSAdata 2 | AA2 | VideoStream A data line 2 | | VSAData 3 | Y1 | VideoStream A data line 3 | | VSAData 4 | Y3 | VideoStream A data line 4 | | VSAData 5 | W2 | VideoStream A data line 5 | | VSAData 6 | Y2. | VideoStream A data line 6 | | VSAData 7 | W3 | VideoStream A data line 7 | | VSAResetN | V4 | Video Stream reset | | VSBClk | H4 | VideoStream B clock | | VSBClkOut | 13 | Video Stream B clock out | | VSBData 0 | F4 | VideoStream B data line 0 | | VSBData 1 | Gl | VideoStream B data line 1 | | VSBData_1 | G2 | VideoStream B data line 2 | | VSBData 3 | G3 | VideoStream B data line 3 | | VSBData_5<br>VSBData_4 | G4 | VideoStream B data line 4 | | VSBData_5 | HI | VideoStream B data line 5 | | VSBData_5 | H2 | VideoStream B data line 6 | | VSBData_0<br>VSBData_7 | H3 | VideoStream B data line 7 | | VSBResetN | F2 | Video Stream B Reset Out | | VSCtl 0 | K1 | VideoStreams Control line 0 | | VSCtl_1 | K2 | VideoStreams Control line 1 | | VSCtl_2 | 1.4 | VideoStreams Control line 2 | | VSCtl_3 | L1 | VideoStreams Control line 3 | | VSCtl 4 | L2 | VideoStreams Control line 4 | | VSCtl_5 | L3 | VideoStreams Control line 5 | | VSCtl 6 | M3 | VideoStreams Control line 6 | | VSCtl_7 | M4 | VideoStreams Control line 7 | | VSGPChipSelectN | K3 | VS GP bus chip select | | VSGPDataAckN | K4 | VS GP bus data ack | | V JOH Data/ICKIN | IV-T | VO GI DUS UATA ACK | Table 8-2 Pinlist by Name | NAME | NO. | DESCRIPTION | |------------------|-----|-----------------------------| | VSGPDataStrob eN | J1 | VS GP bus data strobe | | VSGPReadWrit eN | J2 | VS GP bus read/write signal | | WbfN | AF5 | | | Xtal1 | T1 | Crystal i/p 1 | | Xtal2 | T4 | Crystal i/p 2 | # **Memory System** The PERMEDIA memory system is intended for use with Synchronous Dynamic Memories. The memories can be SGRAM or SDRAM devices. The width of the memory interface is 128 bits, but can be configured to 64 bits. Control lines are provided for 4 blocks of memories, these are Select (3-0). Four ClockOut and ClockReturn signals are also provided, these are to assist in de-skewing the return data and reducing the load on each clock line. The Clock lines should be wired as illustrated in Figure 9.1. The memory system has one set of primary control signals which are common to all blocks, these are Data, Address, RAS, CAS, WriteEnable (WE), DSF, ClkEnable and Byte enables (DQM). A typical organization is shown below. Figure 9.1 Organization of memory devices The diagram shows a 16-megabyte memory array, constructed from 16, 8-Megabit memories, arranged into 4 blocks. The devices used are 32 bit wide with 2 banks, where each bank has 512 rows and 256 columns. # 9.1 System Parameters The Memory System employs a rich set of registers, which allow for a diverse range of memory configurations. The various timing parameters used to control synchronous memories can be adjusted to allow for optimum performance depending on memory type, speed grade and the PERMEDIA system clock frequency (MClk). Memory functionally can be enabled depending on the type fitted. Full addressing control is available so that virtually any memory configuration can be fitted. The following parameters are used to control accesses to the memory. These values fall into three categories - Addressing - Functionality and Optimizations - Timing and Mode # 9.1.1 Addressing #### 9.1.1.1 ColumnAddress This parameter defines the number of address bits required to generate the column addresses for the memory devices fitted. This parameter is normally quoted in the memory device data sheet. For example CA7~CA0 therefore the Column Address parameter would be 8 #### 9.1.1.2 RowAddress This parameter defines the number of address bits required to generate the row addresses for the memory device fitted. This parameter is normally quoted in the memory device data sheet. For example RA8~RA0 therefore the Row Address parameter would be 9 #### 9.1.1.3 BankAddress This parameter defines the number of address bits required to generate the bank addresses for the memory device fitted. This parameter is normally quoted in the memory device data sheet. 9-2 Proprietary and Confidential 3D labs Permedia3 Reference Guide Memory Systems For example A9(BA) therefore the Bank Address parameter would be 1 #### 9.1.1.4 ChipSelect This parameter defines the number of address bits needed to select all the blocks of memory devices fitted to the PERMEDIA device. | For 1 Block of memories | Chip Select $= 1$ | |--------------------------|-------------------| | For 2 Blocks of memories | Chip Select $= 1$ | | For 3 Blocks of memories | Chip Select $= 2$ | | For 4 Blocks of memories | Chip Select $= 2$ | ## 9.1.1.5 PageSize This parameter defines the address range for a memory page of the memory array fitted. The value can be calculated as (column address bits of device -5). The PageSize parameter modified if either Interleave (0) or Halfwidth (9.1.1.9) are set. PageSize can be calculated as ((column address bits) -5) + Interleave - Halfwidth. #### 9.1.1.6 RegionSize This parameter defines the addressing range for each of the four page-detectors implemented in the memory controller. The minimum region a page-detector can be assigned to is one internal bank, the maximum is all of the memory fitted. There are some memory configurations where not all the page-detectors can be deployed. An example of this is when three blocks of memory devices are used. The value can be calculated as Where $$Log2 \left( \frac{TotalMemory}{BytesperMemWidth \times RegionsUsed} \right) - 5$$ TotalMemory = The total size of memory fitted in megabytes Bytes per Memory Width = 16 (128 / 8) Regions Used = (if total number of Banks (Blocks fitted x Internal Banks) > 4 then Blocks Fitted else Total Banks) As an example the memory configuration in Figure 9-1 is constructed from sixteen 8-megabit devices each with two internal banks TotalMemory = 16777216 (16-megabytes) Bytes per Memory Width = 16 Regions Used = (Blocks fitted = 4) x (Internal Banks = 2) = 8 = 8 > 4 $$= 4$$ $$Log2\left(\frac{16777216}{16\times4}\right) - 5$$ $$= 13$$ RegionSize #### 9.1.1.7 CombineBanks This flag should be set, when the total number of banks fitted is greater than 4. The total number of banks can be determined by multiplying the number of internal banks of the device by the number of device blocks fitted. In the example shown in Figure 9-1, there are 4 device blocks fitted (Blocks 0 to 3), each device has 2 internal banks (Banks A and B), so the total number of banks is 8, therefore CombineBanks should be set. #### 9.1.1.8 InterLeave This flag when set doubles the page size of the memory array. This is accomplished by combining two blocks of memory and operating them as one. Both blocks are PRECHARGED and ACTIVATED together, and any command sequences issued that cross from one block to the other, do so without incurring a page brake. From the example configuration detailed in Figure 9-1, Block 1 would interleave with Block 0, and Block 3 with Block 2. When this flag is set the value loaded into the PageSize parameter (9.1.1.5) should be increased by one. As the Blocks are now operating in pairs the total number of banks fitted is halved. This may have a bearing on the CombineBanks flag (9.1.1.7). #### 9.1.1.9 HalfWidth This flag should be set only when the memory buffer fitted is 64 bits wide. When set, this flag has an impact on the PageSize register, (section 9.1.1.5). # 9.1.2 Controlling larger memory devices Permedia3 can drive 64MBx32bit memory devices as follows: - Tie the CS of the memories Low - Wire chip Address lines A10 to A0 to memory address lines A10 to A0, - Wire chip Address line A11 to memory BA0 - Wire chip BankSelect0 to memory BA1 #### LocalMemCaps register configuration: Load the register with the value 0x30E311B8. This sets the following parameters: | • | Cas address bits | 8 | |---|-------------------|----| | • | Ras address bits | 11 | | • | Bank address bits | 1 | | • | ChipSelect bits | 1 | | • | Region Size | 14 | Permedia Reference Guide Memory Systems This tactic 'tricks' the Memory Controller into operating as if 2 blocks of twin bank devices are fitted. This approach is reliable and used on a number of **3D***Labs* board products. # 9.1.3 Functionality and Optimizations #### 9.1.3.1 NoPrechargeOpt This flag when set will disable the back to back READ - PRECHARGE optimization, inserting clocks to the value of the CAS Latency between the commands. If the memory devices fitted are capable of executing a READ command directly followed by a PRECHARGE command, this flag should be left clear for optimal performance. The bit setting cannot be read back directly and should be set or reset when in doubt. #### 9.1.3.2 SpecialModeOpt This flag when set enables the memory controller to issue a Special Mode Register Set (SMRS) command, without regard to the current state of the internal banks of the SGRAM. Some memory devices require all internal banks to be in the same state before an SMRS command is issued. For these devices, ensure that the flag is cleared. The memory controller will issue a PRECHARGE command to the devices to ensure all internal banks are in the IDLE mode before issuing the SMRS command. If the memory devices fitted are capable of this function, optimally this flag should be set. #### 9.1.3.3 TwoColorBlockFill This flag when set allows the memory controller to utilize the 2 internal Color Registers that some SGRAM devices are equipped with. If the memory devices fitted only have 1 Color Register, this flag should be cleared. When this flag is cleared the memory controller will fully emulate the two color fill operations. #### 9.1.3.4 NoWriteMask This flag when set disables the memory controller from using the internal MASK Register of an SGRAM. This flag must be set if SDRAMS are fitted. When this flag is set, the memory controller will emulate the write mask operations. This is only a partial emulation using the byte enables so bit precision is not achieved. ## 9.1.3.5 NoBlockFill This flag when set disables the memory controller from issuing a Block Fill command to the memories. This flag must be set if SDRAMS are fitted. When this flag is set the memory controller will fully emulate the block fill operations. ## 9.1.3.6 NoLookAhead This flag when set disables the memory controller from issuing command to one bank of memory, whilst another bank is in the process of PRECHARGHING. Nominally for performance, this flag should be left cleared. ## 9.1.4 Timing and Mode #### 9.1.4.1 TurnOn (Block to Block Read Delay) This parameter defines the number of MClk cycles that need to be inserted between issuing a READ command to one block of memory devices to a READ of another Block. (Block to Block Read Delay). Two parameters from the memory device data sheet must be used to determine what value TurnOn must be set to. The timing parameter tHZ defines the tri-state time and the parameter tLZ defines the drive time of the device. If tLZ is greater than tHZ, then this parameter can safely be set to zero. #### 9.1.4.2 TurnOff (Read to Write Turn around) This parameter defines the number of MClk cycles that need to be inserted between issuing a READ and a WRITE command (Read – Write turn around). This parameter is defined in the memory device data sheet, usually as tHZ. #### 9.1.4.3 RegisterLoad (RL) This parameter defines the number of MClk cycles that need to be inserted between issuing a SMRS and another command. This parameter is usually detailed in the memory device data sheet as tRSC. If tRSC is quoted including the SMRS cycle, then RegisterLoad should be calculated as tRSC (in MClk cycles) – 1. #### 9.1.4.4 BlockWrite (BW) This parameter defines the number of MClk cycles that need to be inserted between issuing a BLOCK WRITE and another command. This parameter is usually detailed in the memory device data sheet as tBWC. If tBWC is quoted including the SMRS cycle, then BlockWrite should be calculated as tBWC (in MClk cycles) -1. #### 9.1.4.5 ActivateToCommand (ATC) This parameter defines the number of MClk cycles that need to be inserted between issuing an ACTIVATE and a command. This parameter is usually detailed in the memory device data sheet as tRCD. If tRCD is quoted including the ACTIVATE cycle, then ActivateToCommand should be calculated as tRCD (in MClk cycles) – 1. #### 9.1.4.6 PrechargeToActivate (PTA) This parameter defines the number of MClk cycles that need to be inserted between issuing a PRECHARGE and an ACTIVATE command. This parameter is usually detailed in the memory device data sheet as tRP. If tRP is quoted including the PRECHARGE cycle, then PreChargeToActivate should be calculated as tRP (in MClk cycles) – 1. ### 9.1.4.7 BlockWriteToPrecharge (BTP) This parameter defines the number of MClk cycles that need to be inserted between issuing a BLOCKWRITE and a PRECHARGE command. This parameter is usually detailed in the memory Permedia Reference Guide Memory Systems device data sheet as tBPL (tBWR). If tBPL is quoted including the BLOCKWRITE cycle, then BlockWriteToPrecharge should be calculated as tBPL (in MClk cycles) – 1. #### 9.1.4.8 WriteToPrecharge (WTP) This parameter defines the number of MClk cycles that need to be inserted between issuing a WRITE and a PRECHARGE command. This parameter is usually detailed in the memory device data sheet as tRDL (tWR). If tRDL is quoted including the WRITE cycle, then WriteToPrecharge should be calculated as tRDL (in MClk cycles) – 1. #### 9.1.4.9 ActivateToPrecharge (ATP) This parameter defines the number of MClk cycles that need to be inserted between issuing an ACTIVATE and a PRECHARGE command. This parameter is usually detailed in the memory device data sheet as tRAS. If tRAS is quoted including the ACTIVATE cycle, then ActivateToPrecharge should be calculated as tRAS (in MClk cycles) – 1. ### 9.1.4.10 RefreshCycle (RC) This parameter defines the number of MClk cycles that need to be inserted between issuing and REFRESH and an ACTIVATE command. This parameter is usually detailed in the memory device data sheet as tRC. If tRC is quoted including the REFRESH command cycle, then RefreshCycle should be calculated as tRC (in MClk cycles) – 1. #### 9.1.4.11 CasLatency (CL) This parameter determines the CAS latency expected by the memory controller. The CasLatency parameter can be loaded directly with the appropriate value from the memory device data sheet. For example, if a CAS latency of 2 is required then the CasLatency parameter should be set to 2. #### 9.1.4.12 Mode This parameter defines the value of the Mode Register loaded into the SGRAM at the end of the boot sequence (see data sheet). Items to note: Burst type should be sequential, burst length should be set to one and CAS latency should be consistent with the CASLatency parameter. For devices that have a Color Register field, this should be consistent with the TwoColorBlockFill flag. All other bits in the Mode field should be set low. #### 9.1.4.13 RefreshEnable This flag should be set for Refresh commands to be issued by the memory controller. #### 9.1.4.14 RefreshCount This parameter defines the period between AUTO-REFRESH commands being issued to the synchronous memories. The count is in ((MClks/32) + 16) i.e. if RefreshCount = 1, the synchronous memories will be refreshed every 48 MClk cycles. For the required refresh rate, see the synchronous memory data sheet. # 9.2 Example Parameter Values The following device types and values are given as examples and should not be taken as recommendations. Permedia3 Reference Guide Memory Systems # 9.2.1 100MHz/Samsung KM4132G271A-10 SGRAM /total SGRAM 12MB For a PERMEDIA device running with an MClk of 100MHz, fitted with 12, 8Mbit, 2x512x256x32 SGRAMS arranged into 3 Blocks. Table 9.1 100MHz/Samsung KM4132G271A-10 SGRAM /total SGRAM 12MB | Addressing Parameters | Value (binary) | Comment | |-----------------------|----------------|-----------------------| | ColumnAddress | 1000 | 8 | | RowAddress | 1001 | 9 | | BankAddress | 0001 | 1 (2 Banks A/B) | | ChipSelect | 0010 | 2 (3 Blocks) | | PageSize | 0011 | 3 (256) | | RegionSize | 1101 | 13 (4 MB) | | CombineBanks | 1 | 6 = 3 Blocks x 2Banks | | Interleave | 0 | Optional | | HalfWidth | 0 | Unavailable 128 bit | | Functionality Parameters | Value (binary) | Comment | |--------------------------|----------------|-----------------------| | NoPrechargeOpt | 0 | Preferred | | SpecialModeOpt | 1 | Preferred | | TwoColorBlockFill | 0 | Only 1 Color Register | | NoWriteMask | 0 | Preferred | | NoBlockFill | 0 | Preferred | | NoLookAhead | 0 | Preferred | | Timing and Mode Parameters | Value (binary) | Comment | |------------------------------|----------------|----------------------| | TurnOn (Block to Block Read) | 01 | Tshz 7ns | | TurnOff (Read to Write) | 01 | Tshz 7ns | | RegisterLoad (RL) | 00 | New command next Clk | | BlockWrite (BW) | 01 | Tbwc 20ns, 2Clk -1 | | ActivateToCommand (ATC) | 001 | Trcd 20ns, 2Clk –1 | | PrechargeToActivate (PTA) | 010 | Trp 26ns, 3Clk -1 | | BlockWriteToPrecharge (BTP) | 001 | Tbpl 20ns, 2Clk -1 | | WriteToPrecharge (WTP) | 000 | Trdl 1Clk -1 | | ActivateToPrecharge (ATP) | 0100 | Tras 50ns, 5Clk –1 | | RefreshCycle (RC) | 0111 | Trc 80ns 8Clk -1 | | CasLatency (CL) | 011 | CasLatency 3 | | Mode | 0000110000 | CL3 | | RefreshEnable | 1 | | | RefreshCount | 0110000 | 64432 Refresh c/s | **3D** labs Proprietary and Confidential # 9.2.2 125MHz<sup>1</sup>/SIEMENS HYB39S16320-7 SGRAM /total SGRAM 16MB For a PERMEDIA device running with an MClk of 125MHz, fitted with 8, 16Mbit, 2x1024x256x32 SGRAMS arranged into 2 Blocks. Table 9.2 125MHz/SIEMENS HYB39S16320-7 SGRAM /total SGRAM 16MB | Addressing Parameters | Value (binary) | Comment | |-----------------------|----------------|-----------------------| | ColumnAddress | 1000 | 8 | | RowAddress | 1010 | 10 | | BankAddress | 0001 | 1 (2 Banks A/B) | | ChipSelect | 0001 | 1 (2 Blocks) | | PageSize | 0011 | 3 (256) | | RegionSize | 1101 | 13 (4 MB) | | CombineBanks | 0 | 4 = 2 Blocks x 2Banks | | Interleave | 0 | Optional | | HalfWidth | 0 | Unavailable 128 bit | | Functionality Parameters | Value (binary) | Comment | |--------------------------|----------------|-----------| | NoPrechargeOpt | 0 | Preferred | | SpecialModeOpt | 1 | Preferred | | TwoColorBlockFill | 1 | Preferred | | NoWriteMask | 0 | Preferred | | NoBlockFill | 0 | Preferred | | NoLookAhead | 0 | Preferred | | Timing and Mode Parameters | Value (binary) | Comment | |------------------------------|----------------|--------------------| | TurnOn (Block to Block Read) | 01 | Thz 8ns | | TurnOff (Read to Write) | 01 | Thz 8ns | | RegisterLoad (RL) | 01 | Trsc 2Clk -1 | | BlockWrite (BW) | 01 | Tbwc 14ns, 2Clk -1 | | ActivateToCommand (ATC) | 010 | Trcd 21ns, 3Clk –1 | | PrechargeToActivate (PTA) | 010 | Trp 21ns, 3Clk -1 | | BlockWriteToPrecharge (BTP) | 001 | Tbwr 14ns, 2Clk -1 | | WriteToPrecharge (WTP) | 000 | Trdl 1Clk -1 | | ActivateToPrecharge (ATP) | 0110 | Tras 49ns, 7Clk –1 | | RefreshCycle (RC) | 1001 | Trc 70ns 9Clk -1 | | CasLatency (CL) | 010 | CasLatency 2 | | Mode | 0001100000 | 2 Color Reg + CL2 | | RefreshEnable | 1 | | | RefreshCount | 0111100 | 64566 Refresh c/s | $<sup>^{1}</sup>$ Please note: 125MHz MClk is provisional. 9-10 Proprietary and Confidential **3D** labs Permedia3 Reference Guide Memory Systems # 9.2.3 125MHz2/ MICRON MT48LC1M16A1-8A SDRAM /total SDRAM 16MB For a PERMEDIA device running with an MClk of $125 \mathrm{MHz}$ , fitted with 8, $16 \mathrm{Mbit}$ , 2x2048x256x16 SDRAMS arranged into 1 Block. Table 9.3 125MHz/MICRON MT48LC1M16A1-8A SDRAM /total SDRAM 16MB | Addressing Parameters | Value (binary) | Comment | |-----------------------|----------------|--------------------------| | ColumnAddress | 1000 | 8 | | RowAddress | 1011 | 11 | | BankAddress | 0001 | 1 A/B | | ChipSelect | 0001 | 1 (1 Blocks) | | PageSize | 0011 | 3 (256) | | RegionSize | 1101 | 14 ( 8 MB) | | CombineBanks | 0 | 2 = 1 Block x 2Banks | | Interleave | 0 | Unavailable only 1 block | | HalfWidth | 0 | Unavailable 128 bit | | Functionality Parameters | Value (binary) | Comment | |--------------------------|----------------|-------------| | NoPrechargeOpt | 0 | Preferred | | SpecialModeOpt | 1 | Preferred | | TwoColorBlockFill | 0 | Unavailable | | NoWriteMask | 1 | Unavailable | | NoBlockFill | 1 | Unavailable | | NoLookAhead | 0 | Preferred | | Timing and Mode Parameters | Value (binary) | Comment | |------------------------------|----------------|--------------------| | TurnOn (Block to Block Read) | 01 | Thz 7ns | | TurnOff (Read to Write) | 01 | Thz 7ns | | RegisterLoad (RL) | 01 | Tmrd 2Clk -1 | | BlockWrite (BW) | 00 | NA | | ActivateToCommand (ATC) | 011 | Trcd 30ns, 4Clk -1 | | PrechargeToActivate (PTA) | 011 | Trp 30ns, 4Clk -1 | | BlockWriteToPrecharge (BTP) | 000 | NA | | WriteToPrecharge (WTP) | 000 | Twr 1Clk -1 | | ActivateToPrecharge (ATP) | 0110 | Tras 50ns, 7Clk –1 | | RefreshCycle (RC) | 1001 | Trc 80ns 10Clk -1 | | CasLatency (CL) | 010 | CasLatency 2 | | Mode | 0000100000 | CL2 | | RefreshEnable | 1 | | | RefreshCount | 0111100 | 64566 Refresh c/s | **3D***labs* Proprietary and Confidential 9-11 <sup>&</sup>lt;sup>2</sup> Please note: 125MHz MClk is provisional. # **Timing Diagrams** The following timing diagrams show specific operations of the memory controller. PERMEDIA3 Reference Guide Memory Systems PERMEDIA3 Reference Guide Memory Systems PERMEDIA3 Reference Guide Memory Systems Permedia3 Reference Guide Memory Systems # RAS Minimum Access Timing @ ATP = 4 PERMEDIA3 Reference Guide Memory Systems 9-22 PERMEDIA3 Reference Guide Memory Systems 10 # **Reset Controls** At reset, certain signal pins are read and the values present, due to pull-ups or pull-downs, are used to initialized bits of particular registers. Table 10-1 Reset Signal Pins | Name | pin | Description | |--------------------|------------|-----------------------------------------------------------------------------------------------------------------------| | BaseClassZero | VSAData(0) | 1 = force PCI Bass Class Code to be zero | | VGAEnable | VSAData(1) | 1 = internal VGA subsystem present | | VGAFixed | VSAData(2) | 1 = enable VGA fixed address decoding | | Retry Disa ble | VSAData(3) | 1 = disable PCI Retry using "Disconnect-Without-<br>Data" | | ShortReset | VSAData(4) | 1 = generate short "AReset" pulse (BusReset + 64 clocks) | | AGP1XCapable | VSAData(5) | 1 = AGP 1XCapable | | SBACapable | VSBData(0) | 1 = AGP Sideband Addressing Capable | | Subsystem From Rom | VSBData(1) | 1 = Load subsystem Vendor ID and SubsystemID from ROM . 0 = leave as reset values | | AGP2XCapable | VSAData(6) | 1 = AGP 2X Capable | | AGP4XCapable | VSAData(7) | 1 = AGP 4XCa pable - this should never be set on a P3,<br>unless<br>4X drivers are added | | IndirectIOEnable | VSBData(2) | 1 = Indirect IO accesses using BaseAddress 3 are enabled | | WCEnable | VSBData(3) | 0 = Upper half of region Zero is byte-swapped<br>1= Upper half of region Zero flagged internally as<br>write-combined | | Prefetch Enable | VSBData(4) | 1 = Base Address registers 1 and 2 marked as prefetchable | A hard configuration pin also exists (Table 10-2). Table 10-2 Hard Configuration Pin | Name | Pin | Description | |----------|-----------|-------------------------------| | PCIClk66 | PCIClkSel | 0 = up to 33MHz<br>1 = 66 MHz | **Note:** Note: During Power-up resets the external frequency reference must be powered at the same time as the Permedia3 or before it, to ensure normal operation. 11 # **Thermal Characteristics** The maximum junction temperature must be kept below $T_j(max)$ and this can only be guaranteed by proper analysis of the operating environment and the thermal path between the die and the air surrounding it. #### 11.1 Device Characteristics These are fixed characteristics of the device and are independent of the operating environment or the characteristics of any heatsink:- ``` Maximum Junction Temperature T_{j(max)} = 125 °C. Maximum Power Dissipation Pd(max) = 6.7 Watts Nominal memory clock frequency f_{MClk} = 125 MHz Nominal core clock frequency f_{KClk} = 125 MHz Junction to case resistance \theta_{jt} = 5.5 °C/Watt (Eq: 11-1) ``` #### 11.2 Thermal Model The formula used to calculate the junction temperature $(T_j)$ is $$T_j$$ = $T_a$ + Pd( $\theta_{jt}$ + $\theta_{cs}$ + $\theta_{sa}$ ) = $T_a$ + Pd $\theta_{ja}$ (Eq: 11-2) Where. ``` = Junction temperature (°C) Τi T_a = Ambient temperature (°C) Pd = Power dissipation (Watts) \theta_{\text{it}} = Junction to top of case thermal resistance (°C/Watt) \theta_{ t cs} = Case to Heatsink thermal resistance (°C/Watt) \theta_{ extsf{sa}} = Heatsink to Air thermal resistance (°C/Watt) \theta_{\text{ja}} = Total Junction to Air thermal resistance (°C/Watt) (Eq: 11-3) ``` # 11.3 Cooling PERMEDIA 3 should be operated with an attached heatsink or fan. # 11.4 Operation with Heatsink With a heatsink attached to the device the junction temperature will depend on $\theta_{\text{CS}}$ and $\theta_{\text{SA}}$ where $\theta_{\text{CS}}$ is the thermal resistance of the join between the heatsink and the case and $\theta_{\text{SA}}$ is the thermal resistance of the heatsink, which will be a function of system airflow. An ambient temperature of $40^{\circ}$ C is assumed. ``` Heatsink to air thermal resistance \thetasa Maximum Junction Temperature T<sub>i(max)</sub> = 125°C 40°C Ambient Temperature Ta Maximum Power Dissipation Pd(max) = 6.7 Watts Junction to case resistance \thetajt 5.5°C/Watt Heatsink to case resistance \thetacs = 1.0°C/Watt (EG 7655 epoxy - see below) then: \thetasa \leq [(125 - 40)/6.7] - 5.5 - 1.0 \leq 6.2°C/Watt. Eq: 11-4 ``` In this example a heatsink must be chosen which has a thermal resistance figure of no greater than 6.2°C/Watt at an airflow matching the expected airflow in the system.. ## 11.5 1.1 Heatsink Attachment The following method has been approved for the purpose of attaching a heatsink directly onto the copper surface of the SBGA package: Thermally conductive epoxy using either Loctite Output 315 with Loctite 7386 or type EG 7655 from A.I. Technology Inc. The thickness of the epoxy layer should be between 0.05mm and 0.15mm with 95% coverage of the contact area. Typical achievable ?cs using this method is 1.0 ° C/Wat PERMEDIA3 Reference Guide Electrical Characteristics **12** ## **Electrical Characteristics** #### 12.1 Absolute Maximum Ratings | Junction Temperature | 125°C | |-------------------------------------|------------------------| | Storage Temperature | -65°C to 150°C | | VCC2.5 DC Supply Voltage | 2.8V | | VCC3.3 DC Supply Voltage | 3.8V | | I/O Pin Voltage with respect to GND | -0.5V to VCC3.3 + 0.5V | #### 12.2 DC Specifications | Symbol | Parameter | Min | Max | Unit | |------------|----------------------|------|-------------------|------| | VCC3.3 | Supply Voltage | 3.15 | 3.45 | V | | VCC2.5 | Supply Voltage | 2.25 | 2.75 | V | | LPIN | Pin Inductance | | 10 (sig); 8 (pwr) | nН | | ICC (3V) | Power Supply Current | | 1 | A | | ICC (2.5V) | Power Supply Current | | 1.4 | A | #### 12.2.1 PCI Signal DC Specifications | Symbol | Parameter | Min | Max | Unit | |----------------------|-----------------------------|-----|-----|------| | $ m V_{PIL}$ | Input Low Voltage | | 0.8 | V | | $\Lambda_{ m bih}$ | Input High Voltage | 2.0 | | V | | $V_{POL}$ | Output Low Voltage | | 0.5 | V | | $V_{POH}$ | Output High Voltage | 2.4 | | V | | ${ m I}_{ m PIL}$ | Input Low Current | | -20 | uA | | $I_{\mathrm{PIH}}$ | Input High Current | | +20 | uA | | $C_{PIN}$ | Input Capacitance | | 10 | pF | | $C_{\rm CLK}$ | PCI Clock Input | | 10 | pF | | | Capacitance | | | | | $C_{\mathrm{IDSEL}}$ | PCI Idsel Input Capacitance | | 8 | pF | Electrical Characteristics Permedia3 Reference Guide #### 12.2.2 Non-PCI Signal DC Specifications | Symbol | Parameter | Min | Max | Unit | |-----------------|--------------------------------|-----|-----|------| | $V_{IL}$ | Input Low Voltage | | 0.8 | V | | $V_{IH}$ | Input High Voltage | 2.0 | | V | | VOL | Output Low Voltage | | 0.5 | V | | VOH | Output High Voltage | 2.4 | | V | | IIL | Input Low Current | | +10 | uA | | I <sub>IH</sub> | Input High Current | | -10 | uA | | IIHPD | Pulldown Input High<br>Current | | 250 | uA | | IILPU | Pullup Input Low Current | | 250 | uA | | $c_{\rm IN}$ | Input Capacitance | | 10 | pF | ### 12.3 AC Specifications | Pin Name | Capacitive Load | |----------------------------------------------------------|-----------------| | MADD[9:0]., MCAS[1:0], MDSF[1:0], MRAS[1:0], MWE[1:0]. | 80pF | | PCIAD[31:0], PCICBEN[3:0], PCIPar, PCIFrameN, PCIIRdyN, | 50pF in PCI 33 | | PCITRdyN, | system 10pF in | | PCIStopN, PCIIdsel, PCIDevselN, PCIReqN, PCIGntN, | AGP system | | PCIIntAN ,AGPPipeN, AGPRbfN, AGPSBA[7:0], | | | MBANK[3:0], MBYTE[7:0], MEMCKE, MEMCKOUT[1:0], | 50pF | | VidDDCClk, VidDDCData, VidRightEye, VidHSYNC, | | | VidVSYNC,VSAResetN,VSBResetN,RenderSyncN | | | MDAT[63:0]. | 40pF | | ROMSelectN, ROMWEN, SBClk, SBData, VSAData[7:0], | 30pF | | VSBData[7:0], VSCtl[7:0], VSGPChipSelectN, VSGPDataAckN, | | | VSGPDataStrobeN, VSGPReadWriteN. | | PERMEDIA3 Reference Guide Electrical Characteristics #### 12.3.1 Clock Timing | Symbol | Parameter | Min | Max | Units | Notes | |--------------------|-------------------|-----|-----|-------|-------| | ТРСус | PCIClk Cycle Time | 15 | - | ns | | | TpHigh | PCIClk High Time | - | - | ns | | | $T_{SLow}$ | PCIClk Low Time | - | - | ns | | | ТмСус | MClkin Cycle Time | 8 | - | ns | | | T <sub>MHigh</sub> | MClkin High Time | - | - | ns | | | T <sub>MLow</sub> | MClkin Low Time | - | - | ns | | | $T_{SCyc}$ | SClkin Cycle Time | 15 | - | ns | | | T <sub>SHigh</sub> | SClkin High Time | 6 | - | ns | | | $T_{SLow}$ | SClkin Low Time | 6 | - | ns | | | T <sub>DCyc</sub> | DClk Cycle Time | 4 | - | ns | | | T <sub>DHigh</sub> | DClk High Time | - | - | ns | | | $T_{ m DLow}$ | DClk Low Time | - | - | ns | | Figure 12.1 Input Timing Parameters Figure 12.2 Output Timing Parameters **3D**/<sub>a</sub> bs Proprietary and Confidential 12-3 Electrical Characteristics Permedia3 Reference Guide #### 12.3.2 PCI Clock Referenced Input Timing | Parameter | $T_{Su}$ | TH | Units | Notes | |---------------------------------|----------|-----|-------|-------| | | Min | Min | | | | PCIAD(31:0), PCICBEN(3:0), | 5 | 0 | ns | | | PCIPar, | | | | | | PCIFrameN, PCIIRdyN, PCITRdyN, | | | | | | PCIStopN, PCIIdsel, PCIDevselN, | | | | | | AGPSt0-2 | | | | | | PCIGntN | 5 | 0 | ns | | | PCIRstN | 7 | 0 | ns | 1 | Note 1: PCIRstN is resynchronised internally. The timings given, when met, ensure that the reset is detected in the current cycle. #### 12.3.3 PCI -Referenced Output Timing | | $T_{Val}$ | | $T_{On}$ | | $T_{Off}$ | | | | |---------------|-----------|-----|----------|-----|-----------|-----|-------|-------| | Parameter | Min | Max | Min | Max | Min | Max | Units | Notes | | PCIAD(31:0), | 2 | 11 | 2 | 11 | 2 | 11 | ns | | | PCICBEN(3:0), | | | | | | | | | | PCIPar, | | | | | | | | | | PCIFrameN, | | | | | | | | | | PCIIRdyN, | | | | | | | | | | PCITRdyN, | | | | | | | | | | PCIStopN, | | | | | | | | | | PCIIdsel, | | | | | | | | | | PCIDevselN | | | | | | | | | | PCIReqN | 2 | 12 | | | | | ns | | | PCIIntAN | 2 | 11 | | | | | ns | 1 | Note 1: Timings given are for falling edges of the open drain signal. Rise times are dependent on the external pull-up resistor. PERMEDIA3 Reference Guide Electrical Characteristics #### 12.3.4 AGP Referenced Output Timing | | $T_{Val}$ | | $T_{On}$ | | $T_{Off}$ | | | | |---------------|-----------|-----|----------|-----|-----------|-----|-------|-------| | Parameter | Min | Max | Min | Max | Min | Max | Units | Notes | | PCIAD(31:0), | 1.5 | 6 | 1.5 | 6 | 1.0 | 14 | ns | | | PCICBEN(3:0), | | | | | | | | | | PCIPar, | | | | | | | | | | PCIFrameN, | | | | | | | | | | PCIIRdyN, | | | | | | | | | | PCITRdyN, | | | | | | | | | | PCIStopN, | | | | | | | | | | PCIIdsel, | | | | | | | | | | PCIDevselN | | | | | | | | | | PCIReqN | 1.5 | 6 | | | | | ns | | | PCIIntAN | 1.5 | 6 | | | | | ns | 1 | Note 1: Timings given are for falling edges of the open drain signal. Rise times are dependent on the external pull-up resistor. #### 12.3.5 MEMCKOUT Referenced Input Timing All timings below are with respect to MEMCKOUT, which is a delayed version of MClk. | Parameter | TSu Min | TH Min | Units | Notes | |------------|---------|--------|-------|-------| | MDAT[63:0] | 1 | 3 | ns | | #### 12.3.6 MEMCKOUT Referenced Output Timing All timings below are with respect to MEMCKOUT, which is a delayed version of MClk. | | $T_{Val}$ | | $T_{On}$ | T <sub>On</sub> | | $T_{Off}$ | | | |-------------------|-----------|-----|----------|-----------------|-----|-----------|-------|-------| | Parameter | Min | Max | Min | Max | Min | Max | Units | Notes | | All memory | | 8.5 | | | | | ns | | | control, data and | | | | | | | | | | address lines | | | | | | | | | # 13 # Index | A | | |-----------------------------------------------------------------------------|--------------------------| | Address address regions AGP AGP 2X | 2-4<br>1-3 | | В | | | BankAddress bankswitching VESA base address regions | 1-7 | | С | | | CasLatency (CL) ChipSelect color storage ColumnAddress CombineBanks Cooling | 9-3<br>1-4<br>9-2<br>9-4 | | depth data storage | 4-3<br>3-1<br>1-8 | | Enhancement summary1 | -1 | |--------------------------------------------------------|----------| | F | | | Flash ROM1<br>format | | | framebuffer data and | -1 | | displaying | | | G | | | graphics core PCI Interface and | -5 | | Н | | | HalfWidth 9 Hardware Registers 4 HbEnd timing values 3 | -3 | | Heatsink | | | Alternative Attachment Method | -3<br>-2 | | HgEnd | | | timing values | -1 | | timing values | -1 | | timing values | -1 | | timing values | -1 | |----------------------------------------------------------------------------------------------|----------| | I | | | Indirect RAMDAC Registers 4- input FIFO 1- InterLeave 9- Introduction 1- | -4<br>-4 | | L | | | Local Bus Standard conformance 1- local memory 1- | | | M | | | MClk9-2, 9-7, 11-<br>memory<br>organization1- | | | N | | | NoPrechargeOpt9- | -4 | | P | | | Package Diagram (Bottom View) | -2<br>-3 | | Local Bus Standard conformance | -3<br>-3 | | Pin Assignment 8- Pinlist by Name 8-1 Pinlist by Number 8- | 18 | | pipelined reads<br>support for1- | -3 | #### R | RAMDAC | 1-7 | |---------------------------------|------| | configuring | 3-1 | | refresh frequency | | | framebuffer data and | 3-1 | | RefreshCount | 9-7 | | RefreshEnable | 9-7 | | Region 0 Bypass Controls | 4-35 | | Region 0 Control Status | | | Region 0 GP FIFO | | | Region 0 Memory Control | 4-46 | | Region 0 RAMDAC | 4-66 | | Region 0 VGA Control | | | Region 0 Video Control | | | Region 0 Video Stream | | | Region 3 Indirect Addressing | | | RegionSize | | | Register Cross Reference | 6-7 | | Registers Alphabetically Sorted | | | Registers Sorted by Offset | | | resolution | | | framebuffer data and | 3-1 | | RowAddress | 9-2 | | S | | | SGRAM | | | bit-masking | 1-5 | | block fill | | | organization | | | sideband addressing | | | support for | 1-3 | | stencil and depth data storage | | | SVGA | | #### T | texture data storage1-4 | |----------------------------------| | Thermal | | Model11-1 | | resistance | | Timing Values for 800x600 32 BPP | | U | | | | Unified 1-4 | | V | | VESA bankswitching 1-7 | | VESA mode | | support for1-7 | | VESA VBE Graphics Modes1-6 | | VESA VBE Text Modes1-7 | | VGA modes | | supported1-5 | | Video1-7, 1-8 | | Video Overlay1-7 | | video unit | | configuring | | Comiguing5-1 |